/**
 * 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);
}

/* ==========================================================================
   LIST VIEW MODE — applicato runtime via JS toggle (.is-view-list).
   ----
   Su desktop ≥768px, le card si trasformano in righe orizzontali (image sx,
   body al centro+dx). Mobile rimane single-column come default (no override).
   ========================================================================== */
@media (min-width: 768px) {
	.woocommerce ul.products.is-view-list {
		grid-template-columns: 1fr !important;
		gap: 12px;
	}
	.ess-layout-sidebar .woocommerce ul.products.is-view-list,
	.ess-layout-sidebar ul.products.is-view-list {
		grid-template-columns: 1fr !important;
	}
	.woocommerce ul.products.is-view-list li.product {
		flex-direction: row;
	}
	.woocommerce ul.products.is-view-list li.product .ess-product-card {
		display: grid;
		grid-template-columns: 200px 1fr;
		gap: 0;
		width: 100%;
	}
	.woocommerce ul.products.is-view-list li.product .ess-product-card__image {
		height: 180px;
	}
	.woocommerce ul.products.is-view-list li.product .ess-product-card__body {
		padding: 16px 18px;
		display: flex;
		flex-direction: column;
		justify-content: space-between;
	}
	.woocommerce ul.products.is-view-list li.product .ess-product-card__title {
		font-size: 15px;
		min-height: 0;
		-webkit-line-clamp: 2;
	}
	.woocommerce ul.products.is-view-list li.product .ess-product-card__footer {
		margin-top: auto;
	}
	.woocommerce ul.products.is-view-list li.product .ess-product-card__price {
		font-size: 22px;
	}
}

/* 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 — Login + Register layout editoriale (4.4.9)
   2-col su desktop ≥768px, panel squared, button primary terra,
   H1 contenuto, input outlined coerente con resto tema.
   ========================================================================== */

/* H1 "Il mio account" — ridotto da entry__title gigante a editorial scale */
.woocommerce-account .ess-entry__title {
	font-size: clamp(1.875rem, 1.5rem + 1.5vw, 2.5rem);
	margin-bottom: 0;
}
.woocommerce-account .ess-entry__header {
	border-bottom: 1px solid var(--ess-line);
	padding-bottom: var(--ess-space-5);
	margin-bottom: var(--ess-space-8);
}

/* Layout 2-col su desktop quando sono presenti login + register sibling.
   :has() supportato Chromium 105+, Safari 15.4+, Firefox 121+. */
@media (min-width: 768px) {
	.woocommerce-account .ess-entry__content > .woocommerce:has(.u-column1):has(.u-column2) {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: var(--ess-space-8);
		align-items: start;
	}
	.woocommerce-account .ess-entry__content > .woocommerce > .woocommerce-notices-wrapper {
		grid-column: 1 / -1;
	}
	/* Fallback per browser senza :has() — su .u-columns wrapper se presente. */
	.woocommerce-account .u-columns {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: var(--ess-space-8);
		align-items: start;
	}
}

/* H2 sezione (Accedi / Registrati) — DM Serif scaled, no underline */
.woocommerce-account .u-column1 > h2,
.woocommerce-account .u-column2 > h2 {
	font-family: var(--ess-font-serif);
	font-size: clamp(1.5rem, 1.25rem + 1vw, 2rem);
	margin: 0 0 var(--ess-space-5);
	color: var(--ess-color-heading);
	font-weight: 400;
	line-height: 1.1;
}

/* Outer column = card unica per Accedi/Registrati. WC/Dokan applica
   automaticamente la classe .ess-card alle u-column1/u-column2; usiamo quella
   come singolo wrapper con padding generoso. */
.woocommerce-account .u-column1.ess-card,
.woocommerce-account .u-column2.ess-card {
	padding: var(--ess-space-7) var(--ess-space-6);
	height: 100%;          /* match heights nelle 2 colonne grid */
}
@media (min-width: 768px) {
	.woocommerce-account .u-column1.ess-card,
	.woocommerce-account .u-column2.ess-card {
		padding: var(--ess-space-8);
	}
}

/* Disabilita hover lift sui form panels (è un form, non una nav card). */
.woocommerce-account .u-column1.ess-card:hover,
.woocommerce-account .u-column2.ess-card:hover,
.woocommerce-account .u-column1.ess-card:focus-within,
.woocommerce-account .u-column2.ess-card:focus-within {
	transform: none;
	box-shadow: none;
}

/* Form interno — completamente trasparente, l'outer card fornisce border + bg */
.woocommerce-account .woocommerce-form-login,
.woocommerce-account .woocommerce-form-register {
	max-width: none;
	margin: 0;
	padding: 0;
	background: transparent;
	border: 0;
	border-radius: 0;
	box-shadow: none;
}

/* Form row spacing */
.woocommerce-account .woocommerce-form-row,
.woocommerce-account .form-row {
	margin-bottom: var(--ess-space-4);
}

/* Label */
.woocommerce-account .woocommerce-form-row > label,
.woocommerce-account .form-row > label {
	display: block;
	font-size: var(--ess-text-sm);
	font-weight: 600;
	margin-bottom: var(--ess-space-2);
	color: var(--ess-color-heading);
}
.woocommerce-account .woocommerce-form-row label .required,
.woocommerce-account .form-row label .required {
	color: var(--ess-color-accent);
	text-decoration: none;
	font-weight: 700;
}

/* Input + password — outlined squared, focus ring terra */
.woocommerce-account .woocommerce-form-row input.input-text,
.woocommerce-account .form-row input.input-text,
.woocommerce-account .woocommerce-Input.input-text {
	width: 100%;
	padding: 12px 14px;
	border: 1px solid var(--ess-line);
	border-radius: 0;
	background: #ffffff;
	color: var(--ess-color-text);
	font-size: var(--ess-text-base);
	font-family: inherit;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.woocommerce-account .woocommerce-form-row input.input-text:focus,
.woocommerce-account .form-row input.input-text:focus,
.woocommerce-account .woocommerce-Input.input-text:focus {
	border-color: var(--ess-color-accent);
	outline: 2px solid var(--ess-color-accent);
	outline-offset: -1px;
}

/* "Ricordami" + radio "Sono un cliente/venditore" inline checkbox style */
.woocommerce-account .woocommerce-form__label-for-checkbox,
.woocommerce-account .woocommerce-form-login__rememberme {
	display: inline-flex;
	align-items: center;
	gap: var(--ess-space-2);
	margin: var(--ess-space-3) 0 0;
	font-size: var(--ess-text-sm);
	color: var(--ess-color-text);
	cursor: pointer;
}
.woocommerce-account .woocommerce-form-login__rememberme input[type="checkbox"],
.woocommerce-account .woocommerce-form__input-checkbox {
	width: 18px;
	height: 18px;
	accent-color: var(--ess-color-accent);
	cursor: pointer;
}

/* Submit button — primary terra squared, full-width edge-to-edge nel card */
.woocommerce-account .woocommerce-form-login button.woocommerce-button,
.woocommerce-account .woocommerce-form-register button.woocommerce-button,
.woocommerce-account .woocommerce-Button.button {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 48px;
	margin-top: var(--ess-space-5);
	padding: 12px 28px;
	background: var(--ess-color-accent);
	color: #ffffff;
	border: 2px solid var(--ess-color-accent);
	border-radius: 0;
	font-family: inherit;
	font-weight: 700;
	font-size: var(--ess-text-sm);
	letter-spacing: 0.5px;
	text-transform: uppercase;
	cursor: pointer;
	transition: background-color 0.15s ease, border-color 0.15s ease;
}
.woocommerce-account .woocommerce-form-login button.woocommerce-button:hover,
.woocommerce-account .woocommerce-form-register button.woocommerce-button:hover,
.woocommerce-account .woocommerce-Button.button:hover {
	background: var(--ess-color-accent-hover);
	border-color: var(--ess-color-accent-hover);
}
.woocommerce-account .woocommerce-form-login button.woocommerce-button:focus-visible,
.woocommerce-account .woocommerce-form-register button.woocommerce-button:focus-visible {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: 2px;
}

/* "Password dimenticata?" link */
.woocommerce-account .woocommerce-LostPassword,
.woocommerce-account .lost_password {
	margin-top: var(--ess-space-4);
}
.woocommerce-account .woocommerce-LostPassword a,
.woocommerce-account .lost_password a {
	color: var(--ess-color-accent);
	text-decoration: underline;
	font-size: var(--ess-text-sm);
	font-weight: 500;
}
.woocommerce-account .woocommerce-LostPassword a:hover {
	text-decoration: none;
}

/* Privacy policy text (sotto register form) */
.woocommerce-account .woocommerce-privacy-policy-text,
.woocommerce-account .woocommerce-form-register__privacy {
	font-size: var(--ess-text-sm);
	color: var(--ess-color-text-sec);
	line-height: 1.55;
	margin: var(--ess-space-3) 0;
}
.woocommerce-account .woocommerce-privacy-policy-text a {
	color: var(--ess-color-accent);
	text-decoration: underline;
}

/* Radio Dokan "Sono un cliente / venditore" — stack vertical, padding consistent */
.woocommerce-account .dokan-customer-vendor-options,
.woocommerce-account p.create-account label,
.woocommerce-account .form-row.dokan-customer-vendor-options {
	display: flex;
	flex-direction: column;
	gap: var(--ess-space-2);
	margin: var(--ess-space-3) 0;
}
.woocommerce-account input[type="radio"] {
	width: 18px;
	height: 18px;
	accent-color: var(--ess-color-accent);
	margin-right: var(--ess-space-2);
	vertical-align: middle;
}

/* Password show/hide button (WC default eye icon) — squared */
.woocommerce-account .woocommerce-Input.input-text + .show-password-input,
.woocommerce-account .show-password-input {
	border-radius: 0;
}

/* ==========================================================================
   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 (asymmetric 1.2:1 grid). */
		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 (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;
	justify-content: center;
	gap: 8px;
	margin: 0 !important;
	padding: 0 20px !important;
	background: #25D366 !important;
	color: #ffffff !important;
	border: 1px solid #25D366 !important;
	border-radius: 0 !important;            /* matcha .ess-pdp__cta squadrato */
	font-family: var(--ess-font-body) !important;
	font-weight: 500 !important;
	font-size: 12px !important;
	letter-spacing: 1px !important;
	text-transform: uppercase !important;
	height: 48px !important;                /* stessa altezza esatta di .ess-pdp__cta + .ess-pdp__wish */
	min-height: 48px !important;
	line-height: 1 !important;
	cursor: pointer;
	transition: background var(--ess-transition-fast), border-color var(--ess-transition-fast);
	flex: 0 0 auto;
}

.dokan-live-chat-whatsapp.button:hover,
button.dokan-live-chat-whatsapp:hover {
	background: #1EBE5A !important;
	border-color: #1EBE5A !important;
	color: #ffffff !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");
}

/* Quando il WhatsApp button è dentro il cta-row del PDP, fagli matchare flex */
.ess-pdp__cta-group .dokan-live-chat-whatsapp,
.ess-pdp__cta-row .dokan-live-chat-whatsapp {
	flex: 1 1 auto;
}

/* ==========================================================================
   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: 40px;
	height: 40px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: var(--ess-font-serif);
	font-size: 16px;
	font-weight: 400;
	color: #ffffff;
	background: var(--ess-sea);
	flex-shrink: 0;
	overflow: hidden;
	text-transform: uppercase;
	letter-spacing: -0.2px;
}
/* Variante --logo: contiene <img> store logo Dokan */
.ess-pdp__vendor-avatar--logo {
	background: #ffffff;          /* niente tone bg quando c'è il logo */
	border: 1px solid var(--ess-line);
	padding: 0;
}
.ess-pdp__vendor-avatar--logo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	border-radius: 50%;
}
/* 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 1 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 0 20px;
	/* BG --ess-orange-strong = --ess-terra-dark (#9e4323) per WCAG AA white-on-bg 6.40:1 */
	background: var(--ess-orange-strong);
	color: #ffffff;
	border: 1px solid var(--ess-orange-strong);
	border-radius: 0;                       /* squadrato */
	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;
	height: 48px;                           /* fisso, allineato a .ess-pdp__wish e WhatsApp */
}
.ess-pdp__cta:hover,
.ess-pdp__cta:focus-visible {
	background: var(--ess-terra-strong);
	border-color: var(--ess-terra-strong);
	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; } }

/* ==========================================================================
   ACCOUNT v2 — Split panel + Tabs + Trust + Vendor showcase (v6.0.6)
   ========================================================================== */

.ess-account {
	margin: var(--ess-space-6) 0 var(--ess-space-12);
}

/* ----- Split layout: form (left) + brand panel (right) ----------------- */
.ess-account__split {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0;
	background: #ffffff;
	border: 1px solid var(--ess-line);
	overflow: hidden;
}
@media (min-width: 960px) {
	.ess-account__split {
		grid-template-columns: 1.05fr 0.95fr;
		min-height: 620px;
	}
}

.ess-account__pane {
	position: relative;
}
.ess-account__pane--form {
	padding: var(--ess-space-7) var(--ess-space-6);
	display: flex;
	flex-direction: column;
}
@media (min-width: 768px) {
	.ess-account__pane--form {
		padding: var(--ess-space-10) var(--ess-space-9);
	}
}
@media (min-width: 1280px) {
	.ess-account__pane--form {
		padding: var(--ess-space-12) var(--ess-space-10);
	}
}

/* ----- Intro ----------------------------------------------------------- */
.ess-account__intro {
	margin-bottom: var(--ess-space-6);
}
.ess-account__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(1.625rem, 1.25rem + 1.75vw, 2.25rem);
	margin: var(--ess-space-2) 0 0;
	font-weight: 400;
	line-height: 1.15;
	color: var(--ess-color-heading);
}

/* ----- Tabs Login/Registrati ------------------------------------------- */
.ess-account__tabs {
	display: inline-flex;
	gap: 0;
	background: var(--ess-surface);
	border: 1px solid var(--ess-line);
	padding: 4px;
	margin-bottom: var(--ess-space-6);
	width: 100%;
	max-width: 360px;
}
.ess-account__tab {
	flex: 1;
	background: transparent;
	border: 0;
	padding: 10px 14px;
	font-family: var(--ess-font-body);
	font-size: var(--ess-text-sm);
	font-weight: 600;
	letter-spacing: 0.2px;
	color: var(--ess-color-text-sec);
	cursor: pointer;
	transition: color var(--ess-transition-fast), background-color var(--ess-transition-fast);
}
.ess-account__tab:hover {
	color: var(--ess-color-heading);
}
.ess-account__tab.is-active {
	background: #ffffff;
	color: var(--ess-color-heading);
	box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
.ess-account__tab:focus-visible {
	outline: 2px solid var(--ess-terra);
	outline-offset: 2px;
}

/* ----- Panels & form --------------------------------------------------- */
.ess-account__panel:not(.is-active) { display: none; }
.ess-account__form {
	max-width: 480px;
	margin: 0;
	padding: 0;
	background: transparent;
	border: 0;
	box-shadow: none;
	display: flex;
	flex-direction: column;
	gap: var(--ess-space-4);
}

.ess-account__field { margin: 0; }
.ess-account__field label {
	display: block;
	font-size: var(--ess-text-sm);
	font-weight: 600;
	margin-bottom: var(--ess-space-2);
	color: var(--ess-color-heading);
}
.ess-account__field .required {
	color: var(--ess-terra);
	font-weight: 700;
	margin-left: 2px;
	text-decoration: none;
}

/* Input */
.ess-account__input {
	width: 100%;
	padding: 12px 14px;
	border: 1px solid var(--ess-line-strong);
	background: #ffffff;
	font-size: var(--ess-text-base);
	font-family: inherit;
	color: var(--ess-color-heading);
	transition: border-color var(--ess-transition-fast), box-shadow var(--ess-transition-fast);
}
.ess-account__input::placeholder { color: var(--ess-muted-aa, #9aa1a6); }
.ess-account__input:focus {
	outline: none;
	border-color: var(--ess-terra);
	box-shadow: 0 0 0 3px rgba(197, 85, 45, 0.16);
	background: #ffffff;
}

/* Password wrap with toggle icon */
.ess-account__pwd-wrap {
	position: relative;
}
.ess-account__pwd-wrap .ess-account__input { padding-right: 44px; }
.ess-account__pwd-toggle {
	position: absolute;
	right: 8px;
	top: 50%;
	transform: translateY(-50%);
	background: transparent;
	border: 0;
	padding: 6px;
	color: var(--ess-color-text-sec);
	cursor: pointer;
	display: flex;
	align-items: center;
}
.ess-account__pwd-toggle:hover,
.ess-account__pwd-toggle:focus-visible {
	color: var(--ess-color-heading);
}
.ess-account__pwd-toggle:focus-visible {
	outline: 2px solid var(--ess-terra);
	outline-offset: 1px;
}

/* Hint */
.ess-account__hint {
	font-size: var(--ess-text-xs);
	color: var(--ess-color-text-sec);
	margin: var(--ess-space-2) 0 0;
	line-height: 1.5;
}

/* Actions row (Ricordami + Password dimenticata?) */
.ess-account__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--ess-space-3);
	margin: var(--ess-space-1) 0 var(--ess-space-3);
	font-size: var(--ess-text-sm);
}
.ess-account__checkbox {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin: 0 !important;
	font-weight: 500 !important;
	color: var(--ess-color-text-sec) !important;
	cursor: pointer;
}
.ess-account__checkbox input[type="checkbox"] {
	width: 16px;
	height: 16px;
	margin: 0;
	accent-color: var(--ess-terra);
}
.ess-account__link {
	color: var(--ess-terra);
	text-decoration: none;
	font-weight: 600;
}
.ess-account__link:hover,
.ess-account__link:focus-visible { text-decoration: underline; }
.ess-account__link--strong {
	font-weight: 700;
	display: inline-flex;
	align-items: center;
	gap: 4px;
}

/* Submit */
.ess-account__submit {
	width: 100%;
	justify-content: center;
	margin-top: var(--ess-space-2);
}

/* Terms */
.ess-account__terms {
	font-size: var(--ess-text-xs);
	color: var(--ess-color-text-sec);
	line-height: 1.55;
	margin: var(--ess-space-3) 0 0;
}
.ess-account__terms a { color: var(--ess-terra); text-decoration: underline; }

/* ----- Trust row ------------------------------------------------------- */
.ess-account__trust {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ess-space-5);
	margin: var(--ess-space-7) 0 0;
	padding: var(--ess-space-5) 0 0;
	border-top: 1px solid var(--ess-line);
	list-style: none;
	padding-left: 0;
}
.ess-account__trust li {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: var(--ess-text-xs);
	color: var(--ess-color-text-sec);
	letter-spacing: 0.1px;
}
.ess-account__trust svg {
	flex-shrink: 0;
	color: var(--ess-ulivo, #6b7a3a);
}

/* ----- Brand panel (RIGHT) -------------------------------------------- */
.ess-account__pane--brand {
	position: relative;
	color: #ffffff;
	background: var(--ess-navy, #1E3A5F);
	overflow: hidden;
	min-height: 480px;
}
.ess-account__brand-bg {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(160deg, rgba(30,58,95,0.85) 0%, rgba(22,21,18,0.75) 100%),
		var(--ess-account-bg, url('https://images.unsplash.com/photo-1530538987395-032d1800fdd4?w=1600&q=80&auto=format&fit=crop')) center/cover no-repeat;
	z-index: 0;
}
.ess-account__brand-content {
	position: relative;
	z-index: 1;
	padding: var(--ess-space-8) var(--ess-space-6);
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	gap: var(--ess-space-6);
}
@media (min-width: 768px) {
	.ess-account__brand-content {
		padding: var(--ess-space-10) var(--ess-space-9);
	}
}
@media (min-width: 1280px) {
	.ess-account__brand-content {
		padding: var(--ess-space-12) var(--ess-space-10);
	}
}

.ess-account__brand-eyebrow {
	font-family: var(--ess-font-mono);
	font-size: 11px;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	color: rgba(255,255,255,0.75);
	margin: 0;
}
.ess-account__brand-title {
	font-family: var(--ess-font-serif);
	font-size: clamp(1.5rem, 1.1rem + 1.6vw, 2rem);
	line-height: 1.2;
	margin: var(--ess-space-2) 0 0;
	color: #ffffff;
	font-weight: 400;
}

/* Benefits list */
.ess-account__benefits {
	list-style: none;
	padding: 0;
	margin: var(--ess-space-6) 0 0;
	display: flex;
	flex-direction: column;
	gap: var(--ess-space-4);
}
.ess-account__benefit {
	display: grid;
	grid-template-columns: 38px 1fr;
	gap: var(--ess-space-3);
	align-items: start;
}
.ess-account__benefit-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	background: rgba(255,255,255,0.10);
	border: 1px solid rgba(255,255,255,0.15);
	border-radius: 2px;
	color: var(--ess-limone, #e8c341);
}
.ess-account__benefit strong {
	display: block;
	font-family: var(--ess-font-body);
	font-size: var(--ess-text-base);
	font-weight: 600;
	color: #ffffff;
	margin-bottom: 4px;
}
.ess-account__benefit p {
	margin: 0;
	font-size: var(--ess-text-sm);
	color: rgba(255,255,255,0.80);
	line-height: 1.5;
}

/* Quote */
.ess-account__quote {
	margin: var(--ess-space-6) 0 0;
	padding: var(--ess-space-4) 0 0;
	border-top: 1px solid rgba(255,255,255,0.15);
}
.ess-account__quote blockquote {
	font-family: var(--ess-font-serif);
	font-size: 1.05rem;
	line-height: 1.5;
	margin: 0;
	color: rgba(255,255,255,0.95);
}
.ess-account__quote figcaption {
	margin-top: var(--ess-space-2);
	font-family: var(--ess-font-mono);
	font-size: 11px;
	letter-spacing: 0.8px;
	text-transform: uppercase;
	color: rgba(255,255,255,0.60);
}

/* ----- Vendor showcase (sotto split) ----------------------------------- */
.ess-account__vendor {
	margin-top: var(--ess-space-10);
}
.ess-account__vendor-head {
	max-width: 720px;
	margin-bottom: var(--ess-space-6);
}
.ess-account__vendor-title {
	font-family: var(--ess-font-serif);
	font-size: clamp(1.5rem, 1.1rem + 1.4vw, 2rem);
	font-weight: 400;
	line-height: 1.2;
	margin: var(--ess-space-2) 0 var(--ess-space-3);
	color: var(--ess-color-heading);
}
.ess-account__vendor-lead {
	font-size: var(--ess-text-base);
	color: var(--ess-color-text-sec);
	line-height: 1.55;
	margin: 0;
}

.ess-account__plans {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--ess-space-4);
	margin-top: var(--ess-space-6);
}
@media (min-width: 768px) {
	.ess-account__plans {
		grid-template-columns: repeat(3, 1fr);
	}
}

.ess-account__plan {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: var(--ess-space-2);
	background: #ffffff;
	border: 1px solid var(--ess-line);
	padding: var(--ess-space-6);
	text-decoration: none;
	color: var(--ess-color-heading);
	transition: border-color var(--ess-transition-fast), box-shadow var(--ess-transition-fast), transform var(--ess-transition-fast);
}
.ess-account__plan:hover,
.ess-account__plan:focus-visible {
	border-color: var(--ess-terra);
	box-shadow: 0 4px 16px rgba(22,21,18,0.06);
	transform: translateY(-2px);
	outline: none;
}
.ess-account__plan--featured {
	border-color: var(--ess-terra);
	box-shadow: 0 2px 8px rgba(197,85,45,0.10);
}
.ess-account__plan-badge {
	position: absolute;
	top: -10px;
	left: var(--ess-space-5);
	background: var(--ess-terra);
	color: #ffffff;
	font-family: var(--ess-font-mono);
	font-size: 10px;
	letter-spacing: 0.8px;
	text-transform: uppercase;
	padding: 4px 10px;
	font-weight: 700;
}
.ess-account__plan-name {
	font-family: var(--ess-font-serif);
	font-size: var(--ess-text-xl);
	font-weight: 400;
	color: var(--ess-color-heading);
}
.ess-account__plan-price {
	display: flex;
	align-items: baseline;
	gap: 6px;
	font-family: var(--ess-font-serif);
	font-size: 1.75rem;
	color: var(--ess-color-heading);
	font-weight: 500;
}
.ess-account__plan-period {
	font-family: var(--ess-font-body);
	font-size: var(--ess-text-sm);
	color: var(--ess-color-text-sec);
	font-weight: 400;
}
.ess-account__plan-desc {
	font-size: var(--ess-text-sm);
	color: var(--ess-color-text-sec);
	line-height: 1.5;
	margin: var(--ess-space-1) 0 var(--ess-space-2);
}
.ess-account__plan-cta {
	margin-top: auto;
	color: var(--ess-terra);
	font-weight: 700;
	font-size: var(--ess-text-sm);
	letter-spacing: 0.2px;
}

.ess-account__vendor-foot {
	margin: var(--ess-space-5) 0 0;
}

@media (prefers-reduced-motion: reduce) {
	.ess-account__plan,
	.ess-account__plan:hover { transition: none; transform: none; }
}

/* === LEGACY (.ess-account-hero, .ess-account-grid, .ess-account-card)
   Manteniamo per fallback se altri template usano ancora le vecchie classi.
   Possono essere rimosse in un futuro cleanup. ============================= */
.ess-account-hero {
	margin-bottom: var(--ess-space-8);
	max-width: 720px;
}

.ess-account-hero__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(1.75rem, 1.25rem + 2vw, 2.5rem);
	margin: var(--ess-space-2) 0 var(--ess-space-3);
	font-weight: 400;
	line-height: 1.15;
	color: var(--ess-color-heading);
}

.ess-account-hero__lead {
	font-size: var(--ess-text-base);
	color: var(--ess-color-text-sec);
	line-height: 1.6;
	margin: 0;
	max-width: 56ch;
}

/* Grid 2-col */
.ess-account-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--ess-space-6);
	margin: 0 0 var(--ess-space-10);
	align-items: stretch;
}

@media (min-width: 768px) {
	.ess-account-grid {
		grid-template-columns: 1fr 1fr;
		gap: var(--ess-space-8);
	}
}

/* Card uniformi (Accedi / Registrati) */
.ess-account-card {
	background: #ffffff;
	border: 1px solid var(--ess-line);
	padding: var(--ess-space-7) var(--ess-space-6);
	display: flex;
	flex-direction: column;
}
@media (min-width: 768px) {
	.ess-account-card {
		padding: var(--ess-space-8);
	}
}

.ess-account-card > h2 {
	font-family: var(--ess-font-serif);
	font-size: clamp(1.5rem, 1.25rem + 1vw, 2rem);
	margin: 0 0 var(--ess-space-5);
	color: var(--ess-color-heading);
	font-weight: 400;
	line-height: 1.1;
	border-bottom: 1px solid var(--ess-line);
	padding-bottom: var(--ess-space-4);
}

/* Form internal — neutralizza WC default */
.ess-account-card .woocommerce-form-login,
.ess-account-card .woocommerce-form-register {
	max-width: none;
	margin: 0;
	padding: 0;
	background: transparent;
	border: 0;
	border-radius: 0;
	box-shadow: none;
	flex: 1;
	display: flex;
	flex-direction: column;
}

/* Row spacing */
.ess-account-card .woocommerce-form-row,
.ess-account-card .form-row {
	margin-bottom: var(--ess-space-4);
}

/* Labels */
.ess-account-card label:not(.woocommerce-form__label-for-checkbox) {
	display: block;
	font-size: var(--ess-text-sm);
	font-weight: 600;
	margin-bottom: var(--ess-space-2);
	color: var(--ess-color-heading);
}
.ess-account-card .required {
	color: var(--ess-color-accent, var(--ess-terra));
	text-decoration: none;
	font-weight: 700;
	margin-left: 2px;
}

/* Input styling — outline pulito */
.ess-account-card input[type="text"],
.ess-account-card input[type="email"],
.ess-account-card input[type="password"] {
	width: 100%;
	padding: 12px 14px;
	border: 1px solid var(--ess-line-strong);
	background: var(--ess-surface);
	font-size: var(--ess-text-base);
	font-family: inherit;
	color: var(--ess-color-heading);
	transition: border-color var(--ess-transition-fast), box-shadow var(--ess-transition-fast);
}
.ess-account-card input[type="text"]:focus,
.ess-account-card input[type="email"]:focus,
.ess-account-card input[type="password"]:focus {
	outline: none;
	border-color: var(--ess-terra);
	box-shadow: 0 0 0 2px rgba(197, 85, 45, 0.18);
	background: #ffffff;
}

/* Actions row (Ricordami + Password dimenticata) */
.ess-account-card__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--ess-space-3);
	margin: var(--ess-space-3) 0 var(--ess-space-5);
	font-size: var(--ess-text-sm);
}
.ess-account-card__actions label {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin: 0 !important;
	font-weight: 500 !important;
	color: var(--ess-color-text-sec) !important;
	cursor: pointer;
}
.ess-account-card__actions input[type="checkbox"] {
	width: 16px;
	height: 16px;
	margin: 0;
	accent-color: var(--ess-terra);
}

.ess-account-card__lost-password {
	color: var(--ess-terra);
	text-decoration: none;
	font-weight: 600;
	font-size: var(--ess-text-sm);
}
.ess-account-card__lost-password:hover,
.ess-account-card__lost-password:focus-visible {
	text-decoration: underline;
}

/* Submit row — button full-width all'interno della card */
.ess-account-card__submit-row {
	margin-top: auto !important;
	padding-top: var(--ess-space-4);
}
.ess-account-card__submit-row .ess-btn {
	width: 100%;
	justify-content: center;
}

/* Hint text */
.ess-account-card__hint {
	display: block;
	font-size: var(--ess-text-xs);
	color: var(--ess-muted-aa, var(--ess-color-text-sec));
	margin-top: var(--ess-space-2);
	line-height: 1.4;
}

/* Terms text sotto bottone register */
.ess-account-card__terms {
	font-size: var(--ess-text-xs);
	color: var(--ess-color-text-sec);
	line-height: 1.5;
	margin: var(--ess-space-3) 0 0;
}
.ess-account-card__terms a {
	color: var(--ess-terra);
	text-decoration: underline;
}

/* Dokan vendor signup radio (hook woocommerce_register_form) — restyling se presente */
.ess-account-card .woocommerce-form-register .form-row label[for="seller-account"],
.ess-account-card .woocommerce-form-register .form-row label[for="customer-account"],
.ess-account-card .woocommerce-form-register #dokan-seller-reg-fields label {
	font-weight: 500;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin-right: var(--ess-space-4);
}
.ess-account-card .woocommerce-form-register input[type="radio"] {
	width: 16px;
	height: 16px;
	accent-color: var(--ess-terra);
}

/* ===== Vendor CTA "Vendi con noi" ===== */
.ess-account-vendor-cta {
	background: var(--ess-surface);
	border: 1px solid var(--ess-line);
	border-left: 4px solid var(--ess-terra);
	padding: var(--ess-space-7) var(--ess-space-6);
	margin: var(--ess-space-10) 0 var(--ess-space-8);
}
@media (min-width: 768px) {
	.ess-account-vendor-cta {
		padding: var(--ess-space-8);
	}
}

.ess-account-vendor-cta__inner {
	max-width: 640px;
}

.ess-account-vendor-cta__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(1.375rem, 1.1rem + 1.2vw, 1.875rem);
	margin: var(--ess-space-2) 0 var(--ess-space-3);
	font-weight: 400;
	line-height: 1.2;
	color: var(--ess-color-heading);
}

.ess-account-vendor-cta__lead {
	font-size: var(--ess-text-base);
	color: var(--ess-color-text-sec);
	line-height: 1.6;
	margin: 0 0 var(--ess-space-5);
}

.ess-account-vendor-cta .ess-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}
