/**
 * ESS Components — BEM UI Components
 *
 * Buttons, Product Card, Vendor Card, Badge, Form, Tabs, Breadcrumb, Widget
 *
 * @version 1.0.0
 */

/* ==========================================================================
   BUTTONS
   ========================================================================== */

.ess-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--ess-space-2);
	padding: var(--ess-space-2) var(--ess-space-5);
	font-weight: var(--ess-weight-semibold);
	font-size: var(--ess-text-sm);
	line-height: 1;
	text-decoration: none;
	white-space: nowrap;
	border: 2px solid transparent;
	border-radius: var(--ess-radius-md);
	cursor: pointer;
	transition: all var(--ess-transition-fast);
	min-height: 44px;
}

.ess-btn:focus-visible {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: 2px;
}

.ess-btn--primary {
	background: var(--ess-color-accent);
	color: var(--ess-color-white);
}

.ess-btn--primary:hover {
	background: var(--ess-color-accent-hover);
	color: var(--ess-color-white);
}

.ess-btn--secondary {
	background: var(--ess-color-primary);
	color: var(--ess-color-white);
}

.ess-btn--secondary:hover {
	background: var(--ess-color-primary-hover);
	color: var(--ess-color-white);
}

.ess-btn--outline {
	background: transparent;
	border-color: var(--ess-color-primary);
	color: var(--ess-color-primary);
}

.ess-btn--outline:hover {
	background: var(--ess-color-primary);
	color: var(--ess-color-white);
}

.ess-btn--sm {
	padding: var(--ess-space-2) var(--ess-space-4);
	font-size: var(--ess-text-xs);
}

.ess-btn--lg {
	padding: var(--ess-space-4) var(--ess-space-8);
	font-size: var(--ess-text-base);
}

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

.ess-btn:disabled,
.ess-btn[aria-disabled="true"] {
	opacity: 0.5;
	cursor: not-allowed;
	pointer-events: none;
}

/* ==========================================================================
   PRODUCT CARD — Editorial, squared, affiliate-aware
   ========================================================================== */

.ess-product-card {
	position: relative;
	background: #ffffff;
	border: 1px solid var(--ess-line);
	border-radius: 0;
	overflow: hidden;
	transition: transform var(--ess-transition-fast), box-shadow var(--ess-transition-fast);
	font-family: var(--ess-font-body);
}
.ess-product-card:hover,
.ess-product-card:focus-within {
	transform: translateY(-2px);
	box-shadow: var(--ess-shadow-card-hover);
}

/* Stretched link — whole card is a pointer to the product. CTA + heart
   sono interattivi sopra via z-index, il link è sotto. */
.ess-product-card__link {
	position: absolute;
	inset: 0;
	z-index: 1;
	text-indent: -9999px;
	overflow: hidden;
}
.ess-product-card__link:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: -3px;
}

/* Image area — height fissa (no aspect-ratio) per matchare design */
.ess-product-card__image {
	position: relative;
	height: 170px;
	overflow: hidden;
	background: var(--ess-surface);
}
.ess-product-card--small .ess-product-card__image,
.ess-flash-offers .ess-product-card__image {
	height: 140px;
}

.ess-product-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.4s ease;
}
.ess-product-card:hover .ess-product-card__image img {
	transform: scale(1.04);
}

/* Badges — positioning matching design */
.ess-product-card__badge {
	position: absolute;
	z-index: 2;
	padding: 3px 7px;
	font-family: var(--ess-font-mono);
	font-size: 9px;
	font-weight: 500;
	line-height: 1.4;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	color: #ffffff;
	border-radius: 0;
}

/* Top-left: certification DOP/IGP (wave blue-olive) */
.ess-product-card__badge--cert {
	top: 8px;
	left: 8px;
	background: var(--ess-wave);
}

/* Top-right: sale discount (arancio) */
.ess-product-card__badge--sale {
	top: 8px;
	right: 8px;
	background: var(--ess-orange);
	font-size: 10px;
}

/* Out of stock: top-right grey */
.ess-product-card__badge--outofstock {
	top: 8px;
	right: 8px;
	background: var(--ess-muted);
}

/* Heart bookmark — bottom-right della cover */
.ess-product-card__wish {
	position: absolute;
	bottom: 8px;
	right: 8px;
	z-index: 3;
	width: 30px;
	height: 30px;
	padding: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: #ffffff;
	border: 1px solid var(--ess-line);
	color: var(--ess-navy-soft);
	cursor: pointer;
	border-radius: 0;
	transition: color var(--ess-transition-fast), border-color var(--ess-transition-fast);
}
.ess-product-card__wish svg { width: 16px; height: 16px; display: block; }
.ess-product-card__wish:hover,
.ess-product-card__wish:focus-visible {
	color: var(--ess-orange);
	border-color: var(--ess-orange);
}
.ess-product-card__wish:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: 2px;
}
.ess-product-card__wish[aria-pressed="true"],
.ess-product-card__wish.is-active {
	color: var(--ess-orange);
	border-color: var(--ess-orange);
}
.ess-product-card__wish[aria-pressed="true"] svg,
.ess-product-card__wish.is-active svg {
	fill: var(--ess-orange);
}

/* Body */
.ess-product-card__body {
	padding: 12px;
	position: relative;
	z-index: 2;
}

/* Vendor — mono uppercase muted */
.ess-product-card__vendor {
	font-family: var(--ess-font-mono);
	font-size: 10px;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	color: var(--ess-muted);
	margin-bottom: 6px;
	line-height: 1.2;
}
.ess-product-card__vendor a {
	color: inherit;
	text-decoration: none;
}
.ess-product-card__vendor a:hover { color: var(--ess-orange); }

/* Title — NON serif (design usa sans body con peso regular per product cards) */
.ess-product-card__title {
	font-family: var(--ess-font-body);
	font-size: 13px;
	font-weight: 400;
	line-height: 1.35;
	color: var(--ess-navy);
	margin: 0 0 12px;
	letter-spacing: 0;
	min-height: 36px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.ess-product-card__title a {
	color: inherit;
	text-decoration: none;
}

/* Footer — prezzo serif + CTA mono, separati da border-top */
.ess-product-card__footer {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: var(--ess-space-2);
	padding-top: 12px;
	border-top: 1px solid var(--ess-line);
}

.ess-product-card__price {
	font-family: var(--ess-font-serif);
	font-size: 18px;
	font-weight: 400;
	color: var(--ess-navy);
	line-height: 1.1;
	letter-spacing: -0.2px;
}
.ess-product-card__price .woocommerce-Price-amount { font-family: var(--ess-font-serif); }
.ess-product-card__price del {
	color: var(--ess-muted);
	font-family: var(--ess-font-body);
	font-weight: 400;
	font-size: 10px;
	margin-left: 6px;
	text-decoration: line-through;
}
.ess-product-card__price ins {
	text-decoration: none;
	color: var(--ess-navy);
	font-family: var(--ess-font-serif);
}

/* "Prezzo su richiesta" — emitted when the external product has no price set.
   Use body sans, smaller, muted to keep card layout balanced. */
.ess-product-card__price .ess-price-on-request,
.ess-pdp__price .ess-price-on-request {
	font-family: var(--ess-font-body);
	font-size: 12px;
	font-weight: 400;
	color: var(--ess-muted);
	font-style: italic;
	letter-spacing: 0;
}
.ess-pdp__price .ess-price-on-request {
	font-size: 16px;
}

/* CTA — mono, color sea, no button chrome */
.ess-product-card__cta {
	position: relative;
	z-index: 3;
	background: none;
	border: none;
	padding: 0;
	font-family: var(--ess-font-mono);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	color: var(--ess-sea);
	text-decoration: none;
	cursor: pointer;
	white-space: nowrap;
	transition: color var(--ess-transition-fast);
}
.ess-product-card__cta:hover,
.ess-product-card__cta:focus-visible {
	color: var(--ess-orange);
}
.ess-product-card__cta:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: 3px;
}
.ess-product-card__cta--disabled {
	color: var(--ess-muted);
	pointer-events: none;
	cursor: default;
}

/* Legacy actions container — kept for retrocompat, non usato dal nuovo card */
.ess-product-card__actions {
	padding: 0 12px 12px;
	position: relative;
	z-index: 2;
}

/* Legacy rating block — still supported if future card variants need it */
.ess-product-card__rating {
	display: flex;
	align-items: center;
	gap: var(--ess-space-1);
	color: var(--ess-orange);
	font-size: var(--ess-text-xs);
	margin-top: 6px;
	font-family: var(--ess-font-mono);
	letter-spacing: 0.3px;
}

/* ==========================================================================
   VENDOR CARD
   ========================================================================== */

.ess-vendor-card {
	background: var(--ess-color-card-bg);
	border: 0;
	border-radius: var(--ess-radius-lg);
	padding: var(--ess-space-6);
	text-align: center;
	box-shadow: var(--ess-shadow);
	transition: box-shadow var(--ess-transition-normal), transform var(--ess-transition-normal);
	overflow: hidden;
}

.ess-vendor-card:hover {
	box-shadow: var(--ess-shadow-lg);
	transform: translateY(-2px);
}

.ess-vendor-card__avatar {
	width: 72px;
	height: 72px;
	border-radius: var(--ess-radius-full);
	margin-inline: auto;
	margin-bottom: var(--ess-space-3);
	object-fit: cover;
	border: 3px solid var(--ess-color-primary-light);
	transition: border-color var(--ess-transition-fast);
}

.ess-vendor-card:hover .ess-vendor-card__avatar {
	border-color: var(--ess-color-accent);
}

.ess-vendor-card__name {
	font-weight: var(--ess-weight-semibold);
	font-size: var(--ess-text-lg);
	margin-bottom: var(--ess-space-2);
}

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

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

.ess-vendor-card__meta {
	display: flex;
	flex-direction: column;
	gap: var(--ess-space-1);
	margin-bottom: var(--ess-space-3);
	font-size: var(--ess-text-xs);
	color: var(--ess-color-text-sec);
}

.ess-vendor-card__location,
.ess-vendor-card__count {
	display: inline-flex;
	align-items: center;
	gap: var(--ess-space-1);
}

.ess-vendor-card__rating {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--ess-space-1);
	color: var(--ess-color-warning);
}

/* ==========================================================================
   BADGE
   ========================================================================== */

.ess-badge {
	display: inline-flex;
	align-items: center;
	padding: var(--ess-space-1) var(--ess-space-3);
	font-size: var(--ess-text-xs);
	font-weight: var(--ess-weight-semibold);
	border-radius: var(--ess-radius-full);
	line-height: 1.5;
}

.ess-badge--success { background: #dcfce7; color: #166534; }
.ess-badge--warning { background: #fef3c7; color: #92400e; }
.ess-badge--error   { background: #fee2e2; color: #991b1b; }
.ess-badge--info    { background: #dbeafe; color: #1e40af; }

/* ==========================================================================
   FORMS
   ========================================================================== */

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

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

.ess-input--error {
	border-color: var(--ess-color-error);
}

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

.ess-field-error {
	font-size: var(--ess-text-xs);
	color: var(--ess-color-error);
	margin-top: var(--ess-space-1);
}

/* ==========================================================================
   TABS
   ========================================================================== */

.ess-tabs__list {
	display: flex;
	gap: 0;
	border-bottom: 2px solid var(--ess-color-border);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.ess-tabs__tab {
	padding: var(--ess-space-3) var(--ess-space-6);
	font-weight: var(--ess-weight-medium);
	border: none;
	background: none;
	cursor: pointer;
	color: var(--ess-color-neutral-500);
	border-bottom: 2px solid transparent;
	margin-bottom: -2px;
	min-height: 44px;
	white-space: nowrap;
	transition: all var(--ess-transition-fast);
}

.ess-tabs__tab:hover {
	color: var(--ess-color-primary);
}

.ess-tabs__tab[aria-selected="true"] {
	color: var(--ess-color-primary);
	border-bottom-color: var(--ess-color-primary);
}

.ess-tabs__tab:focus-visible {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: -2px;
}

.ess-tabs__panel[hidden] {
	display: none;
}

.ess-tabs__panel {
	padding-top: var(--ess-space-6);
}

/* ==========================================================================
   BREADCRUMB
   ========================================================================== */

.ess-breadcrumb {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--ess-space-2);
	font-size: var(--ess-text-sm);
	color: var(--ess-color-neutral-500);
	padding: var(--ess-space-4) 0;
}

.ess-breadcrumb a {
	color: var(--ess-color-neutral-500);
	text-decoration: none;
}

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

.ess-breadcrumb__separator {
	color: var(--ess-color-neutral-300);
}

.ess-breadcrumb [aria-current="page"] {
	color: var(--ess-color-heading);
	font-weight: var(--ess-weight-medium);
}

/* ==========================================================================
   WIDGET
   ========================================================================== */

.ess-widget {
	margin-bottom: var(--ess-space-8);
}

.ess-widget__title {
	font-size: var(--ess-text-lg);
	font-weight: var(--ess-weight-semibold);
	margin-bottom: var(--ess-space-4);
	padding-bottom: var(--ess-space-3);
	border-bottom: 2px solid var(--ess-color-border);
}

/* ==========================================================================
   HEADER — Editorial, squared, pill search
   ========================================================================== */

.ess-header {
	background: #ffffff;
	border-bottom: 1px solid var(--ess-line);
	position: relative;
	z-index: var(--ess-z-sticky);
	font-family: var(--ess-font-body);
}

.ess-header--sticky {
	position: sticky;
	top: 0;
	box-shadow: var(--ess-shadow-sm);
}

.ess-header__row {
	display: flex;
	align-items: center;
	gap: 1.75rem;
	padding-block: 14px;
	min-height: 64px;
}
@media (min-width: 1024px) {
	.ess-header__row { min-height: 72px; }
}

/* Logo */
.ess-header__logo {
	flex-shrink: 0;
}

.ess-header__logo a {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
}

.ess-header__logo img {
	height: 40px;
	width: auto;
	display: block;
}
@media (min-width: 768px) {
	.ess-header__logo img { height: 46px; }
}

.ess-site-logo__text {
	/* Fallback wordmark quando manca SVG: Cormorant Garamond come brand-guidelines */
	font-family: var(--ess-font-wordmark);
	font-size: 1.625rem; /* 26px — matches brand-guidelines */
	font-weight: 600;
	color: var(--ess-sea);
	text-decoration: none;
	letter-spacing: -0.4px;
	letter-spacing: -0.4px;
}
.ess-site-logo__text:hover { color: var(--ess-terra); }

/* Logo SVG (variante ufficiale dal logo-package) */
.ess-site-logo { display: inline-flex; align-items: center; text-decoration: none; }
.ess-site-logo__svg {
	height: 40px;
	width: auto;
	display: block;
}
@media (min-width: 768px) { .ess-site-logo__svg { height: 48px; } }

/* Search form — pill-shaped con bordo navy + bottone CERCA dark */
.ess-header__search {
	flex: 1;
	max-width: 640px;
	margin-inline: auto;
}

.ess-search-form {
	width: 100%;
}

.ess-search-form__wrapper {
	display: flex;
	align-items: stretch;
	position: relative;
	border: 1px solid var(--ess-navy);
	border-radius: var(--ess-radius-full);
	background: #ffffff;
	overflow: hidden;
	transition: box-shadow var(--ess-transition-fast);
}
.ess-search-form__wrapper:focus-within {
	box-shadow: 0 0 0 3px rgba(232, 121, 42, 0.18);
}

.ess-search-form__input {
	flex: 1;
	min-width: 0;
	padding: 10px 20px;
	border: none;
	background: transparent;
	font-family: var(--ess-font-body);
	font-size: var(--ess-text-sm);
	color: var(--ess-navy);
	outline: none;
	border-radius: 0;
}
.ess-search-form__input::placeholder {
	color: var(--ess-muted);
}
.ess-search-form__input:focus {
	background: transparent;
	box-shadow: none;
}

.ess-search-form__btn {
	position: static;
	transform: none;
	background: var(--ess-navy);
	color: #ffffff;
	border: none;
	border-radius: 0;
	padding: 10px 22px;
	font-family: var(--ess-font-body);
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	cursor: pointer;
	transition: background var(--ess-transition-fast);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--ess-space-2);
	width: auto;
	height: auto;
}
.ess-search-form__btn:hover,
.ess-search-form__btn:focus-visible {
	background: #000000;
	color: #ffffff;
}
.ess-search-form__btn:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: -4px;
}
.ess-search-form__btn svg { width: 18px; height: 18px; }

/* Header actions (Preferiti + Account, text + icon) */
.ess-header__actions {
	display: flex;
	align-items: center;
	gap: var(--ess-space-4);
	font-size: 12px;
	color: var(--ess-navy-soft);
	flex-shrink: 0;
}

.ess-header__action-link {
	display: inline-flex;
	align-items: center;
	gap: var(--ess-space-1);
	padding: var(--ess-space-2) var(--ess-space-2);
	min-height: 44px;
	font-family: var(--ess-font-body);
	font-size: 12px;
	color: var(--ess-navy-soft);
	text-decoration: none;
	background: transparent;
	border: none;
	border-radius: 0;
	cursor: pointer;
	transition: color var(--ess-transition-fast);
	line-height: 1;
}
.ess-header__action-link:hover,
.ess-header__action-link:focus-visible {
	color: var(--ess-orange);
}
.ess-header__action-link:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: 2px;
}
.ess-header__action-link svg {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
}

/* Badge count arancio accanto a "Preferiti" */
.ess-header__action-count {
	background: var(--ess-orange);
	color: #ffffff;
	border-radius: 999px;
	padding: 1px 7px;
	font-size: 10px;
	font-family: var(--ess-font-mono);
	font-weight: 500;
	line-height: 1.4;
	margin-left: var(--ess-space-1);
}

/* Icon-only buttons (mobile: hamburger, search toggle) — retain old look but squared */
.ess-header__action-btn,
.ess-header__action-btn.ess-hide-mobile,
.ess-header__action-btn.ess-hide-desktop {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	padding: 0;
	margin: 0;
	border: none;
	background: none;
	cursor: pointer;
	color: var(--ess-navy);
	border-radius: 0;
	transition: color var(--ess-transition-fast), background var(--ess-transition-fast);
	text-decoration: none;
	position: relative;
	line-height: 0;
	vertical-align: middle;
}
.ess-header__action-btn.ess-hide-mobile { display: none !important; }
.ess-header__action-btn.ess-hide-desktop { display: inline-flex !important; }
@media (min-width: 768px) {
	.ess-header__action-btn.ess-hide-mobile { display: inline-flex !important; }
	.ess-header__action-btn.ess-hide-desktop { display: none !important; }
}

.ess-header__action-btn svg {
	display: block;
	width: 22px;
	height: 22px;
	flex: 0 0 22px;
}

.ess-header__action-btn:hover {
	color: var(--ess-orange);
	background: transparent;
}
.ess-header__action-btn:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: 2px;
}

.ess-header__mobile-search {
	padding: var(--ess-space-3) 0 var(--ess-space-4);
	border-top: 1px solid var(--ess-line);
}

/* Hide desktop-only header elements on mobile and vice versa */
@media (max-width: 767px) {
	.ess-header__search,
	.ess-header__actions .ess-header__action-link { display: none; }
}
@media (min-width: 768px) {
	.ess-header__actions .ess-header__action-btn[data-ess-toggle="search"],
	.ess-header__actions .ess-header__action-btn[data-ess-toggle="mobile-menu"] { display: none !important; }
}

/* ==========================================================================
   SECONDARY NAV — tab nav dentro header, underline arancio sull'attiva
   (bianca, sotto la search row, con territori mono a destra)
   ========================================================================== */

.ess-header__subnav {
	display: flex;
	align-items: center;
	gap: var(--ess-space-6);
	padding: 0 0 14px;
	font-family: var(--ess-font-body);
	font-size: 13px;
	color: var(--ess-navy-soft);
}

.ess-header__subnav-territory {
	margin-left: auto;
	font-family: var(--ess-font-mono);
	font-size: var(--ess-text-xs);
	letter-spacing: 0.5px;
	text-transform: uppercase;
	color: var(--ess-muted);
}

/* Reset container styles */
.ess-navbar {
	background: transparent;
	border: none;
	box-shadow: none;
	position: static;
}
.ess-header--sticky + .ess-navbar {
	position: static;
	box-shadow: none;
}

/* Desktop horizontal nav menu */
.ess-nav-menu {
	display: flex;
	align-items: center;
	gap: var(--ess-space-6);
	list-style: none;
	margin: 0;
	padding: 0;
	flex-wrap: wrap;
}

.ess-nav-menu > li { position: relative; }

.ess-nav-menu > li > a {
	display: inline-flex;
	align-items: center;
	position: relative;
	padding: 10px 0 12px;
	font-family: var(--ess-font-body);
	font-size: 13px;
	font-weight: 400;
	color: var(--ess-navy-soft);
	text-decoration: none;
	letter-spacing: 0;
	border-bottom: 2px solid transparent;
	transition: color var(--ess-transition-fast), border-color var(--ess-transition-fast);
	line-height: 1;
}

.ess-nav-menu > li > a:hover {
	color: var(--ess-navy);
	border-bottom-color: var(--ess-orange);
}

.ess-nav-menu > li > a:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: 4px;
}

/* Active state: underline arancio 2px + testo navy + font-weight medium */
.ess-nav-menu > li.current-menu-item > a,
.ess-nav-menu > li.current-menu-ancestor > a,
.ess-nav-menu > li.current-menu-parent > a,
.ess-nav-menu > li > a[aria-current="page"] {
	color: var(--ess-navy);
	font-weight: 500;
	border-bottom-color: var(--ess-orange);
}

/* Submenu dropdown (desktop) — editoriale, squared */
.ess-nav-menu .menu-item-has-children { position: relative; }

.ess-nav-menu .sub-menu {
	position: absolute;
	top: 100%;
	left: 0;
	min-width: 220px;
	background: #ffffff;
	border: 1px solid var(--ess-line);
	border-top: 2px solid var(--ess-orange);
	border-radius: 0;
	box-shadow: var(--ess-shadow-md);
	padding: var(--ess-space-2) 0;
	list-style: none;
	opacity: 0;
	visibility: hidden;
	transform: translateY(4px);
	transition: opacity var(--ess-transition-fast), transform var(--ess-transition-fast), visibility var(--ess-transition-fast);
	z-index: var(--ess-z-dropdown);
}

.ess-nav-menu .menu-item-has-children:hover > .sub-menu,
.ess-nav-menu .sub-menu.ess-sub-menu--open {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.ess-nav-menu .sub-menu a {
	display: flex;
	align-items: center;
	padding: var(--ess-space-2) var(--ess-space-4);
	font-size: var(--ess-text-sm);
	font-weight: 400;
	color: var(--ess-navy-soft);
	text-decoration: none;
	min-height: 40px;
	transition: background var(--ess-transition-fast), color var(--ess-transition-fast);
}

.ess-nav-menu .sub-menu a:hover {
	background: var(--ess-surface);
	color: var(--ess-orange);
}

.ess-nav-menu .sub-menu li + li {
	border-top: 1px solid var(--ess-line);
}

/* ==========================================================================
   MOBILE MENU (off-canvas)
   ========================================================================== */

.ess-mobile-overlay {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.5);
	z-index: var(--ess-z-overlay);
	opacity: 0;
	visibility: hidden;
	transition: opacity var(--ess-transition-normal), visibility var(--ess-transition-normal);
}

.ess-mobile-overlay--active {
	opacity: 1;
	visibility: visible;
}

.ess-mobile-menu {
	position: fixed;
	top: 0;
	right: 0;
	width: min(320px, 85vw);
	height: 100vh;
	background: var(--ess-color-white);
	z-index: var(--ess-z-modal);
	overflow-y: auto;
	transform: translateX(100%);
	transition: transform var(--ess-transition-normal);
	display: flex;
	flex-direction: column;
}

.ess-mobile-menu:not([hidden]) {
	transform: translateX(0);
}

.ess-mobile-menu__header {
	padding: var(--ess-space-4) var(--ess-space-4);
	border-bottom: 1px solid var(--ess-color-border);
}

.ess-mobile-menu__title {
	font-size: var(--ess-text-lg);
}

.ess-mobile-menu__close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border: none;
	background: none;
	cursor: pointer;
	color: var(--ess-color-neutral-700);
	border-radius: var(--ess-radius-md);
}

.ess-mobile-menu__close:hover {
	background: var(--ess-color-neutral-100);
}

.ess-mobile-menu__close:focus-visible {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: 2px;
}

/* Mobile nav links */
.ess-mobile-nav {
	list-style: none;
	padding: var(--ess-space-2) 0;
	flex: 1;
}

.ess-mobile-nav > li {
	border-bottom: 1px solid var(--ess-color-neutral-100);
}

.ess-mobile-nav > li > a {
	display: block;
	padding: var(--ess-space-3) var(--ess-space-4);
	font-size: var(--ess-text-base);
	font-weight: var(--ess-weight-medium);
	color: var(--ess-color-neutral-800);
	text-decoration: none;
	min-height: 44px;
	line-height: 1.5;
}

.ess-mobile-nav > li > a:hover {
	color: var(--ess-color-primary);
	background: var(--ess-color-primary-light);
}

/* Submenu toggle button */
.ess-submenu-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border: none;
	background: none;
	cursor: pointer;
	color: var(--ess-color-neutral-500);
	position: absolute;
	right: 0;
	top: 0;
	transition: transform var(--ess-transition-fast);
}

.ess-submenu-toggle[aria-expanded="true"] {
	transform: rotate(180deg);
}

.ess-submenu-toggle:focus-visible {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: -2px;
}

.ess-mobile-nav .menu-item-has-children {
	position: relative;
}

/* Mobile submenu */
.ess-mobile-nav .sub-menu {
	list-style: none;
	padding-left: var(--ess-space-4);
	background: var(--ess-color-neutral-50);
}

.ess-mobile-nav .sub-menu a {
	display: block;
	padding: var(--ess-space-2) var(--ess-space-4);
	font-size: var(--ess-text-sm);
	color: var(--ess-color-neutral-600);
	text-decoration: none;
	min-height: 44px;
	line-height: 2;
}

.ess-mobile-nav .sub-menu a:hover {
	color: var(--ess-color-primary);
}

/* Mobile menu actions */
.ess-mobile-menu__actions {
	padding: var(--ess-space-4);
	border-top: 1px solid var(--ess-color-border);
}

/* Body no scroll when menu is open */
.ess-no-scroll {
	overflow: hidden;
}

/* ==========================================================================
   FOOTER
   ========================================================================== */

/* (Pre-footer trust badges — rimosso dal footer, ora gestito da ess_render_trust_bar() in homepage) */

/* ==========================================================================
   FOOTER
   ========================================================================== */

.ess-footer {
	background: var(--ess-sea-dark);
	color: #d8e1ed;
	margin-top: auto;
	font-family: var(--ess-font-body);
	font-size: 12px;
	line-height: 1.55;
}

.ess-footer a {
	color: #d8e1ed;
	text-decoration: none;
	opacity: 0.7;
	transition: opacity var(--ess-transition-fast), color var(--ess-transition-fast);
}

.ess-footer a:hover,
.ess-footer a:focus-visible {
	opacity: 1;
	color: var(--ess-orange);
}
.ess-footer a:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: 2px;
}

.ess-footer__widgets {
	padding: 40px 0 28px;
}

/* 5 colonne: Brand (1.4fr) + 4 link columns (1fr each) */
.ess-footer__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--ess-space-8);
	padding-bottom: 28px;
	border-bottom: 1px solid #2a3a52;
}

@media (min-width: 640px) {
	.ess-footer__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 1024px) {
	.ess-footer__grid { grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr; }
}

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

/* Brand column */
.ess-footer__col--brand {
	padding-right: 0;
}

.ess-footer__logo {
	display: inline-block;
	margin-bottom: 14px;
	/* No background: il logo SVG "on-mare" è progettato per fondi scuri. */
}
.ess-footer__logo img {
	display: block;
	max-height: 40px;
	width: auto;
}
.ess-footer__logo a { display: inline-flex; }

.ess-footer__logo img {
	height: 36px;
	width: auto;
	display: block;
}

/* Logo fallback inverted — kept for legacy */
.ess-footer__logo--inverted { filter: none; }

.ess-footer__site-name {
	font-family: var(--ess-font-serif);
	font-size: var(--ess-text-xl);
	font-weight: 400;
	color: #ffffff;
	letter-spacing: -0.2px;
}

.ess-footer__description {
	font-size: 12px;
	line-height: 1.55;
	color: rgba(216, 225, 237, 0.75);
	margin: 0;
	max-width: 320px;
}

/* Column titles: mono uppercase, no border, compact */
.ess-footer__col-title,
.ess-footer-widget__title {
	color: #ffffff;
	font-family: var(--ess-font-body);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	margin-bottom: 10px;
	padding-bottom: 0;
	border-bottom: none;
	display: block;
}

/* Link lists */
.ess-footer__links,
.ess-footer-widget ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.ess-footer__links li,
.ess-footer-widget li {
	margin-bottom: 6px;
}

.ess-footer__links a,
.ess-footer-widget li a {
	font-size: 12px;
	color: #d8e1ed;
	opacity: 0.65;
	line-height: 1.55;
}
.ess-footer__links a:hover,
.ess-footer-widget li a:hover {
	opacity: 1;
	color: var(--ess-orange);
}

/* Contacts (legacy, kept for mailto/whatsapp if used) */
.ess-footer__contacts {
	list-style: none;
	padding: 0;
	margin: 0;
}
.ess-footer__contacts li { margin-bottom: 6px; }
.ess-footer__contacts a {
	display: inline-flex;
	align-items: center;
	gap: var(--ess-space-2);
	font-size: 12px;
	color: #d8e1ed;
	opacity: 0.65;
}
.ess-footer__contacts a:hover { opacity: 1; color: var(--ess-orange); }

/* Social icons (opzionali) */
.ess-footer__social {
	display: flex;
	gap: var(--ess-space-2);
	margin-top: var(--ess-space-4);
}
.ess-footer__social a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border: 1px solid #2a3a52;
	border-radius: 0;
	background: transparent;
	color: #d8e1ed;
	opacity: 0.7;
	transition: opacity var(--ess-transition-fast), background var(--ess-transition-fast), border-color var(--ess-transition-fast), color var(--ess-transition-fast);
}
.ess-footer__social a:hover {
	opacity: 1;
	background: var(--ess-orange);
	border-color: var(--ess-orange);
	color: #ffffff;
}
.ess-footer__social a:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: 2px;
}

/* Affiliate disclosure — stripe intermedia */
.ess-footer__disclosure {
	border-top: none;
	padding: 14px 0;
	font-family: var(--ess-font-body);
	font-size: 11px;
	color: rgba(216, 225, 237, 0.55);
	line-height: 1.6;
}
.ess-footer__disclosure p {
	margin: 0;
	max-width: 900px;
}

/* Bottom bar mono */
.ess-footer__bottom {
	border-top: none;
	padding: 16px 0 24px;
}
.ess-footer__bottom-inner {
	font-family: var(--ess-font-mono);
	font-size: 10px;
	color: rgba(216, 225, 237, 0.5);
	letter-spacing: 0.3px;
}
.ess-footer__copyright {
	font-family: var(--ess-font-mono);
	font-size: 10px;
	color: rgba(216, 225, 237, 0.5);
	margin: 0;
}
.ess-footer__menu {
	list-style: none;
	display: flex;
	gap: var(--ess-space-4);
	margin: 0;
	padding: 0;
}
.ess-footer__menu a {
	font-family: var(--ess-font-mono);
	font-size: 10px;
	color: rgba(216, 225, 237, 0.5);
	letter-spacing: 0.3px;
	text-transform: uppercase;
}
.ess-footer__menu a:hover { color: var(--ess-orange); opacity: 1; }

/* ==========================================================================
   ENTRY CONTENT (post/page body)
   ========================================================================== */

.ess-entry__content p,
.ess-entry__content ul,
.ess-entry__content ol {
	margin-bottom: var(--ess-space-4);
	line-height: var(--ess-leading-normal);
}

.ess-entry__content ul,
.ess-entry__content ol {
	padding-left: var(--ess-space-6);
}

.ess-entry__content ul {
	list-style: disc;
}

.ess-entry__content ol {
	list-style: decimal;
}

.ess-entry__content h2 {
	margin-top: var(--ess-space-8);
	margin-bottom: var(--ess-space-4);
}

.ess-entry__content h3 {
	margin-top: var(--ess-space-6);
	margin-bottom: var(--ess-space-3);
}

.ess-entry__content img {
	border-radius: var(--ess-radius-md);
}

.ess-entry__content blockquote {
	border-left: 4px solid var(--ess-color-primary);
	padding: var(--ess-space-4) var(--ess-space-6);
	margin: var(--ess-space-6) 0;
	background: var(--ess-color-primary-light);
	border-radius: 0 var(--ess-radius-md) var(--ess-radius-md) 0;
}

/* Pagination */
.navigation.pagination {
	margin-top: var(--ess-space-8);
}

.navigation.pagination .nav-links {
	display: flex;
	gap: var(--ess-space-2);
	justify-content: center;
	flex-wrap: wrap;
}

.navigation.pagination .page-numbers {
	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);
	transition: all var(--ess-transition-fast);
}

.navigation.pagination .page-numbers:hover {
	border-color: var(--ess-color-primary);
	color: var(--ess-color-primary);
}

.navigation.pagination .page-numbers.current {
	background: var(--ess-color-primary);
	color: var(--ess-color-white);
	border-color: var(--ess-color-primary);
}

/* ==========================================================================
   TOP UTILITY BAR — ink warm (brand-guidelines v3), informativa sopra header
   ========================================================================== */

.ess-topbar {
	background: var(--ess-ink);
	color: #e9e2d0;
	font-family: var(--ess-font-body);
	font-size: var(--ess-text-xs);
	letter-spacing: 0.3px;
	padding: var(--ess-space-2) 0;
}

.ess-topbar a {
	color: #e9e2d0;
	text-decoration: none;
	opacity: 0.85;
	transition: opacity var(--ess-transition-fast);
}

.ess-topbar a:hover,
.ess-topbar a:focus-visible {
	opacity: 1;
	color: #ffffff;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.ess-topbar__inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--ess-space-2) var(--ess-space-4);
}

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

.ess-topbar__right {
	display: flex;
	align-items: center;
	gap: var(--ess-space-4);
	opacity: 0.95;
}

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

.ess-topbar__sep {
	opacity: 0.35;
}

.ess-topbar__item svg {
	width: 14px;
	height: 14px;
	flex-shrink: 0;
}

/* ==========================================================================
   HOMEPAGE — Promo Banners (grid promozionale stile Dafré)
   ========================================================================== */

.ess-promo {
	padding: var(--ess-space-4) 0 var(--ess-space-6);
}

@media (min-width: 768px) {
	.ess-promo {
		padding: var(--ess-space-6) 0 var(--ess-space-8);
	}
}

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

@media (min-width: 768px) {
	.ess-promo__grid {
		grid-template-columns: 3fr 2fr;
		gap: var(--ess-space-4);
	}

	.ess-promo__grid--single {
		grid-template-columns: 1fr;
	}
}

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

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

.ess-promo__banner {
	display: block;
	position: relative;
	border-radius: var(--ess-radius-lg);
	overflow: hidden;
	text-decoration: none;
	color: var(--ess-color-white);
	min-height: 180px;
}

.ess-promo__banner--main {
	min-height: 280px;
}

@media (min-width: 768px) {
	.ess-promo__banner--main {
		min-height: 100%;
	}

	.ess-promo__banner--secondary {
		min-height: 0;
	}
}

.ess-promo__banner:focus-visible {
	outline: 3px solid var(--ess-color-focus-ring);
	outline-offset: 2px;
}

.ess-promo__image {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease;
}

.ess-promo__banner:hover .ess-promo__image {
	transform: scale(1.04);
}

.ess-promo__overlay {
	position: relative;
	z-index: 1;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: flex-end;
	padding: var(--ess-space-6);
	min-height: inherit;
	background: linear-gradient(to top, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0.15) 50%, transparent 100%);
}

.ess-promo__title {
	font-size: clamp(1.1rem, 2vw, 1.5rem);
	font-weight: var(--ess-weight-bold);
	margin: 0 0 var(--ess-space-1);
	color: var(--ess-color-white);
	line-height: 1.2;
}

.ess-promo__banner--secondary .ess-promo__title {
	font-size: clamp(0.9rem, 1.4vw, 1.15rem);
}

.ess-promo__subtitle {
	font-size: var(--ess-text-sm);
	opacity: 0.9;
	margin: 0 0 var(--ess-space-3);
	line-height: 1.4;
}

.ess-promo__banner--secondary .ess-promo__subtitle {
	display: none;
}

@media (min-width: 768px) {
	.ess-promo__banner--secondary .ess-promo__subtitle {
		display: block;
	}
}

/* ==========================================================================
   HOMEPAGE — Category Chips (navigazione rapida)
   ========================================================================== */

.ess-category-chips {
	padding: var(--ess-space-6) 0;
	border-bottom: 1px solid var(--ess-color-border);
}

.ess-category-chips__scroll {
	display: flex;
	gap: var(--ess-space-4);
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	padding-bottom: var(--ess-space-2);
	scrollbar-width: none;
}

.ess-category-chips__scroll::-webkit-scrollbar {
	display: none;
}

@media (min-width: 1024px) {
	.ess-category-chips__scroll {
		justify-content: center;
		overflow-x: visible;
		flex-wrap: wrap;
	}
}

.ess-category-chip {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--ess-space-2);
	text-decoration: none;
	color: var(--ess-color-text);
	min-width: 80px;
	scroll-snap-align: start;
	transition: color var(--ess-transition-fast);
	padding: var(--ess-space-1);
}

.ess-category-chip:hover {
	color: var(--ess-color-primary);
}

.ess-category-chip:focus-visible {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: 2px;
	border-radius: var(--ess-radius-md);
}

.ess-category-chip__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	border-radius: var(--ess-radius-full);
	background: var(--ess-color-bg-sec);
	border: 2px solid var(--ess-color-border);
	color: var(--ess-color-primary);
	transition: all var(--ess-transition-fast);
}

.ess-category-chip:hover .ess-category-chip__icon {
	background: var(--ess-color-blue-pale);
	border-color: var(--ess-color-primary);
}

.ess-category-chip__label {
	font-size: var(--ess-text-xs);
	font-weight: var(--ess-weight-medium);
	text-align: center;
	white-space: nowrap;
}

/* ==========================================================================
   HOMEPAGE — Featured Row (banner laterale + product grid)
   ========================================================================== */

.ess-featured-row {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--ess-space-4);
}

@media (min-width: 768px) {
	.ess-featured-row {
		grid-template-columns: 1fr 3fr;
		gap: var(--ess-space-6);
	}
}

.ess-featured-row__banner {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: var(--ess-space-8) var(--ess-space-6);
	border-radius: var(--ess-radius-lg);
	color: var(--ess-color-white);
}

.ess-featured-row__banner--primary {
	background: linear-gradient(135deg, var(--ess-color-blue) 0%, #2A4F7F 100%);
}

.ess-featured-row__banner--accent {
	background: linear-gradient(135deg, var(--ess-color-accent) 0%, #C86620 100%);
}

.ess-featured-row__banner-title {
	font-size: clamp(1.15rem, 1.8vw, 1.5rem);
	font-weight: var(--ess-weight-bold);
	margin: 0 0 var(--ess-space-3);
	color: var(--ess-color-white);
	line-height: 1.25;
}

.ess-featured-row__banner-desc {
	font-size: var(--ess-text-sm);
	opacity: 0.9;
	margin: 0 0 var(--ess-space-6);
	line-height: 1.6;
}

.ess-featured-row__banner .ess-btn {
	align-self: flex-start;
}

.ess-featured-row__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--ess-space-4);
}

@media (min-width: 1024px) {
	.ess-featured-row__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* --------------------------------------------------------------------------
   HOMEPAGE — Ad Banner Slots (stacked in featured row left column)
   -------------------------------------------------------------------------- */

.ess-featured-row__ads {
	display: flex;
	flex-direction: column;
	gap: var(--ess-space-3);
	height: 100%;
}

.ess-ad-slot {
	display: block;
	flex: 1;
	border-radius: var(--ess-radius-lg);
	overflow: hidden;
	transition: transform var(--ess-transition-fast), box-shadow var(--ess-transition-fast);
}

.ess-ad-slot:hover {
	transform: translateY(-2px);
	box-shadow: var(--ess-shadow-md);
}

.ess-ad-slot:focus-visible {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: 2px;
}

.ess-ad-slot__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: var(--ess-radius-lg);
}

@media (max-width: 767px) {
	.ess-featured-row__ads {
		flex-direction: row;
	}
}

/* ==========================================================================
   HOMEPAGE — Product Grid (standard, non-scroll)
   ========================================================================== */

.ess-product-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--ess-space-4);
}

@media (min-width: 640px) {
	.ess-product-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.ess-product-grid--6 {
	/* Override for 6 cols on large screens */
}

@media (min-width: 1024px) {
	.ess-product-grid--6 {
		grid-template-columns: repeat(6, 1fr);
	}
}

/* ==========================================================================
   HOMEPAGE — Brand Scroll (vendor logos orizzontali)
   ========================================================================== */

.ess-brand-scroll {
	display: flex;
	gap: var(--ess-space-6);
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	padding-bottom: var(--ess-space-2);
	scrollbar-width: thin;
	scrollbar-color: var(--ess-color-neutral-300) transparent;
}

.ess-brand-scroll::-webkit-scrollbar {
	height: 4px;
}

.ess-brand-scroll::-webkit-scrollbar-thumb {
	background: var(--ess-color-neutral-300);
	border-radius: 2px;
}

@media (min-width: 1024px) {
	.ess-brand-scroll {
		justify-content: center;
		flex-wrap: wrap;
		overflow-x: visible;
	}
}

.ess-brand-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--ess-space-2);
	text-decoration: none;
	color: var(--ess-color-text);
	min-width: 100px;
	scroll-snap-align: start;
	padding: var(--ess-space-2);
	transition: all var(--ess-transition-fast);
}

.ess-brand-item:hover {
	color: var(--ess-color-primary);
}

.ess-brand-item:focus-visible {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: 2px;
	border-radius: var(--ess-radius-md);
}

.ess-brand-item__logo {
	width: 80px;
	height: 80px;
	border-radius: var(--ess-radius-full);
	object-fit: cover;
	border: 2px solid var(--ess-color-border);
	background: var(--ess-color-white);
	transition: border-color var(--ess-transition-fast), box-shadow var(--ess-transition-fast);
}

.ess-brand-item:hover .ess-brand-item__logo {
	border-color: var(--ess-color-primary);
	box-shadow: var(--ess-shadow-md);
}

.ess-brand-item__name {
	font-size: var(--ess-text-xs);
	font-weight: var(--ess-weight-medium);
	text-align: center;
	white-space: nowrap;
	max-width: 100px;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* ==========================================================================
   HOMEPAGE — Trust Bar (pre-footer badges stile Dafré)
   ========================================================================== */

.ess-trust-bar {
	background: var(--ess-color-bg-sec);
	padding: var(--ess-space-8) 0;
	border-top: 1px solid var(--ess-color-border);
	border-bottom: 1px solid var(--ess-color-border);
}

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

@media (min-width: 640px) {
	.ess-trust-bar__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.ess-trust-bar__grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

.ess-trust-bar__item {
	display: flex;
	align-items: flex-start;
	gap: var(--ess-space-3);
}

.ess-trust-bar__icon {
	flex-shrink: 0;
	color: var(--ess-color-primary);
}

.ess-trust-bar__text {
	flex: 1;
	min-width: 0;
}

.ess-trust-bar__title {
	display: block;
	font-size: var(--ess-text-sm);
	font-weight: var(--ess-weight-semibold);
	color: var(--ess-color-heading);
	margin-bottom: var(--ess-space-1);
}

.ess-trust-bar__desc {
	display: block;
	font-size: var(--ess-text-xs);
	color: var(--ess-color-text-sec);
	line-height: 1.5;
}

/* ==========================================================================
   HOMEPAGE — CTA Compact (singola riga, pre-footer)
   ========================================================================== */

.ess-cta-compact {
	background: linear-gradient(135deg, var(--ess-color-blue) 0%, #0f2a42 100%);
	color: var(--ess-color-white);
	padding: var(--ess-space-8) 0;
}

.ess-cta-compact__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--ess-space-4);
	text-align: center;
}

@media (min-width: 768px) {
	.ess-cta-compact__inner {
		flex-direction: row;
		justify-content: space-between;
		text-align: left;
	}
}

.ess-cta-compact__title {
	font-size: clamp(1.1rem, 1.5vw, 1.35rem);
	font-weight: var(--ess-weight-bold);
	color: var(--ess-color-white);
	margin: 0;
}

.ess-cta-compact__desc {
	font-size: var(--ess-text-sm);
	opacity: 0.85;
	margin: var(--ess-space-1) 0 0;
}

.ess-cta-compact .ess-btn--accent {
	white-space: nowrap;
	flex-shrink: 0;
}

/* ==========================================================================
   HOMEPAGE — Sections (generic)
   ========================================================================== */

.ess-section {
	padding: var(--ess-space-10) 0;
}

@media (min-width: 768px) {
	.ess-section {
		padding: var(--ess-space-16) 0;
	}
}

.ess-section--gray {
	background: var(--ess-color-bg-sec);
}

.ess-section__header {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: var(--ess-space-4);
	margin-bottom: var(--ess-space-8);
	flex-wrap: wrap;
}

.ess-section__title {
	font-size: clamp(1.25rem, 1.1rem + 1vw, 1.75rem);
	margin: 0;
	color: var(--ess-color-heading);
}

.ess-section__header-center {
	text-align: center;
	margin-bottom: var(--ess-space-10);
}

.ess-section__header-center .ess-section__title::after {
	content: "";
	display: block;
	width: 40px;
	height: 3px;
	background: var(--ess-color-accent);
	border-radius: 2px;
	margin: var(--ess-space-3) auto 0;
}

.ess-section__subtitle {
	font-size: var(--ess-text-base);
	color: var(--ess-color-text-sec);
	margin-top: var(--ess-space-3);
	max-width: 480px;
	margin-inline: auto;
	line-height: 1.6;
}

/* ==========================================================================
   HOMEPAGE — Scroll Row (horizontal scrollable product/vendor row)
   ========================================================================== */

.ess-scroll-row-wrapper {
	position: relative;
}

.ess-scroll-row {
	display: flex;
	gap: var(--ess-grid-gap);
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	padding-bottom: var(--ess-space-4);
	scrollbar-width: thin;
	scrollbar-color: var(--ess-color-neutral-300) transparent;
}

.ess-scroll-row::-webkit-scrollbar {
	height: 6px;
}

.ess-scroll-row::-webkit-scrollbar-track {
	background: transparent;
}

.ess-scroll-row::-webkit-scrollbar-thumb {
	background: var(--ess-color-neutral-300);
	border-radius: 3px;
}

/* Scroll row navigation arrows */
.ess-scroll-btn {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 2;
	display: none;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border: 1px solid var(--ess-color-border);
	border-radius: var(--ess-radius-full);
	background: var(--ess-color-white);
	color: var(--ess-color-neutral-700);
	cursor: pointer;
	box-shadow: var(--ess-shadow-md);
	transition: all var(--ess-transition-fast);
}

@media (min-width: 768px) {
	.ess-scroll-btn {
		display: inline-flex;
	}
}

.ess-scroll-btn:hover {
	background: var(--ess-color-primary);
	color: var(--ess-color-white);
	border-color: var(--ess-color-primary);
}

.ess-scroll-btn:focus-visible {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: 2px;
}

.ess-scroll-btn--prev {
	left: -20px;
}

.ess-scroll-btn--next {
	right: -20px;
}

.ess-scroll-btn[disabled] {
	opacity: 0.3;
	cursor: default;
	pointer-events: none;
}

.ess-scroll-row__item {
	flex: 0 0 240px;
	scroll-snap-align: start;
}

.ess-scroll-row__item--vendor {
	flex: 0 0 200px;
}

@media (min-width: 768px) {
	.ess-scroll-row__item {
		flex: 0 0 260px;
	}
}

/* ==========================================================================
   HOMEPAGE — Category Grid (overlay style)
   ========================================================================== */

.ess-category-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--ess-space-3);
}

@media (min-width: 640px) {
	.ess-category-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 768px) {
	.ess-category-grid {
		grid-template-columns: repeat(4, 1fr);
		gap: var(--ess-space-4);
	}
}

@media (min-width: 1024px) {
	.ess-category-grid {
		grid-template-columns: repeat(5, 1fr);
	}
}

.ess-category-card {
	display: block;
	position: relative;
	text-decoration: none;
	border-radius: var(--ess-radius-lg);
	overflow: hidden;
	aspect-ratio: 4 / 3;
}

.ess-category-card:focus-visible {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: 2px;
}

.ess-category-card__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}

.ess-category-card:hover .ess-category-card__image {
	transform: scale(1.08);
}

/* Dark gradient overlay for text readability */
.ess-category-card::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0, 0, 0, 0.65) 0%, rgba(0, 0, 0, 0.1) 60%, transparent 100%);
	border-radius: var(--ess-radius-lg);
	transition: background var(--ess-transition-fast);
}

.ess-category-card:hover::after {
	background: linear-gradient(to top, rgba(0, 0, 0, 0.75) 0%, rgba(0, 0, 0, 0.2) 60%, transparent 100%);
}

.ess-category-card__name {
	position: absolute;
	bottom: var(--ess-space-4);
	left: 0;
	right: 0;
	padding: 0 var(--ess-space-3);
	font-size: var(--ess-text-sm);
	font-weight: var(--ess-weight-semibold);
	color: var(--ess-color-white);
	text-align: center;
	z-index: 1;
	line-height: 1.3;
}

.ess-category-card__count {
	position: absolute;
	bottom: var(--ess-space-1);
	left: 0;
	right: 0;
	padding: 0 var(--ess-space-3);
	font-size: var(--ess-text-xs);
	color: rgba(255, 255, 255, 0.8);
	text-align: center;
	z-index: 1;
}

/* (Feature Card "Come Funziona" — RIMOSSA)
   (Vendor Grid — sostituita da Brand Scroll, vedi sopra)
   (CTA Banner — sostituita da CTA Compact, vedi sopra) */

/* ==========================================================================
   LANDING PAGES — Hero with background image
   ========================================================================== */

.ess-landing-hero {
	position: relative;
	min-height: 300px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-size: cover;
	background-position: center;
	color: var(--ess-color-white);
	padding: var(--ess-space-16) 0;
}

@media (min-width: 768px) {
	.ess-landing-hero {
		min-height: 400px;
	}
}

.ess-landing-hero__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.5);
}

.ess-landing-hero__content {
	position: relative;
	z-index: 1;
	text-align: center;
}

.ess-landing-hero__logo {
	max-width: 200px;
	height: auto;
	margin-inline: auto;
	margin-bottom: var(--ess-space-6);
}

.ess-landing-hero__title {
	color: var(--ess-color-white);
	font-size: var(--ess-text-3xl);
	max-width: 700px;
	margin-inline: auto;
}

@media (min-width: 768px) {
	.ess-landing-hero__title {
		font-size: var(--ess-text-4xl);
	}
}

/* ==========================================================================
   LANDING PAGES — Header (no background image)
   ========================================================================== */

.ess-landing-header {
	padding: var(--ess-space-12) 0 var(--ess-space-8);
	background: var(--ess-color-primary-light);
}

.ess-landing-header__logo {
	max-width: 200px;
	height: auto;
	margin-inline: auto;
	margin-bottom: var(--ess-space-6);
}

.ess-landing-header__title {
	font-size: var(--ess-text-3xl);
	max-width: 700px;
	margin-inline: auto;
	margin-bottom: var(--ess-space-4);
}

@media (min-width: 768px) {
	.ess-landing-header__title {
		font-size: var(--ess-text-4xl);
	}
}

/* ==========================================================================
   PRICING CARDS
   ========================================================================== */

.ess-pricing-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--ess-grid-gap);
	max-width: 960px;
	margin-inline: auto;
}

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

.ess-pricing-card {
	position: relative;
	background: var(--ess-color-card-bg);
	border: 0;
	border-radius: var(--ess-radius-lg);
	padding: var(--ess-space-6);
	text-align: center;
	box-shadow: var(--ess-shadow);
	transition: box-shadow var(--ess-transition-fast), transform var(--ess-transition-fast);
}

.ess-pricing-card:hover {
	box-shadow: var(--ess-shadow-lg);
	transform: translateY(-2px);
}

.ess-pricing-card--featured {
	border-color: var(--ess-color-primary);
	box-shadow: var(--ess-shadow-md);
}

.ess-pricing-card__badge {
	position: absolute;
	top: -12px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--ess-color-accent);
	color: var(--ess-color-white);
	font-size: var(--ess-text-xs);
	font-weight: var(--ess-weight-bold);
	padding: var(--ess-space-1) var(--ess-space-4);
	border-radius: var(--ess-radius-full);
	white-space: nowrap;
}

.ess-pricing-card__header {
	padding-bottom: var(--ess-space-4);
	margin-bottom: var(--ess-space-4);
	border-bottom: 1px solid var(--ess-color-border);
}

.ess-pricing-card__name {
	font-size: var(--ess-text-lg);
	font-weight: var(--ess-weight-bold);
	margin-bottom: var(--ess-space-1);
}

.ess-pricing-card__subtitle {
	font-size: var(--ess-text-sm);
	color: var(--ess-color-neutral-500);
}

.ess-pricing-card__price {
	padding: var(--ess-space-4) 0;
	display: flex;
	align-items: baseline;
	justify-content: center;
	gap: var(--ess-space-1);
}

.ess-pricing-card__currency {
	font-size: var(--ess-text-xl);
	font-weight: var(--ess-weight-bold);
	color: var(--ess-color-heading);
}

.ess-pricing-card__amount {
	font-size: var(--ess-text-5xl);
	font-weight: var(--ess-weight-bold);
	color: var(--ess-color-heading);
	line-height: 1;
}

.ess-pricing-card__period {
	font-size: var(--ess-text-sm);
	color: var(--ess-color-neutral-500);
}

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

/* ==========================================================================
   CONTACT FORM WRAP
   ========================================================================== */

.ess-contact-form-wrap {
	max-width: 640px;
	margin-inline: auto;
}

.ess-contact-form-wrap .wpcf7-form-control-wrap {
	display: block;
	margin-bottom: var(--ess-space-4);
}

.ess-contact-form-wrap input[type="text"],
.ess-contact-form-wrap input[type="email"],
.ess-contact-form-wrap input[type="tel"],
.ess-contact-form-wrap textarea {
	width: 100%;
	padding: var(--ess-space-3) var(--ess-space-4);
	font-size: var(--ess-text-base);
	border: 1px solid var(--ess-color-input-border);
	border-radius: var(--ess-radius-md);
	background: var(--ess-color-input-bg);
	min-height: 44px;
}

.ess-contact-form-wrap input:focus,
.ess-contact-form-wrap textarea:focus {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: 1px;
	border-color: var(--ess-color-primary);
}

.ess-contact-form-wrap .wpcf7-submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: var(--ess-space-3) var(--ess-space-8);
	background: var(--ess-color-primary);
	color: var(--ess-color-white);
	border: none;
	border-radius: var(--ess-radius-md);
	font-weight: var(--ess-weight-semibold);
	cursor: pointer;
	min-height: 44px;
	transition: background var(--ess-transition-fast);
}

.ess-contact-form-wrap .wpcf7-submit:hover {
	background: var(--ess-color-primary-hover);
}

/* ==========================================================================
   CONTACT INFO CARDS (Contatti page)
   ========================================================================== */

.ess-contact-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--ess-grid-gap);
	max-width: 640px;
	margin-inline: auto;
}

@media (min-width: 640px) {
	.ess-contact-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

.ess-contact-info-card {
	background: var(--ess-color-card-bg);
	border: 0;
	border-radius: var(--ess-radius-lg);
	padding: var(--ess-space-8);
	text-align: center;
	box-shadow: var(--ess-shadow);
}

.ess-contact-info-card__icon {
	width: 60px;
	height: 60px;
	margin-inline: auto;
	margin-bottom: var(--ess-space-4);
}

.ess-contact-info-card__title {
	font-size: var(--ess-text-lg);
	margin-bottom: var(--ess-space-2);
}

.ess-contact-info-card__link {
	color: var(--ess-color-primary);
	text-decoration: none;
	font-weight: var(--ess-weight-medium);
}

.ess-contact-info-card__link:hover {
	text-decoration: underline;
}

/* ==========================================================================
   CHECKLIST (Piani e Tariffe)
   ========================================================================== */

.ess-checklist {
	list-style: none;
	max-width: 480px;
	margin-inline: auto;
	text-align: left;
}

.ess-checklist li {
	position: relative;
	padding-left: var(--ess-space-6);
	margin-bottom: var(--ess-space-3);
	font-size: var(--ess-text-base);
}

.ess-checklist li::before {
	content: "\2713";
	position: absolute;
	left: 0;
	color: var(--ess-color-success);
	font-weight: var(--ess-weight-bold);
}

/* ==========================================================================
   PRODUCT CARD — LIST VIEW
   ========================================================================== */

/* Mobile-first: 2-column layout (image + body), aside spans full width */
.ess-product-card-list {
	display: grid;
	grid-template-columns: 100px 1fr;
	gap: var(--ess-space-3);
	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);
	padding: var(--ess-space-3);
	align-items: start;
}

.ess-product-card-list:hover {
	box-shadow: var(--ess-shadow-lg);
}

.ess-product-card-list__image {
	position: relative;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	border-radius: var(--ess-radius-md);
}

.ess-product-card-list__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ess-product-card-list__body {
	display: flex;
	flex-direction: column;
	gap: var(--ess-space-2);
}

.ess-product-card-list__excerpt {
	font-size: var(--ess-text-sm);
	color: var(--ess-color-neutral-600);
	line-height: var(--ess-leading-normal);
}

.ess-product-card-list__aside {
	grid-column: 1 / -1;
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: space-between;
	gap: var(--ess-space-3);
}

/* Desktop: 3-column layout with aside on the right */
@media (min-width: 768px) {
	.ess-product-card-list {
		grid-template-columns: 180px 1fr auto;
		gap: var(--ess-space-4);
		padding: var(--ess-space-4);
	}

	.ess-product-card-list__aside {
		grid-column: auto;
		flex-direction: column;
		align-items: flex-end;
		min-width: 140px;
	}
}

/* ==========================================================================
   PRODUCT CARD — COMPACT (sidebar widget)
   ========================================================================== */

.ess-product-compact {
	margin-bottom: var(--ess-space-3);
}

.ess-product-compact__link {
	display: flex;
	gap: var(--ess-space-3);
	text-decoration: none;
	color: inherit;
	align-items: center;
}

.ess-product-compact__link:hover .ess-product-compact__title {
	color: var(--ess-color-primary);
}

.ess-product-compact__image {
	width: 56px;
	height: 56px;
	flex-shrink: 0;
	border-radius: var(--ess-radius-md);
	overflow: hidden;
}

.ess-product-compact__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ess-product-compact__info {
	display: flex;
	flex-direction: column;
	gap: var(--ess-space-1);
	min-width: 0;
}

.ess-product-compact__title {
	font-size: var(--ess-text-sm);
	font-weight: var(--ess-weight-medium);
	color: var(--ess-color-heading);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	transition: color var(--ess-transition-fast);
}

.ess-product-compact__price {
	font-size: var(--ess-text-sm);
	font-weight: var(--ess-weight-bold);
	color: var(--ess-color-accent);
}

/* ==========================================================================
   COMMENTS
   ========================================================================== */

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

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

.ess-comments__list {
	list-style: none;
}

.ess-comments__list .comment {
	padding: var(--ess-space-4) 0;
	border-bottom: 1px solid var(--ess-color-border);
}

.ess-comments__list .comment-author img {
	border-radius: var(--ess-radius-full);
	margin-right: var(--ess-space-3);
	vertical-align: middle;
}

.ess-comments__list .comment-meta {
	font-size: var(--ess-text-sm);
	color: var(--ess-color-neutral-500);
	margin-bottom: var(--ess-space-2);
}

.ess-comments__reply-title {
	font-size: var(--ess-text-xl);
	margin-top: var(--ess-space-8);
	margin-bottom: var(--ess-space-4);
}

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

.ess-comment-form input[type="text"],
.ess-comment-form input[type="email"],
.ess-comment-form input[type="url"],
.ess-comment-form textarea {
	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;
	margin-bottom: var(--ess-space-4);
}

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

.ess-comments__closed {
	margin-top: var(--ess-space-4);
}

/* ==========================================================================
   HOMEPAGE — Editorial sections (hero, ticker, cats grid, stores, offers, seller band)
   ========================================================================== */

/* --- Main wrapper (site-content) — zero padding, sezioni gestiscono il loro spacing --- */
.ess-main { display: block; }

/* --- Tone-colored placeholder (stripes fallback) --- */
.ess-placeholder {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--ess-font-mono);
	font-size: 10px;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	text-align: center;
	padding: 12px;
	overflow: hidden;
}
.ess-placeholder__label {
	position: relative;
	z-index: 1;
	max-width: 80%;
	line-height: 1.35;
}
/* Placeholder tones — palette v3: sea / terra / limone / ulivo */
.ess-placeholder--sea {
	background-image:
		repeating-linear-gradient(135deg, rgba(14, 77, 100, 0.13) 0 10px, rgba(14, 77, 100, 0.04) 10px 20px),
		linear-gradient(180deg, rgba(14, 77, 100, 0.16), rgba(14, 77, 100, 0.06));
	color: var(--ess-sea);
}
.ess-placeholder--terra {
	background-image:
		repeating-linear-gradient(135deg, rgba(197, 85, 45, 0.13) 0 10px, rgba(197, 85, 45, 0.04) 10px 20px),
		linear-gradient(180deg, rgba(197, 85, 45, 0.16), rgba(197, 85, 45, 0.06));
	color: var(--ess-terra);
}
.ess-placeholder--lemon {
	background-image:
		repeating-linear-gradient(135deg, rgba(232, 195, 65, 0.14) 0 10px, rgba(232, 195, 65, 0.04) 10px 20px),
		linear-gradient(180deg, rgba(232, 195, 65, 0.18), rgba(232, 195, 65, 0.06));
	color: #9a7a1a;
}
.ess-placeholder--olive {
	background-image:
		repeating-linear-gradient(135deg, rgba(107, 122, 58, 0.13) 0 10px, rgba(107, 122, 58, 0.04) 10px 20px),
		linear-gradient(180deg, rgba(107, 122, 58, 0.16), rgba(107, 122, 58, 0.06));
	color: var(--ess-ulivo);
}

/* --- Section header — eyebrow + H2 + optional CTA a destra --- */
.ess-section__header {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: var(--ess-space-4);
	margin-bottom: 28px;
	flex-wrap: wrap;
}
.ess-section__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(2rem, 1.5rem + 2vw, 2.5rem);
	line-height: 1;
	letter-spacing: var(--ess-tracking-tight-sm);
	color: var(--ess-navy);
	margin: 0;
	font-weight: 400;
}

/* ==========================================================================
   1. HERO SPLIT — 1.1fr / 1fr
   ========================================================================== */

.ess-hero-split {
	display: grid;
	grid-template-columns: 1fr;
	border-bottom: 1px solid var(--ess-line);
}
@media (min-width: 1024px) {
	.ess-hero-split { grid-template-columns: 1.1fr 1fr; }
}

.ess-hero-split__left {
	padding: 40px 24px;
	background: #ffffff;
	border-bottom: 1px solid var(--ess-line);
}
@media (min-width: 1024px) {
	.ess-hero-split__left {
		padding: 56px 48px 48px;
		border-right: 1px solid var(--ess-line);
		border-bottom: none;
	}
}

.ess-hero-split__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(2.5rem, 1.5rem + 4vw, 4rem);
	line-height: 1.02;
	letter-spacing: var(--ess-tracking-tight);
	color: var(--ess-navy);
	margin: 0 0 18px;
	font-weight: 400;
}

.ess-hero-split__lead {
	font-size: var(--ess-text-md);
	line-height: 1.55;
	color: var(--ess-navy-soft);
	max-width: 460px;
	margin: 0 0 28px;
}

.ess-hero-split__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-bottom: 40px;
}

/* Stats row — 4 metriche */
.ess-hero-split__stats {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--ess-space-6);
	margin: 0;
}
@media (min-width: 768px) {
	.ess-hero-split__stats {
		grid-template-columns: repeat(4, auto);
		gap: 32px;
		justify-content: start;
	}
}

.ess-hero-split__stat { margin: 0; }
.ess-hero-split__stat-n {
	font-family: var(--ess-font-serif);
	font-size: var(--ess-text-3xl);
	color: var(--ess-sea);
	line-height: 1;
	margin: 0;
	font-weight: 400;
}
.ess-hero-split__stat-l {
	font-family: var(--ess-font-body);
	font-size: 10px;
	color: var(--ess-muted);
	letter-spacing: 0.8px;
	text-transform: uppercase;
	margin: 4px 0 0;
}

/* Right panel — sea navy con showcase prodotto */
.ess-hero-split__right {
	padding: 40px 24px;
	background: var(--ess-sea);
	color: #ffffff;
	position: relative;
	overflow: hidden;
	text-decoration: none;
	display: block;
	transition: background var(--ess-transition-fast);
}
@media (min-width: 1024px) {
	.ess-hero-split__right { padding: 48px 48px 40px; }
}
a.ess-hero-split__right:hover { background: #0a3f54; color: #ffffff; }

.ess-hero-split__circle {
	position: absolute;
	top: -40px;
	right: -40px;
	width: 300px;
	height: 300px;
	border-radius: 50%;
	background: var(--ess-limone);
	opacity: 0.18;
	pointer-events: none;
}

.ess-hero-split__right .ess-eyebrow { position: relative; z-index: 1; margin-bottom: 16px; }

.ess-hero-split__showcase-media {
	height: 220px;
	margin-bottom: 18px;
	border: 1px solid rgba(232, 195, 65, 0.35); /* limone alpha */
	position: relative;
	overflow: hidden;
	background: rgba(255, 255, 255, 0.03);
	z-index: 1;
}
.ess-hero-split__showcase-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.ess-hero-split__showcase-title {
	font-family: var(--ess-font-serif);
	font-size: clamp(1.5rem, 1.2rem + 1.2vw, 1.875rem);
	line-height: 1.1;
	margin: 0 0 6px;
	color: #ffffff;
	font-weight: 400;
	letter-spacing: -0.4px;
	position: relative;
	z-index: 1;
}
.ess-hero-split__showcase-meta {
	font-size: var(--ess-text-sm);
	opacity: 0.8;
	margin: 0 0 14px;
	position: relative;
	z-index: 1;
}
.ess-hero-split__showcase-price {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 10px;
	position: relative;
	z-index: 1;
}
.ess-hero-split__price {
	font-family: var(--ess-font-serif);
	font-size: 1.75rem;
	font-weight: 400;
	letter-spacing: -0.3px;
}
.ess-hero-split__price-old {
	font-size: var(--ess-text-xs);
	opacity: 0.6;
	text-decoration: line-through;
}
.ess-hero-split__showcase-badge {
	/* Brand-guidelines v3 — regola del trinomio Terra: sul Mare profondo
	 * l'accento Terra viene sostituito da Limone (`#e8c341`) per contrasto. */
	margin-left: auto;
	font-family: var(--ess-font-mono);
	font-size: var(--ess-text-xs);
	letter-spacing: 0.5px;
	text-transform: uppercase;
	background: var(--ess-limone);
	color: var(--ess-ink);
	padding: 4px 10px;
	border-radius: 0;
}

/* ==========================================================================
   2. TICKER — marquee limone (palette v3: ink text su fondo limone)
   ========================================================================== */

.ess-ticker {
	background: var(--ess-limone);
	color: var(--ess-ink);
	overflow: hidden;
	padding: 10px 0;
	font-family: var(--ess-font-mono);
	font-size: 11px;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	white-space: nowrap;
	position: relative;
}
.ess-ticker__track {
	display: flex;
	gap: 40px;
	width: max-content;
	animation: ess-marquee 40s linear infinite;
	will-change: transform;
}
.ess-ticker__list {
	display: flex;
	gap: 40px;
	list-style: none;
	margin: 0;
	padding: 0 20px;
}
.ess-ticker__item {
	display: inline-flex;
	align-items: center;
	gap: 10px;
}
.ess-ticker__sigil { opacity: 0.9; }

@keyframes ess-marquee {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
	.ess-ticker__track { animation: none; }
}

/* ==========================================================================
   3. CATEGORIES — grid asimmetrica 4 colonne × 180px auto-row
   ========================================================================== */

.ess-cats-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	grid-auto-rows: 160px;
	gap: 12px;
}
@media (min-width: 768px) {
	.ess-cats-grid {
		grid-template-columns: repeat(4, 1fr);
		grid-auto-rows: 180px;
	}
}

.ess-cats-grid__tile {
	position: relative;
	overflow: hidden;
	border: 1px solid var(--ess-line);
	background: #ffffff;
	text-decoration: none;
	color: #ffffff;
	display: block;
	transition: transform var(--ess-transition-fast), box-shadow var(--ess-transition-fast);
}
.ess-cats-grid__tile:hover,
.ess-cats-grid__tile:focus-visible {
	transform: translateY(-2px);
	box-shadow: var(--ess-shadow-card-hover);
	color: #ffffff;
}
.ess-cats-grid__tile:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: 2px;
}

@media (min-width: 768px) {
	.ess-cats-grid__tile--xl {
		grid-column: span 2;
		grid-row: span 2;
	}
	.ess-cats-grid__tile--wide {
		grid-column: span 2;
		grid-row: span 1;
	}
}

.ess-cats-grid__img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.ess-cats-grid__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 40%, rgba(0, 0, 0, 0.55));
	pointer-events: none;
}

.ess-cats-grid__body {
	position: absolute;
	left: 16px;
	bottom: 14px;
	right: 16px;
	color: #ffffff;
	z-index: 1;
}
.ess-cats-grid__name {
	font-family: var(--ess-font-serif);
	font-size: 1.375rem;
	line-height: 1;
	font-weight: 400;
	letter-spacing: -0.4px;
}
.ess-cats-grid__meta {
	font-family: var(--ess-font-mono);
	font-size: 10px;
	opacity: 0.85;
	margin-top: 4px;
	letter-spacing: 0.3px;
}

/* ==========================================================================
   4. STORES OF THE MONTH — bg surface + grid 4 card
   ========================================================================== */

.ess-stores-band {
	background: var(--ess-surface);
	border-top: 1px solid var(--ess-line);
	border-bottom: 1px solid var(--ess-line);
}

.ess-stores-band__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 20px;
}
@media (min-width: 640px) { .ess-stores-band__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .ess-stores-band__grid { grid-template-columns: repeat(4, 1fr); } }

.ess-store-card {
	background: #ffffff;
	border: 1px solid var(--ess-line);
	text-decoration: none;
	color: inherit;
	display: block;
	transition: transform var(--ess-transition-fast), box-shadow var(--ess-transition-fast);
}
.ess-store-card:hover,
.ess-store-card:focus-visible {
	transform: translateY(-2px);
	box-shadow: var(--ess-shadow-card-hover);
	color: inherit;
}
.ess-store-card:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: 2px;
}

.ess-store-card__cover {
	position: relative;
	height: 140px;
	overflow: hidden;
}
.ess-store-card__cover img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.ess-store-card__badge {
	position: absolute;
	top: 10px;
	left: 10px;
	background: var(--ess-navy);
	color: #ffffff;
	font-family: var(--ess-font-mono);
	font-size: 9px;
	padding: 3px 7px;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	z-index: 2;
}

.ess-store-card__body { padding: 16px; }
.ess-store-card__name {
	font-family: var(--ess-font-serif);
	font-size: 1.1875rem;
	line-height: 1.1;
	font-weight: 400;
	letter-spacing: -0.3px;
	color: var(--ess-navy);
	margin: 0;
}
.ess-store-card__meta {
	font-family: var(--ess-font-mono);
	font-size: 11px;
	color: var(--ess-muted);
	letter-spacing: 0.5px;
	text-transform: uppercase;
	margin-top: 4px;
}
.ess-store-card__stats {
	display: flex;
	justify-content: space-between;
	margin-top: 14px;
	padding-top: 14px;
	border-top: 1px solid var(--ess-line);
	font-size: 11px;
	color: var(--ess-navy-soft);
}

/* ==========================================================================
   5. FLASH OFFERS — 5 product cards small
   ========================================================================== */

.ess-flash-offers {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 14px;
}
@media (min-width: 768px) { .ess-flash-offers { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1200px) { .ess-flash-offers { grid-template-columns: repeat(5, 1fr); } }

/* ==========================================================================
   6. SELLER BAND — bg sea, grid 1fr/1fr con stats 2×2 arancio
   ========================================================================== */

.ess-seller-band {
	background: var(--ess-sea);
	color: #ffffff;
	padding: 40px 0;
}
@media (min-width: 1024px) {
	.ess-seller-band { padding: 56px 0; }
}

.ess-seller-band__inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
	align-items: center;
}
@media (min-width: 1024px) {
	.ess-seller-band__inner { grid-template-columns: 1fr 1fr; gap: 48px; }
}

.ess-seller-band__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(2rem, 1.5rem + 2vw, 3rem);
	line-height: 1;
	letter-spacing: var(--ess-tracking-tight-sm);
	color: #ffffff;
	margin: 14px 0;
	font-weight: 400;
}
.ess-seller-band__title .ess-italic-orange { color: var(--ess-orange); }

.ess-seller-band__lead {
	font-size: var(--ess-text-sm);
	line-height: 1.55;
	max-width: 440px;
	opacity: 0.85;
	margin: 0 0 22px;
}

.ess-seller-band .ess-eyebrow { color: var(--ess-orange); margin-bottom: 14px; }

.ess-seller-band__stats {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 2px;
	background: rgba(255, 255, 255, 0.12);
	margin: 0;
}

.ess-seller-band__stat {
	background: var(--ess-sea);
	padding: 20px 18px;
	margin: 0;
}
.ess-seller-band__stat-n {
	font-family: var(--ess-font-serif);
	font-size: clamp(2rem, 1.5rem + 1.5vw, 2.75rem);
	line-height: 1;
	color: var(--ess-orange);
	margin: 0;
	font-weight: 400;
}
.ess-seller-band__stat-l {
	font-size: 11px;
	margin: 6px 0 0;
	text-transform: uppercase;
	letter-spacing: 0.6px;
	opacity: 0.8;
}

/* ==========================================================================
   ARCHIVE (category / shop) — editorial header + 240px sidebar + product grid
   ========================================================================== */

.ess-archive { display: block; }

.ess-archive-header {
	padding-block: 20px 24px;
	border-bottom: 1px solid var(--ess-line);
	font-family: var(--ess-font-body);
}
@media (min-width: 1024px) {
	.ess-archive-header { padding-block: 20px 32px; }
}

/* Breadcrumb — mono 11px uppercase, muted con "/" separator */
.ess-archive-header .ess-breadcrumb,
.ess-breadcrumb {
	font-family: var(--ess-font-mono);
	font-size: var(--ess-text-xs);
	letter-spacing: 0.5px;
	text-transform: uppercase;
	color: var(--ess-muted);
	margin-bottom: 20px;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
	line-height: 1.4;
}
.ess-breadcrumb a {
	color: var(--ess-muted);
	text-decoration: none;
}
.ess-breadcrumb a:hover,
.ess-breadcrumb a:focus-visible {
	color: var(--ess-orange);
}
.ess-breadcrumb [aria-current="page"],
.ess-breadcrumb .current {
	color: var(--ess-navy);
}
.ess-breadcrumb__separator,
.ess-breadcrumb .separator {
	color: var(--ess-muted);
	opacity: 0.5;
}

/* Hero intro — H1 editoriale + descrizione */
.ess-archive-intro { margin-bottom: 20px; }

.ess-archive-title {
	font-family: var(--ess-font-serif);
	font-size: clamp(2.5rem, 1.5rem + 4vw, 4rem);
	line-height: 1;
	letter-spacing: var(--ess-tracking-tight);
	color: var(--ess-navy);
	margin: 0;
	font-weight: 400;
}

.ess-archive-desc {
	font-family: var(--ess-font-body);
	font-size: 14px;
	line-height: 1.55;
	color: var(--ess-navy-soft);
	max-width: 520px;
	margin: 14px 0 0;
}

/* Subcategory chips — pill shape, scroll orizzontale mobile */
.ess-archive-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 20px;
}
@media (max-width: 767px) {
	.ess-archive-chips {
		flex-wrap: nowrap;
		overflow-x: auto;
		scrollbar-width: thin;
		padding-bottom: 4px;
		margin-inline: calc(-1 * var(--ess-container-padding));
		padding-inline: var(--ess-container-padding);
	}
}

.ess-chip {
	display: inline-flex;
	align-items: center;
	padding: 7px 14px;
	font-family: var(--ess-font-body);
	font-size: 12px;
	line-height: 1;
	color: var(--ess-navy-soft);
	background: transparent;
	border: 1px solid var(--ess-line-strong);
	border-radius: 999px;
	cursor: pointer;
	text-decoration: none;
	white-space: nowrap;
	transition: background var(--ess-transition-fast), color var(--ess-transition-fast), border-color var(--ess-transition-fast);
}
.ess-chip:hover,
.ess-chip:focus-visible {
	border-color: var(--ess-navy);
	color: var(--ess-navy);
}
.ess-chip:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: 2px;
}
.ess-chip--active,
.ess-chip[aria-current="page"] {
	background: var(--ess-navy);
	color: #ffffff;
	border-color: var(--ess-navy);
}
.ess-chip--active:hover,
.ess-chip[aria-current="page"]:hover {
	background: #000000;
	border-color: #000000;
	color: #ffffff;
}

/* Layout 240px / 1fr */
.ess-archive-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--ess-space-8);
	padding-block: 28px 56px;
}
@media (min-width: 1024px) {
	.ess-archive-layout {
		grid-template-columns: 240px 1fr;
		gap: 32px;
	}
}

.ess-archive-sidebar { font-size: 13px; color: var(--ess-navy-soft); }
.ess-archive-sidebar__title {
	padding-bottom: 10px;
	border-bottom: 1px solid var(--ess-line);
	margin-bottom: 14px;
	color: var(--ess-orange);
}

.ess-archive-main { min-width: 0; }

.ess-archive-empty {
	padding: 60px 20px;
	text-align: center;
	color: var(--ess-muted);
	font-size: 14px;
	border: 1px dashed var(--ess-line-strong);
	background: #ffffff;
}

/* Sort bar — count + sort select, border-bottom line */
.ess-sort-bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--ess-space-4);
	padding-bottom: 16px;
	margin-bottom: 20px;
	border-bottom: 1px solid var(--ess-line);
	flex-wrap: wrap;
	font-family: var(--ess-font-body);
}
.ess-sort-bar__count {
	font-size: 12px;
	color: var(--ess-muted);
}
.ess-sort-bar__count strong {
	color: var(--ess-navy);
	font-weight: 500;
}
.ess-sort-bar__mobile-toggle {
	padding: 8px 14px;
	font-family: var(--ess-font-body);
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	border: 1px solid var(--ess-navy);
	background: transparent;
	color: var(--ess-navy);
	cursor: pointer;
	border-radius: 0;
}
.ess-sort-bar__mobile-toggle:hover { background: var(--ess-navy); color: #ffffff; }
.ess-sort-bar__controls .woocommerce-ordering { margin: 0; }
.ess-sort-bar__controls select,
.ess-sort-bar .orderby {
	font-family: var(--ess-font-body);
	font-size: 12px;
	padding: 6px 10px;
	border: 1px solid var(--ess-line-strong);
	background: #ffffff;
	color: var(--ess-navy);
	border-radius: 0;
	min-height: 36px;
}

/* Override WC pagination per editorial (squared) */
.ess-archive-main .navigation.pagination .page-numbers {
	border-radius: 0;
	border-color: var(--ess-line-strong);
	color: var(--ess-navy-soft);
	font-weight: 400;
}
.ess-archive-main .navigation.pagination .page-numbers:hover,
.ess-archive-main .navigation.pagination .page-numbers:focus-visible {
	border-color: var(--ess-navy);
	color: var(--ess-navy);
}
.ess-archive-main .navigation.pagination .page-numbers.current {
	background: var(--ess-navy);
	border-color: var(--ess-navy);
	color: #ffffff;
}

/* ==========================================================================
   SEARCH + WISHLIST pages — editorial header + grid + empty state
   ========================================================================== */

.ess-search-page,
.ess-wishlist-page {
	display: block;
	font-family: var(--ess-font-body);
}

.ess-search-page__header,
.ess-wishlist-page__header {
	padding-block: 28px 20px;
	border-bottom: 1px solid var(--ess-line);
	margin-bottom: 32px;
	background: #ffffff;
}
.ess-search-page__header .ess-breadcrumb,
.ess-wishlist-page__header .ess-breadcrumb {
	margin-bottom: 16px;
}

.ess-search-page__header .ess-eyebrow,
.ess-wishlist-page__header .ess-eyebrow {
	margin-bottom: 8px;
}

.ess-search-page__title,
.ess-wishlist-page__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(2rem, 1.25rem + 2.5vw, 3rem);
	line-height: 1;
	letter-spacing: -0.8px;
	color: var(--ess-navy);
	margin: 0;
	font-weight: 400;
}
.ess-search-page__title strong {
	font-weight: inherit;
	color: var(--ess-sea);
	letter-spacing: inherit;
}

/* Search page: list layout for non-product results */
.ess-search-page__list {
	display: grid;
	gap: var(--ess-space-4);
	max-width: 860px;
}

/* Wishlist page wrap */
.ess-wishlist-page__wrap {
	padding-block: 0 56px;
}
.ess-wishlist-page__loader {
	padding: 40px 20px;
	text-align: center;
	color: var(--ess-muted);
	font-family: var(--ess-font-mono);
	font-size: var(--ess-text-xs);
	letter-spacing: 0.5px;
	text-transform: uppercase;
}

/* Empty state — shared by search, wishlist, archive fallback */
.ess-empty-state {
	padding: 56px 24px;
	text-align: center;
	background: #ffffff;
	border: 1px dashed var(--ess-line-strong);
	max-width: 640px;
	margin: 0 auto;
}
.ess-empty-state__title {
	font-family: var(--ess-font-serif);
	font-size: 1.5rem;
	font-weight: 400;
	color: var(--ess-navy);
	margin-bottom: 10px;
	letter-spacing: -0.4px;
}
.ess-empty-state__text {
	color: var(--ess-navy-soft);
	font-size: 14px;
	line-height: 1.55;
	margin-bottom: 22px;
}
.ess-empty-state__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	justify-content: center;
}

/* Pagination (search / wishlist — reuse archive style) */
.ess-search-page .navigation.pagination,
.ess-wishlist-page .navigation.pagination {
	margin-top: 40px;
}
.ess-search-page .navigation.pagination .nav-links,
.ess-wishlist-page .navigation.pagination .nav-links {
	display: flex;
	gap: 6px;
	justify-content: center;
	flex-wrap: wrap;
}
.ess-search-page .navigation.pagination .page-numbers,
.ess-wishlist-page .navigation.pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 12px;
	border: 1px solid var(--ess-line-strong);
	border-radius: 0;
	color: var(--ess-navy-soft);
	text-decoration: none;
	font-size: 13px;
	transition: border-color var(--ess-transition-fast), color var(--ess-transition-fast);
}
.ess-search-page .navigation.pagination .page-numbers:hover,
.ess-wishlist-page .navigation.pagination .page-numbers:hover {
	border-color: var(--ess-navy);
	color: var(--ess-navy);
}
.ess-search-page .navigation.pagination .page-numbers.current,
.ess-wishlist-page .navigation.pagination .page-numbers.current {
	background: var(--ess-navy);
	border-color: var(--ess-navy);
	color: #ffffff;
}
