/**
 * DinnerlyHub - Pagination Component
 * Reusable pagination used in archives and search results.
 */

.dh-pagination {
	margin-top: 8px;
}

.dh-pagination__inner {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	flex-wrap: wrap;
}

/* Prev/Next buttons */
.dh-pagination__btn {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 9px 18px;
	background: var(--dh-white);
	border: 1.5px solid var(--dh-green-border);
	border-radius: var(--dh-radius-pill);
	font-size: 0.82rem;
	font-weight: 600;
	color: var(--dh-green);
	text-decoration: none;
	white-space: nowrap;
	will-change: auto;
	transition: background var(--dh-ease), border-color var(--dh-ease),
	            color var(--dh-ease), transform var(--dh-ease);
}

.dh-pagination__btn:hover {
	background: var(--dh-green);
	border-color: var(--dh-green);
	color: var(--dh-white);
	transform: translateY(-1px);
}

.dh-pagination__btn:focus-visible {
	outline: 2px solid var(--dh-green);
	outline-offset: 3px;
}

.dh-pagination__btn.is-disabled {
	opacity: 0.35;
	cursor: not-allowed;
	pointer-events: none;
}

/* Page numbers container */
.dh-pagination__pages {
	display: flex;
	align-items: center;
	gap: 5px;
}

/* Page number links */
.dh-pagination__page {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	border-radius: 10px;
	font-size: 0.85rem;
	font-weight: 600;
	color: #555;
	text-decoration: none;
	border: 1.5px solid rgba(0, 0, 0, 0.08);
	background: var(--dh-white);
	will-change: auto;
	transition: background var(--dh-ease), border-color var(--dh-ease),
	            color var(--dh-ease), transform var(--dh-ease);
}

.dh-pagination__page:hover {
	background: var(--dh-green-subtle);
	border-color: rgba(74, 124, 89, 0.30);
	color: var(--dh-green);
	transform: translateY(-1px);
}

.dh-pagination__page:focus-visible {
	outline: 2px solid var(--dh-green);
	outline-offset: 3px;
}

/* Current page */
.dh-pagination__page.is-current {
	background: var(--dh-green);
	border-color: var(--dh-green);
	color: var(--dh-white);
	cursor: default;
	box-shadow: 0 2px 10px rgba(74, 124, 89, 0.30);
	pointer-events: none;
}

/* Ellipsis */
.dh-pagination__ellipsis {
	font-size: 0.85rem;
	color: #bbb;
	padding: 0 4px;
	line-height: 38px;
	user-select: none;
}

/* Responsive */
@media (max-width: 640px) {
	.dh-pagination__inner {
		gap: 6px;
	}

	.dh-pagination__btn span {
		display: none;
	}

	.dh-pagination__btn {
		padding: 9px 12px;
	}
}

@media (max-width: 420px) {
	.dh-pagination__page {
		width: 34px;
		height: 34px;
		font-size: 0.78rem;
	}
}
