/* ==========================================================================
   WooCommerce - Le Clic à Vrac
   Product Card (CENTRALISÉ), Prix, Quantité, Messages
   ========================================================================== */

/* ==========================================================================
   Product Card (Composant UNIQUE - utilisé partout)
   ========================================================================== */

.style-product-card {
	position: relative;
	display: flex;
	flex-direction: column;
	background-color: var(--cav-bg-alt);
	border-radius: var(--cav-radius-lg);
	border: 1px solid var(--cav-border);
	overflow: hidden;
	box-shadow: var(--cav-shadow-sm);
	transition: box-shadow var(--cav-transition-base), transform var(--cav-transition-base);
	user-select: none;
	-webkit-user-select: none;
	-webkit-tap-highlight-color: transparent;
}

.style-product-card:hover {
	box-shadow: var(--cav-shadow-md);
	transform: translateY(-2px);
}

.product-card--out-of-stock {
	opacity: 0.7;
}

.product-card--out-of-stock .product-card__image {
	filter: grayscale(50%);
}

.style-product-card.product-card--in-cart {
	border-color: var(--cav-primary);
}

/* Image wrapper */
.product-card__image-wrapper {
	position: relative;
	aspect-ratio: 1;
	overflow: hidden;
}

.product-card__image-link {
	display: block;
	width: 100%;
	height: 100%;
}

.product-card__image {
	width: 100%;
	height: 100%;
	object-fit: contain;
	transition: transform var(--cav-transition-base);
}

.style-product-card:hover .product-card__image {
	transform: scale(1.05);
}

/* Badges */
.product-card__badges {
	position: absolute;
	top: var(--cav-space-sm);
	left: var(--cav-space-sm);
	display: flex;
	align-items: flex-start;
	flex-direction: column;
	gap: var(--cav-space-xs);
	z-index: 2;
}

.product-card__badge {
	padding: 2px 8px;
	font-size: 10px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	border-radius: var(--cav-radius-sm);
}

.product-card__badge--bio {
	color: var(--cav-text-inverse);
	background-color: var(--cav-success);
}

.product-card__badge--local {
	color: var(--cav-text-inverse);
	background-color: var(--cav-secondary);
}

.product-card__badge--promo {
	color: var(--cav-text-inverse);
	background-color: var(--cav-warning);
}

.product-card__badge--short-date {
	background-color: var(--cav-warning);
	color: var(--cav-text-inverse);
}

.product-card__badge--pasteurise {
	background-color: #1e3a5f;
	color: var(--cav-text-inverse);
}

.product-card__badge--lait-cru {
	background-color: #4a90e2;
	color: var(--cav-text-inverse);
}

.product-card__badge--thermise {
	background-color: #6ba3d4;
	color: var(--cav-text-inverse);
}

/* Origine produit */
.product-card__origin {
	position: absolute;
	bottom: var(--cav-space-sm);
	left: var(--cav-space-sm);
	font-size: 11px;
	font-weight: 600;
	color: var(--cav-text-muted);
	z-index: 2;
}

/* Badge pourcentage de réduction */
.product-card__discount-badge {
	position: absolute;
	bottom: var(--cav-space-sm);
	right: var(--cav-space-sm);
	padding: 2px 8px;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.4;
	color: #fff;
	background-color: var(--cav-discount);
	border-radius: var(--cav-radius-sm);
	z-index: 2;
}

/* Meta (poids + prix/kg sur même ligne) */
.product-card__meta {
	display: flex;
	align-items: center;
	gap: var(--cav-space-sm);
	margin-top: auto;
}

/* Poids */
.product-card__weight {
	display: inline-block;
	padding: 2px 8px;
	font-size: var(--cav-font-xs);
	font-weight: 600;
	color: var(--cav-text);
	background-color: var(--cav-bg);
	border-radius: var(--cav-radius-sm);
}

/* Contenu */
.product-card__content {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: var(--cav-space-xs);
	padding: var(--cav-space-sm);
}

@media (min-width: 768px) {
	.product-card__content {
		padding: var(--cav-space-md);
	}
}

/* Titre */
.product-card__title {
	margin: 0;
	font-family: var(--cav-font-primary);
	font-size: var(--cav-font-sm);
	font-weight: 600;
	line-height: 1.3;
}

.product-card__title-link {
	color: var(--cav-text);
	text-decoration: none;
	display: -webkit-box;
	line-clamp: 2;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.product-card__title-link:hover {
	color: var(--cav-primary);
}

/* Footer card (marque + meta, poussé en bas) */
.product-card__footer {
	margin-top: auto;
	display: flex;
	flex-direction: column;
	gap: var(--cav-space-xs);
}

/* Marque */
.product-card__brand {
	margin: 0;
	font-size: var(--cav-font-xs);
	font-weight: 600;
	line-height: 1.3;
	color: var(--cav-primary);
}

/* Producteur */
.product-card__producer {
	margin: 0;
	font-size: var(--cav-font-xs);
	color: var(--cav-text-light);
}

.product-card__producer-link {
	color: var(--cav-text-light);
	text-decoration: none;
}

.product-card__producer-link:hover {
	color: var(--cav-primary);
	text-decoration: underline;
}

/* Header (prix + bouton sur même ligne) */
.product-card__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--cav-space-sm);
	margin-bottom: var(--cav-space-xs);
}

/* Header en rupture de stock : bouton sur sa propre ligne */
.product-card__header--out-of-stock {
	flex-direction: column;
	align-items: stretch;
	gap: var(--cav-space-xs);
}

.product-card__header--out-of-stock .product-card__price {
	order: -1;
}

/* Prix */
.product-card__price {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.product-card__price-old {
	font-size: var(--cav-font-xs);
	color: var(--cav-text-lighter);
	text-decoration: line-through;
}

.product-card__price-current {
	font-size: var(--cav-font-base);
	font-weight: 700;
	color: var(--cav-text);
}

.product-card__price-current--sale {
	color: var(--cav-error);
}

/* Prix au kg - dans la zone meta */
.product-card__price-per-kg {
	font-size: var(--cav-font-xs);
	color: var(--cav-text-light);
}

/* Actions - dans le header (bouton rond) */
.product-card__header .product-card__actions {
	padding: 0;
	flex-shrink: 0;
}

/* Bouton ajouter - style de base */
.product-card__add-btn {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--cav-space-sm) var(--cav-space-lg);
	color: var(--cav-text-inverse);
	background-color: var(--cav-primary);
	border: none;
	border-radius: var(--cav-radius-full);
	cursor: pointer;
	transition: background-color var(--cav-transition-fast), transform var(--cav-transition-fast);
	user-select: none;
	-webkit-user-select: none;
	-webkit-tap-highlight-color: transparent;
}

.product-card__add-btn:hover {
	background-color: var(--cav-primary-dark);
	transform: scale(1.05);
}

/* Bouton rond dans les cartes produit (dans le header) */
.product-card__header .product-card__add-btn {
	width: 30px;
	height: 30px;
	padding: 0;
}

.product-card__add-btn--variable {
	background-color: var(--cav-primary);
	color: var(--cav-text-inverse);
}

.product-card__add-btn--variable:hover {
	background-color: var(--cav-primary-dark);
}

.product-card__add-btn-badge {
	position: absolute;
	top: -6px;
	right: -6px;
	min-width: 20px;
	height: 20px;
	padding: 0 6px;
	font-size: 11px;
	font-weight: 700;
	line-height: 20px;
	text-align: center;
	color: var(--cav-text);
	background-color: var(--cav-secondary);
	border-radius: var(--cav-radius-full);
}

/* Compteur quantité - compact pour tenir dans le footer */
.product-card__quantity {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 2px;
	height: 30px;
	min-width: 80px;
	background-color: var(--cav-primary);
	border-radius: var(--cav-radius-full);
	user-select: none;
	-webkit-user-select: none;
}

.product-card__qty-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	padding: 0;
	color: var(--cav-text-inverse);
	background: none;
	border: none;
	border-radius: var(--cav-radius-full);
	cursor: pointer;
	transition: all var(--cav-transition-fast);
	user-select: none;
	-webkit-user-select: none;
	-webkit-tap-highlight-color: transparent;
}

.product-card__qty-btn:hover {
	color: var(--cav-text-inverse);
	background-color: rgba(255, 255, 255, 0.2);
}

.product-card__qty-value {
	width: 32px;
	font-family: inherit;
	font-size: var(--cav-font-sm);
	font-weight: 700;
	text-align: center;
	color: var(--cav-text-inverse);
	background: none;
	border: none;
	padding: 0;
	-moz-appearance: textfield;
}

.product-card__qty-value::-webkit-outer-spin-button,
.product-card__qty-value::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

/* Rupture de stock */
.product-card__out-of-stock,
.product-card__stock--out {
	display: block;
	width: 100%;
	padding: var(--cav-space-xs) var(--cav-space-sm);
	font-size: var(--cav-font-xs);
	font-weight: 600;
	text-align: center;
	color: var(--cav-text-light);
	background-color: var(--cav-bg);
	border-radius: var(--cav-radius-sm);
}

/* ==========================================================================
   Quantity Selector (générique)
   ========================================================================== */

.quantity-selector {
	display: inline-flex;
	align-items: center;
	gap: 0;
	border: 1px solid var(--cav-border);
	border-radius: var(--cav-radius-md);
	overflow: hidden;
}

.quantity-selector__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	padding: 0;
	color: var(--cav-text);
	background-color: var(--cav-bg);
	border: none;
	cursor: pointer;
	transition: background-color var(--cav-transition-fast);
}

.quantity-selector__btn:hover:not(:disabled) {
	background-color: var(--cav-border);
}

.quantity-selector__btn:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

.quantity-selector__input {
	width: 40px;
	height: 32px;
	padding: 0;
	font-family: inherit;
	font-size: var(--cav-font-sm);
	font-weight: 600;
	text-align: center;
	color: var(--cav-text);
	background-color: var(--cav-bg-alt);
	border: none;
	border-left: 1px solid var(--cav-border);
	border-right: 1px solid var(--cav-border);
	appearance: textfield;
	-moz-appearance: textfield;
}

.quantity-selector__input::-webkit-outer-spin-button,
.quantity-selector__input::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

/* ==========================================================================
   Consigne Notice
   ========================================================================== */

.product-consigne {
	display: flex;
	align-items: center;
	gap: var(--cav-space-xs);
	margin: var(--cav-space-sm) 0;
	padding: var(--cav-space-sm) var(--cav-space-md);
	font-size: var(--cav-font-sm);
	color: var(--cav-primary-dark);
	background-color: rgb(59 154 156 / 0.1);
	border-radius: var(--cav-radius-md);
}

.product-consigne__icon {
	flex-shrink: 0;
}

/* ==========================================================================
   WooCommerce Messages
   ========================================================================== */

.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-noreviews,
p.no-comments {
	padding: var(--cav-space-md) var(--cav-space-lg);
	margin-bottom: var(--cav-space-lg);
	border-radius: var(--cav-radius-md);
	font-size: var(--cav-font-sm);
}

.woocommerce-message {
	background-color: var(--cav-success-light);
	color: #2E7D32;
	border-left: 4px solid var(--cav-success);
}

.woocommerce-info {
	background-color: rgb(59 154 156 / 0.1);
	color: var(--cav-primary-dark);
	border-left: 4px solid var(--cav-primary);
}

.woocommerce-error {
	background-color: var(--cav-error-light);
	color: #C62828;
	border-left: 4px solid var(--cav-error);
	list-style: none;
	padding-left: var(--cav-space-lg);
}

.woocommerce-message a,
.woocommerce-info a {
	font-weight: 600;
}

/* ==========================================================================
   Pagination
   ========================================================================== */

.woocommerce-pagination {
	margin-top: var(--cav-space-2xl);
	text-align: center;
}

.woocommerce-pagination ul {
	display: inline-flex;
	gap: var(--cav-space-xs);
	list-style: none;
	margin: 0;
	padding: 0;
}

.woocommerce nav.woocommerce-pagination ul li {
	margin: 0;
	border: 0;
}

.woocommerce-pagination a,
.woocommerce-pagination span {
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 var(--cav-space-sm);
	font-size: var(--cav-font-sm);
	font-weight: 600;
	color: var(--cav-text);
	background-color: var(--cav-bg-alt);
	border: 1px solid var(--cav-border);
	border-radius: var(--cav-radius-md);
	text-decoration: none;
	transition: border-color var(--cav-transition-fast), background-color var(--cav-transition-fast);
}

.woocommerce-pagination a:hover {
	border-color: var(--cav-primary);
	color: var(--cav-primary);
}

.woocommerce-pagination span.current {
	background-color: var(--cav-primary);
	border-color: var(--cav-primary);
	color: var(--cav-text-inverse);
}

/* ==========================================================================
   Star Rating
   ========================================================================== */

.star-rating {
	display: inline-flex;
	font-size: var(--cav-font-sm);
	color: var(--cav-secondary);
	overflow: hidden;
	position: relative;
	width: 5em;
	height: 1em;
}

.star-rating::before {
	content: '★★★★★';
	color: var(--cav-border);
}

.star-rating span {
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden;
	color: var(--cav-secondary);
}

.star-rating span::before {
	content: '★★★★★';
}

/* ==========================================================================
   Loading States
   ========================================================================== */

.woocommerce-loading {
	position: relative;
	min-height: 100px;
}

.woocommerce-loading::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 32px;
	height: 32px;
	margin: -16px 0 0 -16px;
	border: 3px solid var(--cav-border);
	border-top-color: var(--cav-primary);
	border-radius: 50%;
	animation: cav-spin 0.8s linear infinite;
}

/* ==========================================================================
   Empty States
   ========================================================================== */

.woocommerce-no-products,
.cart-empty {
	text-align: center;
	padding: var(--cav-space-3xl) var(--cav-space-lg);
}

.woocommerce-no-products p,
.cart-empty p {
	margin-bottom: var(--cav-space-lg);
	color: var(--cav-text-light);
}

.woocommerce ul.products::before,
.woocommerce ul.products::after {
	display: none;
}

/* ==========================================================================
   Fix: Masquer bouton toggle password en doublon (WooCommerce bug)
   ========================================================================== */

.password-input > .password-input + .show-password-input {
	display: none !important;
}