/* Pagination — single row: nav left, "1–10 ⌄ of 30" right; nav hidden when single page or hideNav option */
.vault-pagination {
  margin-top: 0.75rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--vault-border);
}

.vault-pagination__nav--hidden {
  display: none !important;
}

.vault-pagination__row {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-start;
  gap: 0.35rem 0.5rem;
  min-width: 0;
  width: 100%;
}

.vault-pagination__rows-wrap {
  position: relative;
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  flex-shrink: 0;
  margin-left: auto;
  font-size: 0.8125rem;
}

.vault-pagination__range-line {
  display: inline-flex;
  align-items: center;
  gap: 0.15rem;
  flex-wrap: nowrap;
  white-space: nowrap;
}

.vault-pagination__range-line--empty .vault-pagination__page-size-trigger {
  visibility: hidden;
  pointer-events: none;
}

.vault-pagination__rows-wrap--fixed-page-size .vault-pagination__range-line {
  gap: 0.35rem;
}

.vault-pagination__range-from-to {
  font-weight: 700;
  color: var(--vault-primary);
  font-size: inherit;
  letter-spacing: 0.01em;
}

.vault-pagination__range-of-total {
  white-space: nowrap;
  color: var(--vault-text-muted);
  font-weight: 400;
}

.vault-pagination__page-size-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.12rem;
  min-height: 1.5rem;
  padding: 0.15rem 0.2rem 0.15rem 0.35rem;
  margin: 0;
  border: none;
  border-radius: 0.25rem;
  background: transparent;
  color: var(--vault-primary);
  cursor: pointer;
  line-height: 1.2;
  max-width: 100%;
}

.vault-pagination__page-size-trigger:hover {
  background: var(--vault-bg-card);
}

.vault-pagination__page-size-trigger-chevron {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  line-height: 0;
}

.vault-pagination__page-size-trigger:focus {
  outline: 2px solid var(--vault-focus-ring);
  outline-offset: 1px;
}

.vault-pagination__page-size-panel {
  position: absolute;
  right: 0;
  bottom: 100%;
  margin-bottom: 0.25rem;
  min-width: 4.5rem;
  padding: 0.25rem;
  background: var(--vault-bg-card, #fff);
  border: 1px solid var(--vault-border);
  border-radius: 0.375rem;
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.12);
  z-index: 50;
}

.vault-pagination__page-size-option {
  display: block;
  width: 100%;
  text-align: left;
  padding: 0.35rem 0.5rem;
  font-size: 0.8125rem;
  color: var(--vault-text);
  background: transparent;
  border: none;
  border-radius: 0.25rem;
  cursor: pointer;
}

.vault-pagination__page-size-option:hover {
  background: var(--vault-bg-muted, #f1f5f9);
}

.vault-pagination__page-size-option--current {
  background: var(--vault-primary-light);
  color: var(--vault-text);
  font-weight: 600;
}

.vault-pagination__nav {
  display: flex;
  align-items: center;
  gap: 0.12rem;
  flex-wrap: nowrap;
  min-width: 0;
  flex: 0 0 auto;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
}

.vault-pagination__pages {
  display: flex;
  align-items: center;
  gap: 0.08rem;
  flex-wrap: nowrap;
  flex-shrink: 0;
}

/* Prev / next: ghost, primary, bold, slightly larger */
.vault-pagination__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.125rem;
  height: 2.125rem;
  padding: 0 0.25rem;
  font-size: 0.8125rem;
  line-height: 1;
  font-weight: 700;
  color: var(--vault-primary);
  background: transparent;
  border: none;
  border-radius: 0.25rem;
  cursor: pointer;
}

.vault-pagination__btn .vault-pagination__chevron {
  display: block;
  width: 1.125rem;
  height: 1.125rem;
}

.vault-pagination__chevron--down {
  width: 1rem;
  height: 1rem;
}

.vault-pagination__btn:hover:not(:disabled) {
  background: var(--vault-primary-light);
}

.vault-pagination__btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.vault-pagination__btn:focus {
  outline: 2px solid var(--vault-focus-ring);
  outline-offset: 1px;
}

.vault-pagination__page {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.45rem;
  height: 1.6rem;
  padding: 0 0.2rem;
  font-size: 0.75rem;
  line-height: 1;
  color: var(--vault-text);
  background: transparent;
  border: none;
  border-radius: 0.25rem;
  cursor: pointer;
}

.vault-pagination__page:hover {
  background: var(--vault-bg-card);
}

.vault-pagination__page--current {
  background: var(--vault-primary-light);
  border: none;
  color: var(--vault-text);
  font-weight: 500;
  cursor: default;
}

.vault-pagination__page:focus {
  outline: 2px solid var(--vault-focus-ring);
  outline-offset: 1px;
}

.vault-pagination__ellipsis {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1rem;
  height: 1.6rem;
  padding: 0 0.05rem;
  font-size: 0.75rem;
  color: var(--vault-text-subtle);
  user-select: none;
}

.vault-pagination__page-jump-wrap {
  display: none;
  align-items: center;
  position: relative;
  flex-shrink: 0;
}

.vault-pagination--nav-as-dropdown:not(.vault-pagination--page-jump-hidden) .vault-pagination__page-jump-wrap {
  display: flex;
}

.vault-pagination__page-jump-label {
  font-weight: 700;
  color: var(--vault-primary);
  font-size: inherit;
  letter-spacing: 0.01em;
}

.vault-pagination__page-jump-panel {
  right: auto;
  left: 0;
  max-height: 14rem;
  overflow-y: auto;
}
