/**
 * ESS Dokan — Professional store page styles.
 *
 * Loaded conditionally on Dokan store/dashboard pages.
 * Supports Dokan template overrides in theme dokan/ directory.
 *
 * @version 2.1.0
 */

/* ==========================================================================
   0. STORE HEADER — FULL WIDTH BANNER
   ========================================================================== */

.ess-store-header-fullwidth {
	width: 100%;
	margin-bottom: var(--ess-space-6);
}

.ess-store-header-fullwidth .dokan-profile-frame-wrapper {
	margin-bottom: 0;
}

.ess-store-header-fullwidth .profile-info-box {
	border-radius: 0;
	position: relative;
	overflow: hidden;
}

.ess-store-header-fullwidth .profile-info-img {
	width: 100%;
	height: 280px;
	object-fit: cover;
	display: block;
}

.ess-store-header-fullwidth .profile-info-img.dummy-image {
	background: linear-gradient(135deg, var(--ess-color-blue) 0%, var(--ess-color-blue-mid) 100%);
}

@media (min-width: 768px) {
	.ess-store-header-fullwidth .profile-info-img {
		height: 360px;
	}
}

@media (min-width: 1024px) {
	.ess-store-header-fullwidth .profile-info-img {
		height: 420px;
	}
}

/* Profile info overlay on banner */
.ess-store-header-fullwidth .profile-info-summery-wrapper {
	max-width: var(--ess-container-max);
	margin-inline: auto;
	padding-inline: var(--ess-container-padding);
}

/* Store tabs contained */
.ess-store-header-fullwidth .dokan-store-tabs {
	max-width: var(--ess-container-max);
	margin-inline: auto;
	padding-inline: var(--ess-container-padding);
	border-bottom: 1px solid var(--ess-color-border);
}

/* ==========================================================================
   1. STORE PAGE LAYOUT (.dokan-store-wrap)
   ========================================================================== */

.dokan-store-wrap {
	display: grid;
	gap: var(--ess-space-8);
	grid-template-columns: 1fr;
}

@media (min-width: 1024px) {
	.dokan-store-wrap.layout-left {
		grid-template-columns: 260px 1fr;
	}

	.dokan-store-wrap.layout-right {
		grid-template-columns: 1fr 260px;
	}
}

.dokan-single-store {
	min-width: 0; /* Prevent grid blowout */
}

/* ==========================================================================
   2. STORE HEADER — banner editorial con overlay e profilo
   ========================================================================== */

.ess-store-wrap {
	margin-bottom: var(--ess-space-6);
}

/* --- Banner with background image --- */
.ess-store-banner {
	position: relative;
	min-height: 220px;
	background-color: var(--ess-color-bg-ter);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	display: flex;
	align-items: flex-end;
}

@media (min-width: 768px) {
	.ess-store-banner {
		min-height: 270px;
	}
}

/* Dark gradient overlay sul banner per leggibilita testo. */
.ess-store-banner__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		180deg,
		rgba(0, 0, 0, 0) 0%,
		rgba(156, 156, 156, 0.1) 30%,
		rgba(11, 11, 11, 0.35) 80%,
		rgba(0, 0, 0, 0.48) 100%
	);
	opacity: 0.65;
	z-index: 1;
}

/* Profile info on top of the overlay */
.ess-store-banner__profile {
	position: relative;
	z-index: 2;
	width: 100%;
	padding: var(--ess-space-4) 0 var(--ess-space-5);
}

/* Profile layout: avatar + info + actions */
.ess-store-profile {
	display: flex;
	align-items: flex-end;
	gap: var(--ess-space-4);
	color: var(--ess-color-white);
}

/* Avatar — extends below banner */
.ess-store-profile__avatar {
	flex-shrink: 0;
	position: relative;
}

.ess-store-profile__avatar img {
	width: 100px;
	height: 100px;
	object-fit: contain;
	padding: 8px;
	background: var(--ess-color-white);
	border-radius: var(--ess-radius-full);
	border: 4px solid var(--ess-color-white);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
	position: relative;
	bottom: -40px;
}

@media (min-width: 768px) {
	.ess-store-profile__avatar img {
		width: 150px;
		height: 150px;
		bottom: -55px;
	}
}

/* Store name + meta text */
.ess-store-profile__info {
	flex: 1;
	min-width: 0;
}

.ess-store-profile__name {
	font-size: clamp(1.25rem, 1rem + 1vw, 1.5rem);
	font-weight: var(--ess-weight-bold);
	color: var(--ess-color-white);
	margin: 0 0 var(--ess-space-2);
	line-height: 1.3;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.4);
	display: flex;
	align-items: center;
	gap: var(--ess-space-2);
	flex-wrap: wrap;
}

.ess-store-profile__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ess-space-2) var(--ess-space-5);
	font-size: var(--ess-text-sm);
	color: rgba(255, 255, 255, 0.85);
}

.ess-store-profile__meta .ess-icon {
	width: 14px;
	height: 14px;
	opacity: 0.7;
	flex-shrink: 0;
}

.ess-store-profile__address,
.ess-store-profile__phone {
	display: inline-flex;
	align-items: center;
	gap: var(--ess-space-1);
}

.ess-store-profile__meta a {
	color: var(--ess-color-white);
	text-decoration: none;
}

.ess-store-profile__meta a:hover {
	text-decoration: underline;
}

/* Open/Closed badge inline */
.ess-store-profile__status {
	display: inline-flex;
	align-items: center;
	gap: var(--ess-space-1);
	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);
	margin-top: var(--ess-space-2);
}

.ess-store-profile__status--open {
	background: rgba(26, 158, 92, 0.8);
	color: var(--ess-color-white);
}

.ess-store-profile__status--closed {
	background: rgba(217, 68, 68, 0.8);
	color: var(--ess-color-white);
}

/* Top-right badge on banner */
.ess-store-profile__actions {
	flex-shrink: 0;
}

.ess-store-badge {
	display: inline-flex;
	align-items: center;
	padding: var(--ess-space-2) var(--ess-space-4);
	font-size: var(--ess-text-xs);
	font-weight: var(--ess-weight-bold);
	border-radius: var(--ess-radius-md);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.ess-store-badge--open {
	background: var(--ess-color-success);
	color: var(--ess-color-white);
}

.ess-store-badge--closed {
	background: var(--ess-color-danger);
	color: var(--ess-color-white);
}

/* Mobile: stack profile vertically */
@media (max-width: 639px) {
	.ess-store-profile {
		flex-direction: column;
		align-items: center;
		text-align: center;
	}

	.ess-store-profile__avatar img {
		bottom: -30px;
	}

	.ess-store-profile__name {
		justify-content: center;
	}

	.ess-store-profile__meta {
		justify-content: center;
	}

	.ess-store-profile__actions {
		position: absolute;
		top: var(--ess-space-3);
		right: var(--ess-space-3);
	}
}

/* ==========================================================================
   3. STORE TABS — barra grigia con separatori verticali
   ========================================================================== */

.ess-store-tabs {
	background: var(--ess-color-bg-sec);
	border-bottom: 1px solid var(--ess-color-border);
}

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

.ess-store-tabs__nav {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
}

.ess-store-tabs__nav::-webkit-scrollbar {
	display: none;
}

/* Offset for avatar overhang */
.ess-store-tabs__list {
	display: flex;
	list-style: none;
	padding: 0;
	margin: 0;
	padding-left: 120px;
}

@media (min-width: 768px) {
	.ess-store-tabs__list {
		padding-left: 170px;
	}
}

@media (max-width: 639px) {
	.ess-store-tabs__list {
		padding-left: 0;
	}
}

.ess-store-tabs__list li a {
	display: inline-flex;
	align-items: center;
	padding: var(--ess-space-3) var(--ess-space-5);
	color: var(--ess-color-text);
	text-decoration: none;
	font-size: var(--ess-text-sm);
	white-space: nowrap;
	border-right: 1px solid var(--ess-color-border);
	min-height: 48px;
	transition: background var(--ess-transition-fast);
}

@media (min-width: 768px) {
	.ess-store-tabs__list li a {
		font-size: 15px;
		padding: 15px 20px;
	}
}

.ess-store-tabs__list li:first-child a {
	border-left: 1px solid var(--ess-color-border);
}

.ess-store-tabs__list li a:hover {
	background: var(--ess-color-white);
}

/* Actions (Seguici, WhatsApp, Condividi — injected by Dokan hooks) */
.ess-store-tabs__actions {
	display: flex;
	gap: var(--ess-space-2);
	flex-shrink: 0;
	padding-right: var(--ess-space-2);
	align-items: center;
}

/* Fix: Dokan injects <li> elements without <ul> — remove bullets and list styling */
.ess-store-tabs__actions li {
	list-style: none;
	margin: 0;
	padding: 0;
}

/* Fix: WhatsApp button inline style "top: 3px" — reset */
.ess-store-tabs__actions button[style] {
	top: 0 !important;
	position: static !important;
}

/* Fix: share modals div inside actions */
.ess-store-tabs__actions .dokan-share-store-modals {
	display: none;
}

/* Override Dokan inline !important on .dokan-btn-theme inside tabs */
.ess-store-tabs__actions a.dokan-btn-theme,
.ess-store-tabs__actions button.dokan-btn-theme,
.ess-store-tabs__actions a,
.ess-store-tabs__actions button {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	gap: var(--ess-space-1);
	padding: var(--ess-space-2) var(--ess-space-3) !important;
	font-size: var(--ess-text-xs) !important;
	font-weight: var(--ess-weight-medium);
	border-radius: var(--ess-radius-md) !important;
	border: 1px solid var(--ess-color-border) !important;
	background: var(--ess-color-white) !important;
	color: var(--ess-color-text) !important;
	cursor: pointer;
	text-decoration: none;
	min-height: 44px;
	white-space: nowrap;
	transition: all var(--ess-transition-fast);
}

.ess-store-tabs__actions a:hover,
.ess-store-tabs__actions button:hover {
	border-color: var(--ess-color-primary) !important;
	color: var(--ess-color-primary) !important;
	background: var(--ess-color-blue-pale) !important;
}

/* Hide FA icons inside action buttons */
.ess-store-tabs__actions .fas,
.ess-store-tabs__actions .far,
.ess-store-tabs__actions .fab {
	display: none !important;
}

/* ==========================================================================
   4. STORE HOURS (<details> collapsible)
   ========================================================================== */

.ess-store-hours {
	background: var(--ess-color-bg-sec);
	border-radius: var(--ess-radius-lg);
	margin-bottom: var(--ess-space-4);
	border: 1px solid var(--ess-color-border);
}

.ess-store-hours__toggle {
	display: flex;
	align-items: center;
	gap: var(--ess-space-2);
	padding: var(--ess-space-3) var(--ess-space-4);
	font-size: var(--ess-text-sm);
	font-weight: var(--ess-weight-medium);
	color: var(--ess-color-heading);
	cursor: pointer;
	list-style: none;
	min-height: 44px;
}

.ess-store-hours__toggle::-webkit-details-marker {
	display: none;
}

.ess-store-hours__toggle svg:first-child {
	color: var(--ess-color-accent);
	flex-shrink: 0;
}

.ess-store-hours__chevron {
	margin-left: auto;
	transition: transform var(--ess-transition-fast);
}

.ess-store-hours[open] .ess-store-hours__chevron {
	transform: rotate(180deg);
}

.ess-store-hours__grid {
	padding: 0 var(--ess-space-4) var(--ess-space-4);
}

.ess-store-hours__day {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	padding: var(--ess-space-2) 0;
	font-size: var(--ess-text-xs);
	color: var(--ess-color-text-sec);
	border-bottom: 1px solid var(--ess-color-bg-ter);
}

.ess-store-hours__day:last-child {
	border-bottom: none;
}

.ess-store-hours__day--today {
	font-weight: var(--ess-weight-bold);
	color: var(--ess-color-heading);
}

.ess-store-hours__name {
	min-width: 80px;
}

.ess-store-hours__time {
	text-align: right;
}

.ess-store-hours__sep {
	margin: 0 2px;
	color: var(--ess-color-text-ter);
}

.ess-store-hours__closed {
	color: var(--ess-color-danger);
	font-weight: var(--ess-weight-medium);
}

/* ==========================================================================
   5. SIDEBAR (Store Info, Categories, Map, Contact, Widgets)
   ========================================================================== */

/* Legacy: ordering was used when the sidebar was nested inside `.dokan-store-wrap.layout-left`.
 * The new editorial store.php uses `.ess-store-page__layout` with explicit
 * grid-template-columns (sidebar left, main right) so we must NOT reorder. */
.ess-store-page__sidebar { order: 0; }

/* Legacy store-wrap support — kept for any 3rd-party template that still uses it. */
.dokan-store-wrap #dokan-secondary { order: 2; }
@media (min-width: 1024px) {
	.dokan-store-wrap.layout-left #dokan-secondary { order: -1; }
}

#dokan-secondary .dokan-widget-area {
	display: flex;
	flex-direction: column;
	gap: var(--ess-space-6);
}

/* Hide FontAwesome icons on store pages (dequeued) */
.ess-dokan-store .fas,
.ess-dokan-store .far,
.ess-dokan-store .fab {
	display: none;
}

/* Singolo widget — card con bordo + ombra leggera. */
#dokan-secondary .widget,
#dokan-secondary .dokan-store-widget,
#dokan-secondary .dokan-category-menu,
#dokan-secondary .dokan-store-contact {
	background: var(--ess-color-white);
	border-top: 1px solid var(--ess-color-border);
	border-radius: 0;
	padding: 20px;
	box-shadow: rgba(0, 0, 0, 0.12) 0 1px 3px;
	margin-bottom: 25px;
	overflow: hidden;
	transition: box-shadow var(--ess-transition-fast);
}

#dokan-secondary .dokan-store-widget:hover {
	box-shadow: rgba(0, 0, 0, 0.1) 0 3px 6px;
}

/* Titoli widget — centrati, sfondo grigio chiaro per separazione visiva. */
#dokan-secondary .widget-title,
#dokan-secondary h3 {
	font-size: 16px;
	font-weight: var(--ess-weight-bold);
	line-height: 18px;
	text-align: center;
	color: var(--ess-color-heading);
	background: var(--ess-color-bg-sec);
	margin: -20px -20px 20px -20px;
	padding: 12px;
	display: block;
}

/* Category list */
#dokan-secondary .dokan-category-menu ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

#dokan-secondary .dokan-category-menu ul li {
	margin-bottom: 0;
}

#dokan-secondary .dokan-category-menu ul li a {
	display: flex;
	align-items: center;
	padding: var(--ess-space-2) var(--ess-space-3);
	font-size: var(--ess-text-sm);
	color: var(--ess-color-neutral-700);
	text-decoration: none;
	border-radius: var(--ess-radius-md);
	transition: all var(--ess-transition-fast);
	min-height: 44px;
}

#dokan-secondary .dokan-category-menu ul li a:hover,
#dokan-secondary .dokan-category-menu ul li.current-cat a {
	background: var(--ess-color-primary-light);
	color: var(--ess-color-primary);
}

/* Map */
#dokan-secondary .dokan-store-location {
	border-radius: var(--ess-radius-lg);
	overflow: hidden;
}

#dokan-secondary .dokan-store-location iframe,
#dokan-secondary .dokan-store-location .gm-style {
	border-radius: var(--ess-radius-lg);
}

/* Contact form */
#dokan-secondary .dokan-store-contact form {
	display: flex;
	flex-direction: column;
	gap: var(--ess-space-3);
}

#dokan-secondary .dokan-store-contact input[type="text"],
#dokan-secondary .dokan-store-contact input[type="email"],
#dokan-secondary .dokan-store-contact textarea {
	width: 100%;
	padding: var(--ess-space-2) var(--ess-space-3);
	border: 1px solid var(--ess-color-input-border);
	border-radius: var(--ess-radius-md);
	font-size: var(--ess-text-sm);
	min-height: 44px;
	transition: border-color var(--ess-transition-fast);
}

#dokan-secondary .dokan-store-contact textarea {
	min-height: 80px;
	resize: vertical;
}

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

#dokan-secondary .dokan-store-contact input[type="submit"],
#dokan-secondary .dokan-store-contact .dokan-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: var(--ess-space-2) var(--ess-space-5);
	background: var(--ess-color-accent);
	color: var(--ess-color-white);
	border: none;
	border-radius: var(--ess-radius-md);
	font-weight: var(--ess-weight-semibold);
	font-size: var(--ess-text-sm);
	cursor: pointer;
	min-height: 44px;
	transition: background var(--ess-transition-fast);
}

#dokan-secondary .dokan-store-contact input[type="submit"]:hover,
#dokan-secondary .dokan-store-contact .dokan-btn:hover {
	background: var(--ess-color-accent-hover);
}

/* Privacy text in contact form */
#dokan-secondary .dokan-store-contact .woocommerce-privacy-policy-text {
	font-size: var(--ess-text-xs);
	color: var(--ess-color-neutral-500);
	line-height: var(--ess-leading-normal);
}

/* ==========================================================================
   7. PRODUCT GRID IN STORE
   ========================================================================== */

.dokan-single-store .seller-items {
	margin-bottom: var(--ess-space-6);
}

/* Product search/order bar in store — mobile-first */
.dokan-store-products-filter-area {
	margin-bottom: var(--ess-space-6);
	border-bottom: 0 !important;       /* batte border ereditato da Dokan core */
	border: 0 !important;
	padding-bottom: 0 !important;
	box-shadow: none !important;
}
.dokan-store-products-filter-area::after,
.dokan-store-products-filter-area::before {
	display: none !important;          /* batte eventuali separator pseudo del clearfix */
}
.dokan-store-products-filter-area + hr,
.dokan-store-products-filter-area ~ hr:first-of-type {
	display: none !important;          /* batte <hr> generato da Dokan dopo il filter */
}

.dokan-store-products-filter-area .dokan-store-products-ordeby {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	gap: var(--ess-space-2);
	width: 100%;
	position: relative;
}

/* Search input: full width on mobile, flex-grow on desktop.
   Squadrato (border-radius:0) per coerenza con design editorial del tema. */
.dokan-store-products-filter-area .product-name-search {
	flex: 1 1 100%;
	padding: var(--ess-space-2) var(--ess-space-4) !important;
	border: 1px solid var(--ess-color-border) !important;
	border-radius: 0 !important;
	background: var(--ess-color-white) !important;
	font-size: var(--ess-text-sm);
	min-height: 44px;
	box-sizing: border-box;
	float: none !important;
	width: auto !important;
	height: auto !important;
}

.dokan-store-products-filter-area .product-name-search:focus {
	outline: none;
	border-color: var(--ess-color-primary) !important;
	box-shadow: 0 0 0 2px var(--ess-color-blue-pale) !important;
}

/* AJAX results dropdown — visibile SOLO quando ha contenuto.
   Senza :empty trick il container vuoto rendeva una linea grigia (border + shadow)
   sotto la barra di ricerca. Squadrato per coerenza editorial. */
.dokan-store-products-filter-area #dokan-store-products-search-result {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	z-index: 10;
	background: var(--ess-color-white);
	border: 1px solid var(--ess-color-border);
	border-radius: 0;
	box-shadow: var(--ess-shadow-md);
}
.dokan-store-products-filter-area #dokan-store-products-search-result:empty {
	display: none;
	border: 0;
	box-shadow: none;
}

/* Submit button — override Dokan's !important inline.
   Squadrato per coerenza editorial. */
.dokan-store-products-filter-area input.search-store-products.dokan-btn-theme,
.dokan-store-products-filter-area input[type="submit"].search-store-products {
	flex: 0 0 auto;
	padding: var(--ess-space-2) var(--ess-space-5) !important;
	background: var(--ess-color-primary) !important;
	color: var(--ess-color-white) !important;
	border: 1px solid var(--ess-color-primary) !important;
	border-radius: 0 !important;
	font-weight: var(--ess-weight-semibold) !important;
	font-size: var(--ess-text-sm) !important;
	cursor: pointer;
	min-height: 44px;
	height: 44px !important;
	line-height: 1 !important;
	float: none !important;
	width: auto !important;
	transition: background var(--ess-transition-fast);
}

.dokan-store-products-filter-area input.search-store-products.dokan-btn-theme:hover {
	background: var(--ess-color-primary-hover) !important;
	border-color: var(--ess-color-primary-hover) !important;
}

/* Sort by select — squadrato per coerenza editorial */
.dokan-store-products-filter-area .orderby,
.dokan-store-products-filter-area select.orderby-search {
	flex: 0 0 auto;
	padding: var(--ess-space-2) var(--ess-space-4) !important;
	border: 1px solid var(--ess-color-border) !important;
	border-radius: 0 !important;
	background: var(--ess-color-white) !important;
	font-size: var(--ess-text-sm);
	min-height: 44px;
	height: 44px !important;
	cursor: pointer;
	float: none !important;
	margin-left: auto;
}

/* Desktop: search takes ~50%, submit + sort on the right */
@media (min-width: 768px) {
	.dokan-store-products-filter-area .product-name-search {
		flex: 1 1 200px;
	}
}

/* ==========================================================================
   8. DOKAN PRO — Vacation Message
   ========================================================================== */

.dokan-vacation-message,
.dokan-store-is-on-vacation {
	padding: var(--ess-space-4);
	margin-bottom: var(--ess-space-6);
	background: #fef3c7;
	border-left: 4px solid var(--ess-color-warning);
	border-radius: var(--ess-radius-md);
	font-size: var(--ess-text-sm);
	color: #92400e;
}

/* ==========================================================================
   9. DOKAN PRO — Store Support / Ticket Form
   ========================================================================== */

.dokan-store-support-btn,
#dokan-store-support-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--ess-space-2);
}

.dokan-store-support-form .dokan-form-group {
	margin-bottom: var(--ess-space-4);
}

.dokan-store-support-form .dokan-form-control {
	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;
}

.dokan-store-support-form .dokan-form-control:focus {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: 1px;
	border-color: var(--ess-color-primary);
}

/* ==========================================================================
   10. DOKAN PAGINATION (store products)
   ========================================================================== */

.dokan-pagination-container {
	margin-top: var(--ess-space-6);
}

.dokan-pagination-container .dokan-pagination {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ess-space-2);
	justify-content: center;
	list-style: none;
	padding: 0;
	margin: 0;
}

.dokan-pagination-container .dokan-pagination li a,
.dokan-pagination-container .dokan-pagination li span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	min-height: 44px;
	padding: var(--ess-space-2);
	border-radius: var(--ess-radius-md);
	text-decoration: none;
	color: var(--ess-color-body-text);
	font-weight: var(--ess-weight-medium);
	font-size: var(--ess-text-sm);
	transition: all var(--ess-transition-fast);
}

.dokan-pagination-container .dokan-pagination li a:hover {
	background: var(--ess-color-primary-light);
	color: var(--ess-color-primary);
}

.dokan-pagination-container .dokan-pagination li.active a,
.dokan-pagination-container .dokan-pagination li.active span,
.dokan-pagination-container .dokan-pagination li .current {
	background: var(--ess-color-primary);
	color: var(--ess-color-white);
	border-radius: var(--ess-radius-md);
	pointer-events: none;
}

.dokan-pagination-container .dokan-pagination li.disabled a {
	opacity: 0.4;
	pointer-events: none;
	cursor: default;
}

/* WP pagination fallback */
.dokan-single-store .pagination-wrap {
	text-align: center;
	margin-top: var(--ess-space-6);
}

.dokan-single-store .pagination-wrap .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	min-height: 44px;
	padding: var(--ess-space-2);
	border-radius: var(--ess-radius-md);
	text-decoration: none;
	color: var(--ess-color-body-text);
	font-weight: var(--ess-weight-medium);
}

.dokan-single-store .pagination-wrap .page-numbers.current {
	background: var(--ess-color-primary);
	color: var(--ess-color-white);
}

/* ==========================================================================
   11. DOKAN BUTTONS (global)
   ========================================================================== */

.dokan-btn,
.dokan-btn-theme {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--ess-space-2);
	padding: var(--ess-space-2) var(--ess-space-5);
	background: var(--ess-color-primary);
	color: var(--ess-color-white);
	border: none;
	border-radius: var(--ess-radius-md);
	font-weight: var(--ess-weight-semibold);
	font-size: var(--ess-text-sm);
	text-decoration: none;
	cursor: pointer;
	min-height: 44px;
	transition: background var(--ess-transition-fast);
}

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

.dokan-btn-danger {
	background: var(--ess-color-error);
}

.dokan-btn-danger:hover {
	background: #b81010;
}

/* ==========================================================================
   12. DOKAN FORMS (global)
   ========================================================================== */

.dokan-form-group {
	margin-bottom: var(--ess-space-4);
}

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

.dokan-form-control {
	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;
}

.dokan-form-control:focus {
	outline: 2px solid var(--ess-color-focus-ring);
	outline-offset: 1px;
	border-color: var(--ess-color-primary);
}

/* ==========================================================================
   13. DOKAN DASHBOARD
   ========================================================================== */

.dokan-dashboard .dokan-dash-sidebar {
	background: var(--ess-color-card-bg);
	border: 0;
	border-radius: var(--ess-radius-lg);
	box-shadow: var(--ess-shadow);
}

.dokan-dashboard .dokan-dash-sidebar ul.dokan-dashboard-menu {
	list-style: none;
	padding: 0;
}

.dokan-dashboard .dokan-dash-sidebar ul.dokan-dashboard-menu li a {
	display: flex;
	align-items: center;
	gap: var(--ess-space-3);
	padding: var(--ess-space-3) var(--ess-space-4);
	color: var(--ess-color-neutral-700);
	text-decoration: none;
	min-height: 44px;
	transition: all var(--ess-transition-fast);
}

.dokan-dashboard .dokan-dash-sidebar ul.dokan-dashboard-menu li a:hover,
.dokan-dashboard .dokan-dash-sidebar ul.dokan-dashboard-menu li.active a {
	color: var(--ess-color-primary);
	background: var(--ess-color-primary-light);
}

.dokan-dashboard-content {
	background: var(--ess-color-card-bg);
	border: 0;
	border-radius: var(--ess-radius-lg);
	padding: var(--ess-space-6);
	box-shadow: var(--ess-shadow);
}

/* ==========================================================================
   14. STORE LISTING PAGE — Filter Bar
   ========================================================================== */

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

.ess-store-filter__count {
	font-size: var(--ess-text-sm);
	color: var(--ess-color-text-sec);
	margin: 0;
}

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

.ess-store-filter__select {
	padding: var(--ess-space-2) var(--ess-space-3);
	border: 1px solid var(--ess-color-border);
	border-radius: var(--ess-radius-md);
	font-size: var(--ess-text-sm);
	min-height: 44px;
	background: var(--ess-color-white);
}

.ess-store-filter__form {
	padding: var(--ess-space-4);
	margin-bottom: var(--ess-space-4);
	background: var(--ess-color-bg-sec);
	border-radius: var(--ess-radius-lg);
}

.ess-store-filter__search {
	margin-bottom: var(--ess-space-3);
}

.ess-store-filter__input {
	width: 100%;
	padding: var(--ess-space-3) var(--ess-space-4);
	border: 1px solid var(--ess-color-border);
	border-radius: var(--ess-radius-md);
	font-size: var(--ess-text-sm);
	min-height: 44px;
}

.ess-store-filter__actions {
	display: flex;
	gap: var(--ess-space-2);
	justify-content: flex-end;
}

/* ==========================================================================
   14b. STORE LISTING PAGE — Card Grid
   ========================================================================== */

#dokan-seller-listing-wrap .dokan-seller-wrap {
	display: grid !important;
	grid-template-columns: 1fr;
	gap: var(--ess-space-4);
	list-style: none;
	padding: 0;
	margin: 0;
}

#dokan-seller-listing-wrap .dokan-single-seller {
	float: none !important;
	width: 100% !important;
	padding: 0 !important;
	margin: 0 !important;
}

@media (min-width: 640px) {
	#dokan-seller-listing-wrap .dokan-seller-wrap {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	#dokan-seller-listing-wrap .dokan-seller-wrap {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* Store card */
#dokan-seller-listing-wrap .store-wrapper {
	background: var(--ess-color-white);
	border: 1px solid var(--ess-color-border);
	border-radius: var(--ess-radius-lg);
	overflow: hidden;
	transition: box-shadow var(--ess-transition-fast), border-color var(--ess-transition-fast);
	display: flex;
	flex-direction: column;
}

#dokan-seller-listing-wrap .store-wrapper:hover {
	box-shadow: var(--ess-shadow-md);
	border-color: var(--ess-color-accent);
}

/* Banner */
#dokan-seller-listing-wrap .store-header {
	position: relative;
	overflow: hidden;
}

#dokan-seller-listing-wrap .store-banner {
	display: block;
}

#dokan-seller-listing-wrap .store-banner img {
	width: 100%;
	height: 130px;
	object-fit: cover;
	display: block;
	transition: transform 0.3s ease;
}

#dokan-seller-listing-wrap .store-wrapper:hover .store-banner img {
	transform: scale(1.03);
}

#dokan-seller-listing-wrap .store-banner__placeholder {
	width: 100%;
	height: 130px;
	background: linear-gradient(135deg, var(--ess-color-blue-pale) 0%, var(--ess-color-bg-ter) 100%);
}

/* Badge on banner */
#dokan-seller-listing-wrap .store-header .ess-store-badge {
	position: absolute;
	top: var(--ess-space-2);
	right: var(--ess-space-2);
	z-index: 2;
}

/* Content */
#dokan-seller-listing-wrap .store-content {
	padding: var(--ess-space-4);
	flex: 1;
}

#dokan-seller-listing-wrap .store-content__top {
	display: flex;
	align-items: center;
	gap: var(--ess-space-3);
	margin-bottom: var(--ess-space-3);
}

#dokan-seller-listing-wrap .store-content__avatar {
	width: 48px;
	height: 48px;
	border-radius: var(--ess-radius-full);
	object-fit: cover;
	flex-shrink: 0;
	border: 2px solid var(--ess-color-border);
}

#dokan-seller-listing-wrap .store-content__info {
	min-width: 0;
}

#dokan-seller-listing-wrap .store-content__name {
	font-size: var(--ess-text-base);
	font-weight: var(--ess-weight-semibold);
	margin: 0 0 var(--ess-space-1);
	line-height: 1.3;
}

#dokan-seller-listing-wrap .store-content__name a {
	color: var(--ess-color-heading);
	text-decoration: none;
}

#dokan-seller-listing-wrap .store-content__name a:hover {
	color: var(--ess-color-primary);
}

#dokan-seller-listing-wrap .store-content__location {
	display: inline-flex;
	align-items: center;
	gap: var(--ess-space-1);
	font-size: var(--ess-text-xs);
	color: var(--ess-color-text-sec);
}

#dokan-seller-listing-wrap .store-content__phone {
	display: flex;
	align-items: center;
	gap: var(--ess-space-1);
	font-size: var(--ess-text-xs);
	color: var(--ess-color-text-sec);
	margin: 0;
}

#dokan-seller-listing-wrap .store-content__phone a {
	color: var(--ess-color-primary);
	text-decoration: none;
}

/* Footer — Visita negozio + Follow button */
#dokan-seller-listing-wrap .store-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--ess-space-2);
	padding: var(--ess-space-3) var(--ess-space-4);
	border-top: 1px solid var(--ess-color-border);
	flex-wrap: wrap;
}

#dokan-seller-listing-wrap .store-footer > a {
	flex: 1 1 auto;
	min-width: 0;
}

/* Follow button in footer — compact, outline style */
#dokan-seller-listing-wrap .store-footer .dokan-follow-store-button {
	flex: 0 0 auto !important;
	padding: var(--ess-space-2) var(--ess-space-3) !important;
	font-size: var(--ess-text-xs) !important;
	font-weight: var(--ess-weight-medium);
	background: var(--ess-color-white) !important;
	color: var(--ess-color-text) !important;
	border: 1px solid var(--ess-color-border) !important;
	border-radius: var(--ess-radius-md) !important;
	min-height: 44px;
	cursor: pointer;
	transition: all var(--ess-transition-fast);
}

#dokan-seller-listing-wrap .store-footer .dokan-follow-store-button:hover {
	border-color: var(--ess-color-primary) !important;
	color: var(--ess-color-primary) !important;
	background: var(--ess-color-blue-pale) !important;
}

#dokan-seller-listing-wrap .store-footer__count {
	font-size: var(--ess-text-xs);
	color: var(--ess-color-text-ter);
}

/* Hide FA icons globally on listing page */
#dokan-seller-listing-wrap .fas,
#dokan-seller-listing-wrap .far,
#dokan-seller-listing-wrap .fab,
#dokan-seller-listing-wrap .dashicons {
	display: none;
}

/* Dokan Pro: Verification in listing */
#dokan-seller-listing-wrap .store-wrapper .sod-verified,
#dokan-seller-listing-wrap .store-wrapper .dokan-verified {
	color: var(--ess-color-success);
}

/* Dokan Pro: Geolocation distance */
#dokan-seller-listing-wrap .store-wrapper .store-footer .dokan-geolocation-distance {
	font-size: var(--ess-text-xs);
	color: var(--ess-color-neutral-500);
}

/* Store listing pagination */
#dokan-seller-listing-wrap .pagination-container {
	grid-column: 1 / -1;
	margin-top: var(--ess-space-4);
}

#dokan-seller-listing-wrap .pagination-container .pagination {
	display: flex;
	gap: var(--ess-space-2);
	justify-content: center;
	list-style: none;
	padding: 0;
}

#dokan-seller-listing-wrap .pagination-container .pagination li a,
#dokan-seller-listing-wrap .pagination-container .pagination li span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	min-height: 44px;
	padding: var(--ess-space-2);
	border-radius: var(--ess-radius-md);
	text-decoration: none;
	color: var(--ess-color-body-text);
	font-weight: var(--ess-weight-medium);
}

#dokan-seller-listing-wrap .pagination-container .pagination li.active span {
	background: var(--ess-color-primary);
	color: var(--ess-color-white);
}

/* ==========================================================================
   15. DOKAN NOTICES / ALERTS
   ========================================================================== */

.dokan-info,
.dokan-alert,
.dokan-alert-info {
	padding: var(--ess-space-4);
	margin-bottom: var(--ess-space-4);
	border-radius: var(--ess-radius-md);
	font-size: var(--ess-text-sm);
	background: #dbeafe;
	color: #1e40af;
	border-left: 4px solid var(--ess-color-info);
}

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

.dokan-alert-warning {
	background: #fef3c7;
	color: #92400e;
	border-left-color: var(--ess-color-warning);
}

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

/* (Old responsive section removed — mobile styles are now built into sections 2-3 above) */

/* ==========================================================================
   17. DOKAN STAR RATING (override default)
   ========================================================================== */

.dokan-seller-rating i.fas.fa-star {
	color: var(--ess-color-warning);
}

.dokan-seller-rating i.far.fa-star {
	color: var(--ess-color-neutral-300);
}

/* ==========================================================================
   18. DOKAN clearfix utility
   ========================================================================== */

.dokan-clearfix::after {
	content: "";
	display: table;
	clear: both;
}

.dokan-right {
	margin-left: auto;
}

/* Hide duplicate contact forms added by Dokan Pro hooks outside the sidebar */
.ess-main > .dokan-store-contact,
.ess-page-content > .dokan-store-contact,
.ess-store-wrap ~ .dokan-store-contact {
	display: none !important;
}

/* Follow button: show only the correct label based on data-status */
.dokan-follow-store-button .dokan-follow-store-button-label-unfollow {
	display: none;
}

.dokan-follow-store-button[data-status="following"] .dokan-follow-store-button-label-current {
	display: none;
}

.dokan-follow-store-button[data-status="following"] .dokan-follow-store-button-label-unfollow {
	display: inline;
}

/* Reset WooCommerce float grid on store page */
.dokan-single-store ul.products {
	float: none !important;
	width: 100% !important;
}

.dokan-single-store ul.products li.product {
	float: none !important;
}

/* Store page: max 3 columns (sidebar takes space) */
.dokan-single-store ul.products.ess-product-grid {
	grid-template-columns: 1fr !important;
}

@media (min-width: 640px) {
	.dokan-single-store ul.products.ess-product-grid {
		grid-template-columns: repeat(2, 1fr) !important;
	}
}

@media (min-width: 1024px) {
	.dokan-single-store ul.products.ess-product-grid {
		grid-template-columns: repeat(3, 1fr) !important;
	}
}

/* Override Dokan inline styles for sidebar open/close widget */
.dokan-store-widget.dokan-store-open-close .store-times {
	flex-direction: row !important;
	flex-wrap: wrap !important;
	padding-left: 0 !important;
	gap: var(--ess-space-2);
}

.dokan-store-widget.dokan-store-open-close .working-day {
	width: auto !important;
	min-width: 70px;
}

.dokan-store-widget.dokan-store-open-close .open-close-day {
	padding-top: var(--ess-space-2) !important;
}

/* ==========================================================================
   14. STORE INFO & CONTATTI TAB
   ========================================================================== */

.ess-store-info {
	max-width: 720px;
}

.ess-store-info__heading {
	font-size: var(--ess-text-2xl);
	font-weight: var(--ess-weight-bold);
	color: var(--ess-color-heading);
	margin-bottom: var(--ess-space-8);
}

.ess-store-info__section {
	margin-bottom: var(--ess-space-8);
	padding-bottom: var(--ess-space-6);
	border-bottom: 1px solid var(--ess-color-border);
}

.ess-store-info__section:last-of-type {
	border-bottom: none;
}

.ess-store-info__subtitle {
	font-size: var(--ess-text-lg);
	font-weight: var(--ess-weight-semibold);
	color: var(--ess-color-heading);
	margin-bottom: var(--ess-space-4);
}

.ess-store-info__list {
	display: grid;
	gap: var(--ess-space-3);
}

.ess-store-info__item {
	display: flex;
	gap: var(--ess-space-4);
}

.ess-store-info__item dt {
	font-weight: var(--ess-weight-semibold);
	color: var(--ess-color-text-secondary);
	min-width: 80px;
}

.ess-store-info__item dd a {
	color: var(--ess-color-primary);
	text-decoration: none;
}

.ess-store-info__item dd a:hover {
	text-decoration: underline;
}

.ess-store-info__address {
	font-style: normal;
	line-height: var(--ess-leading-loose);
}

/* Store hours table */
.ess-store-info__hours {
	width: 100%;
	border-collapse: collapse;
}

.ess-store-info__hours th,
.ess-store-info__hours td {
	padding: var(--ess-space-2) var(--ess-space-3);
	text-align: left;
	border-bottom: 1px solid var(--ess-color-border-light, var(--ess-color-neutral-100));
}

.ess-store-info__hours th {
	font-weight: var(--ess-weight-medium);
	color: var(--ess-color-text-secondary);
	width: 120px;
}

.ess-store-info__hours--today {
	background: var(--ess-color-primary-pale, var(--ess-color-neutral-50));
	font-weight: var(--ess-weight-semibold);
}

.ess-store-info__hours--today th {
	color: var(--ess-color-primary);
	font-weight: var(--ess-weight-semibold);
}

.ess-store-info__time-slot {
	display: inline-block;
	margin-right: var(--ess-space-3);
}

.ess-store-info__closed {
	color: var(--ess-color-neutral-400);
	font-style: italic;
}

/* Social links */
.ess-store-info__social {
	display: flex;
	flex-wrap: wrap;
	gap: var(--ess-space-3);
}

.ess-store-info__social a {
	display: inline-flex;
	align-items: center;
	gap: var(--ess-space-2);
	padding: var(--ess-space-2) var(--ess-space-4);
	background: var(--ess-color-neutral-50);
	border: 1px solid var(--ess-color-border);
	border-radius: var(--ess-radius-md);
	color: var(--ess-color-body-text);
	text-decoration: none;
	font-size: var(--ess-text-sm);
	min-height: 44px;
	transition: all var(--ess-transition-fast);
}

.ess-store-info__social a:hover {
	border-color: var(--ess-color-primary);
	color: var(--ess-color-primary);
	background: var(--ess-color-white);
}

/* ==========================================================================
   STORES DIRECTORY (v2) — /aziende-salerno-e-provincia/
   ========================================================================== */

.ess-stores-dir { font-family: var(--ess-font-body); padding-bottom: 56px; }

.ess-stores-dir__header {
	padding-block: 0 16px;
	border-bottom: 1px solid var(--ess-line);
	margin-bottom: 24px;
	background: #ffffff;
}

.ess-stores-dir__hero {
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
	align-items: end;
	margin-bottom: 20px;
}
@media (min-width: 1024px) {
	.ess-stores-dir__hero { grid-template-columns: 1.3fr 1fr; gap: 48px; }
}

.ess-stores-dir__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(2.5rem, 1.75rem + 3.5vw, 4.75rem);
	line-height: 0.95;
	letter-spacing: var(--ess-tracking-tight-hero);
	color: var(--ess-navy);
	margin: 0;
	font-weight: 400;
}

.ess-stores-dir__hero-right {
	display: flex;
	flex-direction: column;
	gap: 14px;
}

.ess-stores-dir__search-inner {
	display: flex;
	align-items: stretch;
	border: 1px solid var(--ess-navy);
	background: #ffffff;
	overflow: hidden;
	border-radius: 0;
}

.ess-stores-dir__search-input {
	flex: 1;
	min-width: 0;
	padding: 12px 14px;
	font-family: var(--ess-font-body);
	font-size: 13px;
	border: none;
	outline: none;
	background: transparent;
	color: var(--ess-navy);
}
.ess-stores-dir__search-input::placeholder { color: var(--ess-muted); }

.ess-stores-dir__search-btn {
	padding: 12px 18px;
	background: var(--ess-navy);
	color: #ffffff;
	border: none;
	border-radius: 0;
	font-family: var(--ess-font-body);
	font-size: 11px;
	letter-spacing: 1px;
	text-transform: uppercase;
	cursor: pointer;
	transition: background var(--ess-transition-fast);
}
.ess-stores-dir__search-btn:hover,
.ess-stores-dir__search-btn:focus-visible { background: #000000; }

.ess-stores-dir__sort {
	display: flex;
	gap: 14px;
	flex-wrap: wrap;
}
.ess-stores-dir__sort-btn {
	background: none;
	border: none;
	padding: 0;
	cursor: pointer;
	font-family: var(--ess-font-mono);
	font-size: 11px;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	color: var(--ess-muted);
	transition: color var(--ess-transition-fast);
}
.ess-stores-dir__sort-btn:hover,
.ess-stores-dir__sort-btn:focus-visible { color: var(--ess-navy); }
.ess-stores-dir__sort-btn.is-active { color: var(--ess-navy); }

.ess-stores-dir__zones {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
	padding-top: 16px;
	border-top: 1px solid var(--ess-line);
}
@media (max-width: 767px) {
	.ess-stores-dir__zones {
		flex-wrap: nowrap;
		overflow-x: auto;
		padding-bottom: 4px;
	}
}
.ess-stores-dir__zones-label { margin-right: 4px; flex-shrink: 0; }

.ess-stores-dir__count {
	font-size: 12px;
	color: var(--ess-muted);
	margin-bottom: 18px;
}
.ess-stores-dir__count strong { color: var(--ess-navy); font-weight: 500; }

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

.ess-stores-dir__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 18px;
	list-style: none;
	margin: 0;
	padding: 0;
}
@media (min-width: 640px)  { .ess-stores-dir__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .ess-stores-dir__grid { grid-template-columns: repeat(3, 1fr); } } /* era 4-col — cards più grandi con 2 CTA */

.ess-stores-dir__card {
	position: relative;
	background: #ffffff;
	border: 1px solid var(--ess-line);
	border-radius: 0;
	overflow: visible;
	transition: transform var(--ess-transition-fast), box-shadow var(--ess-transition-fast);
	list-style: none;
}
.ess-stores-dir__card:hover,
.ess-stores-dir__card:focus-within {
	transform: translateY(-2px);
	box-shadow: var(--ess-shadow-card-hover);
}

.ess-stores-dir__link {
	position: absolute;
	inset: 0;
	z-index: 1;
	text-indent: -9999px;
	overflow: hidden;
}
.ess-stores-dir__link:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: -3px;
}

.ess-stores-dir__cover {
	position: relative;
	height: 110px;
	overflow: hidden;
	background: var(--ess-surface);
}
.ess-stores-dir__cover img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Variante --logo: il vendor ha caricato logo store ma NON banner cover.
 * Sfondo bianco puro (loghi PNG con trasparenza si vedono nitidi),
 * logo centrato con `object-fit: contain` per non tagliarlo. */
.ess-stores-dir__cover--logo {
	background: #ffffff;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 16px;
}
.ess-stores-dir__cover--logo .ess-stores-dir__cover-logo-img {
	width: auto;
	max-width: 80%;
	height: auto;
	max-height: 80%;
	object-fit: contain;
}

/* .ess-stores-dir__year — etichetta "dal YYYY" rimossa dal markup
 * (decisione cliente, lo store directory non mostra più anno iscrizione).
 * CSS preservato non più usato; può essere rimosso al prossimo cleanup. */

.ess-stores-dir__body {
	padding: 16px;
	position: relative;
	z-index: 2;
}

.ess-stores-dir__avatar {
	position: absolute;
	top: -20px;
	left: 16px;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--ess-font-serif);
	font-size: 18px;
	font-weight: 400;
	color: #ffffff;
	background: var(--ess-sea);
	border: 3px solid #ffffff;
	z-index: 3;
	letter-spacing: -0.2px;
	text-transform: uppercase;
	background-image: none !important;
}
.ess-stores-dir__avatar.ess-placeholder--sea    { background: var(--ess-sea); color: #ffffff; }
.ess-stores-dir__avatar.ess-placeholder--terra  { background: var(--ess-terra); color: #ffffff; }
.ess-stores-dir__avatar.ess-placeholder--lemon  { background: var(--ess-limone); color: var(--ess-ink); }
.ess-stores-dir__avatar.ess-placeholder--olive  { background: var(--ess-ulivo); color: #ffffff; }

/* Variante --logo: contiene <img> store logo Dokan (gravatar attachment).
 * Quadrato (no border-radius) con sfondo bianco — i loghi PNG con trasparenza
 * si vedono nitidi e non vengono ritagliati dalla maschera circolare. */
.ess-stores-dir__avatar--logo {
	background: #ffffff !important;
	background-image: none !important;
	padding: 4px;
	border-radius: 0;
	border: 1px solid var(--ess-line);
}
.ess-stores-dir__avatar--logo img {
	width: 100%;
	height: 100%;
	object-fit: contain;       /* niente crop, logo intero visibile */
	display: block;
	border-radius: 0;
	background: #ffffff;
}

.ess-stores-dir__name {
	margin: 22px 0 0;
	font-family: var(--ess-font-serif);
	font-size: 18px;
	font-weight: 400;
	line-height: 1.1;
	color: var(--ess-navy);
	letter-spacing: -0.3px;
}

.ess-stores-dir__meta {
	font-family: var(--ess-font-mono);
	font-size: 11px;
	color: var(--ess-muted);
	letter-spacing: 0.5px;
	text-transform: uppercase;
	margin-top: 4px;
	line-height: 1.4;
}

.ess-stores-dir__stats {
	display: flex;
	justify-content: space-between;
	margin-top: 16px;
	padding-top: 14px;
	border-top: 1px solid var(--ess-line);
	font-size: 11px;
	color: var(--ess-navy-soft);
}

/* === CTA row (Segui + WhatsApp) — sostituisce stats prodotti/rating ============ */
.ess-stores-dir__ctas {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 8px;
	margin-top: 16px;
	padding-top: 14px;
	border-top: 1px solid var(--ess-line);
	position: relative;
	z-index: 3; /* sopra il link-cover absolute */
}

/* Caso vendor senza WhatsApp: la singola CTA Segui prende tutta la larghezza. */
.ess-stores-dir__ctas > .ess-stores-dir__cta:only-child {
	grid-column: 1 / -1;
}

.ess-stores-dir__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 9px 10px;
	font-family: var(--ess-font-body);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.2px;
	text-decoration: none;
	border: 1px solid transparent;
	cursor: pointer;
	transition: background-color var(--ess-transition-fast), color var(--ess-transition-fast), border-color var(--ess-transition-fast);
	min-height: 38px;
}

/* Segui — outline navy → fill su hover */
.ess-stores-dir__cta--follow {
	background: #ffffff;
	color: var(--ess-navy);
	border-color: var(--ess-navy);
}
.ess-stores-dir__cta--follow:hover,
.ess-stores-dir__cta--follow:focus-visible {
	background: var(--ess-navy);
	color: #ffffff;
}

/* WhatsApp — verde brand classic 25D366 (ratio 3.3:1 fill bianco quindi usiamo testo bianco su 075E54 hover) */
.ess-stores-dir__cta--whatsapp {
	background: #25D366;
	color: #ffffff;
	border-color: #25D366;
}
.ess-stores-dir__cta--whatsapp:hover,
.ess-stores-dir__cta--whatsapp:focus-visible {
	background: #128C7E;
	border-color: #128C7E;
}

/* Override stile per markup nativo Dokan Follow Button (può emettere classi proprie) */
.ess-stores-dir__ctas .dokan-follow-store-button-wrap {
	margin: 0;
	display: flex;
}
.ess-stores-dir__ctas .dokan-follow-store-button-wrap > a,
.ess-stores-dir__ctas .dokan-follow-store-button-wrap > button {
	width: 100%;
	min-height: 38px;
}

.ess-stores-dir__pagination {
	display: flex;
	justify-content: center;
	gap: 6px;
	margin-top: 40px;
	flex-wrap: wrap;
}
.ess-stores-dir__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);
	color: var(--ess-navy-soft);
	text-decoration: none;
	font-size: 13px;
	transition: border-color var(--ess-transition-fast), color var(--ess-transition-fast);
}
.ess-stores-dir__pagination .page-numbers:hover { border-color: var(--ess-navy); color: var(--ess-navy); }
.ess-stores-dir__pagination .page-numbers.current { background: var(--ess-navy); border-color: var(--ess-navy); color: #ffffff; }

/* ==========================================================================
   SINGLE STORE PAGE (v2) — /bottega/{slug}/
   ========================================================================== */

.ess-store-page-main { display: block; margin-top: 0; padding-top: 0; }
.ess-store-page { font-family: var(--ess-font-body); }

.ess-store-page__cover {
	position: relative;
	height: 200px;
	overflow: hidden;
	background: var(--ess-surface);
}
@media (min-width: 768px) { .ess-store-page__cover { height: 260px; } }
.ess-store-page__cover img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.ess-store-page__cover-gradient {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 30%, rgba(22, 21, 18, 0.55));
	pointer-events: none;
}

/* Layout 4-col (desktop): avatar | identity-main | tabs | identity-right (CTA).
 * MODELLO "Twitter-style":
 *   - Avatar 120×120 sporge -60 (metà sopra banner, metà sotto)
 *   - Riga identity: `margin-top: -60` (sale di metà avatar) + `align-items: end`
 *   - Tutti gli elementi (nome, tabs, CTA) sono allineati al BOTTOM della row,
 *     in linea col bottom dell'avatar → nome respira sotto il banner di ~10px.
 * Mobile: stack 1-col. Tablet 768-1099: 3-col + tabs sotto. Desktop ≥1100: 4-col. */
.ess-store-page__identity {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
	margin-top: 0;
	padding: 16px 0 20px;
	align-items: end;
	position: relative;
	z-index: 2;
}
@media (min-width: 768px) {
	.ess-store-page__identity {
		grid-template-columns: auto 1fr auto;
		grid-template-areas:
			"avatar main right"
			"tabs   tabs   tabs";
		gap: 16px 20px;
		margin-top: -44px;       /* l'avatar sborda ~44px sul banner; il titolo (bottom-allineato) resta sotto il bordo senza toccarlo */
		padding: 0 0 20px;       /* no padding top: l'avatar fa da spaziatore */
	}
	.ess-store-page__avatar         { grid-area: avatar; align-self: end; }
	.ess-store-page__identity-main  { grid-area: main; align-self: end; padding-bottom: 6px; }
	.ess-store-page__tabs           { grid-area: tabs; align-self: end; padding-bottom: 6px; }
	.ess-store-page__identity-right { grid-area: right; align-self: end; padding-bottom: 6px; }
}
@media (min-width: 1100px) {
	.ess-store-page__identity {
		grid-template-columns: auto minmax(260px, 1fr) auto auto;
		grid-template-areas: "avatar main tabs right";
		gap: 24px;
	}
}

.ess-store-page__avatar {
	width: 96px;
	height: 96px;
	background: #ffffff;
	color: #ffffff;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 3px solid #ffffff;
	box-shadow: 0 1px 0 var(--ess-line-strong);
	position: relative;
	z-index: 1;
	overflow: hidden;
	flex-shrink: 0;
	font-family: var(--ess-font-serif);
	letter-spacing: -0.4px;
	text-transform: uppercase;
	background-image: none !important;
}
@media (min-width: 768px) { .ess-store-page__avatar { width: 120px; height: 120px; } }

/* Variante --placeholder (no logo store): bg tone-colored con iniziale */
.ess-store-page__avatar--placeholder { background: var(--ess-sea); }

/* Logo store (img) — fit contenuto integro, niente crop */
.ess-store-page__avatar img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
	background: #ffffff;
	padding: 4px;
	box-sizing: border-box;
}
.ess-store-page__avatar-letter {
	font-size: 40px;
	font-weight: 400;
	line-height: 1;
	color: #ffffff;
}
@media (min-width: 768px) { .ess-store-page__avatar-letter { font-size: 44px; } }
.ess-store-page__avatar.ess-placeholder--sea    { background: var(--ess-sea); color: #ffffff; }
.ess-store-page__avatar.ess-placeholder--terra  { background: var(--ess-terra); color: #ffffff; }
.ess-store-page__avatar.ess-placeholder--lemon  { background: var(--ess-limone); color: var(--ess-ink); }
.ess-store-page__avatar.ess-placeholder--olive  { background: var(--ess-ulivo); color: #ffffff; }

.ess-store-page__identity-main { min-width: 0; padding: 0; }

.ess-store-page__title-row {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 6px;
	flex-wrap: wrap;
}

.ess-store-page__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(1.5rem, 1rem + 1.4vw, 2rem);   /* 24px–32px (era 28–40) */
	line-height: 1.05;
	letter-spacing: -0.6px;
	color: var(--ess-navy);
	margin: 0;
	font-weight: 400;
}

.ess-store-page__verified {
	background: var(--ess-ulivo);
	color: #ffffff;
	font-family: var(--ess-font-mono);
	font-size: 9px;
	padding: 3px 7px;
	letter-spacing: 0.5px;
	text-transform: uppercase;
}

/* Badge "Bottega verificata" — variante SVG inline con tooltip accessibile.
   Emesso dai template Dokan quando $is_verified. Il badge SVG è circolare 48px. */
.ess-verified-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	flex-shrink: 0;
	line-height: 0;
}
.ess-verified-badge svg { width: 100%; height: 100%; display: block; }
.ess-verified-badge--sm { width: 32px; height: 32px; }
.ess-verified-badge--xs { width: 24px; height: 24px; }

.ess-store-page__meta {
	font-family: var(--ess-font-mono);
	font-size: 11px;
	color: var(--ess-navy-soft);
	letter-spacing: 0.5px;
	text-transform: uppercase;
	line-height: 1.45;
	margin: 0;
}

.ess-store-page__identity-right {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 12px;
}

/* Stats stile (rating/products/positive) — markup rimosso da store-header.php
 * (richiesta cliente). CSS preservato per backward-compat se template custom
 * altrove ancora include il blocco; può essere rimosso al prossimo cleanup. */
.ess-store-page__stats {
	display: flex;
	gap: 24px;
	margin: 0;
}
.ess-store-page__stat { margin: 0; }
.ess-store-page__stat-n {
	font-family: var(--ess-font-serif);
	font-size: 22px;
	color: var(--ess-sea);
	margin: 0;
	line-height: 1;
	font-weight: 400;
}
.ess-store-page__stat-l {
	font-family: var(--ess-font-mono);
	font-size: 9px;
	color: var(--ess-muted);
	letter-spacing: 0.8px;
	text-transform: uppercase;
	margin: 2px 0 0;
}

/* CTA Contatta — same height come tabs e WhatsApp button (48px), squadrato (no radius). */
.ess-store-page__contact {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 48px;
	padding: 0 22px;
	font-size: 11px;
	letter-spacing: 1px;
	line-height: 1;
	white-space: nowrap;
	border-radius: 0 !important;        /* batte eventuali override WC/Dokan */
}

/* CTA WhatsApp — squadrato, height 48px, stesso style bottoni del sito (no border-radius). */
.ess-store-page__whatsapp {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	height: 48px;
	padding: 0 18px;
	background: #25D366;
	color: #ffffff;
	border: 1px solid #25D366;
	border-radius: 0;
	font-family: var(--ess-font-body);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 1px;
	line-height: 1;
	text-transform: uppercase;
	text-decoration: none;
	white-space: nowrap;
	transition: background var(--ess-transition-fast), border-color var(--ess-transition-fast);
}
.ess-store-page__whatsapp:hover,
.ess-store-page__whatsapp:focus-visible {
	background: #1EBE5A;
	border-color: #1EBE5A;
	color: #ffffff;
}
.ess-store-page__whatsapp:focus-visible {
	outline: 2px solid var(--ess-ink);
	outline-offset: 2px;
}
.ess-store-page__whatsapp svg { flex-shrink: 0; }

/* Tabs — height 48px = stessa altezza CTA. No border-top in desktop (≥1100),
 * border-top in tablet (768-1099) quando wrappano sotto. */
.ess-store-page__tabs {
	display: flex;
	gap: 24px;
	overflow-x: auto;
	scrollbar-width: thin;
	border-top: 1px solid var(--ess-line);
	padding-top: 0;
	height: 48px;
	align-items: center;
}
.ess-store-page__tab {
	height: 100%;
	display: inline-flex;
	align-items: center;
	padding: 0;
	white-space: nowrap;
}
@media (min-width: 1100px) {
	.ess-store-page__tabs {
		border-top: 0;
		justify-content: center;
	}
}
.ess-store-page__tab {
	font-family: var(--ess-font-body);
	font-size: 13px;
	color: var(--ess-navy-soft);
	text-decoration: none;
	border-bottom: 2px solid transparent;
	font-weight: 400;
	transition: color var(--ess-transition-fast), border-color var(--ess-transition-fast);
}
.ess-store-page__tab:hover,
.ess-store-page__tab:focus-visible {
	color: var(--ess-navy);
	border-bottom-color: var(--ess-orange);
}
.ess-store-page__tab:focus-visible {
	outline: 2px solid var(--ess-orange);
	outline-offset: 4px;
}
.ess-store-page__tab.is-active {
	color: var(--ess-navy);
	font-weight: 500;
	border-bottom-color: var(--ess-orange);
}

.ess-store-page__layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
	padding-block: 32px 56px;
}
@media (min-width: 1024px) {
	.ess-store-page__layout { grid-template-columns: 280px 1fr; }
}

.ess-store-page__sidebar { font-size: 13px; color: var(--ess-navy-soft); }

.ess-store-page__info-box {
	background: #ffffff;
	border: 1px solid var(--ess-line);
	padding: 20px;
	margin-bottom: 20px;
}
.ess-store-page__info-box .ess-eyebrow { margin-bottom: 10px; }

.ess-store-page__about {
	font-size: 12px;
	color: var(--ess-navy-soft);
	line-height: 1.55;
	margin: 0;
}

.ess-store-page__shipping-box {
	background: var(--ess-navy);
	color: #e9e2d0;
	padding: 20px;
	margin-bottom: 20px;
}
.ess-store-page__shipping-eyebrow { color: var(--ess-gold); margin-bottom: 10px; }
.ess-store-page__shipping-text {
	font-size: 12px;
	line-height: 1.55;
	opacity: 0.85;
	margin: 0;
}

.ess-store-page__contact-anchor { scroll-margin-top: 80px; }

.ess-store-page__main { min-width: 0; }

/* Wrapper "seller-items" — block normale (NO grid).
   La griglia vera vive sul <ul.ess-product-grid> interno reso da
   woocommerce_product_loop_start(). Vedi override piu' sotto per le 3 col. */
.ess-store-page__products {
	display: block;
	margin: 0;
	padding: 0;
}

/* Pagina vendor: 3 colonne max sul main perche' la sidebar 280px riduce lo
   spazio. Override con specificita' alta per battere .ess-product-grid (4 col). */
.ess-store-page__main ul.products.ess-product-grid {
	grid-template-columns: 1fr;
}
@media (min-width: 640px) {
	.ess-store-page__main ul.products.ess-product-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (min-width: 1024px) {
	.ess-store-page__main ul.products.ess-product-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

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

.ess-store-page__sidebar .widget,
.ess-store-page__sidebar .dokan-widget-area > section {
	background: #ffffff;
	border: 1px solid var(--ess-line);
	padding: 16px;
	margin-bottom: 20px;
	font-size: 12px;
}
.ess-store-page__sidebar .widget-title,
.ess-store-page__sidebar .dokan-widget-area h3 {
	font-family: var(--ess-font-body);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	color: var(--ess-orange);
	margin: 0 0 10px;
	border-bottom: 0;
	padding-bottom: 0;
}
