/**
 * 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 azzurro).
 * Override testo navy per contrasto WCAG AA (5.57:1 vs white-on-wave 2.61 fail). */
.ess-product-card__badge--cert {
	top: 8px;
	left: 8px;
	background: var(--ess-wave);
	color: var(--ess-navy);
}

/* Top-right: sale discount (arancio).
 * BG --ess-orange-strong per contrasto white-on-bg 6.40:1 (WCAG AA). */
.ess-product-card__badge--sale {
	top: 8px;
	right: 8px;
	background: var(--ess-orange-strong);
	font-size: 10px;
}

/* Out of stock: top-right grey scuro per AA (5.84:1). */
.ess-product-card__badge--outofstock {
	top: 8px;
	right: 8px;
	background: #5a6577;
}

/* 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 (contrasto AA 5.91:1) */
.ess-product-card__vendor {
	font-family: var(--ess-font-mono);
	font-size: 10px;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	color: var(--ess-muted-aa);
	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 — sans medium per scannabilità (gerarchia: titolo 500, prezzo accent terra) */
.ess-product-card__title {
	font-family: var(--ess-font-body);
	font-size: 13px;
	font-weight: 500;
	line-height: 1.35;
	color: var(--ess-navy);
	margin: 0 0 6px;
	letter-spacing: 0;
	min-height: 36px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Comparator hint — "X venditori da €Y" — pattern Idealo/Trovaprezzi.
   Body sans, sea color (link feel), ribadisce la natura comparator del marketplace. */
.ess-product-card__compare {
	font-family: var(--ess-font-body);
	font-size: 11px;
	color: var(--ess-sea);
	margin: 0 0 10px;
	letter-spacing: 0;
	line-height: 1.3;
}
.ess-product-card__compare .woocommerce-Price-amount,
.ess-product-card__compare bdi {
	font-family: var(--ess-font-serif);
	font-size: 12px;
	font-weight: 500;
	color: var(--ess-orange);
}
.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);
}

/* Prezzo — terracotta per gerarchia chromatica (AA 5.4:1, accent brand) */
.ess-product-card__price {
	font-family: var(--ess-font-serif);
	font-size: 19px;
	font-weight: 500;
	color: var(--ess-orange);
	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-aa);
	font-family: var(--ess-font-body);
	font-weight: 400;
	font-size: 11px;
	margin-left: 6px;
	text-decoration: line-through;
	opacity: 0.85;
}
.ess-product-card__price ins {
	text-decoration: none;
	color: var(--ess-orange);
	font-family: var(--ess-font-serif);
	font-weight: 500;
}

/* "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.
   Variant --external mostra icona "↗" (link esterno) invece della freccia →,
   per chiarezza semantica DSA: l'utente sa che il click esce dal sito. */
.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;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	transition: color var(--ess-transition-fast);
}
.ess-product-card__cta-icon {
	flex: 0 0 auto;
	width: 12px;
	height: 12px;
	transition: transform 0.18s ease;
}
.ess-product-card__cta:hover .ess-product-card__cta-icon,
.ess-product-card__cta:focus-visible .ess-product-card__cta-icon {
	transform: translateX(2px);
}
.ess-product-card__cta--external:hover .ess-product-card__cta-icon,
.ess-product-card__cta--external:focus-visible .ess-product-card__cta-icon {
	transform: translate(2px, -2px);
}
.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;
}
@media (prefers-reduced-motion: reduce) {
	.ess-product-card__cta-icon { transition: none; }
	.ess-product-card__cta:hover .ess-product-card__cta-icon,
	.ess-product-card__cta:focus-visible .ess-product-card__cta-icon,
	.ess-product-card__cta--external:hover .ess-product-card__cta-icon,
	.ess-product-card__cta--external:focus-visible .ess-product-card__cta-icon { transform: none; }
}

/* 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__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;
	max-width: 100%;
	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 "Logo Finale v3" — viewBox 720×120 ratio 6:1) */
.ess-site-logo { display: inline-flex; align-items: center; text-decoration: none; }
.ess-site-logo__svg {
	height: 40px;
	width: auto;
	max-width: 100%;
	display: block;
}
@media (min-width: 768px) { .ess-site-logo__svg { height: 46px; } }

/* ==========================================================================
   SEARCH FORM — modulo custom .ess-search (replica prototipo §search)
   Pill 44px height ink-bordered + button "CERCA" testuale uppercase.
   Markup in template-parts/header/search-form.php — indipendente da SSS plugin.
   ========================================================================== */

.ess-header__search {
	flex: 1;
	max-width: 640px;
	margin-inline: auto;
}

.ess-search {
	display: flex;
	align-items: stretch;
	width: 100%;
	height: 44px;
	background: #ffffff;
	border: 1px solid var(--ess-ink);
	border-radius: 22px;          /* = height/2: pill perfetta */
	overflow: hidden;             /* taglia il button rettangolare lungo la curva */
	box-sizing: border-box;
	transition: box-shadow var(--ess-transition-fast);
}
.ess-search:focus-within {
	box-shadow: 0 0 0 3px rgba(22, 21, 18, 0.1);
}

.ess-search__input {
	flex: 1 1 auto;
	min-width: 0;
	height: 100%;
	padding: 0 16px;
	font-family: var(--ess-font-body);
	font-size: 13px;
	color: var(--ess-ink);
	background: transparent;
	border: 0;
	outline: none;
	box-sizing: border-box;
	-webkit-appearance: none;
	appearance: none;
}
.ess-search__input::placeholder {
	color: var(--ess-muted-aa);   /* WCAG AA 5.91:1 */
	opacity: 1;
}
.ess-search__input::-webkit-search-cancel-button { display: none; }

.ess-search__btn {
	flex: 0 0 auto;
	height: 100%;
	padding: 0 24px;
	background: var(--ess-ink);
	color: #ffffff;
	font-family: var(--ess-font-body);
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	border: 0;
	border-radius: 0;             /* squadrato — viene tagliato dall'overflow:hidden della pill */
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background var(--ess-transition-fast);
}
.ess-search__btn:hover,
.ess-search__btn:focus-visible {
	background: var(--ess-sea);   /* mare profondo, brand-coerente */
}
.ess-search__btn:focus-visible {
	outline: 2px solid var(--ess-terra);
	outline-offset: -3px;         /* stays inside button (clipped by pill) */
}

/* Mobile: stessa pill, font 16px no-zoom iOS */
@media (max-width: 767px) {
	.ess-search { height: 48px; border-radius: 24px; }
	.ess-search__input { font-size: 16px; }
	.ess-search__btn { padding: 0 20px; font-size: 11px; }
}

.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" — usa orange-strong per AA white-on-bg 5.89:1 */
.ess-header__action-count {
	background: var(--ess-orange-strong);
	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;
	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-aa);  /* WCAG AA 4.59:1 */
}

/* Right rail Blog · Vendi con noi (replica prototipo subnav-right) */
.ess-header__subnav-right {
	margin-left: auto;
	display: inline-flex;
	align-items: center;
	gap: 12px;
	font-size: 12px;
}
.ess-header__subnav-link {
	color: var(--ess-navy-soft);
	text-decoration: none;
	padding: 4px 0;
	transition: color var(--ess-transition-fast);
}
.ess-header__subnav-link:hover,
.ess-header__subnav-link:focus-visible {
	color: var(--ess-navy);
}
.ess-header__subnav-link:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: 2px;
}
.ess-header__subnav-link--accent {
	color: var(--ess-navy);
	font-weight: 500;
}
.ess-header__subnav-link[aria-current="page"] {
	color: var(--ess-navy);
	font-weight: 500;
}
.ess-header__subnav-sep {
	color: var(--ess-line-strong);
	user-select: none;
}

/* Reset container styles */
.ess-navbar {
	background: transparent;
	border: none;
	box-shadow: none;
	position: static;
}
/* 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-ink);
	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 a { display: inline-flex; }
.ess-footer__logo img {
	display: block;
	height: 56px; /* prototipo design footer height */
	width: auto;
	max-width: 100%;
}

/* 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__made-in {
	font-family: var(--ess-font-mono);
	font-size: 10px;
	color: rgba(216, 225, 237, 0.5);
	letter-spacing: 0.04em;
}
.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;
}

/* Topbar accent item — usato per "Vendi con noi" (CTA secondaria sul fondo ink). */
.ess-topbar__item--accent {
	color: var(--ess-limone, #e8c341);
	font-weight: var(--ess-weight-bold, 700);
	opacity: 1;
}
.ess-topbar a.ess-topbar__item--accent {
	color: var(--ess-limone, #e8c341);
	opacity: 1;
}
.ess-topbar a.ess-topbar__item--accent:hover,
.ess-topbar a.ess-topbar__item--accent:focus-visible {
	color: #ffffff;
}

/* ==========================================================================
   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__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: 920px;
	line-height: 1.6;
}

.ess-section__header-center .ess-section__subtitle {
	margin-inline: auto;
}

/* ==========================================================================
   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 — Vendi con noi (replica prototipo LandingPage in pages-4.jsx)
   ========================================================================== */

/* 1. Hero — bg image + dark overlay (gradient già nello style inline del template) */
.ess-landing-hero {
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	color: #ffffff;
	text-align: center;
	padding: 90px 0 100px;
}
@media (max-width: 767px) {
	.ess-landing-hero { padding: 56px 0 64px; }
}

.ess-landing-hero__inner {
	max-width: 1000px;
}

.ess-landing-hero__eyebrow {
	font-family: var(--ess-font-mono);
	font-size: 11px;
	color: var(--ess-orange);
	letter-spacing: 1.4px;
	text-transform: uppercase;
	margin: 0 0 20px;
}

.ess-landing-hero__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(2rem, 1rem + 4.5vw, 4rem); /* 32px–64px */
	line-height: 1.02;
	letter-spacing: -1.5px;
	color: #ffffff;
	margin: 0 auto 20px;
}

.ess-landing-hero__sub {
	font-size: 17px;
	line-height: 1.55;
	max-width: 720px;
	margin: 0 auto;
	opacity: 0.92;
	color: #ffffff;
}

/* Hero CTAs in-fold (fix audit UX 2026-06-01) */
.ess-landing-hero__ctas {
	display: flex;
	flex-direction: column;
	gap: 12px;
	align-items: center;
	margin-top: 28px;
	flex-wrap: wrap;
}
@media (min-width: 640px) {
	.ess-landing-hero__ctas { flex-direction: row; justify-content: center; gap: 14px; }
}
.ess-landing-hero__cta {
	background: #25D366;
	color: #ffffff;
	border-color: #25D366;
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 14px 26px;
	font-weight: 700;
	letter-spacing: 0.3px;
	text-decoration: none;
}
.ess-landing-hero__cta:hover,
.ess-landing-hero__cta:focus-visible {
	background: #128C7E;
	border-color: #128C7E;
	color: #ffffff;
}
.ess-landing-hero__cta-alt {
	color: #ffffff;
	border-color: rgba(255,255,255,0.5);
	background: transparent;
	padding: 14px 24px;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-weight: 600;
	text-decoration: none;
}
.ess-landing-hero__cta-alt:hover,
.ess-landing-hero__cta-alt:focus-visible {
	background: #ffffff;
	color: var(--ess-ink);
	border-color: #ffffff;
}

/* ==========================================================================
   VENDOR JOURNEY — Stepper + Footer Prev/Next (v6.0.7)
   Usata in: Vendi / Come funziona / Piani e tariffe / Servizi aggiuntivi
   ========================================================================== */

.ess-journey {
	background: var(--ess-surface);
	border-bottom: 1px solid var(--ess-line);
	padding: var(--ess-space-4) 0;
}

.ess-journey__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--ess-space-2);
}
@media (min-width: 768px) {
	.ess-journey__list {
		grid-template-columns: repeat(4, 1fr);
		gap: 0;
	}
}

.ess-journey__item {
	margin: 0;
	padding: 0;
	position: relative;
}

/* Linea connettiva tra step su desktop */
@media (min-width: 768px) {
	.ess-journey__item:not(:last-child)::after {
		content: '';
		position: absolute;
		top: 50%;
		right: -1px;
		width: 1px;
		height: 28px;
		background: var(--ess-line);
		transform: translateY(-50%);
	}
}

.ess-journey__link {
	display: flex;
	align-items: center;
	gap: var(--ess-space-3);
	padding: var(--ess-space-3) var(--ess-space-4);
	text-decoration: none;
	color: var(--ess-color-text-sec);
	transition: background-color var(--ess-transition-fast), color var(--ess-transition-fast);
	min-height: 56px;
}
.ess-journey__link:hover,
.ess-journey__link:focus-visible {
	background: rgba(197,85,45,0.06);
	color: var(--ess-color-heading);
	outline: none;
}

.ess-journey__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	flex-shrink: 0;
	border: 1.5px solid currentColor;
	font-family: var(--ess-font-mono);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.5px;
	color: var(--ess-color-text-sec);
	background: #ffffff;
}

.ess-journey__text {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}
.ess-journey__eyebrow {
	font-family: var(--ess-font-mono);
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.8px;
	text-transform: uppercase;
	color: var(--ess-color-text-sec);
	line-height: 1;
}
.ess-journey__label {
	font-family: var(--ess-font-body);
	font-size: var(--ess-text-sm);
	font-weight: 600;
	color: var(--ess-color-heading);
	line-height: 1.2;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* State: active (current step) */
.ess-journey__item.is-active .ess-journey__num {
	background: var(--ess-terra);
	border-color: var(--ess-terra);
	color: #ffffff;
}
.ess-journey__item.is-active .ess-journey__eyebrow,
.ess-journey__item.is-active .ess-journey__label {
	color: var(--ess-color-heading);
}
.ess-journey__item.is-active .ess-journey__link {
	background: #ffffff;
	cursor: default;
	pointer-events: none;
}

/* State: done (step già passato) */
.ess-journey__item.is-done .ess-journey__num {
	background: var(--ess-ulivo, #6b7a3a);
	border-color: var(--ess-ulivo, #6b7a3a);
	color: #ffffff;
}
.ess-journey__item.is-done .ess-journey__label {
	color: var(--ess-color-heading);
}

/* State: upcoming — default style già OK */

/* ========== Footer prev/next ========== */
.ess-journey-footer {
	background: var(--ess-surface);
	border-top: 1px solid var(--ess-line);
	border-bottom: 1px solid var(--ess-line);
	padding: var(--ess-space-6) 0;
	margin-top: var(--ess-space-10);
}

.ess-journey-footer__inner {
	display: flex;
	flex-direction: column;
	gap: var(--ess-space-4);
	align-items: stretch;
}
@media (min-width: 640px) {
	.ess-journey-footer__inner {
		flex-direction: row;
		justify-content: space-between;
		align-items: center;
	}
}

.ess-journey-footer__prev,
.ess-journey-footer__next {
	display: inline-flex;
	align-items: center;
	gap: var(--ess-space-3);
	text-decoration: none;
	color: var(--ess-color-heading);
	padding: var(--ess-space-3) var(--ess-space-4);
	border: 1px solid var(--ess-line);
	background: #ffffff;
	transition: border-color var(--ess-transition-fast), box-shadow var(--ess-transition-fast), transform var(--ess-transition-fast);
	min-width: 240px;
}
.ess-journey-footer__next {
	background: var(--ess-color-heading, var(--ess-ink));
	color: #ffffff;
	border-color: var(--ess-color-heading, var(--ess-ink));
	flex-direction: row-reverse;
	text-align: right;
}
.ess-journey-footer__prev:hover,
.ess-journey-footer__prev:focus-visible {
	border-color: var(--ess-terra);
	box-shadow: 0 2px 8px rgba(22,21,18,0.06);
	transform: translateY(-1px);
	outline: none;
}
.ess-journey-footer__next:hover,
.ess-journey-footer__next:focus-visible {
	background: var(--ess-terra);
	border-color: var(--ess-terra);
	transform: translateY(-1px);
	outline: none;
}

.ess-journey-footer__prev > span,
.ess-journey-footer__next > span {
	display: flex;
	flex-direction: column;
	line-height: 1.2;
}
.ess-journey-footer__hint {
	font-family: var(--ess-font-mono);
	font-size: 10px;
	letter-spacing: 0.8px;
	text-transform: uppercase;
	opacity: 0.7;
	margin-bottom: 2px;
}
.ess-journey-footer__prev strong,
.ess-journey-footer__next strong {
	font-family: var(--ess-font-serif);
	font-size: var(--ess-text-lg);
	font-weight: 400;
}

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

/* ==========================================================================
   COME FUNZIONA (Step 2) — 4 step processo + header
   ========================================================================== */
.ess-cf { padding-block: var(--ess-space-12); }
.ess-cf__header {
	max-width: 720px;
	margin: 0 auto var(--ess-space-8);
	text-align: center;
}
.ess-cf__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(1.625rem, 1.25rem + 1.5vw, 2.25rem);
	font-weight: 400;
	line-height: 1.2;
	color: var(--ess-color-heading);
	margin: var(--ess-space-2) 0 var(--ess-space-3);
}
.ess-cf__lead {
	font-size: var(--ess-text-base);
	color: var(--ess-color-text-sec);
	margin: 0;
	line-height: 1.55;
}

.ess-cf__steps {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--ess-space-5);
	counter-reset: cf-step;
}
@media (min-width: 768px) {
	.ess-cf__steps { grid-template-columns: repeat(2, 1fr); gap: var(--ess-space-6); }
}

.ess-cf__step {
	background: #ffffff;
	border: 1px solid var(--ess-line);
	padding: var(--ess-space-6);
	position: relative;
	display: flex;
	flex-direction: column;
	gap: var(--ess-space-3);
}
.ess-cf__step-head {
	display: flex;
	align-items: center;
	gap: var(--ess-space-4);
	border-bottom: 1px solid var(--ess-line);
	padding-bottom: var(--ess-space-3);
}
.ess-cf__step-num {
	font-family: var(--ess-font-serif);
	font-size: 2.5rem;
	line-height: 1;
	font-weight: 400;
	color: var(--ess-terra);
	flex-shrink: 0;
}
.ess-cf__step-title {
	font-family: var(--ess-font-serif);
	font-size: var(--ess-text-xl);
	margin: 0 0 4px;
	font-weight: 400;
	line-height: 1.2;
	color: var(--ess-color-heading);
}
.ess-cf__step-time {
	font-family: var(--ess-font-mono);
	font-size: 11px;
	letter-spacing: 0.8px;
	text-transform: uppercase;
	color: var(--ess-ulivo, #6b7a3a);
	margin: 0;
	font-weight: 600;
}
.ess-cf__step-desc {
	font-size: var(--ess-text-sm);
	color: var(--ess-color-text-sec);
	line-height: 1.6;
	margin: 0;
}

/* Riuso .ess-feature-card icona SVG (vs vecchia img) */
.ess-feature-card__icon-svg {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	background: var(--ess-surface);
	color: var(--ess-terra);
	margin-bottom: var(--ess-space-4);
}

/* ==========================================================================
   SERVIZI AGGIUNTIVI (Step 4) — Categorie + Empty + Close-loop
   ========================================================================== */
.ess-sa { padding-block: var(--ess-space-12); }
.ess-sa__header {
	max-width: 720px;
	margin: 0 auto var(--ess-space-8);
	text-align: center;
}
.ess-sa__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(1.625rem, 1.25rem + 1.5vw, 2.25rem);
	font-weight: 400;
	line-height: 1.2;
	color: var(--ess-color-heading);
	margin: var(--ess-space-2) 0 var(--ess-space-3);
}
.ess-sa__lead {
	font-size: var(--ess-text-base);
	color: var(--ess-color-text-sec);
	margin: 0;
	line-height: 1.55;
}

.ess-sa__cats {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--ess-space-5);
}
@media (min-width: 640px)  { .ess-sa__cats { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .ess-sa__cats { grid-template-columns: repeat(4, 1fr); } }

.ess-sa-card {
	background: #ffffff;
	border: 1px solid var(--ess-line);
	padding: var(--ess-space-6);
	display: flex;
	flex-direction: column;
	gap: var(--ess-space-3);
	transition: border-color var(--ess-transition-fast), box-shadow var(--ess-transition-fast);
}
.ess-sa-card:hover {
	border-color: var(--ess-terra);
	box-shadow: 0 4px 16px rgba(22,21,18,0.06);
}
.ess-sa-card__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	background: var(--ess-surface);
	color: var(--ess-terra);
}
.ess-sa-card__title {
	font-family: var(--ess-font-serif);
	font-size: var(--ess-text-xl);
	font-weight: 400;
	line-height: 1.2;
	margin: 0;
	color: var(--ess-color-heading);
}
.ess-sa-card__desc {
	font-size: var(--ess-text-sm);
	color: var(--ess-color-text-sec);
	line-height: 1.55;
	margin: 0;
}
.ess-sa-card__tags {
	list-style: none;
	padding: 0;
	margin: var(--ess-space-2) 0 0;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}
.ess-sa-card__tags li {
	font-family: var(--ess-font-mono);
	font-size: 10px;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	padding: 4px 8px;
	background: var(--ess-surface);
	color: var(--ess-color-heading);
	border: 1px solid var(--ess-line);
}

/* Empty state catalogo */
.ess-sa-empty {
	text-align: center;
	padding: var(--ess-space-8);
	background: #ffffff;
	border: 1px dashed var(--ess-line-strong);
	margin-top: var(--ess-space-6);
}
.ess-sa-empty__title {
	font-family: var(--ess-font-serif);
	font-size: var(--ess-text-xl);
	color: var(--ess-color-heading);
	margin: 0 0 var(--ess-space-2);
}
.ess-sa-empty__text {
	font-size: var(--ess-text-base);
	color: var(--ess-color-text-sec);
	max-width: 480px;
	margin: 0 auto var(--ess-space-5);
	line-height: 1.55;
}

/* Close-loop section */
.ess-sa-close {
	padding-block: var(--ess-space-12);
	background: var(--ess-color-heading, var(--ess-ink));
	color: #ffffff;
}
.ess-sa-close__inner {
	max-width: 760px;
	margin: 0 auto;
	text-align: center;
}
.ess-sa-close .ess-eyebrow {
	color: rgba(255,255,255,0.75);
}
.ess-sa-close__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(1.75rem, 1.25rem + 2vw, 2.5rem);
	font-weight: 400;
	line-height: 1.2;
	margin: var(--ess-space-2) 0 var(--ess-space-3);
	color: #ffffff;
}
.ess-sa-close__lead {
	font-size: var(--ess-text-base);
	color: rgba(255,255,255,0.85);
	line-height: 1.55;
	margin: 0 auto var(--ess-space-6);
	max-width: 560px;
}
.ess-sa-close__ctas {
	display: flex;
	gap: var(--ess-space-3);
	justify-content: center;
	flex-wrap: wrap;
}
.ess-sa-close .ess-btn--outline {
	border-color: rgba(255,255,255,0.4);
	color: #ffffff;
}
.ess-sa-close .ess-btn--outline:hover,
.ess-sa-close .ess-btn--outline:focus-visible {
	background: #ffffff;
	color: var(--ess-ink);
	border-color: #ffffff;
}

/* Pulisco landing-cta alt-link aggiunto */
.ess-landing-cta__alt {
	margin-top: var(--ess-space-4);
	font-size: var(--ess-text-sm);
	color: rgba(255,255,255,0.7);
}
.ess-landing-cta__alt a {
	color: #ffffff;
	text-decoration: underline;
}

/* 2. Intro — paragrafi long-form centrati */
.ess-landing-intro {
	background: #ffffff;
	padding: 64px 0 40px;
}
.ess-landing-intro__inner {
	max-width: 820px;
	text-align: center;
}
.ess-landing-intro__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(1.625rem, 1rem + 1.6vw, 2.25rem); /* 26–36px */
	line-height: 1.1;
	letter-spacing: -0.8px;
	margin: 0 0 22px;
	color: var(--ess-navy);
}
.ess-landing-intro__lead,
.ess-landing-intro__body {
	font-size: 15px;
	color: var(--ess-navy-soft);
	line-height: 1.75;
	margin: 0 0 18px;
}
.ess-landing-intro__body:last-child { margin-bottom: 0; }

/* 3. Vantaggi 3-col su bg surface — ogni card con icon glyph in box ink + numbered */
.ess-landing-values {
	background: #ffffff;
	padding: 24px 0 72px;
}
.ess-landing-values__header {
	text-align: center;
	margin-bottom: 40px;
}
.ess-landing-values__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(1.5rem, 1rem + 1vw, 2rem); /* 24–32px */
	letter-spacing: -0.6px;
	max-width: 740px;
	margin: 12px auto 0;
	color: var(--ess-navy);
	line-height: 1.15;
}

.ess-landing-values__grid {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
	max-width: 1180px;
	margin-inline: auto;
}
@media (min-width: 640px)  { .ess-landing-values__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .ess-landing-values__grid { grid-template-columns: repeat(3, 1fr); } }

.ess-landing-value-card {
	position: relative;
	padding: 28px 24px;
	background: var(--ess-surface);
	border: 1px solid var(--ess-line);
}

.ess-landing-value-card__icon {
	position: absolute;
	top: -14px;
	left: 24px;
	width: 40px;
	height: 40px;
	background: var(--ess-navy);
	color: var(--ess-orange);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	font-family: var(--ess-font-serif);
	line-height: 1;
}

.ess-landing-value-card__num {
	font-family: var(--ess-font-mono);
	font-size: 10px;
	color: var(--ess-muted-aa);  /* WCAG AA */
	letter-spacing: 0.8px;
	margin: 12px 0 6px;
}

.ess-landing-value-card__title {
	font-family: var(--ess-font-serif);
	font-size: 22px;
	line-height: 1.15;
	color: var(--ess-navy);
	margin: 0 0 12px;
}

.ess-landing-value-card__desc {
	font-size: 13.5px;
	color: var(--ess-navy-soft);
	line-height: 1.65;
	margin: 0;
}

/* 4. CTA strip ink centered */
.ess-landing-cta {
	background: var(--ess-navy);
	color: #ffffff;
	padding: 64px 0;
	text-align: center;
}
.ess-landing-cta__inner { max-width: 820px; }
.ess-landing-cta__eyebrow {
	font-family: var(--ess-font-mono);
	font-size: 11px;
	color: var(--ess-orange);
	letter-spacing: 1.2px;
	text-transform: uppercase;
	margin: 0 0 14px;
}
.ess-landing-cta__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(1.75rem, 1rem + 2vw, 2.5rem); /* 28–40px */
	line-height: 1.05;
	letter-spacing: -1px;
	margin: 0 auto 14px;
	color: #ffffff;
}
.ess-landing-cta__sub {
	font-size: 15px;
	line-height: 1.6;
	max-width: 680px;
	margin: 0 auto 28px;
	opacity: 0.82;
}

/* 5. Form contattaci — bg surface */
.ess-landing-form {
	background: var(--ess-surface);
	padding: 72px 0;
}

/* ===== Variante WhatsApp card (sostituisce il vecchio CF7) ===== */
.ess-landing-wa__card {
	background: #ffffff;
	border: 1px solid var(--ess-line);
	border-top: 4px solid #25D366; /* verde WhatsApp brand */
	padding: var(--ess-space-8) var(--ess-space-6);
	margin-top: var(--ess-space-7);
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--ess-space-3);
	max-width: 480px;
	margin-inline: auto;
}
@media (min-width: 768px) {
	.ess-landing-wa__card { padding: var(--ess-space-10) var(--ess-space-8); }
}

.ess-landing-wa__icon {
	display: inline-flex;
	width: 72px;
	height: 72px;
	border-radius: 50%;
	background: rgba(37,211,102,0.10);
	color: #25D366;
	align-items: center;
	justify-content: center;
	margin-bottom: var(--ess-space-2);
}

.ess-landing-wa__number {
	font-family: var(--ess-font-mono);
	font-size: var(--ess-text-base);
	letter-spacing: 0.8px;
	color: var(--ess-color-heading);
	margin: 0;
	font-weight: 600;
}

.ess-landing-wa__cta {
	background: #25D366;
	color: #ffffff;
	border-color: #25D366;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 14px 24px;
	font-weight: 700;
	letter-spacing: 0.4px;
	text-decoration: none;
	transition: background-color var(--ess-transition-fast), transform var(--ess-transition-fast);
}
.ess-landing-wa__cta:hover,
.ess-landing-wa__cta:focus-visible {
	background: #128C7E;
	border-color: #128C7E;
	color: #ffffff;
	transform: translateY(-2px);
	outline: none;
}
.ess-landing-wa__cta:focus-visible {
	outline: 2px solid var(--ess-terra);
	outline-offset: 3px;
}

.ess-landing-wa__hint {
	font-size: var(--ess-text-xs);
	color: var(--ess-color-text-sec);
	margin: 0;
}

.ess-landing-wa__alt {
	font-size: var(--ess-text-sm);
	color: var(--ess-color-text-sec);
	margin: var(--ess-space-3) 0 0;
	padding-top: var(--ess-space-3);
	border-top: 1px solid var(--ess-line);
	width: 100%;
}
.ess-landing-wa__alt a {
	color: var(--ess-terra);
	text-decoration: underline;
	font-weight: 600;
}

@media (prefers-reduced-motion: reduce) {
	.ess-landing-wa__cta { transition: none; }
	.ess-landing-wa__cta:hover { transform: none; }
}
.ess-landing-form__inner {
	max-width: 640px;
}
.ess-landing-form__header {
	text-align: center;
	margin-bottom: 32px;
}
.ess-landing-form__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(1.75rem, 1rem + 1.8vw, 2.375rem); /* 28–38px */
	letter-spacing: -0.8px;
	line-height: 1.05;
	margin: 12px 0 0;
	color: var(--ess-navy);
}

/* CF7 styling override per allineamento al design */
.ess-landing-form__wrap .wpcf7 input[type="text"],
.ess-landing-form__wrap .wpcf7 input[type="email"],
.ess-landing-form__wrap .wpcf7 input[type="tel"],
.ess-landing-form__wrap .wpcf7 textarea {
	width: 100%;
	padding: 14px 16px;
	border: 1px solid var(--ess-line-strong);
	background: #ffffff;
	font-family: var(--ess-font-body);
	font-size: 14px;
	color: var(--ess-navy);
	border-radius: 0;
	margin-bottom: 12px;
	box-sizing: border-box;
	outline: none;
	transition: border-color var(--ess-transition-fast);
}
.ess-landing-form__wrap .wpcf7 input:focus-visible,
.ess-landing-form__wrap .wpcf7 textarea:focus-visible {
	border-color: var(--ess-navy);
	outline: 2px solid var(--ess-orange);
	outline-offset: 1px;
}
.ess-landing-form__wrap .wpcf7 textarea { resize: vertical; min-height: 130px; }
.ess-landing-form__wrap .wpcf7 input[type="submit"] {
	width: 100%;
	background: var(--ess-orange-strong);  /* WCAG AA white-on-bg 5.89:1 */
	color: #ffffff;
	padding: 16px;
	font-family: var(--ess-font-body);
	font-size: 12px;
	letter-spacing: 1.2px;
	text-transform: uppercase;
	border: 0;
	cursor: pointer;
	margin-top: 10px;
	transition: background var(--ess-transition-fast);
}
.ess-landing-form__wrap .wpcf7 input[type="submit"]:hover,
.ess-landing-form__wrap .wpcf7 input[type="submit"]:focus-visible {
	background: var(--ess-terra-strong);
}
.ess-landing-form__wrap .wpcf7 .wpcf7-list-item-label,
.ess-landing-form__wrap .wpcf7 label {
	font-size: 11px;
	color: var(--ess-muted-aa);
	line-height: 1.5;
}

.ess-landing-form__fallback {
	text-align: center;
	color: var(--ess-navy-soft);
	font-size: 14px;
	padding: 32px 0;
}

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

.ess-pricing-card__cta-wrap {
	margin: var(--ess-space-4) 0 0;
}

.ess-pricing-card__cta {
	display: inline-flex;
	width: 100%;
	justify-content: center;
}

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

/* Container vuoto del breadcrumb: se ess_breadcrumb() ritorna nulla (es. Rank Math
   skippa la pagina) il `<div class="ess-container">` resta vuoto e genererebbe
   spazio fantasma sopra l'hero della pagina. Collassiamolo. */
.ess-main > .ess-container:empty { display: none; }

/* --- 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 SLIDER — full-width banner con crossfade autoplay
   (replica del prototipo proto/pages-1.jsx HomePage hero)
   ========================================================================== */

.ess-hero-slider {
	position: relative;
	overflow: hidden;
	min-height: 300px;
	border-bottom: 1px solid var(--ess-line);
}

.ess-hero-slider__viewport {
	position: relative;
	/* Altezza FISSA e compatta: tutte le slide (assolute) riempiono il viewport a
	   questa altezza, quindi hanno la STESSA altezza — quella bassa, non la piu'
	   alta. Il contenuto e' centrato; il padding ridotto fa stare anche la slide
	   col testo piu' lungo. overflow:hidden sul .ess-hero-slider taglia l'eccedenza. */
	height: 300px;
}

/* Slide: tutte sovrapposte (assolute), solo .is-active visibile (opacity crossfade) */
.ess-hero-slide {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	padding: 16px 0 40px;
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	color: #ffffff;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.7s ease;
}
.ess-hero-slide.is-active {
	opacity: 1;
	pointer-events: auto;
}

/* Prima slide: <img> dedicato per LCP ottimale (preload-scanner-friendly).
   Le slide successive usano background-image. */
.ess-hero-slide__bg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
	z-index: 0;
}
.ess-hero-slide__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, rgba(14,36,56,0.82) 0%, rgba(14,36,56,0.50) 60%, rgba(14,36,56,0.20) 100%);
	z-index: 1;
	pointer-events: none;
}

.ess-hero-slide__inner {
	position: relative;
	z-index: 2;
	max-width: 720px;
	padding-left: var(--ess-pad-x, 48px);
	padding-right: var(--ess-pad-x, 48px);
}
@media (max-width: 767px) {
	.ess-hero-slide__inner { padding-left: 24px; padding-right: 24px; }
	.ess-hero-slider { min-height: 250px; }
	.ess-hero-slider__viewport { height: 250px; }
	.ess-hero-slide { padding: 12px 0 36px; }
}

.ess-hero-slide__eyebrow {
	font-family: var(--ess-font-mono);
	font-size: 11px;
	color: var(--ess-orange);
	letter-spacing: 1.2px;
	text-transform: uppercase;
	margin: 0 0 10px;
}

.ess-hero-slide__title {
	font-family: var(--ess-font-serif);
	/* Compatto: max 38px (era 58px). A 38px anche il titolo piu' lungo resta su
	   2 righe, cosi' l'hero basso non si taglia (dots overlay in fondo). */
	font-size: clamp(1.6rem, 0.9rem + 2.2vw, 2.375rem); /* 25.6px–38px */
	line-height: 1.08;
	letter-spacing: -1px;
	margin: 0 0 10px;
	color: #ffffff;
}

.ess-hero-slide__sub {
	font-size: 15px;
	line-height: 1.5;
	max-width: 540px;
	margin: 0 0 16px;
	color: #ffffff;
	opacity: 0.92;
}

.ess-hero-slide__ctas {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

/* CTA secondaria: outline bianco su immagine — funziona anche quando il bg cambia tra slide */
.ess-hero-slide__cta-secondary {
	background: transparent;
	color: #ffffff;
	border: 1px solid #ffffff;
}
.ess-hero-slide__cta-secondary:hover,
.ess-hero-slide__cta-secondary:focus-visible {
	background: #ffffff;
	color: var(--ess-navy);
	border-color: #ffffff;
}

/* DOTS — pill shape, current slide larga, WCAG 2.4.7 focus visible */
.ess-hero-slider__dots {
	position: absolute;
	left: 50%;
	bottom: 14px;
	transform: translateX(-50%);
	display: flex;
	gap: 8px;
	z-index: 3;
}
.ess-hero-slider__dot {
	width: 10px;
	height: 4px;
	padding: 0;
	background: rgba(255, 255, 255, 0.5);
	border: 0;
	cursor: pointer;
	transition: width 0.3s, background 0.3s;
}
.ess-hero-slider__dot.is-active {
	width: 28px;
	background: var(--ess-orange);
}
.ess-hero-slider__dot:focus-visible {
	outline: 2px solid #ffffff;
	outline-offset: 3px;
}

/* ARROWS — 40x40 (≥44px coverage with click padding) */
.ess-hero-slider__arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 44px;
	height: 44px;
	background: rgba(0, 0, 0, 0.3);
	border: 1px solid rgba(255, 255, 255, 0.4);
	color: #ffffff;
	cursor: pointer;
	font-size: 20px;
	line-height: 1;
	z-index: 3;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.ess-hero-slider__arrow:hover {
	background: rgba(0, 0, 0, 0.5);
	border-color: #ffffff;
}
.ess-hero-slider__arrow:focus-visible {
	outline: 2px solid #ffffff;
	outline-offset: 3px;
}
.ess-hero-slider__arrow--prev { left: 16px; }
.ess-hero-slider__arrow--next { right: 16px; }

/* Reduce motion: disabilita transizione e autoplay (gestito da JS data-attribute) */
@media (prefers-reduced-motion: reduce) {
	.ess-hero-slide { transition: none; }
}

/* ==========================================================================
   1.b. HERO SPLIT (LEGACY) — preservato per backward-compat se chiamato direttamente.
   La funzione ess_render_hero_split() ora delega a ess_render_hero_slider(),
   ma se template custom usa ancora la classe, il CSS non si rompe.
   ========================================================================== */

.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 — Layout v2 (4.4.5): 6 macro tile uniformi 3×2 + accent strip
   Riferimento: deploy/mockups/homepage-v2.html
   ========================================================================== */

.ess-cats-section { background: var(--ess-color-surface, #f5f1e8); }

.ess-cats-grid-v2 {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 16px;
}
@media (max-width: 1023px) { .ess-cats-grid-v2 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 639px)  { .ess-cats-grid-v2 { grid-template-columns: 1fr; } }

.ess-cats-grid-v2__tile {
	position: relative;
	aspect-ratio: 16/9; /* letterbox più contenuto (era 4/3 = troppo alto/invasivo) */
	overflow: hidden;
	text-decoration: none;
	color: #fff;
	display: block;
	transition: transform 300ms;
}
.ess-cats-grid-v2__tile:hover { transform: translateY(-4px); }
.ess-cats-grid-v2__tile:hover .ess-cats-grid-v2__bg { transform: scale(1.06); }
.ess-cats-grid-v2__tile:focus-visible {
	outline: 2px solid var(--ess-color-terra, #c5552d);
	outline-offset: 2px;
}

.ess-cats-grid-v2__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	transition: transform 600ms;
}
.ess-cats-grid-v2__bg--placeholder { display: flex; align-items: center; justify-content: center; }
.ess-cats-grid-v2__bg--placeholder .ess-placeholder { width: 100%; height: 100%; }

.ess-cats-grid-v2__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(22,21,18,0.10) 0%, rgba(22,21,18,0.85) 100%);
	pointer-events: none;
}

.ess-cats-grid-v2__content {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	justify-content: end;
	padding: 18px 20px; /* era 24px — più compatto */
	z-index: 1;
}
.ess-cats-grid-v2__count {
	font-family: var(--ess-font-mono);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 1.2px;
	text-transform: uppercase;
	opacity: 0.9;
	margin-bottom: 4px;
}
.ess-cats-grid-v2__title {
	font-family: var(--ess-font-serif);
	font-size: 22px; /* era 28px — proporzionato a card più bassa */
	line-height: 1.1;
	margin: 0 0 8px; /* era 12px */
	letter-spacing: -0.02em;
	font-weight: 500;
	/* Override h3 default color (navy) — il tile ha gradient scuro sotto */
	color: #ffffff;
}
.ess-cats-grid-v2__cta {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--ess-font-mono);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 1.2px;
	text-transform: uppercase;
	padding-top: 12px;
	border-top: 1px solid rgba(255,255,255,0.3);
	width: fit-content;
	transition: gap 200ms;
}
.ess-cats-grid-v2__cta::after { content: '→'; font-size: 16px; }
.ess-cats-grid-v2__tile:hover .ess-cats-grid-v2__cta { gap: 14px; }

/* Accent strip top — palette Warm Mediterranean per macro */
.ess-cats-grid-v2__tile::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 3px;
	z-index: 2;
}
.ess-cats-grid-v2__tile--ink::before    { background: var(--ess-ink, #161512); }
.ess-cats-grid-v2__tile--ulivo::before  { background: var(--ess-ulivo, #6b7a3a); }
.ess-cats-grid-v2__tile--terra::before  { background: var(--ess-terra, #c5552d); }
.ess-cats-grid-v2__tile--limone::before { background: var(--ess-limone, #e8c341); }
.ess-cats-grid-v2__tile--sea::before    { background: var(--ess-sea, #0e4d64); }
.ess-cats-grid-v2__tile--cocoa::before  { background: var(--ess-cocoa, #6b3e2f); }

@media (max-width: 639px) {
	.ess-cats-grid-v2__tile { aspect-ratio: 5/3; } /* era 16/10 — più contenuto su mobile */
	.ess-cats-grid-v2__title { font-size: 18px; } /* era 22px */
	.ess-cats-grid-v2__content { padding: 14px 16px; } /* era 20px */
}

@media (prefers-reduced-motion: reduce) {
	.ess-cats-grid-v2__tile,
	.ess-cats-grid-v2__bg,
	.ess-cats-grid-v2__cta { transition: none !important; }
	.ess-cats-grid-v2__tile:hover { transform: none; }
	.ess-cats-grid-v2__tile:hover .ess-cats-grid-v2__bg { transform: none; }
}

/* ==========================================================================
   3-LEGACY. CATEGORIES — grid asimmetrica deprecated (mantenuta per compat)
   ========================================================================== */

.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;
}

/* Store card cover height: 140px (homepage editorial) — vs ess-stores-dir__cover 110px (directory list, denser).
   Pattern: altezza esplicita su entrambe (NO aspect-ratio), differenza voluta per gerarchia visiva. */
.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);
}

/* ==========================================================================
   2.b. FEATURED PRODUCTS — "Selezionati per te" 5-col grid (prototipo §01)
   ========================================================================== */

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

/* Mobile 2-col grid: nascondi il 5° prodotto (orfano in riga finale 2+2+1).
   Si applica solo se sono presenti ≥5 elementi. Tablet (3-col) e desktop (5-col)
   non hanno mai un orfano con 5, quindi non servono override. */
@media (max-width: 767px) {
	.ess-featured-products__grid > li:nth-child(5) {
		display: none;
	}
}

/* Variante .ess-btn--sm: button compatto per header sezioni "Vedi tutti" */
.ess-btn--sm {
	padding: 10px 18px;
	font-size: 11px;
	letter-spacing: 1px;
}

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

/* Mobile 2-col grid: nascondi il 5° prodotto (orfano in riga finale 2+2+1). */
@media (max-width: 767px) {
	.ess-flash-offers > li:nth-child(5) {
		display: none;
	}
}

/* ==========================================================================
   7. BLOG PREVIEW — 3-col cards su bg surface (prototipo §05)
   ========================================================================== */

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

.ess-blog-preview__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 20px;
}
@media (min-width: 768px)  { .ess-blog-preview__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .ess-blog-preview__grid { grid-template-columns: repeat(3, 1fr); } }

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

.ess-blog-card__cover {
	position: relative;
	height: 180px;
	overflow: hidden;
}
.ess-blog-card__cover img,
.ess-blog-card__cover .ess-placeholder {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Categoria badge top-left, bg ink (navy), font mono uppercase 9px */
.ess-blog-card__cat {
	position: absolute;
	top: 12px;
	left: 12px;
	background: var(--ess-navy);
	color: #ffffff;
	font-family: var(--ess-font-mono);
	font-size: 9px;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	padding: 4px 9px;
}

.ess-blog-card__body {
	padding: 18px;
}

.ess-blog-card__meta {
	font-size: 10px;
	color: var(--ess-muted-aa);  /* WCAG AA 4.59:1 (era --ess-muted 3.68:1) */
	font-family: var(--ess-font-mono);
	letter-spacing: 0.5px;
	text-transform: uppercase;
	margin: 0 0 8px;
}

.ess-blog-card__title {
	font-family: var(--ess-font-serif);
	font-size: 22px;
	line-height: 1.15;
	margin: 0 0 8px;
	color: var(--ess-navy);
}

.ess-blog-card__excerpt {
	font-size: 13px;
	color: var(--ess-navy-soft);
	line-height: 1.5;
	margin: 0;
}

/* ==========================================================================
   8. CTA STRIP — banner ink "Sei un'azienda?" (prototipo §CTA)
   ========================================================================== */

.ess-cta-strip {
	background: var(--ess-navy);
	color: #ffffff;
	padding: 28px 0;
	/* Stacco dal footer: la striscia CTA e il footer hanno lo stesso ink (#161512)
	   e altrimenti si fonderebbero. Il margine mostra il fondo pagina chiaro,
	   separando nettamente la striscia dal footer. */
	margin-bottom: 56px;
}
@media (min-width: 768px) { .ess-cta-strip { margin-bottom: 72px; } }

.ess-cta-strip__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}

.ess-cta-strip__text {
	display: flex;
	align-items: center;
	gap: 20px;
	flex: 1;
	min-width: 320px;
}

.ess-cta-strip__eyebrow {
	color: var(--ess-orange);  /* su bg navy: 4.0:1 → AA-large only, va bene per eyebrow short */
	white-space: nowrap;
	margin: 0;
}

.ess-cta-strip__divider {
	display: none;
	width: 1px;
	height: 32px;
	background: rgba(255, 255, 255, 0.2);
	flex-shrink: 0;
}
@media (min-width: 640px) { .ess-cta-strip__divider { display: block; } }

.ess-cta-strip__title {
	font-family: var(--ess-font-serif);
	font-size: 22px;
	line-height: 1.2;
	margin: 0;
	color: #ffffff;
}

/* L'italic-orange su bg navy: 4.0:1 → ok solo per LARGE TEXT (qui 22px ≥ 18pt = ok) */
.ess-cta-strip .ess-italic-orange {
	color: var(--ess-orange);
}

/* ==========================================================================
   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;
}
/* Seller band ha BG --ess-sea (#1a3a5c) — orange su sea = 4.0:1, AA-LG only.
 * Per H2 ≥ 18pt qui, AA-LG sufficiente; mantengo --ess-orange come accento brand. */
.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: 12px 0 16px;
	margin-bottom: 20px;
	border-bottom: 1px solid var(--ess-line);
	flex-wrap: wrap;
	font-family: var(--ess-font-body);
	background: #ffffff;
}
/* Desktop: sticky bar — segue lo scroll e resta accessibile su archive lunghi.
   Mobile: torna statica (sticky+drawer mobile = cattivo UX). */
@media (min-width: 768px) {
	.ess-sort-bar {
		position: sticky;
		top: 0;
		z-index: 40;
		padding: 14px 0 14px;
		margin-bottom: 20px;
		box-shadow: 0 1px 0 var(--ess-line);
	}
}
.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 {
	display: flex;
	align-items: center;
	gap: 12px;
}
.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;
}

/* ==========================================================================
   VIEW TOGGLE (Griglia | Lista) — desktop only
   ----
   Button group con due icone, switcha layout `.products` (CSS-only via
   classe `.is-view-list` applicata dal JS). Attivo: bg ink, icona bianca.
   ========================================================================== */
.ess-view-toggle {
	display: inline-flex;
	align-items: stretch;
	border: 1px solid var(--ess-line-strong);
	border-radius: 0;
	overflow: hidden;
}
.ess-view-toggle__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	padding: 0;
	background: #ffffff;
	border: 0;
	color: var(--ess-muted-aa);
	cursor: pointer;
	transition: background-color 0.15s ease, color 0.15s ease;
}
.ess-view-toggle__btn + .ess-view-toggle__btn {
	border-left: 1px solid var(--ess-line-strong);
}
.ess-view-toggle__btn:hover {
	color: var(--ess-navy);
	background: var(--ess-surface);
}
.ess-view-toggle__btn:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: 2px;
	z-index: 1;
}
.ess-view-toggle__btn.is-active {
	background: var(--ess-navy);
	color: #ffffff;
}
.ess-view-toggle__btn svg { display: block; }

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

/* ─── Mega-menu + Drawer (v4) ─────────────────────────────────────────────
   Desktop (>=1024px): mega-menu 3-col (root | subs | teaser) con sticky footer.
   Mobile  (<1024px):  drawer left-edge 92vw + scrim 8vw, drilldown push-panel L0->L1->L2.
   ──────────────────────────────────────────────────────────────────────── */

:root {
	--ess-mega-bg:        #ffffff;
	--ess-mega-border:    var(--ess-line);
	--ess-mega-shadow:    0 12px 32px -8px rgba(11, 10, 9, 0.18);
	--ess-mega-z:         60;
	--ess-drawer-width:   92vw;
	--ess-drawer-max:     420px;
	--ess-drawer-z:       1100;
}

/* ════════════════════════════════════════════════════════════════════════
   MEGA-MENU (desktop >=1024px)
   ════════════════════════════════════════════════════════════════════════ */

.ess-mega {
	position: relative;
	display: flex;
	align-items: center;
	flex: 1 1 auto;
}

/* Trigger row (menubar) */
.ess-mega__triggers {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: stretch;
	gap: 0;
	flex-wrap: wrap;
}

.ess-mega__item {
	margin: 0;
	padding: 0;
	display: flex;
	align-items: stretch;
}

/* Voci direct (Aziende + Offerte) — spinte a destra dello menubar.
   Il selettore "non-direct + direct" matcha il PRIMO direct sibling dopo
   l'ultimo trigger macro: applichiamo margin-left:auto solo su quello,
   così entrambi i direct vengono pushati a destra come gruppo. */
.ess-mega__item:not(.ess-mega__item--direct) + .ess-mega__item--direct {
	margin-left: auto;
}

.ess-mega__trigger,
.ess-mega__direct {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	min-height: 48px; /* WCAG 2.5.8 touch target */
	padding: 0.5rem 0.875rem;
	background: transparent;
	border: 0;
	border-bottom: 2px solid transparent;
	color: var(--ess-color-text);
	font: inherit;
	font-size: var(--ess-text-sm);
	font-weight: var(--ess-weight-medium);
	letter-spacing: 0.01em;
	cursor: pointer;
	transition: color 0.15s ease, border-color 0.15s ease, background-color 0.15s ease;
	text-decoration: none;
	white-space: nowrap;
}

.ess-mega__trigger > i,
.ess-mega__direct > i {
	font-size: 0.875rem;
	color: var(--ess-color-text-sec);
	transition: color 0.15s ease;
}

.ess-mega__trigger:hover,
.ess-mega__trigger:focus-visible,
.ess-mega__direct:hover,
.ess-mega__direct:focus-visible {
	color: var(--ess-color-accent);
	border-bottom-color: var(--ess-color-accent);
}
.ess-mega__trigger:hover > i,
.ess-mega__trigger:focus-visible > i,
.ess-mega__direct:hover > i,
.ess-mega__direct:focus-visible > i {
	color: var(--ess-color-accent);
}

.ess-mega__trigger[aria-expanded="true"] {
	color: var(--ess-color-accent);
	border-bottom-color: var(--ess-color-accent);
	background-color: var(--ess-color-bg-sec);
}

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

.ess-mega__chevron {
	flex-shrink: 0;
	transition: transform 0.18s ease;
}
.ess-mega__trigger[aria-expanded="true"] .ess-mega__chevron {
	transform: rotate(180deg);
}

.ess-mega__direct--accent {
	color: var(--ess-color-accent);
}

/* Panel — full-width drop sotto la subnav.
   Border-top 2px terra: ancoraggio visivo "questo dropdown appartiene al trigger
   sopra" + frame editorial premium (pattern Aesop/Kinfolk/Eataly). */
.ess-mega__panel {
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	z-index: var(--ess-mega-z);
	background: var(--ess-mega-bg);
	border-top: 2px solid var(--ess-color-accent);
	border-bottom: 1px solid var(--ess-mega-border);
	box-shadow: var(--ess-mega-shadow);
	max-height: calc(100vh - 200px);
	overflow-y: auto;
	overscroll-behavior: contain;
}

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

.ess-mega__panel-inner {
	display: grid;
	grid-template-columns: 260px 1fr 320px;
	gap: 2.5rem;
	padding: 2rem 1rem;
	align-items: start;
}

@media (min-width: 1280px) {
	.ess-mega__panel-inner {
		padding: 2.5rem 2rem;
	}
}

.ess-mega__col-title {
	font-family: var(--ess-font-mono);
	font-size: var(--ess-text-xs);
	font-weight: var(--ess-weight-medium);
	color: var(--ess-color-text-ter);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin: 0 0 1rem;
}

/* Col 1 — roots */
.ess-mega__roots {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.ess-mega__roots-item {
	margin: 0;
	padding: 0;
}

.ess-mega__root-btn {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem;
	min-height: 40px;
	padding: 0.5rem 0.75rem;
	background: transparent;
	border: 0;
	border-left: 2px solid transparent;
	color: var(--ess-color-text);
	font: inherit;
	font-size: var(--ess-text-base);
	text-align: left;
	cursor: pointer;
	transition: background-color 0.12s ease, border-color 0.12s ease, color 0.12s ease;
}
.ess-mega__root-btn:hover,
.ess-mega__root-btn:focus-visible,
.ess-mega__root-btn[aria-current="true"] {
	background: var(--ess-color-bg-sec);
	border-left-color: var(--ess-color-accent);
	color: var(--ess-color-accent);
}
.ess-mega__root-btn:focus-visible {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: 2px;
}

.ess-mega__count,
.ess-mega__sub-count {
	font-family: var(--ess-font-mono);
	font-size: var(--ess-text-xs);
	color: var(--ess-color-text-ter);
	background: var(--ess-color-bg-sec);
	padding: 2px 6px;
	border-radius: 999px;
	min-width: 24px;
	text-align: center;
	flex-shrink: 0;
}
.ess-mega__root-btn[aria-current="true"] .ess-mega__count,
.ess-mega__root-btn:hover .ess-mega__count {
	background: #ffffff;
	color: var(--ess-color-accent);
}

/* Col 2 — subs */
.ess-mega__subs-wrap[hidden] {
	display: none;
}

.ess-mega__subs-title {
	margin: 0 0 1rem;
	padding-bottom: 0.75rem;
	border-bottom: 1px solid var(--ess-color-border);
}
.ess-mega__subs-title-link {
	font-family: var(--ess-font-serif);
	font-size: var(--ess-text-2xl);
	font-weight: 400;
	color: var(--ess-color-text);
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	letter-spacing: -0.02em;
	transition: color 0.15s ease;
}
.ess-mega__subs-title-link:hover,
.ess-mega__subs-title-link:focus-visible {
	color: var(--ess-color-accent);
}
.ess-mega__subs-title-arrow {
	font-size: 0.875em;
	color: var(--ess-color-text-ter);
	transition: transform 0.15s ease;
}
.ess-mega__subs-title-link:hover .ess-mega__subs-title-arrow {
	transform: translateX(3px);
	color: var(--ess-color-accent);
}

.ess-mega__subs {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	column-gap: 1.5rem;
	row-gap: 2px;
}

.ess-mega__subs-item {
	margin: 0;
	padding: 0;
}

.ess-mega__sub-link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem;
	min-height: 36px;
	padding: 0.375rem 0.5rem;
	color: var(--ess-color-text-sec);
	font-size: var(--ess-text-sm);
	text-decoration: none;
	border-radius: 2px;
	transition: color 0.12s ease, background-color 0.12s ease;
}
.ess-mega__sub-link:hover,
.ess-mega__sub-link:focus-visible {
	color: var(--ess-color-accent);
	background: var(--ess-color-bg-sec);
}
.ess-mega__sub-link:focus-visible {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: 1px;
}

.ess-mega__subs-empty {
	font-size: var(--ess-text-sm);
	color: var(--ess-color-text-ter);
	font-style: italic;
	margin: 0;
}

/* Hairline separator (tra sub product e sub merchant — riservato per estensioni future) */
.ess-mega__subs-separator {
	grid-column: 1 / -1;
	border: 0;
	border-top: 1px dashed var(--ess-color-border);
	margin: 0.75rem 0;
}

/* Col 3 — teaser editoriale */
.ess-mega__col--teaser {
	background: var(--ess-color-bg-sec);
	padding: 1.25rem;
	border: 1px solid var(--ess-color-border);
}

.ess-mega__teaser-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	font-family: var(--ess-font-mono);
	font-size: var(--ess-text-xs);
	color: var(--ess-color-accent);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-bottom: 0.5rem;
}

.ess-mega__teaser-title {
	font-family: var(--ess-font-serif);
	font-size: var(--ess-text-xl);
	font-weight: 400;
	color: var(--ess-color-text);
	margin: 0 0 1rem;
	letter-spacing: -0.01em;
}

.ess-mega__teaser-list {
	list-style: none;
	margin: 0 0 1rem;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.ess-mega__teaser-link {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.5rem;
	background: #ffffff;
	border: 1px solid transparent;
	color: var(--ess-color-text);
	text-decoration: none;
	transition: border-color 0.15s ease, transform 0.15s ease;
}
.ess-mega__teaser-link:hover,
.ess-mega__teaser-link:focus-visible {
	border-color: var(--ess-color-accent);
	transform: translateX(2px);
}
.ess-mega__teaser-link:focus-visible {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: 1px;
}

.ess-mega__teaser-thumb {
	flex-shrink: 0;
	width: 44px;
	height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--ess-color-bg-sec);
	color: var(--ess-color-accent);
	font-size: 1rem;
}

.ess-mega__teaser-meta {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.ess-mega__teaser-name {
	font-size: var(--ess-text-sm);
	font-weight: var(--ess-weight-medium);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.ess-mega__teaser-cta {
	font-family: var(--ess-font-mono);
	font-size: var(--ess-text-xs);
	color: var(--ess-color-accent);
	text-transform: uppercase;
	letter-spacing: 0.06em;
}

.ess-mega__teaser-all {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	font-size: var(--ess-text-sm);
	font-weight: var(--ess-weight-medium);
	color: var(--ess-color-accent);
	text-decoration: none;
	padding: 0.5rem 0;
	transition: gap 0.15s ease;
}
.ess-mega__teaser-all:hover,
.ess-mega__teaser-all:focus-visible {
	gap: 0.625rem;
	text-decoration: underline;
}
.ess-mega__teaser-all:focus-visible {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: 2px;
}

/* Sticky footer del panel */
.ess-mega__panel-foot {
	border-top: 1px solid var(--ess-color-border);
	background: var(--ess-color-bg-sec);
	padding: 0.875rem 1rem;
	position: sticky;
	bottom: 0;
}

.ess-mega__panel-foot-inner {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1.5rem;
	flex-wrap: wrap;
}

.ess-mega__foot-link {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	font-size: var(--ess-text-sm);
	color: var(--ess-color-text-sec);
	text-decoration: none;
	font-weight: var(--ess-weight-medium);
	transition: color 0.12s ease;
}
.ess-mega__foot-link:hover,
.ess-mega__foot-link:focus-visible {
	color: var(--ess-color-accent);
}
.ess-mega__foot-link:focus-visible {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: 2px;
}
.ess-mega__foot-link--accent {
	color: var(--ess-color-accent);
}

/* Live region — visivamente nascosta ma letta da SR */
.ess-mega__live {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* Hide mega su <1024px — il drawer mobile ne prende il posto */
@media (max-width: 1023.98px) {
	.ess-mega {
		display: none;
	}
}

/* Layout panel a 2 colonne se viewport stretto (1024-1199) */
@media (min-width: 1024px) and (max-width: 1199.98px) {
	.ess-mega__panel-inner {
		grid-template-columns: 220px 1fr;
	}
	.ess-mega__col--teaser {
		grid-column: 1 / -1;
		display: grid;
		grid-template-columns: auto 1fr auto;
		gap: 1rem;
		align-items: center;
	}
	.ess-mega__teaser-title { margin-bottom: 0; }
	.ess-mega__teaser-list  { display: none; }
}

/* ════════════════════════════════════════════════════════════════════════
   DRAWER (mobile <1024px) — drilldown push-panel
   ════════════════════════════════════════════════════════════════════════ */

.ess-drawer {
	position: fixed;
	top: 0;
	left: 0;
	bottom: 0;
	width: var(--ess-drawer-width);
	max-width: var(--ess-drawer-max);
	background: var(--ess-mega-bg);
	z-index: var(--ess-drawer-z);
	display: flex;
	flex-direction: column;
	transform: translateX(-100%);
	transition: transform 240ms ease-out;
	box-shadow: 6px 0 32px -8px rgba(11, 10, 9, 0.25);
}
.ess-drawer:not([hidden]) {
	transform: translateX(0);
}

/* Scrim — riusa la classe esistente .ess-mobile-overlay per back-compat con il JS pre-esistente */
.ess-drawer__scrim {
	position: fixed;
	inset: 0;
	background: rgba(11, 10, 9, 0.45);
	opacity: 0;
	visibility: hidden;
	transition: opacity 240ms ease-out, visibility 240ms;
	z-index: calc(var(--ess-drawer-z) - 1);
}
.ess-drawer__scrim.ess-mobile-overlay--active {
	opacity: 1;
	visibility: visible;
}

/* Head: back + title + close */
.ess-drawer__head {
	display: grid;
	grid-template-columns: 48px 1fr 48px;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem;
	border-bottom: 1px solid var(--ess-color-border);
	min-height: 56px;
	flex-shrink: 0;
}

.ess-drawer__back,
.ess-drawer__close {
	width: 48px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: transparent;
	border: 0;
	color: var(--ess-color-text);
	cursor: pointer;
	border-radius: 2px;
	transition: background-color 0.12s ease, color 0.12s ease;
}
.ess-drawer__back:hover,
.ess-drawer__close:hover {
	background: var(--ess-color-bg-sec);
}
.ess-drawer__back:focus-visible,
.ess-drawer__close:focus-visible {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: -2px;
}
.ess-drawer__back[hidden] {
	visibility: hidden;
	display: inline-flex;
}

.ess-drawer__title {
	font-family: var(--ess-font-serif);
	font-size: var(--ess-text-lg);
	font-weight: 400;
	margin: 0;
	color: var(--ess-color-text);
	text-align: center;
	letter-spacing: -0.01em;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* Search bar sticky in cima */
.ess-drawer__search {
	padding: 0.75rem;
	border-bottom: 1px solid var(--ess-color-border);
	flex-shrink: 0;
	background: var(--ess-color-bg-sec);
}

/* Track — ospita i 3 panel in stack */
.ess-drawer__track {
	flex: 1 1 auto;
	overflow: hidden;
	position: relative;
}

.ess-drawer__panel {
	position: absolute;
	inset: 0;
	overflow-y: auto;
	overscroll-behavior: contain;
	background: var(--ess-mega-bg);
	transform: translateX(100%);
	transition: transform 240ms ease-out;
	-webkit-overflow-scrolling: touch;
}
.ess-drawer__panel--l0 {
	transform: translateX(0);
}
.ess-drawer__panel.is-active {
	transform: translateX(0);
}
.ess-drawer__panel.is-prev {
	transform: translateX(-30%);
}
.ess-drawer__panel[hidden] {
	display: none;
}

.ess-drawer__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.ess-drawer__list-item {
	margin: 0;
	padding: 0;
	border-bottom: 1px solid var(--ess-color-border);
}

.ess-drawer__list-item--separator {
	height: 0.5rem;
	background: var(--ess-color-bg-sec);
	border-top: 1px solid var(--ess-color-border);
	border-bottom: 1px solid var(--ess-color-border);
}

.ess-drawer__row {
	width: 100%;
	display: flex;
	align-items: center;
	gap: 0.75rem;
	min-height: 56px; /* WCAG 2.5.8 + comodo touch */
	padding: 0.75rem 1rem;
	background: transparent;
	border: 0;
	color: var(--ess-color-text);
	font: inherit;
	font-size: var(--ess-text-base);
	text-align: left;
	text-decoration: none;
	cursor: pointer;
	transition: background-color 0.12s ease, color 0.12s ease;
}
.ess-drawer__row:hover,
.ess-drawer__row:active {
	background: var(--ess-color-bg-sec);
}
.ess-drawer__row:focus-visible {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: -2px;
}

.ess-drawer__row-icon {
	flex-shrink: 0;
	width: 28px;
	height: 28px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--ess-color-accent);
	font-size: 1rem;
}

.ess-drawer__row-label {
	flex: 1 1 auto;
	font-weight: var(--ess-weight-medium);
	min-width: 0;
}

.ess-drawer__row-count {
	font-family: var(--ess-font-mono);
	font-size: var(--ess-text-xs);
	color: var(--ess-color-text-ter);
	background: var(--ess-color-bg-sec);
	padding: 2px 8px;
	border-radius: 999px;
	flex-shrink: 0;
}

.ess-drawer__row-arrow {
	flex-shrink: 0;
	color: var(--ess-color-text-ter);
}

.ess-drawer__row--accent .ess-drawer__row-label {
	color: var(--ess-color-accent);
}
.ess-drawer__row--accent .ess-drawer__row-icon {
	color: var(--ess-color-accent);
}

.ess-drawer__row--all {
	background: var(--ess-color-bg-sec);
	font-weight: var(--ess-weight-semibold);
}
.ess-drawer__row--all .ess-drawer__row-label {
	color: var(--ess-color-accent);
}

/* Foot drawer */
.ess-drawer__foot {
	padding: 1rem;
	border-top: 1px solid var(--ess-color-border);
	background: var(--ess-color-bg-sec);
	flex-shrink: 0;
}

/* Riduci-motion: niente slide-X, solo fade rapido. */
@media (prefers-reduced-motion: reduce) {
	.ess-drawer,
	.ess-drawer__panel,
	.ess-drawer__scrim {
		transition-duration: 80ms;
		transition-property: opacity;
	}
	.ess-drawer {
		transition-property: opacity;
		transform: none;
	}
	.ess-drawer[hidden] {
		opacity: 0;
		visibility: hidden;
	}
	.ess-drawer:not([hidden]) {
		opacity: 1;
		visibility: visible;
	}
	.ess-drawer__panel {
		transition: none;
		transform: translateX(0);
	}
	.ess-drawer__panel[hidden] {
		display: none;
	}
}

/* Hide drawer su desktop >=1024px — il mega lo sostituisce. */
@media (min-width: 1024px) {
	.ess-drawer,
	.ess-drawer__scrim {
		display: none !important;
	}
}

/* ─── Single Category Templates (v4) ────────────────────────────────────────
   Templates: taxonomy-product_cat.php / taxonomy-store_category.php
   - Banner editoriale full-width con accent colorato (--ess-cat-accent)
   - Chip strip orizzontale con scroll-snap-type x mandatory + arrow buttons
   - Mini-mappa Mapbox (200x200 standard / 320x180 prominent)
   - Tab segmented (pill style, aria-selected fill)
   - Listing layout 280px / 1fr
   ────────────────────────────────────────────────────────────────────────── */

.ess-cat-page {
	--ess-cat-accent: var(--ess-color-accent, #E8792B);
	min-height: 60vh;
}

.ess-cat-page__container {
	margin-top: 1.25rem;
}
@media (min-width: 768px) {
	.ess-cat-page__container {
		margin-top: 1.5rem;
	}
}

/* Banner editoriale — la linea arancio (::before) si poggia direttamente sotto
   l'header (border-bottom 1px) e funge da separatore visivo tra menu e banner.
   Padding-top contenuto (16px mobile / 20px desktop) per accorciare la distanza
   menu↔breadcrumb senza schiacciare il titolo. */
.ess-cat-page__banner {
	background: linear-gradient(135deg, color-mix(in srgb, var(--ess-cat-accent) 8%, var(--ess-color-bg-sec, #FAF7F2)) 0%, var(--ess-color-bg-sec, #FAF7F2) 100%);
	border-bottom: 1px solid var(--ess-color-border, #E8E2D5);
	padding: 0.25rem 0 1.25rem;
	position: relative;
}
.ess-cat-page__banner::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 4px;
	background: var(--ess-cat-accent);
}
.ess-cat-page__banner-inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.25rem;
	align-items: center;
}
@media (min-width: 768px) {
	.ess-cat-page__banner {
		padding: 0.375rem 0 1.5rem;
	}
	/* Two-column layout solo se c'è contenuto editoriale a destra
	   (description o banner image). Senza right-rail il banner resta single-col. */
	.ess-cat-page__banner--two-col .ess-cat-page__banner-inner {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1.15fr);
		gap: 2rem;
	}
}
.ess-cat-page__crumbs {
	margin-bottom: 0.3rem;
	font-size: 0.78rem;
}
.ess-cat-page__title {
	font-size: clamp(1.75rem, 1.2rem + 2.5vw, 3rem);
	font-weight: 700;
	line-height: 1.1;
	margin: 0 0 0.5rem;
	color: var(--ess-color-text, #1A1A1A);
}
.ess-cat-page__count {
	font-family: var(--ess-font-mono, monospace);
	font-size: 0.85rem;
	color: var(--ess-color-text-mute, #555);
	margin: 0;
	letter-spacing: 0.02em;
}
.ess-cat-page__count strong {
	color: var(--ess-cat-accent);
	font-weight: 700;
}

/* RIGHT COLUMN — descrizione editoriale breve (term->description) e/o banner image.
   On mobile sta sotto al titolo (single-column grid). On desktop fianco al titolo. */
.ess-cat-page__banner-aside {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	padding-left: 0;
	border-left: none;
}
@media (min-width: 768px) {
	.ess-cat-page__banner-aside {
		padding-left: 1.5rem;
		border-left: 1px solid color-mix(in srgb, var(--ess-cat-accent) 20%, transparent);
	}
}
.ess-cat-page__desc {
	font-size: 0.95rem;
	line-height: 1.55;
	color: var(--ess-color-text-mute, #555);
	margin: 0;
	max-width: 68ch;
}
@media (min-width: 768px) {
	.ess-cat-page__desc {
		font-size: 0.975rem;
	}
}
.ess-cat-page__banner-media {
	margin: 0;
}
.ess-cat-page__banner-media img {
	width: 100%;
	height: auto;
	border-radius: 0;
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.08);
	display: block;
}

/* LONG DESCRIPTION — sezione editoriale SEO long-form sotto la pagination.
   Pattern Idealo/Trovaprezzi: 300-800 parole, contestualizza la categoria,
   ranking long-tail. Larghezza limitata a 72ch per leggibilità (regola tipografica). */
.ess-cat-page__long-desc {
	margin: 3rem 0 1rem;
	padding-top: 2rem;
	border-top: 1px solid var(--ess-color-border, #E8E2D5);
}
.ess-cat-page__long-desc-inner {
	max-width: 72ch;
	margin-left: auto;
	margin-right: auto;
}
.ess-cat-page__long-desc-title {
	font-size: clamp(1.25rem, 1.05rem + 0.9vw, 1.625rem);
	font-weight: 700;
	line-height: 1.2;
	margin: 0 0 1rem;
	color: var(--ess-color-text, #1A1A1A);
	position: relative;
	padding-bottom: 0.5rem;
}
.ess-cat-page__long-desc-title::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 48px;
	height: 3px;
	background: var(--ess-cat-accent);
}

/* Long-form content territoriale (page-territorio.php — 4.4.4).
   Wrapper sezione full-width con padding asimmetrico, fondo carta + accent left
   border in territory-color (var --ess-territory-accent, settata inline dal template). */
.ess-territory__long-content {
	background: var(--ess-color-surface, #f8f6f1);
	padding: 4rem 0;
	margin-top: 2rem;
	border-top: 1px solid var(--ess-color-line, #e5e0d6);
}
.ess-territory__prose {
	max-width: 760px;
	margin-inline: auto;
}
.ess-territory__prose h2 {
	font-size: clamp(1.5rem, 2.5vw, 2rem);
	font-family: var(--ess-font-serif, Georgia, serif);
	font-weight: 600;
	line-height: 1.2;
	margin: 0 0 1.5rem;
	color: var(--ess-color-text, #1A1A1A);
}
.ess-territory__prose h3 {
	font-size: 1.25rem;
	font-family: var(--ess-font-serif, Georgia, serif);
	font-weight: 600;
	margin: 2.5rem 0 0.75rem;
	color: var(--ess-territory-accent, var(--ess-color-text, #1A1A1A));
	border-left: 3px solid var(--ess-territory-accent, var(--ess-color-line));
	padding-left: 0.75rem;
}
.ess-territory__prose p {
	margin: 0 0 1.25rem;
	font-size: 1.0625rem;
	line-height: 1.75;
	color: var(--ess-color-text-soft, #2c2c2c);
}
.ess-territory__prose strong {
	color: var(--ess-color-text, #1A1A1A);
	font-weight: 600;
}
.ess-territory__prose em {
	font-style: italic;
	color: var(--ess-territory-accent, var(--ess-color-text-soft, #2c2c2c));
}
@media (max-width: 767px) {
	.ess-territory__long-content { padding: 2.5rem 0; }
	.ess-territory__prose p { font-size: 1rem; }
}

/* ess-prose — utility typography per contenuto editoriale long-form (long
   description, blocchi rich-text). Tipografia leggibile, spaziature consistenti,
   no margin-top sul primo elemento, no margin-bottom sull'ultimo (rifila container). */
.ess-prose {
	font-size: 1rem;
	line-height: 1.7;
	color: var(--ess-color-text, #1A1A1A);
}
.ess-prose > *:first-child { margin-top: 0; }
.ess-prose > *:last-child  { margin-bottom: 0; }
.ess-prose p {
	margin: 0 0 1em;
}
.ess-prose h2,
.ess-prose h3,
.ess-prose h4 {
	font-weight: 700;
	line-height: 1.3;
	margin: 1.5em 0 0.5em;
	color: var(--ess-color-text, #1A1A1A);
}
.ess-prose h2 { font-size: 1.25rem; }
.ess-prose h3 { font-size: 1.125rem; }
.ess-prose h4 { font-size: 1rem; }
.ess-prose ul,
.ess-prose ol {
	margin: 0 0 1em;
	padding-left: 1.5em;
}
.ess-prose li { margin-bottom: 0.35em; }
.ess-prose li:last-child { margin-bottom: 0; }
.ess-prose a {
	color: var(--ess-cat-accent, var(--ess-color-accent, #E8792B));
	text-decoration: underline;
	text-underline-offset: 2px;
	text-decoration-thickness: 1px;
}
.ess-prose a:hover,
.ess-prose a:focus-visible {
	text-decoration-thickness: 2px;
}
.ess-prose strong { font-weight: 700; }
.ess-prose em    { font-style: italic; }
.ess-prose blockquote {
	margin: 1.25em 0;
	padding: 0.5em 1em;
	border-left: 3px solid var(--ess-cat-accent);
	color: var(--ess-color-text-mute, #555);
	font-style: italic;
}

/* Chip strip — scroll-snap-type x mandatory mobile, fade edges */
.ess-cat-page__chips {
	position: relative;
	margin: 1.5rem 0 1.25rem;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}
.ess-cat-page__chips-track {
	display: flex;
	flex-wrap: nowrap;
	gap: 0.5rem;
	overflow-x: auto;
	overflow-y: hidden;
	-webkit-overflow-scrolling: touch;
	scroll-snap-type: x mandatory;
	scroll-padding-left: 1rem;
	padding: 0.25rem 1rem;
	margin: 0 -1rem;
	flex: 1 1 auto;
	scrollbar-width: none;
	mask-image: linear-gradient(to right, transparent 0, #000 24px, #000 calc(100% - 24px), transparent 100%);
	-webkit-mask-image: linear-gradient(to right, transparent 0, #000 24px, #000 calc(100% - 24px), transparent 100%);
}
.ess-cat-page__chips-track::-webkit-scrollbar { display: none; }

.ess-cat-page__chips-track > .ess-chip {
	scroll-snap-align: start;
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.5rem 1rem;
	min-height: 44px;
	border: 1px solid var(--ess-color-border, #E8E2D5);
	border-radius: 999px;
	background: var(--ess-color-bg, #FFF);
	color: var(--ess-color-text, #1A1A1A);
	text-decoration: none;
	font-size: 0.9rem;
	white-space: nowrap;
	transition: background 120ms ease, border-color 120ms ease, color 120ms ease;
}
.ess-cat-page__chips-track > .ess-chip:hover,
.ess-cat-page__chips-track > .ess-chip:focus-visible {
	background: var(--ess-color-bg-sec, #FAF7F2);
	border-color: var(--ess-cat-accent);
	color: var(--ess-cat-accent);
}
.ess-cat-page__chips-track > .ess-chip--active,
.ess-cat-page__chips-track > .ess-chip[aria-current="page"] {
	background: var(--ess-cat-accent);
	border-color: var(--ess-cat-accent);
	color: #FFF;
}
.ess-chip__count {
	font-family: var(--ess-font-mono, monospace);
	font-size: 0.78rem;
	opacity: 0.75;
}

/* Arrow buttons — desktop only */
.ess-cat-page__chips-arrow {
	flex: 0 0 auto;
	display: none;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	min-width: 36px;
	border: 1px solid var(--ess-color-border, #E8E2D5);
	border-radius: 50%;
	background: var(--ess-color-bg, #FFF);
	color: var(--ess-color-text, #1A1A1A);
	cursor: pointer;
	transition: background 120ms ease, border-color 120ms ease;
}
.ess-cat-page__chips-arrow:hover,
.ess-cat-page__chips-arrow:focus-visible {
	background: var(--ess-color-bg-sec, #FAF7F2);
	border-color: var(--ess-cat-accent);
}
.ess-cat-page__chips-arrow--prev .ess-icon { transform: rotate(90deg); }
.ess-cat-page__chips-arrow--next .ess-icon { transform: rotate(-90deg); }
.ess-cat-page__chips-arrow[hidden] { display: none !important; }
@media (min-width: 1024px) {
	.ess-cat-page__chips-arrow:not([hidden]) { display: inline-flex; }
}

/* Mini-map */
.ess-cat-page__map {
	margin: 1rem 0 1.5rem;
	border: 1px solid var(--ess-color-border, #E8E2D5);
	border-radius: 0;
	overflow: hidden;
	background: var(--ess-color-bg-sec, #FAF7F2);
}
.ess-cat-page__map-canvas {
	width: 100%;
	max-width: 100%;
	display: block;
	background:
		radial-gradient(circle at 30% 30%, color-mix(in srgb, var(--ess-cat-accent) 12%, transparent), transparent 60%),
		linear-gradient(135deg, #E8F2F7 0%, #D5E5EE 100%);
}
.ess-cat-page__map--prominent {
	margin: 1.25rem 0 2rem;
	box-shadow: 0 6px 18px rgba(26, 58, 92, 0.08);
}
.ess-cat-page__map--prominent .ess-cat-page__map-canvas {
	height: 180px !important;
	width: 100%;
}
.ess-cat-page__map-noscript {
	padding: 0.75rem 1rem;
	font-size: 0.85rem;
	color: var(--ess-color-text-mute, #555);
}

/* Tab segmented — pill style */
.ess-tab-segmented {
	display: inline-flex;
	gap: 0.25rem;
	padding: 0.25rem;
	background: var(--ess-color-bg-sec, #FAF7F2);
	border: 1px solid var(--ess-color-border, #E8E2D5);
	border-radius: 999px;
	margin: 0.5rem 0 1.5rem;
}
.ess-tab-segmented__btn {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.6rem 1.25rem;
	min-height: 44px;
	border: none;
	background: transparent;
	color: var(--ess-color-text, #1A1A1A);
	border-radius: 999px;
	font-size: 0.95rem;
	font-weight: 500;
	cursor: pointer;
	transition: background 140ms ease, color 140ms ease;
}
.ess-tab-segmented__btn[aria-selected="true"] {
	background: var(--ess-cat-accent);
	color: #FFF;
	font-weight: 600;
}
.ess-tab-segmented__btn:focus-visible {
	outline: 2px solid var(--ess-cat-accent);
	outline-offset: 2px;
}
.ess-tab-segmented__count {
	font-family: var(--ess-font-mono, monospace);
	font-size: 0.85rem;
	opacity: 0.85;
}

/* Pannelli (tabpanel content) */
.ess-cat-page__panel[hidden] { display: none; }
.ess-cat-page__panel { margin-bottom: 3rem; }

/* Layout sidebar + listing — 280px / 1fr (mobile-first stacked) */
.ess-cat-page__layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 1024px) {
	.ess-cat-page__layout {
		grid-template-columns: 280px minmax(0, 1fr);
		gap: 2rem;
	}
}

.ess-cat-page__sidebar {
	background: var(--ess-color-bg, #FFF);
	border: 1px solid var(--ess-color-border, #E8E2D5);
	border-radius: 0;
	padding: 1rem 1.25rem;
}
.ess-cat-page__sidebar-title {
	margin: 0 0 0.75rem;
	font-size: 0.78rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--ess-color-text-mute, #555);
}
.ess-cat-page__sidebar-empty {
	font-size: 0.85rem;
	color: var(--ess-color-text-mute, #555);
	margin: 0 0 0.5rem;
}
.ess-cat-page__hints {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}
.ess-cat-page__hint {
	font-size: 0.85rem;
	padding: 0.4rem 0.6rem;
	background: var(--ess-color-bg-sec, #FAF7F2);
	border-radius: 0;
}

.ess-cat-page__listing {
	min-width: 0; /* prevents grid blowout */
}

.ess-cat-page__empty {
	padding: 2rem 1rem;
	text-align: center;
	background: var(--ess-color-bg, #FFF);
	border: 1px dashed var(--ess-color-border, #E8E2D5);
	border-radius: 0;
}

.ess-cat-page__products-preview .products {
	margin: 0;
	padding: 0;
}
.ess-cat-page__preview-cta {
	margin-top: 1.5rem;
	text-align: center;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
	.ess-cat-page__chips-track {
		scroll-behavior: auto;
	}
	.ess-tab-segmented__btn,
	.ess-cat-page__chips-track > .ess-chip,
	.ess-cat-page__chips-arrow {
		transition-duration: 60ms;
	}
}

/* ───────────────────────────────────────────────────────────────────────
   Page Categorie Hub (v4)
   Directory hub stile Yelp/PagineGialle: hero + ToC sticky + sezioni
   per macro-area + grid card root con anteprima sub-cat.
   ─────────────────────────────────────────────────────────────────────── */

.ess-cat-hub {
	--ess-cat-hub-toc-width: 240px;
	--ess-cat-hub-gap: 1.5rem;
	--ess-cat-hub-radius: 0;       /* squadrato editorial (allineato shop card/CTA) */
}

/* ── Header directory (chiaro, coerente con .ess-cat-page__banner) ──────
   Niente hero "marketing" colorato: questa è una directory di categorie
   (stile Trovaprezzi). Header sobrio su carta + barra accent terra in cima,
   come l'header delle pagine categoria. La ricerca vive nell'header del sito,
   non duplicata qui. */
.ess-cat-hub__hero {
	background: var( --ess-surface, #f5f1e8 );
	color: var( --ess-color-text, #161512 );
	padding: clamp( 1rem, 3vw, 1.75rem ) 0 clamp( 1.25rem, 3vw, 2rem );
	margin-bottom: 2rem;
	border-bottom: 1px solid var( --ess-color-border, #e5dfd1 );
	position: relative;
}
.ess-cat-hub__hero::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 4px;
	background: var( --ess-terra, #c5552d );
}
.ess-cat-hub__hero .ess-breadcrumb {
	margin-bottom: 0.5rem;
}
.ess-cat-hub__hero-title {
	font-size: clamp( 1.75rem, 4vw, 2.5rem );
	line-height: 1.15;
	margin: 0;
	color: var( --ess-color-text, #161512 );
	font-weight: 700;
}

/* ── Body ─────────────────────────────────────────────────────────── */
.ess-cat-hub__body {
	padding-bottom: 3rem;
}

/* ── Griglia di card categoria (stile Trovaprezzi "Mappa Categorie") ─── */
.ess-cat-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
	align-items: start;
}
@media ( min-width: 480px ) {
	.ess-cat-grid {
		grid-template-columns: repeat( 2, 1fr );
	}
}
@media ( min-width: 768px ) {
	.ess-cat-grid {
		grid-template-columns: repeat( 3, 1fr );
		gap: 1.25rem;
	}
}
@media ( min-width: 1100px ) {
	.ess-cat-grid {
		grid-template-columns: repeat( 4, 1fr );
	}
}

/* ── Card categoria ──────────────────────────────────────────────── */
.ess-cat-tile {
	--ess-color-accent: var( --ess-terra, #c5552d );
	display: flex;
	flex-direction: column;
	background: #fff;
	border: 1px solid var( --ess-color-border, #e6e6e1 );
	border-top: 3px solid var( --ess-color-accent );
	padding: 1.1rem 1.1rem 0.9rem;
	transition: box-shadow 0.15s ease, transform 0.15s ease;
}
.ess-cat-tile:hover {
	box-shadow: 0 10px 24px rgba( 0, 0, 0, 0.08 );
	transform: translateY( -2px );
}
.ess-cat-tile__head {
	display: flex;
	align-items: center;
	gap: 0.625rem;
	text-decoration: none;
	margin-bottom: 0.75rem;
	padding-bottom: 0.75rem;
	border-bottom: 1px solid var( --ess-color-border, #e6e6e1 );
}
.ess-cat-tile__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	flex: 0 0 auto;
	color: var( --ess-color-accent );
	background: color-mix( in srgb, var( --ess-color-accent ) 12%, #fff );
}
.ess-cat-tile__title {
	margin: 0;
	font-size: 1.05rem;
	font-weight: 700;
	line-height: 1.2;
	color: var( --ess-color-text, #161512 );
}
.ess-cat-tile__head:hover .ess-cat-tile__title,
.ess-cat-tile__head:focus-visible .ess-cat-tile__title {
	color: var( --ess-terra-dark, #9e4323 );
}
.ess-cat-tile__head:focus-visible {
	outline: 3px solid var( --ess-color-accent );
	outline-offset: 3px;
}
.ess-cat-tile__subs {
	list-style: none;
	margin: 0 0 0.5rem;
	padding: 0;
}
.ess-cat-tile__subs li {
	margin: 0;
}
.ess-cat-tile__sub {
	display: block;
	padding: 0.3rem 0;
	min-height: 30px;
	color: var( --ess-color-text-sec, #3a362f );
	text-decoration: none;
	font-size: 0.9rem;
	line-height: 1.35;
}
.ess-cat-tile__sub:hover {
	color: var( --ess-terra-dark, #9e4323 );
	text-decoration: underline;
}
.ess-cat-tile__sub:focus-visible {
	outline: 2px solid var( --ess-color-accent );
	outline-offset: 2px;
}
.ess-cat-tile__all {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	margin-top: auto;
	padding-top: 0.5rem;
	color: var( --ess-terra-dark, #9e4323 );
	font-size: 0.875rem;
	font-weight: 600;
	text-decoration: none;
}
.ess-cat-tile__all:hover {
	text-decoration: underline;
}
.ess-cat-tile__all:focus-visible {
	outline: 2px solid var( --ess-color-accent );
	outline-offset: 2px;
}

/* ── CTA finale ──────────────────────────────────────────────────── */
.ess-cat-hub__cta {
	margin-top: 2rem;
	padding: 2.5rem 0;
	background: var( --ess-color-bg-alt, #f7f7f5 );
	border-top: 1px solid var( --ess-color-border, #e6e6e1 );
}
.ess-cat-hub__cta-inner {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 1.25rem;
}
@media ( min-width: 768px ) {
	.ess-cat-hub__cta-inner {
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
		gap: 2rem;
	}
}
.ess-cat-hub__cta-title {
	margin: 0 0 0.375rem;
	font-size: clamp( 1.375rem, 2.5vw, 1.75rem );
	font-weight: 700;
	color: var( --ess-color-secondary, #1E3A5F );
}
.ess-cat-hub__cta-lede {
	margin: 0;
	color: var( --ess-color-text, #111 );
	font-size: 1rem;
	line-height: 1.5;
}
.ess-cat-hub__cta-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.625rem;
	min-height: 48px;
	padding: 0.75rem 1.5rem;
	flex: 0 0 auto;
}

/* ── Reduced motion ──────────────────────────────────────────────── */
@media ( prefers-reduced-motion: reduce ) {
	.ess-cat-tile {
		transition: none;
	}
	.ess-cat-tile:hover {
		transform: none;
	}
}

/* ─── Territory Hub (v4) ──────────────────────────────────────────────────
   Hub editoriale per i 3 product_tag premium del territorio salernitano.
   - Accent dinamico via `--ess-territory-accent` settato inline da PHP.
   - Hero parallax leggero su desktop (background-attachment: fixed),
     scattered su mobile per evitare jitter iOS.
   - Layout mobile-first: 1 col → 2 col → 3 col.
   ----------------------------------------------------------------------- */

.ess-territory {
	--ess-territory-accent: var(--ess-sea, #0e4d64);
	--ess-territory-overlay: rgba(14, 77, 100, 0.62);
	--ess-territory-overlay-strong: rgba(14, 77, 100, 0.82);
}

/* === LANDING INDEX (3 card) ============================================ */
.ess-territory__landing {
	padding-top: 1.5rem;
}
.ess-territory__landing-head {
	max-width: 56rem;
	margin: 0 auto 2.5rem;
	text-align: center;
}
.ess-territory__landing-lead {
	margin-top: 0.75rem;
	font-size: 1.0625rem;
	line-height: 1.55;
	color: var(--ess-color-text-sec, #3a362f);
}

.ess-territory__landing-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.25rem;
}
@media (min-width: 640px) {
	.ess-territory__landing-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1.5rem;
	}
}
@media (min-width: 1024px) {
	.ess-territory__landing-grid {
		grid-template-columns: repeat(3, 1fr);
		gap: 1.75rem;
	}
}

.ess-territory__landing-card {
	display: flex;
	flex-direction: column;
	background: var(--ess-color-bg, #fff);
	border: 1px solid var(--ess-color-neutral-200, #e7e2d6);
	border-radius: 0;
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	transition: transform 200ms ease, box-shadow 200ms ease, border-color 200ms ease;
	min-height: 100%;
}
.ess-territory__landing-card:hover,
.ess-territory__landing-card:focus-visible {
	transform: translateY(-3px);
	box-shadow: 0 12px 28px rgba(8, 52, 68, 0.12);
	border-color: var(--ess-territory-accent);
}
.ess-territory__landing-card:focus-visible {
	outline: 3px solid var(--ess-territory-accent);
	outline-offset: 2px;
}

.ess-territory__landing-card-media {
	aspect-ratio: 16 / 10;
	background:
		linear-gradient(135deg, var(--ess-territory-accent), color-mix(in srgb, var(--ess-territory-accent) 65%, #000));
	overflow: hidden;
}
.ess-territory__landing-card-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 400ms ease;
}
.ess-territory__landing-card:hover .ess-territory__landing-card-media img {
	transform: scale(1.04);
}
.ess-territory__landing-card-fallback {
	display: block;
	width: 100%;
	height: 100%;
	background-image:
		linear-gradient(135deg, var(--ess-territory-accent) 0%, color-mix(in srgb, var(--ess-territory-accent) 50%, #000) 100%);
	background-size: cover;
}

.ess-territory__landing-card-body {
	padding: 1.25rem 1.25rem 1.5rem;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	flex: 1;
}
.ess-territory__landing-card-title {
	margin: 0;
	font-size: 1.25rem;
	line-height: 1.3;
	color: var(--ess-color-heading, #161512);
	font-weight: 700;
}
.ess-territory__landing-card-intro {
	margin: 0;
	color: var(--ess-color-text-sec, #3a362f);
	font-size: 0.9375rem;
	line-height: 1.55;
}
.ess-territory__landing-card-count {
	margin: 0.25rem 0 0;
	color: var(--ess-territory-accent);
	font-weight: 600;
	font-size: 0.875rem;
}
.ess-territory__landing-card-cta {
	margin-top: auto;
	padding-top: 0.75rem;
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-weight: 600;
	color: var(--ess-territory-accent);
	font-size: 0.9375rem;
}

/* === HERO FULL-WIDTH ===================================================== */
.ess-territory__hero {
	position: relative;
	min-height: 320px;
	display: flex;
	align-items: center;
	color: #fff;
	margin-top: 1rem;
	background-color: var(--ess-territory-accent);
	background-image: var(--ess-territory-hero, none);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	overflow: hidden;
	border-radius: 0;
}
.ess-territory__hero.no-image {
	background-image:
		linear-gradient(135deg, var(--ess-territory-accent) 0%, color-mix(in srgb, var(--ess-territory-accent) 55%, #000) 100%);
}

@media (min-width: 1024px) {
	.ess-territory__hero {
		min-height: 420px;
		/* Parallax effect: solo desktop, prefers-reduced-motion safe */
		background-attachment: fixed;
	}
}
@media (prefers-reduced-motion: reduce) {
	.ess-territory__hero {
		background-attachment: scroll !important;
	}
}

.ess-territory__hero-overlay {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(8, 52, 68, 0.35) 0%, var(--ess-territory-overlay-strong) 100%);
	pointer-events: none;
}
.ess-territory__hero.no-image .ess-territory__hero-overlay {
	background: linear-gradient(180deg, rgba(0, 0, 0, 0.05) 0%, rgba(0, 0, 0, 0.18) 100%);
}

.ess-territory__hero-inner {
	position: relative;
	z-index: 1;
	padding: 2.5rem 1rem;
}
@media (min-width: 768px) {
	.ess-territory__hero-inner {
		padding: 3.5rem 1rem;
	}
}

.ess-territory__hero-eyebrow {
	margin: 0 0 0.5rem;
	font-size: 0.8125rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: rgba(255, 255, 255, 0.85);
}
.ess-territory__hero-title {
	margin: 0 0 0.85rem;
	font-size: clamp(1.75rem, 4vw, 2.75rem);
	line-height: 1.1;
	color: #fff;
	font-weight: 800;
	max-width: 26ch;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.25);
}
.ess-territory__hero-intro {
	margin: 0 0 1rem;
	font-size: 1.0625rem;
	line-height: 1.55;
	max-width: 56ch;
	color: rgba(255, 255, 255, 0.95);
}
.ess-territory__hero-count {
	margin: 0 0 1.25rem;
	font-size: 0.9375rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.9);
}
.ess-territory__hero-cta {
	margin: 0;
}
.ess-territory__hero-cta .ess-btn--primary {
	background: #fff;
	color: var(--ess-territory-accent);
	border-color: #fff;
}
.ess-territory__hero-cta .ess-btn--primary:hover,
.ess-territory__hero-cta .ess-btn--primary:focus-visible {
	background: var(--ess-color-bg, #fff);
	color: color-mix(in srgb, var(--ess-territory-accent) 75%, #000);
}

/* === SECTION HEAD (riusato per vendors / products / editorial) =========== */
.ess-territory__section-head {
	margin-bottom: 1.5rem;
}
.ess-territory__section-head .ess-section__title {
	margin-bottom: 0.5rem;
	border-left: 4px solid var(--ess-territory-accent);
	padding-left: 0.75rem;
}
.ess-territory__section-sub {
	margin: 0;
	color: var(--ess-color-text-sec, #3a362f);
	font-size: 0.9375rem;
}

/* === VENDORS GRID ======================================================== */
.ess-territory__vendors-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
}
@media (min-width: 480px) {
	.ess-territory__vendors-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (min-width: 768px) {
	.ess-territory__vendors-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.ess-territory__vendor-card {
	background: var(--ess-color-bg, #fff);
	border: 1px solid var(--ess-color-neutral-200, #e7e2d6);
	border-radius: 0;
	transition: border-color 200ms ease, transform 200ms ease, box-shadow 200ms ease;
}
.ess-territory__vendor-card:hover {
	border-color: var(--ess-territory-accent);
	transform: translateY(-2px);
	box-shadow: 0 8px 18px rgba(8, 52, 68, 0.08);
}

.ess-territory__vendor-link {
	display: flex;
	align-items: center;
	gap: 0.85rem;
	padding: 1rem;
	text-decoration: none;
	color: inherit;
	border-radius: inherit;
}
.ess-territory__vendor-link:focus-visible {
	outline: 3px solid var(--ess-territory-accent);
	outline-offset: 2px;
}

.ess-territory__vendor-avatar {
	flex: 0 0 64px;
	width: 64px;
	height: 64px;
	border-radius: 50%;
	overflow: hidden;
	background: color-mix(in srgb, var(--ess-territory-accent) 14%, #fff);
	display: flex;
	align-items: center;
	justify-content: center;
}
.ess-territory__vendor-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.ess-territory__vendor-initial {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--ess-territory-accent);
}

.ess-territory__vendor-body {
	flex: 1;
	min-width: 0;
}
.ess-territory__vendor-name {
	margin: 0 0 0.25rem;
	font-size: 1rem;
	font-weight: 600;
	color: var(--ess-color-heading, #161512);
	line-height: 1.3;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.ess-territory__vendor-city {
	margin: 0 0 0.2rem;
	font-size: 0.8125rem;
	color: var(--ess-color-text-sec, #3a362f);
}
.ess-territory__vendor-count {
	margin: 0;
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--ess-territory-accent);
}

/* === PRODUCTS GRID (riusa .ess-product-card) ============================ */
.ess-territory__products-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem;
}
@media (min-width: 768px) {
	.ess-territory__products-grid {
		grid-template-columns: repeat(3, 1fr);
		gap: 1.25rem;
	}
}
@media (min-width: 1024px) {
	.ess-territory__products-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

/* === EDITORIAL LIST ====================================================== */
.ess-territory__editorial-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.75rem;
}
@media (min-width: 640px) {
	.ess-territory__editorial-list {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (min-width: 1024px) {
	.ess-territory__editorial-list {
		grid-template-columns: repeat(3, 1fr);
	}
}

.ess-territory__editorial-link {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.5rem;
	padding: 0.85rem 1rem;
	background: color-mix(in srgb, var(--ess-territory-accent) 6%, #fff);
	border: 1px solid color-mix(in srgb, var(--ess-territory-accent) 18%, #fff);
	border-radius: 0;
	text-decoration: none;
	color: var(--ess-color-text, #161512);
	font-weight: 500;
	transition: background-color 180ms ease, border-color 180ms ease, transform 180ms ease;
}
.ess-territory__editorial-link:hover {
	background: color-mix(in srgb, var(--ess-territory-accent) 12%, #fff);
	border-color: var(--ess-territory-accent);
	transform: translateX(2px);
}
.ess-territory__editorial-link:focus-visible {
	outline: 3px solid var(--ess-territory-accent);
	outline-offset: 2px;
}
.ess-territory__editorial-link svg {
	color: var(--ess-territory-accent);
	flex-shrink: 0;
}

/* === CTA finale (vendor onboarding) ====================================== */
.ess-territory__cta {
	background: var(--ess-color-neutral-100, #faf7f0);
}
.ess-territory__cta-card {
	max-width: 56rem;
	margin: 0 auto;
	padding: 2rem 1.5rem;
	text-align: center;
	border-radius: 0;
	background:
		linear-gradient(135deg, var(--ess-sea, #0e4d64) 0%, var(--ess-sea-dark, #083444) 100%);
	color: #fff;
}
@media (min-width: 768px) {
	.ess-territory__cta-card {
		padding: 2.75rem 2rem;
	}
}
.ess-territory__cta-title {
	margin: 0 0 0.5rem;
	font-size: clamp(1.375rem, 3vw, 1.875rem);
	color: #fff;
}
.ess-territory__cta-text {
	margin: 0 auto 1.25rem;
	max-width: 48ch;
	color: rgba(255, 255, 255, 0.92);
	font-size: 1rem;
	line-height: 1.55;
}
.ess-territory__cta .ess-btn--primary {
	background: var(--ess-limone, #e8c341);
	color: var(--ess-ink, #161512);
	border-color: var(--ess-limone, #e8c341);
}
.ess-territory__cta .ess-btn--primary:hover,
.ess-territory__cta .ess-btn--primary:focus-visible {
	background: color-mix(in srgb, var(--ess-limone, #e8c341) 88%, #000);
	border-color: color-mix(in srgb, var(--ess-limone, #e8c341) 88%, #000);
}

/* === Reduce motion ======================================================= */
@media (prefers-reduced-motion: reduce) {
	.ess-territory__landing-card,
	.ess-territory__landing-card-media img,
	.ess-territory__vendor-card,
	.ess-territory__editorial-link {
		transition: none !important;
	}
	.ess-territory__landing-card:hover,
	.ess-territory__vendor-card:hover,
	.ess-territory__editorial-link:hover {
		transform: none !important;
	}
}

/* ==========================================================================
   BACK-TO-TOP FAB
   ----
   Floating action button bottom-right, appare via JS dopo 600px di scroll.
   Mobile: 16px dai bordi, 44x44 (touch target). Desktop: 24px, 48x48.
   Stato `[hidden]` (display:none) → `is-visible` (transition fade+slide).
   ========================================================================== */
.ess-back-to-top {
	position: fixed;
	bottom: 16px;
	right: 16px;
	z-index: 80;
	width: 44px;
	height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--ess-sea);
	color: #ffffff;
	border: none;
	border-radius: 999px;
	box-shadow: 0 4px 14px rgba(11, 10, 9, 0.18);
	cursor: pointer;
	opacity: 0;
	transform: translateY(8px);
	transition: opacity 0.2s ease, transform 0.2s ease, background-color 0.15s ease;
}
.ess-back-to-top.is-visible {
	opacity: 1;
	transform: translateY(0);
}
.ess-back-to-top:hover {
	background: var(--ess-orange);
}
.ess-back-to-top:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: 3px;
}
.ess-back-to-top svg {
	display: block;
	width: 20px;
	height: 20px;
}
@media (min-width: 768px) {
	.ess-back-to-top {
		bottom: 24px;
		right: 24px;
		width: 48px;
		height: 48px;
	}
}
@media (prefers-reduced-motion: reduce) {
	.ess-back-to-top {
		transition: opacity 0.15s linear;
		transform: none;
	}
	.ess-back-to-top.is-visible {
		transform: none;
	}
}

/* ==========================================================================
   PIANI E TARIFFE V6
   Tre piani: Vetrina €179 · Vetrina Plus €299 · Shop €490.
   BEM prefix: .ess-pt-*
   ========================================================================== */

/* --- Hero supplements ---------------------------------------------------- */
.ess-pt-hero__anchor-copy {
	margin: var(--ess-space-5) 0 0;
	font-size: var(--ess-text-base);
	line-height: 1.65;
	color: var(--ess-color-text-sec);
	max-width: 56ch;
}

.ess-pt-hero__scroll {
	margin: var(--ess-space-6) 0 0;
}

.ess-pt-hero__scroll-link {
	display: inline-flex;
	align-items: center;
	gap: 0.35em;
	font-size: var(--ess-text-sm);
	font-weight: 600;
	color: var(--ess-terra);
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: border-color var(--ess-transition-fast);
}

.ess-pt-hero__scroll-link:hover,
.ess-pt-hero__scroll-link:focus-visible {
	border-bottom-color: var(--ess-terra);
}

/* --- Plans grid ---------------------------------------------------------- */
.ess-pt-plans {
	padding-block: var(--ess-space-16);
}

.ess-pt-plans__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--ess-space-6);
	align-items: start;
	margin-top: var(--ess-space-10);
}

@media (min-width: 768px) {
	.ess-pt-plans__grid {
		grid-template-columns: repeat(3, 1fr);
		align-items: stretch;
	}
}

/* --- Plan card ----------------------------------------------------------- */
.ess-pt-card {
	position: relative;
	display: flex;
	flex-direction: column;
	background: var(--ess-color-card-bg);
	border: 2px solid var(--ess-color-border);
	padding: var(--ess-space-6);
	transition: box-shadow var(--ess-transition-fast), transform var(--ess-transition-fast);
}

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

/* Vestibular-safe: reduce/disabilita transform su hover per utenti con prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
	.ess-pt-card,
	.ess-pt-card:hover {
		transition: none;
		transform: none;
	}
}

/* Featured (Vetrina Plus) */
.ess-pt-card--featured {
	border-color: var(--ess-color-primary);
	box-shadow: var(--ess-shadow-md);
	margin-top: 0; /* handled by grid align-items:stretch */
}

/* Shop card — terra border (WCAG AA pass: 4.65:1 vs precedente #E07A2F 3.6:1) */
.ess-pt-card--shop {
	border-color: var(--ess-terra);
}

/* Badge top strip */
.ess-pt-card__badge {
	position: absolute;
	top: -14px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--ess-color-primary);
	color: #fff;
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	padding: 4px 12px;
	white-space: nowrap;
	line-height: 1.4;
}

.ess-pt-card__badge--shop {
	background: var(--ess-terra);
}

/* Give cards with a badge extra top padding so content clears the badge */
.ess-pt-card--featured,
.ess-pt-card--shop {
	padding-top: calc(var(--ess-space-6) + 14px);
}

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

.ess-pt-card__name {
	font-family: var(--ess-font-serif);
	font-size: var(--ess-text-2xl);
	font-weight: 400;
	line-height: 1.1;
	color: var(--ess-color-heading);
	margin: 0 0 var(--ess-space-2);
}

.ess-pt-card__for {
	font-size: var(--ess-text-sm);
	color: var(--ess-color-text-sec);
	line-height: 1.5;
	margin: 0;
}

/* Price block */
.ess-pt-card__price {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 0 var(--ess-space-1);
	margin-bottom: var(--ess-space-4);
	padding-bottom: var(--ess-space-4);
	border-bottom: 1px solid var(--ess-color-border);
}

.ess-pt-card__price-amount {
	display: flex;
	align-items: baseline;
	gap: 2px;
}

.ess-pt-card__currency {
	font-size: var(--ess-text-xl);
	font-weight: 700;
	color: var(--ess-color-heading);
	line-height: 1;
}

.ess-pt-card__price-amount > span:first-child {
	font-size: clamp(2.5rem, 4vw, 3rem);
	font-weight: 800;
	color: var(--ess-color-heading);
	line-height: 1;
}

.ess-pt-card__period {
	font-size: var(--ess-text-sm);
	color: var(--ess-color-text-sec);
	flex-shrink: 0;
}

.ess-pt-card__monthly {
	flex: 0 0 100%;
	font-size: var(--ess-text-sm);
	color: var(--ess-color-text-sec);
	font-style: italic;
	margin-top: var(--ess-space-1);
}

.ess-pt-card__vat {
	flex: 0 0 100%;
	font-size: 0.6875rem;
	color: var(--ess-muted-aa);
}

/* Inherit note */
.ess-pt-card__inherit {
	font-size: var(--ess-text-sm);
	font-weight: 600;
	color: var(--ess-color-text-sec);
	margin: 0 0 var(--ess-space-3);
}

/* Sub-headings within feature list */
.ess-pt-card__sub-heading {
	font-size: var(--ess-text-sm);
	font-weight: 700;
	color: var(--ess-color-heading);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	margin: var(--ess-space-4) 0 var(--ess-space-2);
}

/* Features list */
.ess-pt-card__features {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--ess-space-4);
	flex: 1; /* push CTA to bottom */
}

.ess-pt-card__features li {
	position: relative;
	padding-left: 1.5rem;
	font-size: var(--ess-text-sm);
	color: var(--ess-color-text-sec);
	line-height: 1.55;
	margin-bottom: var(--ess-space-2);
}

.ess-pt-card__features li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.35em;
	width: 10px;
	height: 10px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' fill='none'%3E%3Cpath d='M2 6l3 3 5-5' stroke='%23c5552d' stroke-width='1.75' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-size: contain;
}

/* CTA */
.ess-pt-card__cta-wrap {
	margin-top: auto;
	padding-top: var(--ess-space-4);
}

.ess-pt-card__cta {
	display: flex;
	width: 100%;
	justify-content: center;
}

.ess-pt-card__cta-micro {
	margin: var(--ess-space-2) 0 0;
	font-size: 0.6875rem;
	color: var(--ess-muted-aa);
	text-align: center;
}

/* --- Comparison table ---------------------------------------------------- */
.ess-pt-comparison {
	padding-block: var(--ess-space-16);
}

.ess-pt-comparison__sub {
	margin: var(--ess-space-2) 0 0;
	font-size: var(--ess-text-base);
	color: var(--ess-color-text-sec);
}

.ess-pt-comparison__scroll-wrap {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	margin-top: var(--ess-space-8);
	/* Accessible focus ring for keyboard users scrolling */
	outline: none;
}

.ess-pt-comparison__scroll-wrap:focus-visible {
	outline: 2px solid var(--ess-terra);
	outline-offset: 2px;
}

.ess-pt-comparison__table {
	width: 100%;
	min-width: 640px; /* prevents collapse on narrow screens */
	border-collapse: collapse;
	font-size: var(--ess-text-sm);
}

.ess-pt-comparison__table th,
.ess-pt-comparison__table td {
	padding: var(--ess-space-3) var(--ess-space-4);
	text-align: center;
	border-bottom: 1px solid var(--ess-color-border);
	vertical-align: middle;
}

.ess-pt-comparison__th-feature,
.ess-pt-comparison__row-label {
	text-align: left;
	font-weight: 600;
	color: var(--ess-color-heading);
	width: 40%;
}

.ess-pt-comparison__th-plan {
	font-family: var(--ess-font-serif);
	font-size: var(--ess-text-lg);
	font-weight: 400;
	color: var(--ess-color-heading);
}

.ess-pt-comparison__th-plan--featured {
	background: color-mix(in srgb, var(--ess-color-primary) 6%, transparent);
}

.ess-pt-comparison__th-plan--shop {
	background: color-mix(in srgb, #E07A2F 5%, transparent);
}

.ess-pt-comparison__th-price {
	display: block;
	font-family: var(--ess-font-body);
	font-size: var(--ess-text-xs);
	font-weight: 600;
	color: var(--ess-muted-aa);
	margin-top: 2px;
}

.ess-pt-comparison__cell--featured {
	background: color-mix(in srgb, var(--ess-color-primary) 4%, transparent);
}

.ess-pt-comparison__cell--yes {
	color: var(--ess-terra-dark);
	font-weight: 700;
}

.ess-pt-comparison__cell--no {
	color: var(--ess-muted);
}

.ess-pt-comparison__cta-row td {
	padding-top: var(--ess-space-5);
	padding-bottom: var(--ess-space-5);
	border-bottom: none;
}

.ess-pt-comparison__cta-btn {
	min-width: 90px;
}

/* --- GR AI Shop Lite section --------------------------------------------- */
.ess-pt-grshop {
	padding-block: var(--ess-space-16);
}

.ess-pt-grshop__inner {
	max-width: 760px;
}

.ess-pt-grshop .ess-section__title {
	margin-bottom: var(--ess-space-6);
}

/* "Not included" list — dash style instead of checkmark */
.ess-pt-grshop__not-list li::before {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 6h8' stroke='%23686459' stroke-width='1.75' stroke-linecap='round'/%3E%3C/svg%3E");
}

/* --- telaio.digital section ---------------------------------------------- */
.ess-pt-telaio {
	padding-block: var(--ess-space-16);
}

.ess-pt-telaio__inner {
	max-width: 760px;
}

.ess-pt-telaio .ess-section__title {
	margin-bottom: var(--ess-space-6);
}

.ess-pt-telaio__cta {
	margin-top: var(--ess-space-8);
}

.ess-pt-telaio__cta .ess-btn {
	gap: var(--ess-space-2);
}

/* --- FAQ accordion ------------------------------------------------------- */
.ess-pt-faq {
	padding-block: var(--ess-space-16);
}

.ess-pt-faq__list {
	max-width: 760px;
	margin: var(--ess-space-10) auto 0;
}

.ess-pt-faq__item {
	border-bottom: 1px solid var(--ess-color-border);
}

.ess-pt-faq__item:first-child {
	border-top: 1px solid var(--ess-color-border);
}

.ess-pt-faq__question-wrap {
	margin: 0;
}

.ess-pt-faq__question {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--ess-space-4);
	width: 100%;
	padding: var(--ess-space-4) 0;
	background: none;
	border: none;
	cursor: pointer;
	text-align: left;
	color: var(--ess-color-heading);
	font-size: var(--ess-text-base);
	font-weight: 600;
	font-family: var(--ess-font-body);
	line-height: 1.4;
	transition: color var(--ess-transition-fast);
}

.ess-pt-faq__question:hover,
.ess-pt-faq__question:focus-visible {
	color: var(--ess-terra);
}

.ess-pt-faq__question:focus-visible {
	outline: 2px solid var(--ess-terra);
	outline-offset: 2px;
}

.ess-pt-faq__question-text {
	flex: 1;
}

.ess-pt-faq__chevron {
	flex-shrink: 0;
	color: var(--ess-muted-aa);
	transition: transform var(--ess-transition-fast), color var(--ess-transition-fast);
}

.ess-pt-faq__question[aria-expanded="true"] .ess-pt-faq__chevron {
	transform: rotate(180deg);
	color: var(--ess-terra);
}

.ess-pt-faq__answer {
	/* `hidden` attr handles display:none; no extra CSS needed for hide state */
}

.ess-pt-faq__answer-inner {
	padding: 0 0 var(--ess-space-5);
}

/* --- Footer CTA ---------------------------------------------------------- */
.ess-pt-footer-cta {
	padding-block: var(--ess-space-16);
	background: var(--ess-ink);
	color: #fff;
	text-align: center;
}

.ess-pt-footer-cta__inner {
	max-width: 820px;
	margin-inline: auto;
}

.ess-pt-footer-cta__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(1.75rem, 1rem + 2vw, 2.5rem);
	font-weight: 400;
	color: #fff;
	margin: 0 0 var(--ess-space-3);
}

.ess-pt-footer-cta__sub {
	font-size: var(--ess-text-base);
	color: rgba(255,255,255,0.85);
	line-height: 1.6;
	margin: 0 0 var(--ess-space-8);
	max-width: 56ch;
	margin-inline: auto;
	margin-bottom: var(--ess-space-8);
}

.ess-pt-footer-cta__buttons {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ess-space-3);
	justify-content: center;
	margin-bottom: var(--ess-space-6);
}

.ess-pt-footer-cta__buttons .ess-btn--primary {
	/* On dark bg: use white button with dark text for contrast */
	background: #fff;
	color: var(--ess-terra-dark);
	border-color: #fff;
}

.ess-pt-footer-cta__buttons .ess-btn--primary:hover,
.ess-pt-footer-cta__buttons .ess-btn--primary:focus-visible {
	background: rgba(255,255,255,0.9);
	border-color: rgba(255,255,255,0.9);
	color: var(--ess-terra-strong);
}

.ess-pt-footer-cta__micro {
	font-size: var(--ess-text-sm);
	color: rgba(255,255,255,0.75);
	line-height: 1.6;
}

.ess-pt-footer-cta__micro a {
	color: rgba(255,255,255,0.9);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 2px;
}

.ess-pt-footer-cta__micro a:hover,
.ess-pt-footer-cta__micro a:focus-visible {
	color: #fff;
	text-decoration-thickness: 2px;
}

/* --- Reduce motion -------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
	.ess-pt-card,
	.ess-pt-faq__chevron {
		transition: none !important;
	}
	.ess-pt-card:hover {
		transform: none !important;
	}
}

/* ==========================================================================
   PAGE HERO — pattern editorial unificato per landing pages (4.4.8)
   ========================================================================== */
.ess-section--surface {
    background: var(--ess-surface);
}
.ess-page-hero {
    padding-block: clamp(48px, 8vh, 96px);
    border-bottom: 1px solid var(--ess-line);
}

/* Variante con immagine territorio salernitano in background (vendor journey) */
.ess-page-hero--territory {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    color: #ffffff;
    border-bottom: 0;
    padding-block: clamp(72px, 12vh, 140px);
}
.ess-page-hero--territory .ess-page-hero__title,
.ess-page-hero--territory .ess-page-hero__subtitle,
.ess-page-hero--territory .ess-page-hero__eyebrow {
    color: #ffffff;
}
.ess-page-hero--territory .ess-page-hero__subtitle {
    opacity: 0.92;
    max-width: 720px;
}
.ess-page-hero--territory .ess-page-hero__eyebrow {
    opacity: 0.85;
}
.ess-page-hero .ess-eyebrow {
    margin-bottom: 16px;
}
.ess-page-hero__title {
    font-family: var(--ess-font-serif);
    font-size: clamp(2rem, 1.5rem + 2vw, 3rem);
    line-height: 1.05;
    letter-spacing: -0.02em;
    color: var(--ess-ink);
    margin: 0 0 16px;
    max-width: 22ch;
    font-weight: 400;
}
.ess-page-hero__subtitle {
    font-size: var(--ess-text-lg);
    color: var(--ess-color-text-sec);
    line-height: 1.55;
    max-width: 60ch;
    margin: 0;
}
@media (min-width: 768px) {
    .ess-page-hero__title { font-size: clamp(2.25rem, 1.5rem + 2.5vw, 3.5rem); }
}

/* ==========================================================================
   PAGINA UNICA VENDOR (ess-vp-*) — landing /vendi-con-eshopping-salerno/
   Consolida Vendi + Come funziona + Piani. Riusa ess-landing-hero / ess-cf /
   ess-feature-card / ess-pt-card; qui solo i componenti nuovi.
   ========================================================================== */

/* Ancore non nascoste dalla sub-nav sticky */
.ess-vp [id] { scroll-margin-top: 72px; }

/* Hero trust row */
.ess-vp-trust {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--ess-space-6);
	margin: var(--ess-space-8) 0 0;
	padding: 0;
	font-family: var(--ess-font-mono);
	font-size: var(--ess-text-sm);
	letter-spacing: 0.3px;
	color: rgba(255, 255, 255, 0.85);
}
.ess-vp-trust li { white-space: nowrap; }
.ess-vp-trust b { color: var(--ess-limone); font-weight: var(--ess-weight-semibold); }

/* Benefit cards — le classi base ess-features-grid/ess-feature-card non hanno
   stile nel tema, quindi le definiamo qui (3 colonne centrate con riquadro) */
.ess-vp .ess-features-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--ess-space-5);
}
.ess-vp .ess-feature-card {
	background: #fff;
	border: 1px solid var(--ess-line);
	padding: var(--ess-space-8) var(--ess-space-6);
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}
.ess-vp .ess-feature-card__icon-svg {
	color: var(--ess-orange);
	background: var(--ess-surface);
	border-radius: 50%;
	margin-bottom: var(--ess-space-4);
}
.ess-vp .ess-feature-card__title {
	font-family: var(--ess-font-serif);
	font-size: var(--ess-text-xl);
	line-height: 1.15;
	margin: 0 0 var(--ess-space-2);
}
.ess-vp .ess-feature-card__desc {
	font-size: var(--ess-text-base);
	color: var(--ess-muted-aa);
	line-height: 1.6;
	margin: 0;
}
@media (max-width: 820px) {
	.ess-vp .ess-features-grid { grid-template-columns: 1fr; }
}

/* Bottoni hero/CTA — alta specificità (.ess-vp ...) per battere gli override
   globali di .ess-btn--primary / .ess-btn--outline in ess-sss-integration.css */
.ess-vp .ess-vp-btn-wa {
	display: inline-flex;
	align-items: center;
	gap: var(--ess-space-2);
	background: #25d366;
	color: #fff;
	border-color: #25d366;
}
.ess-vp .ess-vp-btn-wa:hover,
.ess-vp .ess-vp-btn-wa:focus-visible { background: #1da851; border-color: #1da851; color: #fff; }
.ess-vp .ess-vp-btn-wa svg { flex: 0 0 auto; }
.ess-vp .ess-vp-btn-ghost {
	background: transparent;
	color: #fff;
	border-color: rgba(255, 255, 255, 0.65);
}
.ess-vp .ess-vp-btn-ghost:hover,
.ess-vp .ess-vp-btn-ghost:focus-visible { background: #fff; color: var(--ess-ink); border-color: #fff; }

/* Sub-nav sticky con ancore */
.ess-vp-subnav {
	position: sticky;
	top: 0;
	z-index: 40;
	background: #fff;
	border-bottom: 1px solid var(--ess-line);
}
.ess-vp-subnav__inner {
	display: flex;
	align-items: center;
	gap: var(--ess-space-1);
	min-height: 56px;
	overflow-x: auto;
}
.ess-vp-subnav a {
	font-family: var(--ess-font-mono);
	font-size: var(--ess-text-xs);
	letter-spacing: 0.8px;
	text-transform: uppercase;
	color: var(--ess-muted-aa);
	text-decoration: none;
	padding: var(--ess-space-2) var(--ess-space-3);
	white-space: nowrap;
}
.ess-vp-subnav a:hover { color: var(--ess-ink); }
.ess-vp-subnav a.ess-btn { color: #fff; }
.ess-vp-subnav__spacer { flex: 1 1 auto; }

/* Nota sotto le card piani */
.ess-vp-plans-note {
	text-align: center;
	font-family: var(--ess-font-mono);
	font-size: var(--ess-text-xs);
	letter-spacing: 0.4px;
	color: var(--ess-muted-aa);
	margin: var(--ess-space-8) 0 0;
}

/* Accordion (details/summary) — confronto + FAQ */
.ess-vp-acc { max-width: 820px; margin: 0 auto; }
.ess-vp-acc details {
	border: 1px solid var(--ess-line);
	background: #fff;
	margin-bottom: var(--ess-space-3);
}
.ess-vp-acc summary {
	cursor: pointer;
	list-style: none;
	padding: var(--ess-space-5) var(--ess-space-6);
	font-family: var(--ess-font-serif);
	font-size: var(--ess-text-lg);
	line-height: 1.2;
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--ess-space-4);
}
.ess-vp-acc summary::-webkit-details-marker { display: none; }
.ess-vp-acc summary::after {
	content: '+';
	font-family: var(--ess-font-mono);
	font-size: 1.4rem;
	line-height: 1;
	color: var(--ess-orange);
	flex: 0 0 auto;
}
.ess-vp-acc details[open] summary::after { content: '\2013'; }
.ess-vp-acc summary:focus-visible { outline: 2px solid var(--ess-orange); outline-offset: -2px; }
.ess-vp-acc__body {
	padding: 0 var(--ess-space-6) var(--ess-space-6);
	font-size: var(--ess-text-base);
	color: var(--ess-muted-aa);
	line-height: 1.6;
}
.ess-vp-acc__body p { margin: 0; }

/* Tabella comparativa compatta */
.ess-vp-cmp__wrap { overflow-x: auto; }
.ess-vp-cmp { width: 100%; border-collapse: collapse; font-size: var(--ess-text-sm); }
.ess-vp-cmp th,
.ess-vp-cmp td { padding: var(--ess-space-2) var(--ess-space-3); border-bottom: 1px solid var(--ess-line); text-align: center; vertical-align: top; }
.ess-vp-cmp thead th {
	font-family: var(--ess-font-mono);
	font-size: var(--ess-text-xs);
	letter-spacing: 0.5px;
	text-transform: uppercase;
	color: var(--ess-ink);
	white-space: nowrap;
}
.ess-vp-cmp thead th span { display: block; color: var(--ess-orange); margin-top: 2px; }
.ess-vp-cmp tbody th { text-align: left; font-weight: var(--ess-weight-medium); color: var(--ess-ink); }
.ess-vp-cmp td { color: var(--ess-muted-aa); }
.ess-vp-cmp__feat { background: rgba(197, 85, 45, 0.06); }
.ess-vp-cmp__yes { color: var(--ess-ulivo); font-weight: var(--ess-weight-bold); }
.ess-vp-cmp__no { color: var(--ess-line-strong); }

/* CTA finale (dark) */
.ess-vp-final { background: var(--ess-sea-dark); color: #fff; }
.ess-vp-final__eyebrow { color: var(--ess-limone); }
.ess-vp-final__title { font-family: var(--ess-font-serif); font-size: clamp(2rem, 1.2rem + 2.6vw, 3rem); line-height: 1.05; margin: var(--ess-space-2) 0 var(--ess-space-4); }
.ess-vp-final__sub { color: rgba(255, 255, 255, 0.8); font-size: var(--ess-text-md); margin: 0 auto var(--ess-space-8); max-width: 52ch; }
.ess-vp-final__ctas { display: flex; gap: var(--ess-space-3); justify-content: center; flex-wrap: wrap; }
.ess-vp-final__ghost { color: #fff; border-color: rgba(255, 255, 255, 0.6); }
.ess-vp-final__ghost:hover { background: #fff; color: var(--ess-ink); }
.ess-vp-final__email { margin: var(--ess-space-6) 0 0; font-family: var(--ess-font-mono); font-size: var(--ess-text-xs); color: rgba(255, 255, 255, 0.65); }
.ess-vp-final__email a { color: var(--ess-limone); }

/* FAB WhatsApp flottante */
.ess-vp-fab {
	position: fixed;
	right: 1.25rem;
	bottom: 1.25rem;
	z-index: 60;
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: #25d366;
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 8px 24px rgba(37, 211, 102, 0.45);
	text-decoration: none;
}
.ess-vp-fab:hover,
.ess-vp-fab:focus-visible { background: #1da851; color: #fff; }

@media (prefers-reduced-motion: no-preference) {
	html { scroll-behavior: smooth; }
}

