/* WooCommerce overrides — merge Woo default markup into the Pureflex look. */

/* Kill Woo's default paragraph on notices */
.woocommerce-notices-wrapper { margin: 0 0 20px; }
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	background: var(--pf-tint) !important;
	border-top: 3px solid var(--pf-primary) !important;
	color: var(--pf-ink) !important;
	padding: 14px 20px !important;
	border-radius: 0 !important;
}
.woocommerce-message { background: #EAF6EE !important; border-top-color: var(--pf-success) !important; }

/* Product loop */
.woocommerce ul.products li.product { text-align: start; }

/* Result count + sorting */
.woocommerce-result-count, .woocommerce-ordering { font-size: 13px; color: var(--pf-muted); margin: 0 0 14px; }
.woocommerce-ordering select { padding: 8px 12px; border: 1px solid var(--pf-hairline); background: var(--pf-surface); font: inherit; }

/* Pagination */
.woocommerce nav.woocommerce-pagination ul { border: 0; display: flex; gap: 4px; justify-content: center; }
.woocommerce nav.woocommerce-pagination ul li { border: 0; margin: 0; }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	padding: 8px 14px; font-family: 'Barlow Condensed'; font-weight: 700;
	background: #fff; border: 1px solid var(--pf-hairline); color: var(--pf-ink);
	min-width: 40px; text-align: center;
}
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current {
	background: var(--pf-primary); border-color: var(--pf-primary); color: #fff;
}

/* Single product — le layout est géré par content-single-product.php (.pf-pdp).
   PAS de grille sur div.product (elle cassait la fiche). */
.woocommerce div.product.pf-pdp { display: block; }
.woocommerce div.product .product_title { font-size: clamp(28px, 3.4vw, 38px); margin-top: 8px; }
.woocommerce div.product .woocommerce-tabs ul.tabs { padding: 0; border-bottom: 1px solid var(--pf-hairline); list-style: none; margin: 0; }
.woocommerce div.product .woocommerce-tabs ul.tabs::before { display: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li { background: transparent; border: 0; margin: 0; padding: 0; display: inline-block; }
.woocommerce div.product .woocommerce-tabs ul.tabs li a { padding: 14px 20px; font-family: 'Barlow Condensed'; font-weight: 700; text-transform: uppercase; color: var(--pf-muted); }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--pf-primary); box-shadow: inset 0 -3px 0 var(--pf-primary); }
.woocommerce div.product .woocommerce-Tabs-panel { padding-top: 20px; max-width: 860px; }
.woocommerce div.product .woocommerce-Tabs-panel img { height: auto; margin: 12px 0; }

/* Related products */
.related.products { padding-top: 40px; border-top: 1px solid var(--pf-hairline); margin-top: 40px; }
.related.products > h2 { margin-bottom: 20px; }

/* Cart page — la grille est sur .pf-cart-page__grid (dans main.css).
   PAS de grille sur .pf-container (ça coupait la page en 3). */
.woocommerce-cart-form { background: #fff; border: 1px solid var(--pf-hairline); }
.woocommerce table.shop_table { border: 0; border-radius: 0; margin: 0; }
.woocommerce table.shop_table th { background: var(--pf-surface); color: var(--pf-muted); font-family: 'Barlow Condensed'; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; font-size: 12.5px; padding: 12px 16px; }
.woocommerce table.shop_table td { padding: 16px; border-top: 1px solid var(--pf-hairline); }
.woocommerce table.shop_table td.product-name a { color: var(--pf-ink); font-weight: 700; }
.woocommerce .cart-collaterals { grid-column: auto; }
.woocommerce .cart_totals { background: var(--pf-ink); color: #fff; padding: 24px; }
.woocommerce .cart_totals h2 { color: #fff; font-size: 20px; margin-bottom: 14px; }
.woocommerce .cart_totals table.shop_table { background: transparent; }
.woocommerce .cart_totals table.shop_table th,
.woocommerce .cart_totals table.shop_table td { background: transparent; color: #fff; border-color: rgba(255,255,255,.1); }
.woocommerce .cart_totals .checkout-button { background: var(--pf-primary); color: #fff; width: 100%; padding: 14px 20px; text-align: center; font-family: 'Barlow Condensed'; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; border-radius: 0; margin-top: 10px; }
.woocommerce .cart_totals .checkout-button:hover { background: var(--pf-primary-hover); }
.woocommerce .coupon input[type="text"] { padding: 10px 14px; border: 1px solid var(--pf-hairline); background: var(--pf-surface); font: inherit; }
.woocommerce .coupon .button { background: var(--pf-ink); color: #fff; padding: 10px 18px; border-radius: 0; font-family: 'Barlow Condensed'; font-weight: 700; text-transform: uppercase; }

/* Checkout page */
/* Checkout : la grille doit être sur form.checkout (customer_details | order_review) */
.woocommerce-checkout form.checkout.woocommerce-checkout {
	display: grid;
	grid-template-columns: 1.35fr 1fr;
	grid-template-areas: "details reviewhead" "details review";
	gap: 0 32px;
	align-items: start;
}
.woocommerce-checkout #customer_details { grid-area: details; }
.woocommerce-checkout #customer_details .col2-set { display: block; }
.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2 { width: 100%; float: none; }
.woocommerce-checkout #order_review_heading { grid-area: reviewhead; color: var(--pf-ink); margin-top: 0; }
.woocommerce-checkout #order_review { grid-area: review; position: sticky; top: 120px; }
.woocommerce-checkout #order_review { background: var(--pf-ink); color: #fff; padding: 24px; }
.woocommerce-checkout #order_review table th,
.woocommerce-checkout #order_review table td { background: transparent; color: #fff; border-color: rgba(255,255,255,.1); }
.woocommerce-checkout #payment { background: transparent; }
.woocommerce-checkout #payment ul.payment_methods { background: transparent; border: 0; padding: 0; }
.woocommerce-checkout #payment ul.payment_methods li { background: rgba(255,255,255,.06); padding: 14px; margin-bottom: 8px; }
.woocommerce-checkout #payment ul.payment_methods li label { color: #fff; font-weight: 600; }
.woocommerce-checkout #payment #place_order { background: var(--pf-primary); color: #fff; padding: 16px 22px; width: 100%; border-radius: 0; font-family: 'Barlow Condensed'; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; }
.woocommerce-checkout #payment #place_order:hover { background: var(--pf-primary-hover); }
.woocommerce form .form-row { padding: 0; margin: 0 0 14px; }
.woocommerce form .form-row label { font-size: 12px; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; color: var(--pf-muted); }
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea, .woocommerce form .form-row .select2-container .select2-selection {
	padding: 12px 14px !important; background: var(--pf-surface) !important; border: 1px solid var(--pf-hairline) !important; font: 400 14px 'Barlow', sans-serif !important;
	border-radius: 0 !important; color: var(--pf-ink);
}
.woocommerce form .form-row .select2-container .select2-selection__rendered { padding: 0 !important; line-height: 22px; }
.woocommerce form .form-row .select2-container .select2-selection { height: auto !important; }

/* My account — la grille est gérée par main.css (body.logged-in uniquement,
   pour ne pas casser le formulaire de connexion déconnecté). */
.woocommerce-account nav.woocommerce-MyAccount-navigation ul { background: #fff; border: 1px solid var(--pf-hairline); }
.woocommerce-account nav.woocommerce-MyAccount-navigation li { border-bottom: 1px solid var(--pf-hairline); }
.woocommerce-account nav.woocommerce-MyAccount-navigation li:last-child { border-bottom: 0; }
.woocommerce-account nav.woocommerce-MyAccount-navigation a { display: block; padding: 12px 16px; font-family: 'Barlow Condensed'; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--pf-ink); }
.woocommerce-account nav.woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account nav.woocommerce-MyAccount-navigation a:hover { background: var(--pf-tint); color: var(--pf-primary); }

@media (max-width: 1000px) {
	.woocommerce div.product { grid-template-columns: 1fr; }
	.woocommerce div.product .woocommerce-product-gallery { position: static; }
	.woocommerce-cart .pf-container,
	.woocommerce-checkout .woocommerce,
	.woocommerce-account .woocommerce { grid-template-columns: 1fr; }
	.woocommerce-checkout #order_review, .woocommerce-checkout #order_review_heading { grid-column: 1; position: static; }
}

/* ==== v1.3.0 — neutralise le layout float/width par défaut de Woo, partout ==== */
.woocommerce ul.products,
.woocommerce-page ul.products,
div.woocommerce ul.products,
ul.products.pf-grid,
ul.products {
	display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(216px, 1fr)) !important;
	gap: 16px !important;
	padding: 0 !important;
	margin: 0 !important;
	list-style: none !important;
	width: 100% !important;
}
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product,
div.woocommerce ul.products li.product,
ul.products li.product {
	width: auto !important;
	max-width: none !important;
	min-width: 0 !important;
	float: none !important;
	clear: none !important;
	margin: 0 !important;
	padding: 0 !important;
	text-align: start !important;
}
.woocommerce ul.products li.product .pf-card { width: 100%; height: 100%; }
.woocommerce ul.products li.product .onsale,
.woocommerce span.onsale { display: none !important; }
.woocommerce ul.products::before,
.woocommerce ul.products::after { display: none !important; }
/* TI Wishlist dans la carte : bouton coeur circulaire en haut à droite */
.pf-card__actions .tinv-wishlist { margin: 0; }
.pf-card__actions .tinv-wishlist p { margin: 0; }
.pf-card__actions .tinvwl_add_to_wishlist_button {
	width: 34px; height: 34px; padding: 0 !important; margin: 0 !important;
	display: inline-flex !important; align-items: center; justify-content: center;
	background: #fff !important; border: 1px solid var(--pf-border-2) !important;
	color: var(--pf-ink) !important; font-size: 0 !important; line-height: 0;
	border-radius: 0 !important;
}
.pf-card__actions .tinvwl_add_to_wishlist_button::before {
	font-size: 15px !important; margin: 0 !important; color: inherit;
}
.pf-card__actions .tinvwl_add_to_wishlist_button:hover,
.pf-card__actions .tinvwl_add_to_wishlist_button.added {
	border-color: var(--pf-primary) !important; color: var(--pf-primary) !important;
}
.pf-card__actions .tinvwl-tooltip,
.pf-card__actions .tinvwl_add_to_wishlist_button .tinvwl_add_to_wishlist_text { display: none !important; }
@media (max-width: 760px) {
	.woocommerce ul.products,
	ul.products {
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 10px !important;
	}
}

/* ==== v1.7.0 — grille 4 produits/ligne + panier plus large + checkout responsive ==== */
.woocommerce ul.products,
.woocommerce-page ul.products,
div.woocommerce ul.products,
ul.products.pf-grid,
ul.products {
	grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
	gap: 18px !important;
}
.related.products ul.products,
.up-sells ul.products {
	grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}
@media (max-width: 1100px) {
	.woocommerce ul.products, ul.products,
	.related.products ul.products { grid-template-columns: repeat(3, minmax(0,1fr)) !important; }
}
@media (max-width: 760px) {
	.woocommerce ul.products, ul.products,
	.related.products ul.products { grid-template-columns: repeat(2, minmax(0,1fr)) !important; gap: 10px !important; }
}

/* Panier : occupe toute la largeur du conteneur, mieux réparti */
.pf-cart-page { max-width: var(--pf-container-max); }
.pf-cart-page__grid { grid-template-columns: 1.7fr 1fr; gap: 40px; }
@media (max-width: 1000px) {
	.pf-cart-page__grid { grid-template-columns: 1fr; }
}

/* Checkout responsive */
@media (max-width: 1000px) {
	.woocommerce-checkout form.checkout.woocommerce-checkout {
		grid-template-columns: 1fr;
		grid-template-areas: "details" "reviewhead" "review";
	}
	.woocommerce-checkout #order_review { position: static; }
}
