/* File: assets/frontend/archive-product-cards.css */

/* C2 products owns its grid rules (Bricks Woo defaults only target .brxe-woocommerce-products). */
.brxe-c2-products ul.products,
.c2-products ul.products {
	display: grid;
	grid-template-columns: repeat(var(--c2c-products-columns, 4), minmax(0, 1fr));
	gap: var(--c2c-grid-gap, 20px);
	list-style: none;
	margin: 0;
	padding: 0;
}

.brxe-c2-products ul.products > li.product,
.c2-products ul.products > li.product {
	width: auto;
	margin: 0;
}

.brxe-c2-products .bricks-products-widgets.before {
	margin-bottom: var(--c2c-widgets-gap, 0) !important;
}

.brxe-c2-products .bricks-products-widgets.after {
	margin-top: var(--c2c-widgets-gap, 0) !important;
}

.brxe-c2-products li.product,
.c2-products li.product {
	display: block;
}

.brxe-c2-products .c2-product-card,
.brxe-c2-products .brxe-c2-product-card,
.brxe-c2-products [data-c2-product-card="1"],
.brxe-c2-products .c2c-archive-card-shell {
	display: flex;
	flex-direction: column;
	gap: var(--c2c-card-gap, 8px);
	min-width: 0;
	position: relative;
}

.brxe-c2-products .c2-product-card > .c2c-archive-card-click-overlay,
.brxe-c2-products .brxe-c2-product-card > .c2c-archive-card-click-overlay,
.brxe-c2-products [data-c2-product-card="1"] > .c2c-archive-card-click-overlay,
.brxe-c2-products .c2c-archive-card-shell > .c2c-archive-card-click-overlay {
	position: absolute !important;
	inset: 0 !important;
	display: block !important;
	z-index: 2 !important;
	border-radius: inherit !important;
}

@media (max-width: 991px) {
	.brxe-c2-products ul.products,
	.c2-products ul.products {
		grid-template-columns: repeat(var(--c2c-products-columns-tablet, var(--c2c-products-columns, 4)), minmax(0, 1fr));
	}
}

@media (max-width: 767px) {
	.brxe-c2-products ul.products,
	.c2-products ul.products {
		grid-template-columns: repeat(var(--c2c-products-columns-mobile-landscape, var(--c2c-products-columns-tablet, 2)), minmax(0, 1fr));
	}
}

@media (max-width: 478px) {
	.brxe-c2-products ul.products,
	.c2-products ul.products {
		grid-template-columns: repeat(var(--c2c-products-columns-mobile-portrait, 1), minmax(0, 1fr));
	}
}

/* Card-level layout + non-blocking paint polish for archive product cards. */
.wvs-archive-product-wrapper {
	--c2c-main-image-fade-ms: 130ms;
	--c2c-card-ready-ms: 180ms;
	display: block !important;
	max-width: 100% !important;
	min-width: 0 !important;
}

.wvs-archive-product-wrapper .c2c-archive-card-head {
	display: flex !important;
	align-items: baseline;
	justify-content: space-between;
	column-gap: 12px;
	width: 100%;
	margin: 0 0 8px !important;
}

.wvs-archive-product-wrapper .c2c-archive-card-title,
.wvs-archive-product-wrapper h5.dynamic {
	position: static !important;
	float: none !important;
	margin: 0 !important;
	flex: 1 1 auto;
	min-width: 0;
	color: var(--c2c-title-color, inherit);
}

.wvs-archive-product-wrapper .c2c-archive-card-title a,
.wvs-archive-product-wrapper h5.dynamic a {
	color: inherit;
	transition-property: color, opacity !important;
	transition-duration: var(--c2c-title-hover-duration, 120ms) !important;
	transition-timing-function: var(--c2c-title-hover-easing, ease) !important;
}

.c2c-archive-card > .c2-product-card:hover .c2c-archive-card-title,
.c2c-archive-card > .c2-product-card:hover .c2c-archive-card-title a,
.c2c-archive-card > .c2-product-card:hover h5.dynamic,
.c2c-archive-card > .c2-product-card:hover h5.dynamic a,
.c2c-archive-card > .brxe-c2-product-card:hover .c2c-archive-card-title,
.c2c-archive-card > .brxe-c2-product-card:hover .c2c-archive-card-title a,
.c2c-archive-card > .brxe-c2-product-card:hover h5.dynamic,
.c2c-archive-card > .brxe-c2-product-card:hover h5.dynamic a,
.c2c-archive-card > .c2-product-card:focus-within .c2c-archive-card-title,
.c2c-archive-card > .c2-product-card:focus-within .c2c-archive-card-title a,
.c2c-archive-card > .c2-product-card:focus-within h5.dynamic,
.c2c-archive-card > .c2-product-card:focus-within h5.dynamic a,
.c2c-archive-card > .brxe-c2-product-card:focus-within .c2c-archive-card-title,
.c2c-archive-card > .brxe-c2-product-card:focus-within .c2c-archive-card-title a,
.c2c-archive-card > .brxe-c2-product-card:focus-within h5.dynamic,
.c2c-archive-card > .brxe-c2-product-card:focus-within h5.dynamic a {
	color: var(--c2c-title-hover-color, var(--c2c-title-color, inherit));
}

.wvs-archive-product-wrapper .c2c-archive-card-count,
.wvs-archive-product-wrapper h6.dynamic {
	display: block !important;
	visibility: visible !important;
	opacity: 1 !important;
	position: static !important;
	float: none !important;
	margin: 0 !important;
	text-align: right;
	white-space: nowrap;
	flex: 0 0 auto;
	justify-self: end;
	align-self: baseline;
	color: var(--c2c-count-color, inherit);
}

.wvs-archive-product-wrapper .c2c-archive-card-image-slot {
	position: relative !important;
	aspect-ratio: var(--c2c-card-image-ratio, auto);
	border-radius: var(--c2c-image-radius, 0);
	width: 100% !important;
	height: auto !important;
	block-size: auto !important;
	flex: 0 0 auto !important;
	min-height: 1px !important;
	overflow: hidden !important;
	margin: 0 !important;
}

.wvs-archive-product-wrapper .c2c-archive-card-image-slot a,
.wvs-archive-product-wrapper .c2c-archive-card-image-slot .woocommerce-LoopProduct-link {
	display: block !important;
	width: 100% !important;
	height: 100% !important;
	border-radius: inherit !important;
	overflow: hidden !important;
}

.wvs-archive-product-wrapper .c2c-archive-card-swatch-slot,
.brxe-c2-products li.product [data-c2c-swatch-zone="1"],
.brxe-c2-products li.product .c2c-archive-card-swatch-zone {
	display: block !important;
	position: relative !important;
	z-index: 5 !important;
	width: var(--c2c-rail-width, 100%) !important;
	max-width: 100% !important;
	min-width: 0 !important;
	min-height: var(--c2c-rail-reserved-size, var(--c2c-rail-item-size, 34px)) !important;
	margin: 0 !important;
	opacity: 0;
	pointer-events: none;
}

/* Subtle load-disguise: only active while selected image state is unresolved. */
.wvs-archive-product-wrapper .c2c-archive-card-image,
.wvs-archive-product-wrapper .c2c-archive-card-swatch-slot {
	transition: opacity var(--c2c-card-ready-ms) ease-out, filter var(--c2c-card-ready-ms) ease-out !important;
}

.wvs-archive-product-wrapper.c2c-archive-boot-pending .c2c-archive-card-image,
.wvs-archive-product-wrapper.c2c-archive-boot-pending img.wvs-archive-product-image {
	opacity: 1;
	filter: none;
}

.wvs-archive-product-wrapper.c2c-archive-boot-ready .c2c-archive-card-image,
.wvs-archive-product-wrapper.c2c-archive-boot-ready img.wvs-archive-product-image,
.wvs-archive-product-wrapper.c2c-archive-boot-ready[data-c2c-rail-ready="1"] .c2c-archive-card-swatch-slot {
	opacity: 1;
	filter: none;
	pointer-events: auto;
}

.wvs-archive-product-wrapper img.wvs-archive-product-image,
.wvs-archive-product-wrapper img.c2c-archive-card-image {
	display: block !important;
	visibility: visible !important;
	opacity: 1 !important;
	width: 100% !important;
	max-width: 100% !important;
	height: 100% !important;
	border-radius: inherit !important;
	object-fit: var(--c2c-image-fit, cover) !important;
	object-position: center center !important;
	aspect-ratio: auto;
	transition: none !important;
	will-change: auto;
}
