/**
 * Shop / category archive — filters, grid toolbar, pagination.
 */

.xm-archive-products {
	padding: var(--xm-space-xl) 0 var(--xm-space-3xl);
}

/* Mobile sticky-note quick links moved to assets/css/sticky-tags.css */

.xm-archive-breadcrumbs {
	margin-bottom: var(--xm-space-md);
}

.xm-archive-breadcrumbs .xm-breadcrumb {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35rem 0;
	margin: 0;
	padding: 0;
	list-style: none;
	font-size: var(--xm-font-size-sm);
	color: var(--xm-color-text-muted);
}

.xm-archive-header {
	margin-bottom: var(--xm-space-lg);
}

.xm-archive-header__title {
	font-size: clamp(1.75rem, 2vw + 1rem, 2.25rem);
	font-weight: var(--xm-font-weight-bold);
	margin: 0;
	line-height: 1.2;
}

/* Filters bar */
.xm-archive-filters {
	margin-bottom: var(--xm-space-lg);
}

.xm-archive-filters__bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--xm-space-md);
	padding: 0.85rem 1rem;
	border: 1px solid var(--xm-color-border);
	border-radius: var(--xm-radius-md);
	background: var(--xm-color-bg);
}

.xm-archive-filters__toggle,
.xm-archive-filters__show {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	padding: 0;
	border: 0;
	background: transparent;
	color: var(--xm-color-text);
	font-size: var(--xm-font-size-sm);
	font-weight: var(--xm-font-weight-medium);
	cursor: pointer;
}

.xm-archive-filters__toggle {
	font-weight: var(--xm-font-weight-bold);
}

.xm-archive-filters__show {
	color: var(--xm-color-primary);
}

.xm-archive-filters__panel {
	margin-top: var(--xm-space-sm);
	padding: var(--xm-space-lg);
	border: 1px solid var(--xm-color-border);
	border-radius: var(--xm-radius-md);
	background: var(--xm-color-bg-alt);
}

.xm-archive-filters__panel[hidden] {
	display: none !important;
}

.xm-archive-filters__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--xm-space-md);
	margin-bottom: var(--xm-space-md);
}

.xm-archive-filters__field {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	font-size: var(--xm-font-size-sm);
}

.xm-archive-filters__field--checkbox {
	flex-direction: row;
	align-items: center;
	gap: var(--xm-space-sm);
}

.xm-archive-filters__label {
	font-weight: var(--xm-font-weight-medium);
	color: var(--xm-color-text);
}

.xm-archive-filters__field input[type='number'] {
	min-height: var(--xm-touch-min);
	padding: var(--xm-space-sm) var(--xm-space-md);
	border: 1px solid var(--xm-color-border);
	border-radius: var(--xm-radius-md);
	font-size: var(--xm-font-size-sm);
	background: var(--xm-color-white);
}

.xm-archive-filters__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--xm-space-md);
}

.xm-archive-filters__apply {
	min-height: var(--xm-touch-min);
	padding: 0 var(--xm-space-lg);
}

.xm-archive-filters__clear {
	font-size: var(--xm-font-size-sm);
	font-weight: var(--xm-font-weight-medium);
	color: var(--xm-color-text-muted);
	text-decoration: underline;
	text-underline-offset: 2px;
}

/* Controls row */
.xm-archive-controls {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: var(--xm-space-sm) var(--xm-space-md);
	margin-bottom: var(--xm-space-lg);
}

.xm-archive-controls__count {
	margin: 0;
	justify-self: start;
	font-size: var(--xm-font-size-sm);
	font-weight: var(--xm-font-weight-medium);
	color: var(--xm-color-text);
	white-space: nowrap;
}

.xm-archive-grid-toggle {
	justify-self: center;
	display: inline-flex;
	align-items: center;
	padding: 0.2rem;
	border: 1px solid var(--xm-color-border);
	border-radius: var(--xm-radius-md);
	background: var(--xm-color-bg);
}

.xm-archive-controls__sort {
	justify-self: end;
}

.xm-archive-grid-toggle__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	height: 2.5rem;
	padding: 0;
	border: 0;
	border-radius: calc(var(--xm-radius-md) - 2px);
	background: transparent;
	cursor: pointer;
	transition: background-color var(--xm-transition), box-shadow var(--xm-transition);
}

.xm-archive-grid-toggle__btn.is-active {
	background: var(--xm-color-primary-soft);
	box-shadow: inset 0 0 0 1px rgba(255, 103, 0, 0.18);
}

.xm-archive-grid-toggle__icon {
	display: grid;
	gap: 2px;
	color: var(--xm-color-text-muted);
}

.xm-archive-grid-toggle__btn.is-active .xm-archive-grid-toggle__icon {
	color: var(--xm-color-primary);
}

.xm-archive-grid-toggle__icon i {
	display: block;
	border-radius: 1px;
	background: currentColor;
}

.xm-archive-grid-toggle__icon--large {
	grid-template-columns: repeat(2, 6px);
	grid-template-rows: repeat(2, 6px);
}

.xm-archive-grid-toggle__icon--large i {
	width: 6px;
	height: 6px;
}

.xm-archive-grid-toggle__icon--medium {
	grid-template-columns: repeat(2, 5px);
	grid-template-rows: repeat(2, 5px);
}

.xm-archive-grid-toggle__icon--medium i {
	width: 5px;
	height: 5px;
}

.xm-archive-grid-toggle__icon--small {
	grid-template-columns: repeat(3, 4px);
	grid-template-rows: repeat(3, 4px);
}

.xm-archive-grid-toggle__icon--small i {
	width: 4px;
	height: 4px;
}

.xm-archive-controls__sort .woocommerce-ordering {
	margin: 0;
}

.xm-archive-controls__sort select {
	min-width: 9.5rem;
	min-height: 2.5rem;
	padding: 0.4rem 2rem 0.4rem 0.85rem;
	border: 1px solid var(--xm-color-border);
	border-radius: var(--xm-radius-md);
	background: var(--xm-color-bg);
	font-size: var(--xm-font-size-sm);
	color: var(--xm-color-text);
}

/* Product grid — archive only (cards unchanged; overrides global responsive grid) */
.xm-archive-products ul.products {
	display: grid !important;
	grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	gap: var(--xm-space-md) !important;
	list-style: none;
	padding: 0 !important;
	margin: 0 0 var(--xm-space-xl) !important;
	width: 100% !important;
	float: none !important;
}

.xm-archive-products ul.products > li {
	width: 100% !important;
	max-width: 100% !important;
	float: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

/* Large cards — fewer columns */
.xm-archive-products ul.products.xm-archive-grid--large {
	grid-template-columns: repeat(1, minmax(0, 1fr)) !important;
}

/* Medium cards — default */
.xm-archive-products ul.products.xm-archive-grid--medium {
	grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

/* Small cards — more columns */
.xm-archive-products ul.products.xm-archive-grid--small {
	grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
	gap: 0.5rem !important;
}

/* Pagination */
.xm-archive-pagination {
	margin-top: var(--xm-space-xl);
}

.xm-archive-pagination__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: var(--xm-space-sm) var(--xm-space-md);
}

.xm-archive-pagination__nav {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	min-height: 2.75rem;
	padding: 0 1.1rem;
	border: 1px solid var(--xm-color-border);
	border-radius: 999px;
	background: var(--xm-color-white);
	color: var(--xm-color-text);
	font-size: var(--xm-font-size-sm);
	font-weight: var(--xm-font-weight-medium);
	text-decoration: none;
	box-shadow: 0 8px 20px rgba(15, 23, 42, 0.06);
	transition: border-color var(--xm-transition), color var(--xm-transition), background-color var(--xm-transition), transform var(--xm-transition);
}

.xm-archive-pagination__nav:hover {
	border-color: var(--xm-color-primary);
	color: var(--xm-color-primary);
	transform: translateY(-1px);
}

.xm-archive-pagination__nav.is-disabled {
	opacity: 0.45;
	cursor: not-allowed;
	box-shadow: none;
}

.xm-archive-pagination__pages {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.xm-archive-pagination__pages li {
	margin: 0;
	padding: 0;
	list-style: none;
}

.xm-archive-pagination__pages .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.5rem;
	min-height: 2.5rem;
	padding: 0 0.55rem;
	border: 1px solid var(--xm-color-border);
	border-radius: var(--xm-radius-md);
	background: var(--xm-color-white);
	color: var(--xm-color-text);
	font-size: var(--xm-font-size-sm);
	text-decoration: none;
	transition: background-color var(--xm-transition), color var(--xm-transition), border-color var(--xm-transition);
}

.xm-archive-pagination__pages .page-numbers.current,
.xm-archive-pagination__pages .page-numbers:hover {
	background: var(--xm-color-primary);
	border-color: var(--xm-color-primary);
	color: var(--xm-color-white);
}

.xm-search-results__subtitle {
	margin: 0.35rem 0 0;
	font-size: var(--xm-font-size-sm);
	color: var(--xm-color-text-muted);
}

.xm-search-results__empty {
	padding: var(--xm-space-2xl) 0;
	text-align: center;
}

@media (min-width: 768px) {
	.xm-archive-filters__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.xm-archive-products ul.products.xm-archive-grid--large {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	}

	.xm-archive-products ul.products.xm-archive-grid--medium {
		grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
	}

	.xm-archive-products ul.products.xm-archive-grid--small {
		grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
		gap: var(--xm-space-md) !important;
	}
}

@media (min-width: 1024px) {
	.xm-archive-products ul.products.xm-archive-grid--large {
		grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
	}

	.xm-archive-products ul.products.xm-archive-grid--medium {
		grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
	}

	.xm-archive-products ul.products.xm-archive-grid--small {
		grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
	}
}

@media (max-width: 767px) {
	.xm-archive-products {
		padding-top: 0;
	}

	.xm-archive-breadcrumbs {
		display: none;
	}

	.xm-archive-header {
		margin-top: 0;
		margin-bottom: var(--xm-space-md);
	}

	.xm-archive-controls {
		grid-template-columns: auto 1fr auto;
	}

	.xm-archive-controls__count {
		font-size: 0.8125rem;
	}

	.xm-archive-controls__sort select {
		min-width: 7.5rem;
		padding-right: 1.75rem;
		font-size: 0.8125rem;
	}

	.xm-archive-grid-toggle__btn {
		width: 2.25rem;
		height: 2.25rem;
	}
}
