/**
 * Medinatouna — Habillage WooCommerce (surcharge, charte premium).
 *
 * Chargé après les styles WooCommerce : surcharge couleurs, typographie,
 * cartes, boutons, page produit, panier, commande, compte et notifications.
 * Aucun gabarit n'est remplacé (stabilité aux mises à jour de WooCommerce).
 *
 * Réutilise les variables --med-* définies dans main.css.
 */

/* =========================================================
   1. BOUTONS
   ========================================================= */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce .widget a.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	background: var(--med-cream);
	color: var(--med-ink);
	border: 1px solid var(--med-line);
	border-radius: var(--med-radius-sm);
	padding: 0.7em 1.4em;
	font-family: var(--med-font-body);
	font-weight: 600;
	font-size: 0.95rem;
	line-height: 1.2;
	text-transform: none;
	transition: transform var(--med-trans), box-shadow var(--med-trans), background var(--med-trans), color var(--med-trans);
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover {
	background: #fff;
	color: var(--med-primary);
	border-color: var(--med-primary);
	transform: translateY(-2px);
	box-shadow: var(--med-shadow-sm);
}

/* Bouton d'action principal (ajouter au panier, commander…) */
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt,
.woocommerce #place_order,
.woocommerce button.single_add_to_cart_button {
	background: linear-gradient(135deg, #0E8A63, var(--med-primary));
	color: #fff;
	border: none;
	box-shadow: 0 10px 26px rgba(11, 110, 79, 0.26);
}
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover,
.woocommerce #respond input#submit.alt:hover,
.woocommerce #place_order:hover,
.woocommerce button.single_add_to_cart_button:hover {
	background: linear-gradient(135deg, #0F9A6E, var(--med-primary-dark));
	color: #fff;
	transform: translateY(-2px);
	box-shadow: var(--med-shadow);
}
.woocommerce a.button.disabled,
.woocommerce button.button:disabled,
.woocommerce button.button.disabled {
	opacity: 0.5;
	transform: none;
	box-shadow: none;
}

/* =========================================================
   2. NOTIFICATIONS (succès / info / erreur)
   ========================================================= */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	border-radius: var(--med-radius-sm);
	border: 1px solid var(--med-line);
	border-top: 3px solid var(--med-primary);
	background: #fff;
	box-shadow: var(--med-shadow-sm);
	color: var(--med-text);
	padding: 1em 1.4em;
}
.woocommerce-message { border-top-color: var(--med-primary); }
.woocommerce-info { border-top-color: var(--med-accent-strong); }
.woocommerce-error { border-top-color: #B23A3A; }
.woocommerce-message::before { color: var(--med-primary); }
.woocommerce-info::before { color: var(--med-accent-strong); }
.woocommerce-error::before { color: #B23A3A; }
.woocommerce-message a.button,
.woocommerce-info a.button,
.woocommerce-error a.button { box-shadow: none; }

/* =========================================================
   3. EN-TÊTE BOUTIQUE + BARRE D'OUTILS
   ========================================================= */
.woo-hero { margin-bottom: 0; }
.woocommerce .woocommerce-result-count {
	color: var(--med-muted);
	font-size: 0.92rem;
	margin-top: 0.4rem;
}
.woocommerce .woocommerce-ordering select,
.woocommerce select.orderby {
	border: 1px solid var(--med-line);
	border-radius: var(--med-radius-sm);
	padding: 0.55em 2.2em 0.55em 0.9em;
	font-family: var(--med-font-body);
	color: var(--med-ink);
	background-color: #fff;
}

/* =========================================================
   4. GRILLE PRODUITS (boutique / archives)
   ========================================================= */
.woocommerce ul.products,
.woocommerce-page ul.products {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.6rem;
	margin: 0 0 2.5rem;
	padding: 0;
}
/* WooCommerce ajoute un clearfix ::before/::after sur ul.products ; en mode
   grille, ces pseudo-éléments deviennent de faux items et décalent la grille.
   On les neutralise. */
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after {
	display: none;
}
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	width: auto !important;
	margin: 0 !important;
	float: none !important;
	background: #fff;
	border: 1px solid var(--med-line);
	border-radius: var(--med-radius);
	padding: 1rem 1rem 1.3rem;
	box-shadow: var(--med-shadow-sm);
	transition: transform var(--med-trans), box-shadow var(--med-trans);
	position: relative;
	overflow: hidden;
}
.woocommerce ul.products li.product:hover {
	transform: translateY(-4px);
	box-shadow: var(--med-shadow);
}
.woocommerce ul.products li.product a img {
	border-radius: var(--med-radius-sm);
	margin-bottom: 1rem;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--med-font-head);
	font-size: 1.15rem;
	color: var(--med-ink);
	padding: 0 0 0.4rem;
}
.woocommerce ul.products li.product .price {
	color: var(--med-primary);
	font-family: var(--med-font-head);
	font-size: 1.2rem;
	font-weight: 400;
}
.woocommerce ul.products li.product .price del { color: var(--med-muted); font-size: 0.85em; }
.woocommerce ul.products li.product .price ins { text-decoration: none; }
.woocommerce ul.products li.product .button {
	background: linear-gradient(135deg, #0E8A63, var(--med-primary));
	color: #fff;
	border: none;
	box-shadow: 0 10px 26px rgba(11, 110, 79, 0.26);
	margin-top: 0.8rem;
}
.woocommerce ul.products li.product .button:hover {
	background: linear-gradient(135deg, #0F9A6E, var(--med-primary-dark));
	color: #fff;
}

/* Badge promo doré */
.woocommerce span.onsale {
	background: linear-gradient(135deg, var(--med-accent), #B4882F);
	color: #2A2008;
	font-family: var(--med-font-body);
	font-weight: 700;
	font-size: 0.72rem;
	letter-spacing: 0.04em;
	min-height: auto;
	min-width: auto;
	line-height: 1;
	padding: 0.45em 0.8em;
	border-radius: 100px;
	top: 1rem;
	left: 1rem;
	margin: 0;
}

/* Note en étoiles */
.woocommerce .star-rating span::before,
.woocommerce p.stars a::before { color: var(--med-accent-strong); }
.woocommerce .star-rating { color: var(--med-accent-strong); }

/* =========================================================
   5. PAGE PRODUIT UNIQUE
   ========================================================= */
.woocommerce div.product .product_title {
	font-family: var(--med-font-head);
	color: var(--med-ink);
	font-size: clamp(1.8rem, 1.4rem + 1.6vw, 2.6rem);
	margin-bottom: 0.6rem;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
	color: var(--med-primary);
	font-family: var(--med-font-head);
	font-size: 1.9rem;
	font-weight: 400;
}
.woocommerce div.product p.price del { color: var(--med-muted); font-size: 0.6em; }
.woocommerce div.product p.price ins { text-decoration: none; }
.woocommerce div.product .woocommerce-product-rating { margin-bottom: 1rem; }
.woocommerce div.product .woocommerce-product-details__short-description {
	color: var(--med-text);
	margin-bottom: 1.4rem;
}
.woocommerce div.product form.cart { margin-bottom: 1.6rem; }
.woocommerce div.product form.cart .quantity input.qty {
	border: 1px solid var(--med-line);
	border-radius: var(--med-radius-sm);
	padding: 0.6em 0.4em;
	width: 4.5em;
	text-align: center;
}
.woocommerce div.product .single_add_to_cart_button { padding: 0.9em 1.8em; }

/* Sélecteurs de variations */
.woocommerce div.product table.variations { margin-bottom: 1.2rem; }
.woocommerce div.product table.variations label {
	font-family: var(--med-font-head);
	color: var(--med-ink);
}
.woocommerce div.product table.variations select {
	border: 1px solid var(--med-line);
	border-radius: var(--med-radius-sm);
	padding: 0.6em 2.2em 0.6em 0.9em;
	background-color: #fff;
	min-width: 12rem;
}

/* Métadonnées produit */
.woocommerce div.product .product_meta {
	font-size: 0.9rem;
	color: var(--med-muted);
	border-top: 1px solid var(--med-line);
	padding-top: 1.2rem;
	margin-top: 1.4rem;
}
.woocommerce div.product .product_meta a { color: var(--med-primary); }

/* Onglets (description / avis…) */
.woocommerce div.product .woocommerce-tabs ul.tabs {
	padding: 0 0 0.5rem;
	margin-bottom: 1.6rem;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { display: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
	background: var(--med-cream);
	border: 1px solid var(--med-line);
	border-radius: 100px;
	margin: 0;
	padding: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after { display: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	font-family: var(--med-font-head);
	color: var(--med-ink);
	padding: 0.6em 1.3em;
	display: block;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
	background: var(--med-primary);
	border-color: var(--med-primary);
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: #fff; }
.woocommerce div.product .woocommerce-tabs .panel h2 {
	font-family: var(--med-font-head);
	color: var(--med-ink);
}

/* Produits liés / ventes croisées */
.woocommerce .related > h2,
.woocommerce .upsells > h2,
.woocommerce .cross-sells > h2 {
	font-family: var(--med-font-head);
	color: var(--med-ink);
	font-size: 1.6rem;
	margin-bottom: 1.4rem;
}

/* =========================================================
   6. PANIER (gabarit classique)
   ========================================================= */
.woocommerce table.shop_table {
	border: 1px solid var(--med-line);
	border-radius: var(--med-radius);
	overflow: hidden;
	border-collapse: separate;
	border-spacing: 0;
}
.woocommerce table.shop_table thead th {
	background: var(--med-cream);
	font-family: var(--med-font-head);
	color: var(--med-ink);
	font-weight: 400;
	padding: 1rem 1.1rem;
}
.woocommerce table.shop_table td { padding: 1rem 1.1rem; }
.woocommerce table.shop_table .product-name a { color: var(--med-ink); font-weight: 600; }
.woocommerce table.shop_table .product-name a:hover { color: var(--med-primary); }
.woocommerce a.remove {
	color: var(--med-primary) !important;
	border: 1px solid var(--med-line);
}
.woocommerce a.remove:hover { background: var(--med-primary) !important; color: #fff !important; }
.woocommerce .cart-collaterals .cart_totals > h2,
.woocommerce-cart .cart-collaterals .cart_totals h2 {
	font-family: var(--med-font-head);
	color: var(--med-ink);
}
.woocommerce .cart_totals table {
	border-radius: var(--med-radius);
	overflow: hidden;
}
.woocommerce .cart-collaterals .cart_totals .order-total .amount { color: var(--med-primary); }
.woocommerce form.woocommerce-cart-form .coupon input.input-text {
	border: 1px solid var(--med-line);
	border-radius: var(--med-radius-sm);
	padding: 0.6em 0.9em;
}

/* =========================================================
   7. COMMANDE / CHECKOUT (gabarit classique)
   ========================================================= */
.woocommerce-checkout h3,
.woocommerce-checkout #order_review_heading {
	font-family: var(--med-font-head);
	color: var(--med-ink);
}
.woocommerce-checkout #order_review {
	background: #fff;
	border: 1px solid var(--med-line);
	border-radius: var(--med-radius);
	padding: 1.6rem;
	box-shadow: var(--med-shadow-sm);
}
.woocommerce-checkout #payment {
	background: transparent;
	border-radius: var(--med-radius-sm);
}
.woocommerce-checkout #payment ul.payment_methods {
	background: var(--med-cream);
	border-radius: var(--med-radius-sm);
	border: 1px solid var(--med-line);
}
.woocommerce-checkout #payment div.payment_box {
	background: #fff;
	border: 1px solid var(--med-line);
	color: var(--med-text);
}
.woocommerce-checkout #payment div.payment_box::before { border-bottom-color: #fff; }
.woocommerce-checkout #payment .place-order { padding-top: 1rem; }

/* =========================================================
   8. MON COMPTE
   ========================================================= */
.woocommerce-account .woocommerce-MyAccount-navigation ul {
	list-style: none;
	margin: 0 0 1.5rem;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}
.woocommerce-account .woocommerce-MyAccount-navigation li {
	background: var(--med-cream);
	border: 1px solid var(--med-line);
	border-radius: 100px;
}
.woocommerce-account .woocommerce-MyAccount-navigation li a {
	display: block;
	padding: 0.55em 1.2em;
	font-family: var(--med-font-head);
	color: var(--med-ink);
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active {
	background: var(--med-primary);
	border-color: var(--med-primary);
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a { color: #fff; }

/* =========================================================
   9. CHAMPS DE FORMULAIRE (cohérence avec le thème)
   ========================================================= */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce .woocommerce-form-row input.input-text,
.woocommerce #customer_login input.input-text,
.woocommerce-page form .form-row input.input-text,
.woocommerce-page form .form-row textarea {
	border: 1px solid var(--med-line);
	border-radius: var(--med-radius-sm);
	padding: 0.7em 0.9em;
	font-family: var(--med-font-body);
	color: var(--med-ink);
	background: #fff;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
	outline: none;
	border-color: var(--med-primary);
	box-shadow: 0 0 0 4px var(--med-primary-soft);
}
.woocommerce form .form-row label { color: var(--med-ink); font-weight: 600; font-size: 0.92rem; }
.select2-container--default .select2-selection--single {
	border: 1px solid var(--med-line);
	border-radius: var(--med-radius-sm);
	height: auto;
	padding: 0.45em 0.4em;
}

/* =========================================================
   10. MINI-PANIER / WIDGETS
   ========================================================= */
.woocommerce ul.cart_list li,
.woocommerce.widget_shopping_cart .cart_list li { padding: 0.8rem 0; }
.woocommerce .widget_shopping_cart .total { border-top: 1px solid var(--med-line); padding-top: 0.8rem; }
.woocommerce .widget_shopping_cart .total .amount { color: var(--med-primary); }
.woocommerce .price ins .amount { color: var(--med-primary); }

/* =========================================================
   11. SURCHARGES BLOCS (panier / commande « blocs »)
   Habillage minimal — le système de blocs gère sa propre mise en page.
   ========================================================= */
.wc-block-components-button:not(.is-link),
.wp-block-button__link.wc-block-components-button {
	background: linear-gradient(135deg, #0E8A63, var(--med-primary));
	color: #fff;
	border-radius: var(--med-radius-sm);
}
.wc-block-components-button:not(.is-link):hover {
	background: linear-gradient(135deg, #0F9A6E, var(--med-primary-dark));
}
.wc-block-components-product-price,
.wc-block-grid__product-price,
.wc-block-cart__totals-title,
.wc-block-components-totals-item__value { color: var(--med-ink); }
.wc-block-components-product-price ins,
.wc-block-formatted-money-amount { text-decoration: none; }
.wc-block-checkout__actions .wc-block-components-checkout-place-order-button {
	background: linear-gradient(135deg, #0E8A63, var(--med-primary));
}

/* =========================================================
   12. RESPONSIVE
   ========================================================= */
@media (max-width: 60rem) {
	.woocommerce ul.products,
	.woocommerce-page ul.products { grid-template-columns: repeat(2, 1fr); gap: 1.2rem; }
}
@media (max-width: 38rem) {
	.woocommerce ul.products,
	.woocommerce-page ul.products { grid-template-columns: 1fr; }
}
