/**
 * 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 — ReHub-style banner with overlay + profile
   ========================================================================== */

.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 — matches ReHub's wcvendor-cover-image-mask */
.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 — ReHub style (gray bar, vertical separators)
   ========================================================================== */

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

/* Each widget block — ReHub .rh-cartbox style */
#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;
}

/* Widget titles — centered, gray background like ReHub */
#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);
}

.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 */
.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: var(--ess-radius-md) !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 */
.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: var(--ess-radius-md);
	box-shadow: var(--ess-shadow-md);
}

/* Submit button — override Dokan's !important inline */
.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: var(--ess-radius-md) !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 */
.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: var(--ess-radius-md) !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: 32px 20px;
	border-bottom: 1px solid var(--ess-line);
	margin-bottom: 32px;
	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(4, 1fr); } }

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

.ess-stores-dir__year {
	position: absolute;
	top: 10px;
	right: 10px;
	font-family: var(--ess-font-mono);
	font-size: 10px;
	color: #ffffff;
	background: rgba(22, 21, 18, 0.7);
	padding: 3px 7px;
	letter-spacing: 0.3px;
	z-index: 2;
}

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

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

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

.ess-store-page__identity {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
	margin-top: -48px;
	padding-bottom: 20px;
	align-items: end;
	position: relative;
	z-index: 2;
}
@media (min-width: 900px) {
	.ess-store-page__identity {
		grid-template-columns: auto 1fr auto;
		gap: 24px;
	}
}

.ess-store-page__avatar {
	width: 100px;
	height: 100px;
	background: var(--ess-sea);
	color: #ffffff;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 4px solid #ffffff;
	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; } }
.ess-store-page__avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ess-store-page__avatar-letter {
	font-size: 48px;
	font-weight: 400;
	line-height: 1;
	color: #ffffff;
}
@media (min-width: 768px) { .ess-store-page__avatar-letter { font-size: 56px; } }
.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-bottom: 4px; }

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

.ess-store-page__title {
	font-family: var(--ess-font-serif);
	font-size: clamp(1.75rem, 1.25rem + 2vw, 2.5rem);
	line-height: 1;
	letter-spacing: -0.8px;
	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: 12px;
	color: var(--ess-navy-soft);
	letter-spacing: 0.5px;
	text-transform: uppercase;
	line-height: 1.4;
}

.ess-store-page__identity-right {
	display: flex;
	align-items: flex-end;
	gap: 20px;
	padding-bottom: 4px;
	flex-wrap: wrap;
}

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

.ess-store-page__contact {
	padding: 12px 22px;
	font-size: 11px;
	letter-spacing: 1px;
	min-height: 44px;
}

.ess-store-page__tabs {
	display: flex;
	gap: 32px;
	border-top: 1px solid var(--ess-line);
	overflow-x: auto;
	scrollbar-width: thin;
}
.ess-store-page__tab {
	padding: 14px 0;
	font-family: var(--ess-font-body);
	font-size: 13px;
	color: var(--ess-navy-soft);
	text-decoration: none;
	border-bottom: 2px solid transparent;
	white-space: nowrap;
	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; }

.ess-store-page__products {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
	list-style: none;
	margin: 0;
	padding: 0;
}
@media (min-width: 640px)  { .ess-store-page__products { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .ess-store-page__products { 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;
}
