/**
 * ESS WooCommerce — Styles for WooCommerce pages.
 *
 * Loaded conditionally only on WC pages.
 * Placeholder for Fase 3.
 *
 * @version 1.0.0
 */

/* WooCommerce notices */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	padding: var(--ess-space-4);
	margin-bottom: var(--ess-space-4);
	border-radius: var(--ess-radius-md);
	border-left: 4px solid;
	font-size: var(--ess-text-sm);
}

.woocommerce-message {
	background: #dcfce7;
	border-left-color: var(--ess-color-success);
	color: #166534;
}

.woocommerce-info {
	background: #dbeafe;
	border-left-color: var(--ess-color-info);
	color: #1e40af;
}

.woocommerce-error {
	background: #fee2e2;
	border-left-color: var(--ess-color-error);
	color: #991b1b;
}

.woocommerce-error li {
	list-style: none;
}

/* ==========================================================================
   PRODUCT GRID — Override WooCommerce default float-based layout
   WC defaults set float:left, width:48%/25%, margin-right, clear on li.product.
   We must reset ALL of these to use CSS Grid.
   ========================================================================== */

.woocommerce ul.products {
	display: grid !important;
	gap: var(--ess-grid-gap);
	grid-template-columns: repeat(2, 1fr);
	list-style: none;
	padding: 0;
	margin: 0 0 var(--ess-space-6);
}

@media (min-width: 768px) {
	.woocommerce ul.products { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 1024px) {
	.woocommerce ul.products { grid-template-columns: repeat(4, 1fr); }
	/* With sidebar: 3 columns — 4 are too narrow in ~960px content area */
	.ess-layout-sidebar .woocommerce ul.products,
	.ess-layout-sidebar ul.products {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* Reset WC float-based grid on product items */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	float: none !important;
	width: 100% !important;
	margin-right: 0 !important;
	margin-left: 0 !important;
	margin-bottom: 0 !important;
	clear: none !important;
	padding: 0;
	min-width: 0;
	display: flex;
	flex-direction: column;
	background: var(--ess-color-card-bg);
	border: 0;
	border-radius: var(--ess-radius-lg);
	overflow: hidden;
	box-shadow: var(--ess-shadow);
	transition: box-shadow var(--ess-transition-normal), transform var(--ess-transition-normal);
}

.woocommerce ul.products li.product:hover {
	box-shadow: var(--ess-shadow-lg);
	transform: translateY(-2px);
}

/* Product link — wraps image + title + price */
.woocommerce ul.products li.product > a {
	display: block;
	width: 100%;
	min-width: 0;
}

.woocommerce ul.products li.product a img,
.woocommerce ul.products li.product > a > img {
	margin: 0;
	width: 100% !important;
	height: auto !important;
	max-width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	display: block;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
	padding: var(--ess-space-3) var(--ess-space-4) var(--ess-space-1);
	font-size: var(--ess-text-sm);
	font-weight: var(--ess-weight-semibold);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	word-break: break-word;
	min-height: 2.5em;
}

.woocommerce ul.products li.product .price {
	padding: var(--ess-space-1) var(--ess-space-4) var(--ess-space-2);
	font-size: var(--ess-text-lg);
	font-weight: var(--ess-weight-bold);
	color: var(--ess-color-heading);
}

.woocommerce ul.products li.product .price del {
	color: var(--ess-color-neutral-400);
	font-size: var(--ess-text-sm);
}

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

/* Add to cart / Buy button */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product > a.button,
.woocommerce ul.products li.product > a.product_type_external,
.woocommerce ul.products li.product > a.add_to_cart_button {
	display: block !important;
	width: auto;
	margin: auto var(--ess-space-3) var(--ess-space-3) !important;
	text-align: center;
	padding: var(--ess-space-2) var(--ess-space-3);
	background: var(--ess-color-accent) !important;
	color: var(--ess-color-white) !important;
	border-radius: var(--ess-radius-md);
	text-decoration: none;
	font-weight: var(--ess-weight-semibold);
	font-size: var(--ess-text-sm);
	min-height: 44px;
	line-height: 1.5;
	transition: background var(--ess-transition-fast);
	white-space: nowrap;
}

.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product > a.button:hover,
.woocommerce ul.products li.product > a.product_type_external:hover {
	background: var(--ess-color-accent-hover) !important;
	color: var(--ess-color-white) !important;
}

/* ==========================================================================
   AFFILIATE LINK — external product CTA (loop cards + single product)
   ========================================================================== */

.ess-affiliate-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--ess-space-2);
}

.ess-affiliate-link .ess-icon--external {
	opacity: 0.85;
	flex-shrink: 0;
}

.ess-affiliate-link:hover .ess-icon--external,
.ess-affiliate-link:focus .ess-icon--external {
	opacity: 1;
	transform: translate(1px, -1px);
	transition: transform var(--ess-transition-fast), opacity var(--ess-transition-fast);
}

.ess-affiliate-link--lg {
	font-size: var(--ess-text-lg);
	padding: var(--ess-space-4) var(--ess-space-8);
	min-height: 52px;
}

.ess-affiliate-cta {
	margin-block: var(--ess-space-6);
}

.ess-affiliate-cta__disclosure {
	margin-top: var(--ess-space-3);
	font-size: var(--ess-text-sm);
	color: var(--ess-color-neutral-500);
	line-height: var(--ess-leading-relaxed);
}

/* ==========================================================================
   SPMV COMPARATOR — other vendors selling the same product
   ========================================================================== */

.ess-spmv {
	margin: var(--ess-space-10) 0;
	padding: var(--ess-space-6);
	background: var(--ess-color-neutral-50);
	border: 1px solid var(--ess-color-border);
	border-radius: var(--ess-radius-lg);
}

.ess-spmv__title {
	font-size: var(--ess-text-xl);
	margin-bottom: var(--ess-space-2);
}

.ess-spmv__intro {
	color: var(--ess-color-neutral-600);
	font-size: var(--ess-text-sm);
	margin-bottom: var(--ess-space-5);
}

.ess-spmv__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: var(--ess-space-3);
}

.ess-spmv__row {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--ess-space-3);
	padding: var(--ess-space-4);
	background: var(--ess-color-white);
	border: 1px solid var(--ess-color-border);
	border-radius: var(--ess-radius-md);
	transition: border-color var(--ess-transition-fast), box-shadow var(--ess-transition-fast);
}

.ess-spmv__row:hover,
.ess-spmv__row:focus-within {
	border-color: var(--ess-color-primary);
	box-shadow: var(--ess-shadow);
}

.ess-spmv__vendor {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--ess-space-2);
}

.ess-spmv__vendor-name {
	font-weight: var(--ess-weight-semibold);
	color: var(--ess-color-secondary);
	text-decoration: none;
}

.ess-spmv__vendor-name:hover,
.ess-spmv__vendor-name:focus {
	text-decoration: underline;
}

.ess-spmv__rating {
	font-size: var(--ess-text-sm);
}

.ess-spmv__price {
	font-size: var(--ess-text-lg);
	font-weight: var(--ess-weight-bold);
	color: var(--ess-color-primary);
}

.ess-spmv__cta .ess-btn {
	width: 100%;
}

/* Verified vendor badge */
.ess-badge--verified {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 2px var(--ess-space-2);
	background: var(--ess-color-secondary);
	color: var(--ess-color-white);
	font-size: var(--ess-text-xs);
	font-weight: var(--ess-weight-semibold);
	border-radius: var(--ess-radius-sm);
}

@media (min-width: 768px) {
	.ess-spmv__row {
		grid-template-columns: 2fr 1fr 1fr;
		align-items: center;
	}

	.ess-spmv__cta .ess-btn {
		width: auto;
	}
}

/* Sale badge — needs relative parent */
.woocommerce ul.products li.product {
	position: relative;
}

.woocommerce span.onsale {
	position: absolute;
	top: var(--ess-space-3);
	left: var(--ess-space-3);
	padding: var(--ess-space-1) var(--ess-space-3);
	background: var(--ess-color-accent);
	color: var(--ess-color-white);
	font-size: var(--ess-text-xs);
	font-weight: var(--ess-weight-bold);
	border-radius: var(--ess-radius-sm);
	z-index: 1;
	min-width: auto;
	min-height: auto;
	line-height: 1.5;
}

/* Star rating */
.woocommerce .star-rating {
	overflow: hidden;
	position: relative;
	height: 1em;
	line-height: 1;
	font-size: 1em;
	width: 5.4em;
	font-family: star;
	color: var(--ess-color-warning);
}

.woocommerce .star-rating::before {
	content: "sssss";
	color: var(--ess-color-neutral-300);
	float: left;
	top: 0;
	left: 0;
	position: absolute;
}

.woocommerce .star-rating span {
	overflow: hidden;
	float: left;
	top: 0;
	left: 0;
	position: absolute;
	padding-top: 1.5em;
}

.woocommerce .star-rating span::before {
	content: "SSSSS";
	top: 0;
	position: absolute;
	left: 0;
}

/* ==========================================================================
   ESSENTIAL WC STRUCTURAL STYLES (replaces woocommerce-general.css)
   ========================================================================== */

.woocommerce .woocommerce-result-count {
	margin: 0 0 var(--ess-space-4);
	font-size: var(--ess-text-sm);
	color: var(--ess-color-neutral-500);
}

.woocommerce .woocommerce-ordering {
	margin: 0 0 var(--ess-space-4);
}

.woocommerce .woocommerce-ordering select {
	padding: var(--ess-space-2) var(--ess-space-4);
	border: 1px solid var(--ess-color-input-border);
	border-radius: var(--ess-radius-md);
	font-size: var(--ess-text-sm);
	min-height: 44px;
	background: var(--ess-color-input-bg);
}

/* Result count and ordering side by side */
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering {
	display: inline-block;
}

.woocommerce .woocommerce-ordering {
	float: right;
}

/* Clearfix for result count + ordering */
.woocommerce::after,
.woocommerce ul.products::after {
	content: "";
	display: table;
	clear: both;
}

/* --------------------------------------------------------------------------
   Sort bar (catalog header: count + filter toggle + ordering)
   -------------------------------------------------------------------------- */

.ess-sort-bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: var(--ess-space-3);
	margin-bottom: var(--ess-space-4);
	padding-bottom: var(--ess-space-3);
	border-bottom: 1px solid var(--ess-color-border);
}

.ess-sort-bar__count {
	font-size: var(--ess-text-sm);
	color: var(--ess-color-text-sec);
}

.ess-sort-bar__count strong {
	color: var(--ess-color-heading);
	font-weight: var(--ess-weight-semibold);
}

.ess-sort-bar__controls {
	display: flex;
	align-items: center;
	gap: var(--ess-space-3);
}

/* WC ordering inside sort-bar: remove float, inline flex */
.ess-sort-bar .woocommerce-ordering {
	float: none;
	margin: 0;
	display: inline-flex;
}

.ess-sort-bar .woocommerce-ordering select {
	padding: var(--ess-space-2) var(--ess-space-3);
	border: 1px solid var(--ess-color-border);
	border-radius: var(--ess-radius-md);
	font-size: var(--ess-text-sm);
	font-family: var(--ess-font-body);
	min-height: 40px;
	background: var(--ess-color-white);
	color: var(--ess-color-body-text);
	cursor: pointer;
}

/* Mobile filter toggle button */
.ess-sort-bar__mobile-toggle {
	display: inline-flex;
	align-items: center;
	gap: var(--ess-space-2);
	padding: var(--ess-space-2) var(--ess-space-3);
	border: 1px solid var(--ess-color-border);
	border-radius: var(--ess-radius-md);
	background: var(--ess-color-white);
	font-size: var(--ess-text-sm);
	font-weight: var(--ess-weight-medium);
	color: var(--ess-color-body-text);
	cursor: pointer;
	min-height: 40px;
}

.ess-sort-bar__mobile-toggle:hover {
	border-color: var(--ess-color-primary);
	color: var(--ess-color-primary);
}

/* Screen reader text (WC default) */
.woocommerce .screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute;
	height: 1px;
	width: 1px;
	overflow: hidden;
	word-wrap: normal;
}

/* Pagination */
.woocommerce nav.woocommerce-pagination ul {
	display: flex;
	gap: var(--ess-space-2);
	justify-content: center;
	padding: var(--ess-space-6) 0;
	list-style: none;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	min-height: 44px;
	padding: var(--ess-space-2);
	border: 1px solid var(--ess-color-border);
	border-radius: var(--ess-radius-md);
	text-decoration: none;
	color: var(--ess-color-body-text);
	font-weight: var(--ess-weight-medium);
}

.woocommerce nav.woocommerce-pagination ul li span.current {
	background: var(--ess-color-primary);
	color: var(--ess-color-white);
	border-color: var(--ess-color-primary);
}

/* ==========================================================================
   FORM ROWS (shared: my-account login/register/edit-address)
   ========================================================================== */

.woocommerce form .form-row {
	margin-bottom: var(--ess-space-4);
}

.woocommerce form .form-row label {
	display: block;
	font-size: var(--ess-text-sm);
	font-weight: var(--ess-weight-medium);
	margin-bottom: var(--ess-space-2);
}

.woocommerce form .form-row .input-text,
.woocommerce form .form-row select {
	width: 100%;
	padding: var(--ess-space-3) var(--ess-space-4);
	border: 1px solid var(--ess-color-input-border);
	border-radius: var(--ess-radius-md);
	font-size: var(--ess-text-base);
	min-height: 44px;
}

.woocommerce form .form-row .input-text:focus,
.woocommerce form .form-row select:focus {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: 1px;
	border-color: var(--ess-color-primary);
}

/* ==========================================================================
   MY ACCOUNT PAGE
   ========================================================================== */

.woocommerce-account .woocommerce-MyAccount-navigation {
	margin-bottom: var(--ess-space-6);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: var(--ess-space-1);
	border-bottom: 2px solid var(--ess-color-border);
	padding-bottom: var(--ess-space-1);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
	display: inline-flex;
	align-items: center;
	padding: var(--ess-space-3) var(--ess-space-4);
	font-size: var(--ess-text-sm);
	font-weight: var(--ess-weight-medium);
	color: var(--ess-color-neutral-600);
	text-decoration: none;
	border-radius: var(--ess-radius-md) var(--ess-radius-md) 0 0;
	min-height: 44px;
	transition: all var(--ess-transition-fast);
}

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

.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
	color: var(--ess-color-primary);
	border-bottom: 2px solid var(--ess-color-primary);
}

@media (min-width: 768px) {
	.woocommerce-account .woocommerce-MyAccount-content {
		padding-left: var(--ess-space-6);
	}
}

/* Account forms */
.woocommerce-account .woocommerce-form-login,
.woocommerce-account .woocommerce-form-register {
	max-width: 480px;
	margin-inline: auto;
	padding: var(--ess-space-8);
	background: var(--ess-color-card-bg);
	border: 0;
	border-radius: var(--ess-radius-lg);
	box-shadow: var(--ess-shadow);
}

/* ==========================================================================
   SINGLE PRODUCT (basic overrides)
   ========================================================================== */

.woocommerce div.product div.images {
	margin-bottom: var(--ess-space-6);
}

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

.woocommerce div.product .product_title {
	font-size: clamp(1.25rem, 1.1rem + 1.2vw, 1.875rem);
	margin-bottom: var(--ess-space-4);
}

.woocommerce div.product p.price {
	font-size: var(--ess-text-2xl);
	font-weight: var(--ess-weight-bold);
	margin-bottom: var(--ess-space-4);
}

.woocommerce div.product .single_add_to_cart_button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: var(--ess-space-4) var(--ess-space-8);
	background: var(--ess-color-accent);
	color: var(--ess-color-white);
	border: none;
	border-radius: var(--ess-radius-md);
	font-weight: var(--ess-weight-bold);
	font-size: var(--ess-text-lg);
	cursor: pointer;
	min-height: 48px;
	transition: background var(--ess-transition-fast);
}

.woocommerce div.product .single_add_to_cart_button:hover {
	background: var(--ess-color-accent-hover);
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
	display: flex;
	gap: 0;
	border-bottom: 2px solid var(--ess-color-border);
	list-style: none;
	padding: 0;
	margin-bottom: var(--ess-space-6);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
}

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

.woocommerce div.product .woocommerce-tabs ul.tabs li {
	flex-shrink: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	display: inline-flex;
	align-items: center;
	padding: var(--ess-space-3) var(--ess-space-6);
	font-weight: var(--ess-weight-medium);
	color: var(--ess-color-neutral-500);
	text-decoration: none;
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
	min-height: 44px;
}

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

/* Related products */
.woocommerce div.product .related.products h2 {
	font-size: var(--ess-text-2xl);
	margin-bottom: var(--ess-space-6);
}

/* ==========================================================================
   CATALOG PAGE — archive-product.php
   ========================================================================== */

.ess-catalog__title {
	font-size: var(--ess-text-3xl);
	margin-bottom: var(--ess-space-4);
}

.ess-catalog__toolbar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--ess-space-4);
	margin-bottom: var(--ess-space-6);
	padding-bottom: var(--ess-space-4);
	border-bottom: 1px solid var(--ess-color-border);
}

.ess-catalog__toolbar::after {
	display: none;
}

/* ==========================================================================
   SINGLE PRODUCT — content-single-product.php
   ========================================================================== */

.ess-product-single__top {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--ess-space-8);
	margin-bottom: var(--ess-space-8);
}

@media (min-width: 768px) {
	.ess-product-single__top {
		/* Gallery slightly larger than summary, ReHub-style. */
		grid-template-columns: 1.2fr 1fr;
		align-items: start;
	}
}

/* Sticky summary on desktop: the deal box follows the scroll while the user
   reads the description / specs, mirroring ReHub's sidebar-sticky pattern. */
@media (min-width: 1024px) {
	.ess-product-single__summary {
		position: sticky;
		top: var(--ess-space-6);
		max-height: calc(100vh - var(--ess-space-20));
		overflow-y: auto;
		overflow-x: hidden;
		/* Scrollbar only when content exceeds viewport. */
		scrollbar-width: thin;
		padding-right: var(--ess-space-2);
	}
}

.ess-product-single__gallery {
	position: relative;
}

/* WC gallery wrapper: force visible (WC applies opacity:0 via inline style; we don't). */
.ess-product-single__gallery .woocommerce-product-gallery {
	opacity: 1 !important;
	margin: 0;
}

.ess-product-single__gallery .woocommerce-product-gallery__wrapper {
	display: block;
}

.ess-product-single__gallery .woocommerce-product-gallery__image {
	position: relative;
	overflow: hidden;
	border-radius: var(--ess-radius-lg);
	background: var(--ess-color-neutral-50);
	aspect-ratio: 1 / 1;
}

.ess-product-single__gallery .woocommerce-product-gallery__image img,
.ess-product-single__gallery .wp-post-image {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
	border-radius: var(--ess-radius-lg);
}

/* Branded placeholder when no featured image */
.ess-product-placeholder {
	display: flex !important;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--ess-space-3);
	min-height: 300px;
	color: var(--ess-color-neutral-400);
	background: var(--ess-color-neutral-50);
	border: 1px dashed var(--ess-color-border);
}

.ess-product-placeholder svg {
	opacity: 0.6;
}

.ess-product-placeholder span {
	font-size: var(--ess-text-sm);
	font-weight: var(--ess-weight-medium);
}

.ess-product-single__summary {
	display: flex;
	flex-direction: column;
	gap: var(--ess-space-4);
}

.ess-product-single__vendor {
	margin-top: var(--ess-space-6);
	padding-top: var(--ess-space-6);
	border-top: 1px solid var(--ess-color-border);
}

.ess-product-single__vendor-label {
	font-size: var(--ess-text-sm);
	font-weight: var(--ess-weight-semibold);
	color: var(--ess-color-neutral-500);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: var(--ess-space-3);
}

.ess-vendor-card--inline {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--ess-space-4);
	padding: var(--ess-space-4);
	text-align: left;
}

.ess-vendor-card--inline .ess-vendor-card__avatar {
	width: 56px;
	height: 56px;
	border-radius: var(--ess-radius-full);
	margin: 0;
	flex-shrink: 0;
}

.ess-vendor-card--inline .ess-vendor-card__info {
	flex: 1;
	min-width: 0;
}

.ess-vendor-card__name-row {
	display: flex;
	align-items: center;
	gap: var(--ess-space-2);
	flex-wrap: wrap;
}

.ess-vendor-card--inline .ess-vendor-card__name {
	font-size: var(--ess-text-base);
	font-weight: var(--ess-weight-semibold);
}

.ess-vendor-card--inline .ess-vendor-card__name a {
	color: var(--ess-color-heading);
	text-decoration: none;
}

.ess-vendor-card--inline .ess-vendor-card__name a:hover {
	color: var(--ess-color-primary);
}

.ess-vendor-card__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--ess-space-2) var(--ess-space-4);
	margin-top: var(--ess-space-1);
	font-size: var(--ess-text-sm);
	color: var(--ess-color-neutral-600);
}

.ess-vendor-card__since {
	display: inline-flex;
	align-items: center;
}

/* ==========================================================================
   TRUST BAR — up to 3 signals under the title
   ========================================================================== */

.ess-product-single__trust-bar {
	list-style: none;
	padding: 0;
	margin: var(--ess-space-2) 0 var(--ess-space-4);
	display: flex;
	flex-wrap: wrap;
	gap: var(--ess-space-3);
	font-size: var(--ess-text-sm);
	color: var(--ess-color-neutral-700);
}

.ess-product-single__trust-bar li {
	display: inline-flex;
	align-items: center;
	gap: var(--ess-space-2);
	padding: var(--ess-space-1) var(--ess-space-3);
	background: var(--ess-color-neutral-50);
	border: 1px solid var(--ess-color-border);
	border-radius: 999px;
	white-space: nowrap;
}

.ess-product-single__trust-bar .ess-icon {
	color: var(--ess-color-secondary);
	flex-shrink: 0;
}

/* ==========================================================================
   DEAL BOX — groups rating + price + savings + CTA into a card
   ========================================================================== */

.ess-product-single__deal {
	margin: var(--ess-space-4) 0;
	padding: var(--ess-space-5);
	background: var(--ess-color-white);
	border: 1px solid var(--ess-color-border);
	border-radius: var(--ess-radius-lg);
	box-shadow: var(--ess-shadow);
}

.ess-product-single__deal .woocommerce-product-rating {
	margin-bottom: var(--ess-space-3);
}

.ess-product-single__deal p.price,
.ess-product-single__deal .price {
	font-size: clamp(1.5rem, 1.2rem + 1.5vw, 2.25rem);
	line-height: 1.1;
	margin: 0 0 var(--ess-space-2);
}

.ess-product-single__deal .ess-affiliate-cta {
	margin-block: var(--ess-space-4) 0;
}

/* ==========================================================================
   PRICE ON REQUEST — pill used when the product has no price set
   ========================================================================== */

.ess-price-on-request {
	display: inline-block;
	padding: 2px var(--ess-space-3);
	background: var(--ess-color-neutral-100, #f1f1f1);
	color: var(--ess-color-neutral-700);
	font-size: var(--ess-text-base);
	font-weight: var(--ess-weight-semibold);
	border-radius: var(--ess-radius-sm);
}

/* ==========================================================================
   PRICE — avoid <ins> underline (WC wraps sale price in <ins>)
   ========================================================================== */

.woocommerce div.product p.price ins,
.woocommerce div.product span.price ins,
.ess-product-single ins,
.woocommerce-Price-amount {
	text-decoration: none !important;
}

.woocommerce div.product p.price del {
	opacity: 0.55;
	margin-right: var(--ess-space-2);
}

.woocommerce div.product p.price ins {
	font-weight: var(--ess-weight-bold);
}

/* ==========================================================================
   SOCIAL PROOF PILL
   ========================================================================== */

.ess-product-single__social-proof {
	display: inline-flex;
	align-items: center;
	gap: var(--ess-space-2);
	margin: var(--ess-space-4) 0 0;
	padding: var(--ess-space-2) var(--ess-space-3);
	background: var(--ess-color-neutral-50);
	border: 1px solid var(--ess-color-border);
	border-radius: var(--ess-radius-md);
	font-size: var(--ess-text-sm);
	color: var(--ess-color-neutral-700);
}

.ess-product-single__social-proof strong {
	color: var(--ess-color-primary);
	font-weight: var(--ess-weight-bold);
}

/* ==========================================================================
   WHATSAPP LIVE CHAT BUTTON — Dokan live-chat WhatsApp module styling
   ========================================================================== */

.dokan-live-chat-whatsapp.button,
button.dokan-live-chat-whatsapp {
	display: inline-flex !important;
	align-items: center;
	gap: var(--ess-space-2);
	margin: var(--ess-space-3) 0 0 !important;
	padding: var(--ess-space-3) var(--ess-space-4) !important;
	background: #25D366 !important;
	color: #fff !important;
	border: none !important;
	border-radius: var(--ess-radius-md) !important;
	font-weight: var(--ess-weight-semibold) !important;
	font-size: var(--ess-text-sm) !important;
	min-height: 44px !important;
	cursor: pointer;
	transition: background var(--ess-transition-fast);
}

.dokan-live-chat-whatsapp.button:hover,
button.dokan-live-chat-whatsapp:hover {
	background: #1EBE5A !important;
	color: #fff !important;
}

.dokan-live-chat-whatsapp::before {
	content: "";
	width: 18px;
	height: 18px;
	flex-shrink: 0;
	background: center / contain no-repeat url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M17.472 14.382c-.297-.149-1.758-.867-2.03-.967-.273-.099-.471-.148-.67.15-.197.297-.767.966-.94 1.164-.173.199-.347.223-.644.075-.297-.15-1.255-.463-2.39-1.475-.883-.788-1.48-1.761-1.653-2.059-.173-.297-.018-.458.13-.606.134-.133.298-.347.446-.52.149-.174.198-.298.298-.497.099-.198.05-.371-.025-.52-.075-.149-.669-1.612-.916-2.207-.242-.579-.487-.5-.669-.51-.173-.008-.371-.01-.57-.01-.198 0-.52.074-.792.372-.272.297-1.04 1.016-1.04 2.479 0 1.462 1.065 2.875 1.213 3.074.149.198 2.096 3.2 5.077 4.487.709.306 1.262.489 1.694.625.712.227 1.36.195 1.871.118.571-.085 1.758-.719 2.006-1.413.248-.694.248-1.289.173-1.413-.074-.124-.272-.198-.57-.347M12.05 21.785h-.004a9.87 9.87 0 01-5.031-1.378l-.361-.214-3.741.982.998-3.648-.235-.374a9.86 9.86 0 01-1.51-5.26c.001-5.45 4.436-9.884 9.888-9.884 2.64 0 5.122 1.03 6.988 2.898a9.825 9.825 0 012.893 6.994c-.003 5.45-4.437 9.884-9.885 9.884m8.413-18.297A11.815 11.815 0 0012.05 0C5.495 0 .16 5.335.157 11.892c0 2.096.547 4.142 1.588 5.945L.057 24l6.305-1.654a11.882 11.882 0 005.683 1.448h.005c6.554 0 11.89-5.335 11.893-11.893a11.821 11.821 0 00-3.48-8.413z'/%3E%3C/svg%3E");
}

/* ==========================================================================
   REPORT ABUSE LINK — improve affordance (icon + subtle styling)
   ========================================================================== */

.dokan-report-abuse-button {
	display: inline-flex;
	align-items: center;
	gap: var(--ess-space-1);
	margin-top: var(--ess-space-4);
	padding: var(--ess-space-1) 0;
	color: var(--ess-color-neutral-500);
	font-size: var(--ess-text-sm);
	text-decoration: none;
	border: none;
	background: transparent;
	cursor: pointer;
}

.dokan-report-abuse-button::before {
	content: "⚠";
	font-size: 14px;
	line-height: 1;
}

.dokan-report-abuse-button:hover {
	color: var(--ess-color-primary);
	text-decoration: underline;
}

/* ==========================================================================
   SALE SAVINGS PILL
   ========================================================================== */

.ess-product-single__savings {
	display: inline-flex;
	align-items: center;
	gap: var(--ess-space-2);
	margin: 0 0 var(--ess-space-4);
	padding: var(--ess-space-2) var(--ess-space-3);
	background: var(--ess-color-accent-light, rgba(232, 121, 43, 0.12));
	color: var(--ess-color-accent);
	font-size: var(--ess-text-sm);
	font-weight: var(--ess-weight-semibold);
	border-radius: var(--ess-radius-sm);
}

.ess-product-single__savings strong {
	font-weight: var(--ess-weight-bold);
}

.ess-product-single__savings span {
	opacity: 0.85;
}

/* ==========================================================================
   PRODUCT META — dl with icons
   ========================================================================== */

.ess-product-single__meta {
	display: grid;
	gap: var(--ess-space-2);
	font-size: var(--ess-text-sm);
	color: var(--ess-color-neutral-600);
	margin: var(--ess-space-5) 0 var(--ess-space-3);
	padding-top: var(--ess-space-4);
	border-top: 1px solid var(--ess-color-border);
}

.ess-product-single__meta-row {
	display: grid;
	grid-template-columns: minmax(120px, 160px) 1fr;
	gap: var(--ess-space-3);
	align-items: baseline;
}

.ess-product-single__meta dt {
	display: inline-flex;
	align-items: center;
	gap: var(--ess-space-2);
	font-weight: var(--ess-weight-semibold);
	color: var(--ess-color-neutral-700);
	margin: 0;
}

.ess-product-single__meta dt .ess-icon {
	flex-shrink: 0;
}

.ess-product-single__meta dd {
	margin: 0;
}

.ess-product-single__meta a {
	color: var(--ess-color-primary);
	text-decoration: none;
}

.ess-product-single__meta a:hover {
	text-decoration: underline;
}

/* Report abuse link (DSA compliance) */
.ess-product-single__report {
	margin-top: var(--ess-space-3);
	font-size: var(--ess-text-sm);
}

.ess-product-single__report a {
	color: var(--ess-color-neutral-500);
	text-decoration: underline;
}

.ess-product-single__report a:hover {
	color: var(--ess-color-primary);
}

/* ==========================================================================
   STICKY MOBILE CTA
   ========================================================================== */

.ess-sticky-cta {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	display: none;
	align-items: center;
	gap: var(--ess-space-3);
	padding: var(--ess-space-3) var(--ess-space-4);
	background: var(--ess-color-white);
	border-top: 1px solid var(--ess-color-border);
	box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.08);
	z-index: 50;
	transform: translateY(0);
	transition: transform var(--ess-transition-fast);
}

@media (max-width: 767px) {
	.ess-sticky-cta:not([hidden]) {
		display: flex;
	}
}

.ess-sticky-cta--hidden {
	transform: translateY(100%);
}

.ess-sticky-cta__info {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.ess-sticky-cta__title {
	font-size: var(--ess-text-sm);
	color: var(--ess-color-neutral-700);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.ess-sticky-cta__price {
	font-size: var(--ess-text-base);
	font-weight: var(--ess-weight-bold);
	color: var(--ess-color-primary);
}

.ess-sticky-cta .ess-btn {
	flex-shrink: 0;
}

.ess-product-single__description {
	line-height: var(--ess-leading-normal);
}

.ess-product-single__description p {
	margin-bottom: var(--ess-space-4);
}

.ess-related-products {
	margin-top: var(--ess-space-12);
	padding-top: var(--ess-space-8);
	border-top: 1px solid var(--ess-color-border);
}

/* ==========================================================================
   MY ACCOUNT — my-account.php
   ========================================================================== */

.ess-myaccount {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--ess-space-6);
}

@media (min-width: 768px) {
	.ess-myaccount {
		grid-template-columns: 220px 1fr;
	}

	.woocommerce-account .woocommerce-MyAccount-navigation ul {
		flex-direction: column;
		border-bottom: none;
		border-right: 2px solid var(--ess-color-border);
		padding-bottom: 0;
		padding-right: var(--ess-space-1);
	}

	.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
		border-radius: var(--ess-radius-md) 0 0 var(--ess-radius-md);
		border-bottom: none;
	}

	.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
		border-bottom: none;
		border-right: 2px solid var(--ess-color-primary);
		margin-right: -2px;
	}
}

/* ==========================================================================
   PDP EDITORIAL (v2) — Design handoff single product layout
   ========================================================================== */

.ess-pdp-main { display: block; }

.ess-pdp {
	display: block;
	font-family: var(--ess-font-body);
}

/* --- Grid 1.3fr / 1fr (mobile stack) --- */
.ess-pdp__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
	padding-block: 20px 32px;
}
@media (min-width: 1024px) {
	.ess-pdp__grid {
		grid-template-columns: 1.3fr 1fr;
		gap: 48px;
		padding-block: 28px 48px;
	}
}

/* ==========================================================================
   GALLERY — thumbs column 72px + main 480px
   ========================================================================== */

.ess-pdp-gallery {
	display: grid;
	grid-template-columns: 1fr;
	gap: 12px;
}
@media (min-width: 640px) {
	.ess-pdp-gallery { grid-template-columns: 72px 1fr; }
	/* Modifier: prodotto con immagine singola → no thumb column, full-width. */
	.ess-pdp-gallery--single { grid-template-columns: 1fr; }
}

.ess-pdp-gallery__thumbs {
	display: flex;
	gap: 8px;
	overflow-x: auto;
	scrollbar-width: thin;
}
@media (min-width: 640px) {
	.ess-pdp-gallery__thumbs {
		flex-direction: column;
		overflow-x: visible;
		overflow-y: auto;
		max-height: 480px;
	}
}

.ess-pdp-gallery__thumb {
	flex-shrink: 0;
	width: 72px;
	height: 72px;
	padding: 0;
	border: 1px solid var(--ess-line);
	border-radius: 0;
	background: #ffffff;
	cursor: pointer;
	transition: border-color var(--ess-transition-fast);
	overflow: hidden;
}
.ess-pdp-gallery__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.ess-pdp-gallery__thumb:hover { border-color: var(--ess-navy-soft); }
.ess-pdp-gallery__thumb.is-active { border-color: var(--ess-navy); }
.ess-pdp-gallery__thumb:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: 2px;
}

.ess-pdp-gallery__main {
	position: relative;
	height: 400px;
	background: #ffffff;
	border: 1px solid var(--ess-line);
	overflow: hidden;
}
@media (min-width: 768px) { .ess-pdp-gallery__main { height: 480px; } }

.ess-pdp-gallery__main-img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
	background: #ffffff;
}

.ess-pdp-gallery__cert {
	top: 14px;
	left: 14px;
	font-size: 10px;
	padding: 4px 9px;
}
.ess-pdp-gallery__cert-full {
	display: inline;
}

.ess-pdp-gallery__wish {
	position: absolute;
	top: 14px;
	right: 14px;
	width: 32px;
	height: 32px;
	padding: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #ffffff;
	border: 1px solid var(--ess-line);
	color: var(--ess-navy);
	cursor: pointer;
	border-radius: 0;
	transition: color var(--ess-transition-fast), border-color var(--ess-transition-fast);
}
.ess-pdp-gallery__wish:hover,
.ess-pdp-gallery__wish:focus-visible {
	color: var(--ess-orange);
	border-color: var(--ess-orange);
}
.ess-pdp-gallery__wish:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: 2px;
}

/* ==========================================================================
   SUMMARY — vendor badge, title, rating, pricebox, benefits, short-desc
   ========================================================================== */

.ess-pdp__summary { min-width: 0; }

/* Vendor badge (avatar 32px + info + "Bottega →") */
.ess-pdp__vendor-badge {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 0;
	font-size: 12px;
	color: var(--ess-navy-soft);
	margin-bottom: 14px;
	text-decoration: none;
}
a.ess-pdp__vendor-badge:hover { color: var(--ess-orange); }

.ess-pdp__vendor-avatar {
	position: relative;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--ess-font-serif);
	font-size: 14px;
	font-weight: 400;
	color: #ffffff;
	background: var(--ess-sea);
	flex-shrink: 0;
	overflow: hidden;
	text-transform: uppercase;
	letter-spacing: -0.2px;
}
/* When placeholder tone is applied, override bg */
.ess-pdp__vendor-avatar.ess-placeholder--sea    { background: var(--ess-sea); color: #ffffff; background-image: none; }
.ess-pdp__vendor-avatar.ess-placeholder--terra  { background: var(--ess-terra); color: #ffffff; background-image: none; }
.ess-pdp__vendor-avatar.ess-placeholder--lemon  { background: var(--ess-limone); color: var(--ess-ink); background-image: none; }
.ess-pdp__vendor-avatar.ess-placeholder--olive  { background: var(--ess-ulivo); color: #ffffff; background-image: none; }

.ess-pdp__vendor-info {
	display: flex;
	flex-direction: column;
	min-width: 0;
	line-height: 1.2;
}

.ess-pdp__vendor-label {
	font-family: var(--ess-font-mono);
	font-size: 11px;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	color: var(--ess-muted);
}
.ess-pdp__vendor-name {
	font-size: 14px;
	color: var(--ess-navy);
	margin-top: 2px;
}
.ess-pdp__vendor-cta {
	margin-left: auto;
	font-size: 11px;
	color: var(--ess-sea);
	border: 1px solid var(--ess-sea);
	padding: 5px 10px;
	white-space: nowrap;
	letter-spacing: 0.3px;
}
a.ess-pdp__vendor-badge:hover .ess-pdp__vendor-cta {
	background: var(--ess-sea);
	color: #ffffff;
}

/* Title */
.ess-pdp__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(1.75rem, 1.25rem + 2vw, 2.625rem);
	line-height: 1.05;
	letter-spacing: -0.8px;
	color: var(--ess-navy);
	margin: 0 0 10px;
	font-weight: 400;
}

/* Rating */
.ess-pdp__rating {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 12px;
	color: var(--ess-navy-soft);
	margin-bottom: 22px;
}
.ess-pdp__rating .ess-stars { gap: 1px; color: var(--ess-orange); }
.ess-pdp__rating-text {
	display: inline-flex;
	align-items: baseline;
	gap: 6px;
	font-family: var(--ess-font-body);
	font-size: 12px;
	color: var(--ess-navy-soft);
}
.ess-pdp__rating-count { color: var(--ess-muted); }

/* Pricebox — bordo nero, padding 20px */
.ess-pdp__pricebox {
	border: 1px solid var(--ess-navy);
	background: #ffffff;
	padding: 20px;
	margin-bottom: 20px;
}

.ess-pdp__price-row {
	display: flex;
	align-items: baseline;
	gap: 12px;
	flex-wrap: wrap;
	margin-bottom: 4px;
}
.ess-pdp__price {
	font-family: var(--ess-font-serif);
	font-size: 2.75rem;
	font-weight: 400;
	line-height: 1;
	color: var(--ess-navy);
	letter-spacing: -0.8px;
}
.ess-pdp__price .woocommerce-Price-amount {
	font-family: var(--ess-font-serif);
	font-weight: 400;
}
.ess-pdp__price del {
	font-family: var(--ess-font-body);
	font-size: 14px;
	color: var(--ess-muted);
	text-decoration: line-through;
	margin-left: 10px;
	letter-spacing: 0;
}
.ess-pdp__price ins {
	text-decoration: none;
	color: var(--ess-navy);
}

.ess-pdp__price-note {
	font-size: 11px;
	color: var(--ess-muted);
	margin-bottom: 16px;
	font-family: var(--ess-font-body);
}

/* CTA group — full-width arancio + heart outline */
.ess-pdp__cta-group {
	display: flex;
	gap: 8px;
	align-items: stretch;
}
.ess-pdp__cta {
	flex: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 13px 20px;
	background: var(--ess-orange);
	color: #ffffff;
	border: 1px solid var(--ess-orange);
	border-radius: 0;
	font-family: var(--ess-font-body);
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 1px;
	text-transform: uppercase;
	text-decoration: none;
	cursor: pointer;
	transition: background var(--ess-transition-fast), border-color var(--ess-transition-fast);
	line-height: 1;
	min-height: 48px;
}
.ess-pdp__cta:hover,
.ess-pdp__cta:focus-visible {
	background: var(--ess-orange-dark);
	border-color: var(--ess-orange-dark);
	color: #ffffff;
}
.ess-pdp__cta:focus-visible {
	outline: 2px solid var(--ess-navy);
	outline-offset: 2px;
}
.ess-pdp__cta svg { flex-shrink: 0; }
.ess-pdp__cta-label { display: inline; }

/* Wishlist heart button */
.ess-pdp__wish {
	width: 48px;
	height: 48px;
	padding: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--ess-navy);
	background: transparent;
	color: var(--ess-navy);
	cursor: pointer;
	border-radius: 0;
	transition: background var(--ess-transition-fast), color var(--ess-transition-fast);
	flex-shrink: 0;
}
.ess-pdp__wish:hover,
.ess-pdp__wish:focus-visible {
	background: var(--ess-navy);
	color: #ffffff;
}
.ess-pdp__wish:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: 2px;
}
.ess-pdp__wish[aria-pressed="true"] {
	color: var(--ess-orange);
	border-color: var(--ess-orange);
	background: transparent;
}

/* Benefits grid 3 col */
.ess-pdp__benefits {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2px;
	background: var(--ess-line);
	margin-bottom: 20px;
}
@media (max-width: 480px) {
	.ess-pdp__benefits { grid-template-columns: 1fr; }
}
.ess-pdp__benefit {
	background: #ffffff;
	padding: 12px 14px;
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.ess-pdp__benefit-symbol {
	font-family: var(--ess-font-serif);
	font-size: 18px;
	color: var(--ess-sea);
	line-height: 1;
	margin-bottom: 2px;
}
.ess-pdp__benefit-title {
	font-size: 12px;
	color: var(--ess-navy);
	font-weight: 500;
}
.ess-pdp__benefit-desc {
	font-family: var(--ess-font-mono);
	font-size: 10px;
	color: var(--ess-muted);
	letter-spacing: 0.3px;
	line-height: 1.4;
}

/* Short description (excerpt) */
.ess-pdp__short-desc {
	font-size: 13px;
	line-height: 1.65;
	color: var(--ess-navy-soft);
}
.ess-pdp__short-desc p { margin-bottom: 10px; }
.ess-pdp__short-desc p:last-child { margin-bottom: 0; }

/* ==========================================================================
   TABS — Dettagli / Provenienza / Recensioni
   ========================================================================== */

.ess-pdp-tabs {
	background: #ffffff;
	border-top: 1px solid var(--ess-line);
	border-bottom: 1px solid var(--ess-line);
	margin-top: 32px;
}

.ess-pdp-tabs__nav {
	display: flex;
	gap: 28px;
	overflow-x: auto;
	scrollbar-width: thin;
	border-bottom: 1px solid var(--ess-line);
	flex-wrap: nowrap;
}
@media (min-width: 768px) {
	.ess-pdp-tabs__nav { flex-wrap: wrap; overflow-x: visible; gap: 32px; }
}

.ess-pdp-tabs__btn {
	padding: 16px 0;
	font-family: var(--ess-font-body);
	font-size: 13px;
	background: none;
	border: none;
	border-bottom: 2px solid transparent;
	cursor: pointer;
	color: var(--ess-navy-soft);
	font-weight: 400;
	white-space: nowrap;
	transition: color var(--ess-transition-fast), border-color var(--ess-transition-fast);
}
.ess-pdp-tabs__btn:hover { color: var(--ess-navy); }
.ess-pdp-tabs__btn:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: 4px;
}
.ess-pdp-tabs__btn.is-active {
	color: var(--ess-navy);
	border-bottom-color: var(--ess-orange);
	font-weight: 500;
}

.ess-pdp-tabs__panel {
	padding: 32px 0;
	min-height: 220px;
}
.ess-pdp-tabs__panel[hidden] { display: none !important; }
.ess-pdp-tabs__empty {
	color: var(--ess-muted);
	font-style: italic;
	font-size: 14px;
}

/* ---- Dettagli table ---- */
.ess-pdp-details {
	max-width: 640px;
	margin: 0;
}
.ess-pdp-details__row {
	display: flex;
	padding: 10px 0;
	border-bottom: 1px solid var(--ess-line);
	font-size: 13px;
	gap: 16px;
}
.ess-pdp-details__row dt {
	color: var(--ess-muted);
	width: 180px;
	flex-shrink: 0;
	font-weight: 400;
}
.ess-pdp-details__row dd {
	color: var(--ess-navy);
	margin: 0;
	flex: 1;
}
.ess-pdp-details__row dd a {
	color: var(--ess-navy);
	text-decoration: underline;
	text-underline-offset: 2px;
}
.ess-pdp-details__row dd a:hover { color: var(--ess-orange); }

/* ---- Provenance timeline ---- */
.ess-pdp-provenance {
	list-style: none;
	max-width: 520px;
	position: relative;
	padding-left: 18px;
	margin: 0;
}
.ess-pdp-provenance::before {
	content: '';
	position: absolute;
	left: 4px;
	top: 8px;
	bottom: 8px;
	width: 1px;
	background: var(--ess-line-strong);
}
.ess-pdp-provenance__step {
	position: relative;
	padding-bottom: 18px;
	list-style: none;
}
.ess-pdp-provenance__step:last-child { padding-bottom: 0; }
.ess-pdp-provenance__dot {
	position: absolute;
	left: -18px;
	top: 4px;
	width: 9px;
	height: 9px;
	background: #ffffff;
	border: 1.5px solid var(--ess-ulivo);
	border-radius: 50%;
}
.ess-pdp-provenance__step.is-filled .ess-pdp-provenance__dot {
	background: var(--ess-ulivo);
}
.ess-pdp-provenance__label {
	display: block;
	font-size: 13px;
	color: var(--ess-navy);
	margin-bottom: 2px;
}
.ess-pdp-provenance__meta {
	display: block;
	font-family: var(--ess-font-mono);
	font-size: 11px;
	color: var(--ess-muted);
	letter-spacing: 0.3px;
}

/* ---- Reviews — summary left, recent quote right ---- */
.ess-pdp-tabs__panel #reviews { display: block; }
.ess-pdp-tabs__panel #reviews .commentlist {
	list-style: none;
	margin: 0;
	padding: 0;
}
.ess-pdp-tabs__panel #reviews .comment_container {
	display: flex;
	gap: 16px;
	padding: 16px 0;
	border-bottom: 1px solid var(--ess-line);
}

/* ==========================================================================
   RELATED PRODUCTS — "Potrebbero piacerti" row
   ========================================================================== */

.ess-related-products {
	padding: 48px 0;
	margin: 0;
}
.ess-related-products > h2 {
	font-family: var(--ess-font-serif);
	font-size: 28px;
	font-weight: 400;
	color: var(--ess-navy);
	margin: 0 0 20px;
	line-height: 1;
	letter-spacing: -0.4px;
}
.ess-related-products > h2::before {
	content: attr(data-eyebrow);
}
.ess-related-products .products {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 18px;
	list-style: none;
	padding: 0;
	margin: 0;
}
@media (min-width: 768px)  { .ess-related-products .products { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .ess-related-products .products { grid-template-columns: repeat(4, 1fr); } }

/* ==========================================================================
   STICKY MOBILE CTA — restyle per design editoriale
   ========================================================================== */

.ess-sticky-cta {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: var(--ess-z-sticky);
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 10px 14px;
	background: #ffffff;
	border-top: 1px solid var(--ess-line);
	box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.05);
	transform: translateY(0);
	transition: transform var(--ess-transition-normal);
}
.ess-sticky-cta--hidden { transform: translateY(110%); }
.ess-sticky-cta__info {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	line-height: 1.2;
}
.ess-sticky-cta__title {
	font-size: 12px;
	color: var(--ess-navy);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.ess-sticky-cta__price {
	font-family: var(--ess-font-serif);
	font-size: 18px;
	color: var(--ess-navy);
	letter-spacing: -0.2px;
}
.ess-sticky-cta .ess-btn {
	padding: 12px 16px;
	font-size: 11px;
	letter-spacing: 0.8px;
}
@media (min-width: 768px) { .ess-sticky-cta { display: none; } }
