/* =========================================================================
   SANSSERO — WooCommerce Custom Styles
   Design minimaliste, épuré et premium pour une maison d'édition
   ========================================================================= */

/* =========================================================================
   STICKY HEADER
   ========================================================================= */

/* Sticky: target the template-part wrapper (header tag) */
header.wp-block-template-part {
	position: sticky !important;
	top: 0 !important;
	z-index: 9999 !important;
	background: var(--ss-bg);
}

.admin-bar header.wp-block-template-part {
	top: 32px !important;
}

@media (max-width: 782px) {
	.admin-bar header.wp-block-template-part {
		top: 46px !important;
	}
}

.sanssero-header {
	background: var(--ss-bg) !important;
	border-bottom: 1px solid var(--ss-border);
	transition: box-shadow 0.3s ease;
}

.sanssero-header.scrolled {
	box-shadow: 0 2px 20px rgba(15, 25, 35, 0.06);
}

:root {
	--ss-primary: #0f1923;
	--ss-accent: #2563eb;
	--ss-bg: #ffffff;
	--ss-surface: #f7f7f8;
	--ss-border: #e5e7eb;
	--ss-text: #0f1923;
	--ss-text-secondary: #6b7280;
	--ss-success: #059669;
	--ss-error: #dc2626;
	--ss-radius: 8px;
	--ss-radius-sm: 4px;
	--ss-transition: all 0.25s ease;
}

/* =========================================================================
   GLOBAL — Messages, notices, breadcrumbs
   ========================================================================= */

.woocommerce-breadcrumb {
	font-size: 0.8rem;
	color: var(--ss-text-secondary);
	margin-bottom: 1.5rem;
	letter-spacing: 0.02em;
}

.woocommerce-breadcrumb a {
	color: var(--ss-accent);
	text-decoration: none;
	transition: var(--ss-transition);
}

.woocommerce-breadcrumb a:hover {
	color: var(--ss-primary);
}

.woocommerce .woocommerce-message,
.woocommerce .woocommerce-info,
.woocommerce .woocommerce-error {
	border-radius: var(--ss-radius);
	border: 1px solid var(--ss-border);
	padding: 1rem 1.5rem;
	margin-bottom: 2rem;
	font-size: 0.9rem;
	background: var(--ss-surface);
	border-top: 3px solid var(--ss-primary);
}

.woocommerce .woocommerce-message {
	border-top-color: var(--ss-success);
}

.woocommerce .woocommerce-error {
	border-top-color: var(--ss-error);
	background: #fef2f2;
}

.woocommerce .woocommerce-info {
	border-top-color: var(--ss-accent);
}

.woocommerce .woocommerce-message::before,
.woocommerce .woocommerce-info::before,
.woocommerce .woocommerce-error::before {
	color: inherit;
}

/* =========================================================================
   BOUTIQUE — Grille de produits
   ========================================================================= */

.woocommerce .woocommerce-result-count {
	font-size: 0.85rem;
	color: var(--ss-text-secondary);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-weight: 500;
}

.woocommerce .woocommerce-ordering select {
	border: 1px solid var(--ss-border);
	border-radius: var(--ss-radius-sm);
	padding: 0.5rem 2rem 0.5rem 0.75rem;
	font-size: 0.85rem;
	color: var(--ss-text);
	background-color: var(--ss-bg);
	cursor: pointer;
	font-family: inherit;
	transition: var(--ss-transition);
}

.woocommerce .woocommerce-ordering select:focus {
	outline: none;
	border-color: var(--ss-primary);
	box-shadow: 0 0 0 2px rgba(15, 25, 35, 0.08);
}

.woocommerce ul.products {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 2rem;
}

.woocommerce ul.products li.product {
	background: var(--ss-bg);
	border: 1px solid var(--ss-border);
	border-radius: var(--ss-radius);
	overflow: hidden;
	transition: var(--ss-transition);
	text-align: center;
	padding: 0;
	margin: 0;
	width: 100%;
	float: none;
}

.woocommerce ul.products li.product:hover {
	border-color: var(--ss-primary);
	box-shadow: 0 8px 30px rgba(15, 25, 35, 0.08);
	transform: translateY(-2px);
}

.woocommerce ul.products li.product a img {
	margin: 0;
	padding: 1.5rem;
	background: var(--ss-surface);
	transition: var(--ss-transition);
}

.woocommerce ul.products li.product:hover a img {
	transform: scale(1.02);
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2 {
	font-size: 1rem;
	font-weight: 600;
	padding: 1rem 1.5rem 0.25rem;
	color: var(--ss-text);
	line-height: 1.4;
}

.woocommerce ul.products li.product .price {
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--ss-primary);
	padding: 0 1.5rem 0.75rem;
}

.woocommerce ul.products li.product .price del {
	color: var(--ss-text-secondary);
	font-weight: 400;
	font-size: 0.9rem;
}

.woocommerce ul.products li.product .price ins {
	text-decoration: none;
	color: var(--ss-error);
}

.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.add_to_cart_button {
	display: block;
	margin: 0 1.5rem 1.5rem;
	padding: 0.75rem 1.5rem;
	background: var(--ss-primary);
	color: #fff;
	border: none;
	border-radius: var(--ss-radius-sm);
	font-size: 0.85rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	transition: var(--ss-transition);
	cursor: pointer;
	text-align: center;
	text-decoration: none;
	font-family: inherit;
}

.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product a.add_to_cart_button:hover {
	background: var(--ss-accent);
}

.woocommerce ul.products li.product .added_to_cart {
	display: block;
	text-align: center;
	padding: 0.5rem;
	font-size: 0.8rem;
	color: var(--ss-success);
	font-weight: 600;
	text-decoration: none;
}

/* Badge promo */
.woocommerce span.onsale {
	background: var(--ss-primary);
	color: #fff;
	border-radius: var(--ss-radius-sm);
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	padding: 0.4rem 0.8rem;
	min-width: auto;
	min-height: auto;
	line-height: 1;
	top: 1rem;
	left: 1rem;
}

/* =========================================================================
   PAGE PRODUIT — Détail
   ========================================================================= */

.woocommerce div.product {
	max-width: 1200px;
	margin: 0 auto;
}

/* Block theme single product — two-column layout (style SOS EHPAD) */
.single-product .wp-block-columns.alignwide {
	display: grid !important;
	grid-template-columns: 42% 1fr;
	gap: 2.5rem;
	align-items: start;
	max-width: 1200px;
	margin: 1.5rem auto;
}

.single-product .wp-block-columns.alignwide > .wp-block-column {
	width: 100% !important;
	flex-basis: 100% !important;
	flex-grow: 1;
	margin: 0;
	min-width: 0;
}

/* Product image gallery — large, full-width like SOS EHPAD style */
.single-product .wp-block-woocommerce-product-image-gallery {
	background: var(--ss-surface);
	border-radius: var(--ss-radius);
	padding: 2rem;
	overflow: hidden;
}

/* Override WooCommerce inline width on gallery + all children */
.single-product .wp-block-woocommerce-product-image-gallery .woocommerce-product-gallery,
.single-product .wp-block-woocommerce-product-image-gallery .woocommerce-product-gallery--with-images,
.single-product .woocommerce-product-gallery {
	width: 100% !important;
	max-width: 100% !important;
	float: none !important;
}

.single-product .woocommerce-product-gallery__wrapper,
.single-product .wp-block-woocommerce-product-image-gallery .woocommerce-product-gallery__wrapper {
	width: 100% !important;
	max-width: 100% !important;
}

.single-product .woocommerce-product-gallery__image,
.single-product .wp-block-woocommerce-product-image-gallery .woocommerce-product-gallery__image {
	width: 100% !important;
	max-width: 100% !important;
	height: auto !important;
}

.single-product .woocommerce-product-gallery__image img,
.single-product .wp-block-woocommerce-product-image-gallery img.wp-post-image {
	width: 100% !important;
	height: auto !important;
	max-width: 100% !important;
	object-fit: contain !important;
	border-radius: var(--ss-radius-sm);
	display: block;
}

/* Hide zoom image that causes layout issues */
.single-product .zoomImg {
	display: none !important;
}

/* Classic theme fallback */
.woocommerce div.product div.images {
	width: 45% !important;
	float: left !important;
	background: var(--ss-surface);
	border-radius: var(--ss-radius);
	padding: 2rem;
	overflow: hidden;
}

.woocommerce div.product div.images img {
	border-radius: var(--ss-radius-sm);
}

.woocommerce div.product div.summary {
	width: 50% !important;
	float: right !important;
}

/* Product details (tabs) full width */
.single-product .wp-block-woocommerce-product-details {
	clear: both;
}

.woocommerce div.product .woocommerce-tabs,
.woocommerce div.product .related.products,
.woocommerce div.product .up-sells {
	clear: both;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
	font-size: 2rem;
	font-weight: 800;
	color: var(--ss-primary);
	letter-spacing: -0.02em;
}

.woocommerce div.product .woocommerce-product-details__short-description {
	font-size: 1.05rem;
	line-height: 1.7;
	color: var(--ss-text);
	margin: 1.5rem 0;
	padding-bottom: 1.5rem;
	border-bottom: 1px solid var(--ss-border);
}

.woocommerce div.product form.cart {
	margin: 1.5rem 0;
	padding: 1.5rem 0;
	display: flex;
	align-items: center;
	gap: 1rem;
}

.woocommerce div.product form.cart .quantity input.qty {
	width: 70px;
	padding: 0.75rem;
	border: 1px solid var(--ss-border);
	border-radius: var(--ss-radius-sm);
	font-size: 1rem;
	text-align: center;
	font-family: inherit;
	transition: var(--ss-transition);
}

.woocommerce div.product form.cart .quantity input.qty:focus {
	border-color: var(--ss-primary);
	outline: none;
	box-shadow: 0 0 0 2px rgba(15, 25, 35, 0.08);
}

.woocommerce div.product form.cart .single_add_to_cart_button,
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
	background: var(--ss-primary) !important;
	color: #fff !important;
	border: none;
	border-radius: var(--ss-radius-sm);
	padding: 0.85rem 2.5rem;
	font-size: 0.9rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	transition: var(--ss-transition);
	cursor: pointer;
	font-family: inherit;
	text-decoration: none;
	display: inline-block;
}

.woocommerce div.product form.cart .single_add_to_cart_button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
	background: var(--ss-accent) !important;
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(37, 99, 235, 0.25);
}

.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #respond input#submit.alt {
	background: var(--ss-primary) !important;
}

.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover {
	background: var(--ss-accent) !important;
}

/* Onglets produit */
.woocommerce div.product .woocommerce-tabs {
	margin-top: 3rem;
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
	padding: 0;
	margin: 0 0 2rem;
	list-style: none;
	display: flex;
	gap: 0;
	border-bottom: 2px solid var(--ss-border);
}

.woocommerce div.product .woocommerce-tabs ul.tabs::before {
	display: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
	border: none;
	background: none;
	padding: 0;
	margin: 0;
	border-radius: 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 {
	display: block;
	padding: 0.75rem 1.5rem;
	font-size: 0.85rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--ss-text-secondary);
	text-decoration: none;
	transition: var(--ss-transition);
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
	color: var(--ss-primary);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
	color: var(--ss-primary);
	border-bottom-color: var(--ss-primary);
}

.woocommerce div.product .woocommerce-tabs .panel {
	border: none;
	padding: 0;
	margin: 0;
	box-shadow: none;
}

.woocommerce div.product .woocommerce-tabs .panel h2 {
	font-size: 1.5rem;
	font-weight: 700;
	margin-bottom: 1.5rem;
}

/* Meta produit */
.woocommerce div.product .product_meta {
	font-size: 0.85rem;
	color: var(--ss-text-secondary);
	border-top: 1px solid var(--ss-border);
	padding-top: 1.5rem;
	margin-top: 1.5rem;
}

.woocommerce div.product .product_meta > span {
	display: block;
	margin-bottom: 0.5rem;
}

.woocommerce div.product .product_meta a {
	color: var(--ss-accent);
	text-decoration: none;
}

.woocommerce div.product .product_meta a:hover {
	color: var(--ss-primary);
}

/* =========================================================================
   PANIER
   ========================================================================= */

.woocommerce-cart .woocommerce {
	max-width: 1000px;
	margin: 0 auto;
}

.woocommerce table.shop_table {
	border: 1px solid var(--ss-border);
	border-radius: var(--ss-radius);
	border-collapse: separate;
	border-spacing: 0;
	overflow: hidden;
	width: 100%;
}

.woocommerce table.shop_table thead {
	background: var(--ss-surface);
}

.woocommerce table.shop_table thead th {
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--ss-text-secondary);
	padding: 1rem 1.25rem;
	border-bottom: 1px solid var(--ss-border);
}

.woocommerce table.shop_table td {
	padding: 1.25rem;
	border-top: 1px solid var(--ss-border);
	vertical-align: middle;
	font-size: 0.9rem;
}

.woocommerce table.shop_table img {
	width: 70px;
	height: auto;
	border-radius: var(--ss-radius-sm);
	background: var(--ss-surface);
}

.woocommerce table.shop_table td.product-name a {
	color: var(--ss-text);
	font-weight: 600;
	text-decoration: none;
	transition: var(--ss-transition);
}

.woocommerce table.shop_table td.product-name a:hover {
	color: var(--ss-accent);
}

.woocommerce table.shop_table td.product-remove a.remove {
	color: var(--ss-text-secondary) !important;
	font-size: 1.5rem;
	width: 32px;
	height: 32px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	transition: var(--ss-transition);
}

.woocommerce table.shop_table td.product-remove a.remove:hover {
	background: var(--ss-error);
	color: #fff !important;
}

.woocommerce .cart-collaterals .cart_totals {
	float: none;
	width: 100%;
	max-width: 400px;
	margin-left: auto;
}

.woocommerce .cart-collaterals .cart_totals h2 {
	font-size: 1.1rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-bottom: 1rem;
}

.woocommerce .cart-collaterals .cart_totals table {
	border-radius: var(--ss-radius);
}

.woocommerce .cart-collaterals .cart_totals .order-total .amount {
	font-size: 1.3rem;
	font-weight: 800;
	color: var(--ss-primary);
}

.woocommerce .wc-proceed-to-checkout a.checkout-button {
	display: block;
	width: 100%;
	text-align: center;
	padding: 1rem;
	font-size: 1rem;
	font-weight: 700;
	border-radius: var(--ss-radius);
	margin-top: 1rem;
}

/* Coupon */
.woocommerce .coupon {
	display: flex;
	gap: 0.5rem;
	align-items: center;
}

.woocommerce .coupon input.input-text {
	border: 1px solid var(--ss-border);
	border-radius: var(--ss-radius-sm);
	padding: 0.65rem 1rem;
	font-size: 0.85rem;
	font-family: inherit;
	transition: var(--ss-transition);
}

.woocommerce .coupon input.input-text:focus {
	outline: none;
	border-color: var(--ss-primary);
	box-shadow: 0 0 0 2px rgba(15, 25, 35, 0.08);
}

.woocommerce .coupon button {
	font-size: 0.8rem !important;
	padding: 0.7rem 1.2rem !important;
}

/* Panier vide */
.woocommerce .cart-empty {
	text-align: center;
	padding: 4rem 2rem;
	color: var(--ss-text-secondary);
	font-size: 1.1rem;
}

.woocommerce .return-to-shop a {
	display: inline-block;
	margin-top: 1rem;
}

/* =========================================================================
   COMMANDE / CHECKOUT
   ========================================================================= */

.woocommerce-checkout .woocommerce {
	max-width: 1100px;
	margin: 0 auto;
}

.woocommerce form.checkout_coupon,
.woocommerce form.login,
.woocommerce form.register {
	border: 1px solid var(--ss-border);
	border-radius: var(--ss-radius);
	padding: 1.5rem 2rem;
	margin-bottom: 2rem;
	background: var(--ss-surface);
}

.woocommerce-billing-fields h3,
.woocommerce-shipping-fields h3,
.woocommerce-additional-fields h3,
#order_review_heading {
	font-size: 1.1rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	padding-bottom: 0.75rem;
	border-bottom: 2px solid var(--ss-primary);
	margin-bottom: 1.5rem;
}

.woocommerce form .form-row {
	margin-bottom: 1.25rem;
}

.woocommerce form .form-row label {
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--ss-text);
	margin-bottom: 0.4rem;
}

.woocommerce form .form-row label .required {
	color: var(--ss-error);
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce-checkout #payment .form-row input.input-text,
.woocommerce-checkout #payment .form-row textarea {
	width: 100%;
	padding: 0.75rem 1rem;
	border: 1px solid var(--ss-border);
	border-radius: var(--ss-radius-sm);
	font-size: 0.95rem;
	font-family: inherit;
	color: var(--ss-text);
	background: var(--ss-bg);
	transition: var(--ss-transition);
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
	outline: none;
	border-color: var(--ss-primary);
	box-shadow: 0 0 0 3px rgba(15, 25, 35, 0.06);
}

.woocommerce form .form-row.woocommerce-validated input.input-text {
	border-color: var(--ss-success);
}

.woocommerce form .form-row.woocommerce-invalid input.input-text {
	border-color: var(--ss-error);
}

/* Select2 (pays, état) */
.woocommerce .select2-container .select2-selection--single {
	height: auto;
	padding: 0.65rem 1rem;
	border: 1px solid var(--ss-border);
	border-radius: var(--ss-radius-sm);
}

.woocommerce .select2-container--default .select2-selection--single .select2-selection__rendered {
	line-height: 1.5;
	padding: 0;
	color: var(--ss-text);
}

/* Order review */
.woocommerce-checkout #payment {
	background: var(--ss-surface);
	border-radius: var(--ss-radius);
	padding: 2rem;
}

.woocommerce-checkout #payment ul.payment_methods {
	border-bottom: 1px solid var(--ss-border);
	padding: 0 0 1.5rem;
	margin: 0 0 1.5rem;
}

.woocommerce-checkout #payment ul.payment_methods li {
	padding: 0.75rem 0;
}

.woocommerce-checkout #payment ul.payment_methods li label {
	font-weight: 600;
	cursor: pointer;
}

.woocommerce-checkout #payment .payment_box {
	background: var(--ss-bg);
	border: 1px solid var(--ss-border);
	border-radius: var(--ss-radius-sm);
	padding: 1rem 1.25rem;
	margin-top: 0.75rem;
	font-size: 0.85rem;
	color: var(--ss-text-secondary);
}

.woocommerce-checkout #payment .payment_box::before {
	display: none;
}

.woocommerce-checkout #payment .place-order .button {
	width: 100%;
	padding: 1.1rem;
	font-size: 1rem;
	border-radius: var(--ss-radius);
	text-align: center;
}

/* =========================================================================
   MON COMPTE
   ========================================================================= */

.woocommerce-account .woocommerce {
	max-width: 1100px;
	margin: 0 auto;
}

.woocommerce-account .woocommerce-MyAccount-navigation {
	width: 25%;
	float: left;
	padding-right: 2rem;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li {
	margin-bottom: 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
	display: block;
	padding: 0.85rem 1.25rem;
	font-size: 0.9rem;
	font-weight: 500;
	color: var(--ss-text);
	text-decoration: none;
	border-radius: var(--ss-radius-sm);
	transition: var(--ss-transition);
	border-left: 3px solid transparent;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
	background: var(--ss-surface);
	color: var(--ss-primary);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
	background: var(--ss-surface);
	color: var(--ss-primary);
	font-weight: 700;
	border-left-color: var(--ss-primary);
}

.woocommerce-account .woocommerce-MyAccount-content {
	width: 75%;
	float: left;
	padding-left: 2rem;
	border-left: 1px solid var(--ss-border);
}

.woocommerce-account .woocommerce-MyAccount-content p {
	line-height: 1.7;
}

/* Formulaire login/register */
.woocommerce-account .woocommerce form.woocommerce-form-login,
.woocommerce-account .woocommerce form.woocommerce-form-register {
	border: 1px solid var(--ss-border);
	border-radius: var(--ss-radius);
	padding: 2rem;
	background: var(--ss-surface);
	max-width: 500px;
	margin: 0 auto;
}

.woocommerce-account .woocommerce form.woocommerce-form-login h2,
.woocommerce-account .woocommerce form.woocommerce-form-register h2 {
	font-size: 1.3rem;
	font-weight: 700;
	margin-bottom: 1.5rem;
}

/* Orders table */
.woocommerce-account .woocommerce-orders-table {
	font-size: 0.9rem;
}

.woocommerce-account .woocommerce-orders-table .button {
	font-size: 0.8rem !important;
	padding: 0.5rem 1rem !important;
}

/* Addresses */
.woocommerce-account .woocommerce-Addresses {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2rem;
}

.woocommerce-account .woocommerce-Address {
	border: 1px solid var(--ss-border);
	border-radius: var(--ss-radius);
	padding: 1.5rem;
}

.woocommerce-account .woocommerce-Address header h3 {
	font-size: 0.9rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-bottom: 1rem;
}

/* =========================================================================
   MINI-CART / WIDGET
   ========================================================================= */

.woocommerce .widget_shopping_cart .cart_list li {
	padding: 0.75rem 0;
	border-bottom: 1px solid var(--ss-border);
}

.woocommerce .widget_shopping_cart .cart_list li a {
	font-weight: 600;
	color: var(--ss-text);
	text-decoration: none;
}

.woocommerce .widget_shopping_cart .total {
	font-weight: 700;
	padding: 1rem 0;
	border-top: 2px solid var(--ss-primary);
}

.woocommerce .widget_shopping_cart .buttons a {
	display: block;
	text-align: center;
	margin-bottom: 0.5rem;
}

/* =========================================================================
   ÉTOILES & AVIS
   ========================================================================= */

.woocommerce .star-rating {
	color: #f59e0b;
}

.woocommerce .star-rating::before {
	color: #e5e7eb;
}

.woocommerce #reviews #comments ol.commentlist li .comment-text {
	border: 1px solid var(--ss-border);
	border-radius: var(--ss-radius);
	padding: 1.25rem;
}

.woocommerce #review_form #respond .comment-reply-title {
	font-size: 1.1rem;
	font-weight: 700;
}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */

@media (max-width: 768px) {
	.woocommerce ul.products {
		grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
		gap: 1rem;
	}

	.woocommerce ul.products li.product a img {
		padding: 1rem;
	}

	.woocommerce ul.products li.product .woocommerce-loop-product__title,
	.woocommerce ul.products li.product h2 {
		font-size: 0.9rem;
		padding: 0.75rem 1rem 0.25rem;
	}

	.woocommerce ul.products li.product .price {
		padding: 0 1rem 0.5rem;
		font-size: 1rem;
	}

	.woocommerce ul.products li.product .button {
		margin: 0 1rem 1rem;
		font-size: 0.8rem;
	}

	.woocommerce-account .woocommerce-MyAccount-navigation {
		width: 100%;
		float: none;
		padding-right: 0;
		margin-bottom: 2rem;
	}

	.woocommerce-account .woocommerce-MyAccount-navigation ul {
		display: flex;
		flex-wrap: wrap;
		gap: 0.25rem;
	}

	.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
		padding: 0.5rem 0.75rem;
		font-size: 0.8rem;
		border-left: none;
		border-bottom: 2px solid transparent;
	}

	.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
		border-left: none;
		border-bottom-color: var(--ss-primary);
	}

	.woocommerce-account .woocommerce-MyAccount-content {
		width: 100%;
		float: none;
		padding-left: 0;
		border-left: none;
	}

	.woocommerce-account .woocommerce-Addresses {
		grid-template-columns: 1fr;
	}

	.single-product .wp-block-columns.alignwide {
		grid-template-columns: 1fr !important;
		gap: 1.5rem;
	}

	.woocommerce div.product div.images {
		width: 100% !important;
		float: none !important;
	}

	.woocommerce div.product div.summary {
		width: 100% !important;
		float: none !important;
	}

	.woocommerce div.product p.price,
	.woocommerce div.product span.price {
		font-size: 1.5rem;
	}

	.woocommerce .cart-collaterals .cart_totals {
		max-width: 100%;
	}
}

@media (max-width: 480px) {
	.woocommerce ul.products {
		grid-template-columns: 1fr;
	}

	.woocommerce div.product form.cart {
		flex-direction: column;
		align-items: stretch;
	}

	.woocommerce div.product form.cart .quantity {
		width: 100%;
	}

	.woocommerce div.product form.cart .quantity input.qty {
		width: 100%;
	}

	.woocommerce div.product form.cart .single_add_to_cart_button {
		width: 100%;
		text-align: center;
	}
}
