/**
 * Listing Grid — Responsive grid with toolbar and pagination.
 */

/* ─── Wrapper ─── */

.listora-grid-wrapper {
	display: flex;
	flex-direction: column;
	gap: var(--listora-space-4);
	container-type: inline-size;
	container-name: listora-grid;
}

.listora-grid-wrapper.is-loading .listora-grid__results {
	opacity: 0.4;
	pointer-events: none;
}

.listora-grid-wrapper.is-loading .listora-grid__skeletons {
	display: grid !important;
}

/* ─── Split View (Map + List) ─── */

.listora-grid-wrapper--split {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: var(--listora-space-4);
}

.listora-grid-wrapper--split .listora-grid__map-pane {
	position: sticky;
	top: 32px;
	height: calc(100vh - 32px);
	border-radius: var(--listora-radius-xl);
	overflow: hidden;
}

@media (max-width: 1024px) {
	.listora-grid-wrapper--split {
		grid-template-columns: minmax(0, 1fr);
	}

	.listora-grid-wrapper--split .listora-grid__map-pane {
		position: static;
		height: 400px;
	}
}

/* ─── Toolbar ─── */

.listora-grid__toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: var(--listora-space-2);
	padding: 0.6rem 1rem;
	background: var(--listora-bg-surface);
	border-radius: var(--listora-radius-lg);
}

.listora-grid__count {
	font-size: var(--listora-card-meta-size);
	font-weight: var(--listora-weight-semibold);
	color: var(--listora-fg-muted);
}

.listora-grid__toolbar-actions {
	display: flex;
	align-items: center;
	gap: var(--listora-space-2);
}

/* ─── View Toggle (segmented control) ───
 *
 * Specificity boost via descendant chain `.listora-grid__view-toggle
 * .listora-grid__view-btn` (0,2,0). Beats single-class
 * `.wp-element-button` rule (0,1,0) from theme.json compilation so
 * the buttons render with Listora's own segmented-control look
 * regardless of theme palette overrides.
 *
 * background-color and color set explicitly (not via `all: unset` +
 * inheritance) so they win the cascade against any theme rule that
 * lands after ours. Active state uses --listora-primary + inverse fg;
 * inactive state uses --listora-bg-elevated + faint fg.
 * ──────────────────────────────────────────────────────────────────── */
.listora-grid__view-toggle {
	display: inline-flex;
	background: var(--listora-bg-elevated);
	border: 1px solid var(--listora-border);
	border-radius: var(--listora-radius-md);
	overflow: hidden;
	flex-shrink: 0;
}

.listora-grid__view-toggle .listora-grid__view-btn {
	all: unset;
	box-sizing: border-box;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	/* --listora-icon-btn-size is undefined; fall back to the tap-target token
	   so the view toggle meets the 40px tap-target floor on touch surfaces. */
	width: var(--listora-icon-btn-size, var(--listora-tap-target, 44px));
	height: var(--listora-icon-btn-size, var(--listora-tap-target, 44px));
	color: var(--listora-fg-faint);
	background-color: var(--listora-bg-elevated);
	border: 0;
	transition:
		background-color var(--listora-transition-fast),
		color var(--listora-transition-fast);
}

.listora-grid__view-toggle .listora-grid__view-btn + .listora-grid__view-btn {
	border-inline-start: 1px solid var(--listora-border);
}

.listora-grid__view-toggle .listora-grid__view-btn:hover {
	color: var(--listora-fg-default);
	background-color: var(--listora-bg-muted);
}

.listora-grid__view-toggle .listora-grid__view-btn:focus-visible {
	outline: 2px solid var(--listora-primary);
	outline-offset: -2px;
	z-index: 1;
}

.listora-grid__view-toggle .listora-grid__view-btn.is-active {
	color: var(--listora-primary-fg);
	background-color: var(--listora-primary);
}

.listora-grid__view-toggle .listora-grid__view-btn.is-active:hover {
	background-color: var(--listora-primary-hover, var(--listora-primary));
}

/* Sort */
.listora-grid__sort-select {
	font-size: var(--listora-card-meta-size);
	padding-block: 0.35rem;
	min-width: 140px;
	border-radius: var(--listora-radius-md);
}

/* ─── Results Grid ─── */

.listora-grid {
	display: grid;
	grid-template-columns: repeat(var(--listora-grid-columns, 3), minmax(0, 1fr));
	gap: var(--listora-grid-gap, 1.5rem);
}

/* List view: single column, horizontal cards.
 *
 * Specificity escalation via `.listora-grid.listora-grid--list` chain
 * (0,2,0) ensures we beat aggressive theme rules that target
 * `.wp-block-*` ancestors or use single-class selectors at the same
 * specificity. BC-OPEN-2 (card 9895518880) reported the toggle was not
 * visually switching layouts despite the class flipping correctly —
 * theme.json-compiled rules at (0,1,0) were winning source-order ties.
 * Same theme-defence pattern as cf31d77 search-bar polish + 3d9f9e6
 * view-toggle button styling.
 */
.listora-grid.listora-grid--list {
	grid-template-columns: minmax(0, 1fr);
}

.listora-grid.listora-grid--list .listora-card {
	flex-direction: row;
}

.listora-grid.listora-grid--list .listora-card__media {
	width: 220px;
	flex-shrink: 0;
}

.listora-grid.listora-grid--list .listora-card__image-link {
	aspect-ratio: auto;
	height: 100%;
}

/* Container query responsive columns */
@container listora-grid (max-width: 1024px) {
	.listora-grid:not(.listora-grid--list) {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@container listora-grid (max-width: 767px) {
	.listora-grid:not(.listora-grid--list) {
		grid-template-columns: minmax(0, 1fr);
	}

	.listora-grid.listora-grid--list .listora-card {
		flex-direction: column;
	}

	.listora-grid.listora-grid--list .listora-card__media {
		width: 100%;
	}

	.listora-grid.listora-grid--list .listora-card__image-link {
		aspect-ratio: var(--listora-card-image-ratio);
	}
}

/* Media-query fallback for browsers without container query support */
@media (max-width: 1024px) {
	.listora-grid:not(.listora-grid--list) {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 767px) {
	.listora-grid:not(.listora-grid--list) {
		grid-template-columns: minmax(0, 1fr);
	}

	.listora-grid.listora-grid--list .listora-card {
		flex-direction: column;
	}

	.listora-grid.listora-grid--list .listora-card__media {
		width: 100%;
	}

	.listora-grid.listora-grid--list .listora-card__image-link {
		aspect-ratio: var(--listora-card-image-ratio);
	}
}

/* ─── Loading Skeletons ─── */

.listora-grid__skeletons {
	display: none;
}

.listora-card--skeleton {
	pointer-events: none;
}

.listora-card--skeleton .listora-card__body {
	gap: 0;
}

/* Skeleton placeholder shapes (moved out of inline styles in grid.php). */
.listora-skeleton--image {
	aspect-ratio: var(--listora-card-image-ratio);
	width: 100%;
}

.listora-skeleton--label {
	height: 0.7rem;
	width: 60px;
	margin-block-end: 0.5rem;
}

.listora-skeleton--title {
	height: 1.1rem;
	width: 80%;
}

.listora-skeleton--meta {
	height: 0.85rem;
	width: 50%;
	margin-block-start: 0.4rem;
}

.listora-skeleton__pills {
	display: flex;
	gap: 0.4em;
	margin-block-start: 0.5rem;
}

.listora-skeleton__pills .listora-skeleton--pill {
	height: 0.8rem;
	width: 45px;
}

/* ─── Empty State ─── */

.listora-grid__empty {
	display: none;
}

.listora-grid__empty:not(.is-hidden) {
	display: flex;
}

.listora-grid__empty-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: var(--listora-space-12) var(--listora-space-4);
	width: 100%;
	color: var(--listora-fg-faint);
	animation: listora-fadeInScale 0.4s ease;
}

.listora-grid__empty-inner svg {
	margin-block-end: var(--listora-space-4);
	opacity: 0.4;
}

.listora-grid__empty-inner h3 {
	margin: 0 0 0.5rem;
	font-size: var(--listora-text-size-lg);
	color: var(--listora-fg-default);
}

.listora-grid__empty-inner p {
	margin: 0 0 var(--listora-space-4);
	font-size: var(--listora-card-meta-size);
}

/* ─── Pagination ─── */

.listora-grid__pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--listora-space-1);
	padding-block-start: var(--listora-space-4);
}

.listora-grid__page-btn {
	font-size: var(--listora-card-meta-size);
	padding: 0.4em 0.8em;
}

.listora-grid__page-btn svg {
	flex-shrink: 0;
}

.listora-grid__page-info {
	font-size: var(--listora-card-meta-size);
	color: var(--listora-fg-muted);
}

/* Page number buttons */
.listora-grid__page-numbers {
	display: flex;
	align-items: center;
	gap: var(--listora-space-1);
}

.listora-grid__page-num {
	all: unset;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 2rem;
	height: 2rem;
	font-size: var(--listora-text-size-sm);
	font-weight: var(--listora-weight-medium);
	color: var(--listora-fg-muted);
	border-radius: var(--listora-radius-md);
	transition: background var(--listora-transition-fast), color var(--listora-transition-fast);
}

.listora-grid__page-num:hover {
	background: var(--listora-bg-surface);
	color: var(--listora-fg-default);
}

.listora-grid__page-num.is-active {
	background: var(--listora-primary);
	color: var(--listora-fg-inverse, var(--listora-bg-elevated));
	font-weight: var(--listora-weight-semibold);
}

.listora-grid__page-ellipsis {
	color: var(--listora-fg-faint);
	padding: 0 0.25rem;
}

/* Load More button */
.listora-grid__load-more {
	display: flex;
	justify-content: center;
	padding-block-start: var(--listora-space-4);
}

/* ─── Hidden ─── */

.is-hidden {
	display: none !important;
}

/* ─── Mobile ─── */

@media (max-width: 767px) {
	.listora-grid__toolbar {
		flex-direction: column;
		align-items: stretch;
	}

	.listora-grid__toolbar-actions {
		justify-content: space-between;
	}

	.listora-grid__view-btn {
		width: 2.75rem;
		height: 2.75rem;
	}

	.listora-grid__sort-select {
		min-width: 0;
		flex: 1;
		min-height: 2.75rem;
	}

	.listora-grid__page-numbers {
		flex-wrap: wrap;
		justify-content: center;
	}

	.listora-grid__page-num {
		min-width: 2.75rem;
		height: 2.75rem;
	}
}
