/*!
 * CzarCommerce Woo — Shop archive (FASE 12.4)
 * -----------------------------------------------------------------------------
 * Camada CSS opt-in para a página de loja (archive de produtos, taxonomias).
 * Não toca em `.products`, `.product`, `.woocommerce-loop-product__title` etc.
 * — esses são padrões do core do WC e do framework legado, intocados até
 * a migração de template a template (PR-por-template — ver design-system.md
 * "Pipeline final 12.3").
 *
 * Classes próprias:
 *   .czar-shop                 wrapper de página de loja
 *   .czar-shop-toolbar         linha superior (count + sort + view-toggle)
 *   .czar-shop-toolbar__count  texto "Mostrando 1-12 de 47"
 *   .czar-shop-toolbar__sort   <select> de ordenação (consome .czar-select)
 *   .czar-shop-results         container do grid (consome .czar-grid)
 *   .czar-product-card         card de produto no loop (consome .czar-card)
 *   .czar-product-card__title  título do produto
 *   .czar-product-card__price  preço (consome --czar-color-price)
 *   .czar-product-card__sale   "ON SALE" badge
 *   .czar-product-card__rating estrelas (display flex de spans)
 *   .czar-pagination           navegação numerada
 */

.czar-shop {
	display: flex;
	flex-direction: column;
	gap: var(--czar-space-6);
	padding-top: var(--czar-space-6);
	padding-bottom: var(--czar-space-12);
}

/* ---- Toolbar superior ---- */

.czar-shop-toolbar {
	display: flex;
	flex-wrap: wrap;
	gap: var(--czar-space-4);
	align-items: center;
	justify-content: space-between;
	padding-bottom: var(--czar-space-4);
	border-bottom: 1px solid color-mix(in srgb, var(--czar-color-text) 10%, transparent);
}

.czar-shop-toolbar__count {
	font-family: var(--czar-font-family-base);
	font-size: var(--czar-font-size-sm);
	color: color-mix(in srgb, var(--czar-color-text) 70%, transparent);
}

.czar-shop-toolbar__sort {
	min-width: 220px;
}

/* ---- Card de produto no loop ---- */

.czar-product-card {
	position: relative;
}

.czar-product-card__media {
	aspect-ratio: 1 / 1;
	background-color: color-mix(in srgb, var(--czar-color-text) 6%, transparent);
}

.czar-product-card__sale {
	position: absolute;
	top: var(--czar-space-3);
	left: var(--czar-space-3);
	background-color: var(--czar-color-sale, #d33);
	color: #fff;
	font-family: var(--czar-font-family-base);
	font-size: var(--czar-font-size-xs);
	font-weight: var(--czar-font-weight-bold);
	text-transform: uppercase;
	letter-spacing: var(--czar-letter-spacing-wide);
	padding: var(--czar-space-1) var(--czar-space-3);
	border-radius: var(--czar-radius-full);
	z-index: 2;
}

.czar-product-card__title {
	font-family: var(--czar-font-family-heading);
	font-size: var(--czar-font-size-md);
	font-weight: var(--czar-font-weight-semibold);
	line-height: var(--czar-line-height-snug);
	color: var(--czar-color-text);
	margin: 0;
}

.czar-product-card__price {
	font-family: var(--czar-font-family-base);
	font-size: var(--czar-font-size-lg);
	font-weight: var(--czar-font-weight-bold);
	color: var(--czar-color-price);
	margin: 0;
}

.czar-product-card__price del {
	color: color-mix(in srgb, var(--czar-color-text) 50%, transparent);
	text-decoration: line-through;
	font-weight: var(--czar-font-weight-regular);
	font-size: var(--czar-font-size-sm);
	margin-right: var(--czar-space-2);
}

.czar-product-card__price ins {
	background: none;
	text-decoration: none;
	color: var(--czar-color-sale, #d33);
}

.czar-product-card__rating {
	display: inline-flex;
	gap: 1px;
	font-size: var(--czar-font-size-sm);
	color: var(--czar-color-accent);
}

.czar-product-card__rating[data-rating="0"] {
	color: color-mix(in srgb, var(--czar-color-text) 25%, transparent);
}

/* ---- Paginação ---- */

.czar-pagination {
	display: flex;
	flex-wrap: wrap;
	gap: var(--czar-space-2);
	align-items: center;
	justify-content: center;
	padding: var(--czar-space-8) 0;
}

.czar-pagination__item {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.5em;
	padding: var(--czar-space-2) var(--czar-space-3);
	border: 1.5px solid transparent;
	border-radius: var(--czar-radius-md);
	font-family: var(--czar-font-family-base);
	font-size: var(--czar-font-size-md);
	color: var(--czar-color-text);
	text-decoration: none;
	transition: background-color 0.15s ease, border-color 0.15s ease;
}

.czar-pagination__item:hover {
	border-color: color-mix(in srgb, var(--czar-color-primary) 30%, transparent);
}

.czar-pagination__item--current {
	background-color: var(--czar-color-primary);
	color: var(--czar-color-surface, #fff);
	border-color: var(--czar-color-primary);
}

.czar-pagination__item--disabled {
	opacity: 0.4;
	pointer-events: none;
}

@media (max-width: 640px) {
	.czar-shop-toolbar {
		flex-direction: column;
		align-items: stretch;
	}
	.czar-shop-toolbar__sort {
		min-width: 0;
	}
}
