:root {
	--eswl-primary:         #0678be;
	--eswl-primary-hover:   #53a2d2;
	--eswl-primary-light:   #fde8ea;
	--eswl-secondary:       #005f27;
	--eswl-text:            #383838;
	--eswl-text-muted:      #6c757d;
	--eswl-bg:              #ffffff;
	--eswl-bg-alt:          #f8f9fa;
	--eswl-border:          #dee2e6;
	--eswl-border-radius:   8px;
	--eswl-radius-sm:       4px;
	--eswl-shadow:          0 2px 8px rgba(0, 0, 0, 0.10);
	--eswl-shadow-hover:    0 4px 16px rgba(0, 0, 0, 0.16);
	--eswl-transition:      0.2s ease;
	--eswl-font-size:       16px;
	--eswl-font-size-sm:    13px;
	--eswl-success:         #005f27;
	--eswl-success-bg:      #2a9857;
	--eswl-error:           #9b2226;
	--eswl-error-bg:        #fde8e8;
	--eswl-info:            #1d6fa4;
	--eswl-info-bg:         #d0eaf8;
}
.eswl-button-wrap {
	margin-top: 2rem;
	margin-bottom: 1rem;
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.eswl-button-wrap .eswl-wishlist-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.65rem 1.25rem;
	background-color: var(--eswl-success);
	color: var(--eswl-bg);
	border: 2px solid var(--eswl-border);
	border-radius: var(--eswl-border-radius);
	font-size: var(--eswl-font-size);
	font-weight: 500;
	cursor: pointer;
	text-decoration: none;
	transition: background-color var(--eswl-transition), border-color var(--eswl-transition), color var(--eswl-transition), box-shadow var(--eswl-transition);
	-webkit-appearance: none;
	appearance: none;
}

.eswl-button-wrap .eswl-wishlist-btn:hover,
.eswl-button-wrap .eswl-wishlist-btn:focus {
	background-color: var(--eswl-success-bg);
	border-color: var(--eswl-success);
	color: var(--eswl-bg);
	box-shadow: var(--eswl-shadow);
	outline: none;
}

.eswl-wishlist-btn:focus-visible {
	outline: 3px solid var(--eswl-primary);
	outline-offset: 2px;
}

/* Stato attivo: tour già nei preferiti */
.eswl-wishlist-btn.eswl-active {
	background-color: var(--eswl-primary);
	border-color: var(--eswl-primary);
	color: #ffffff;
}

.eswl-wishlist-btn.eswl-active:hover,
.eswl-wishlist-btn.eswl-active:focus {
	background-color: var(--eswl-primary-hover);
	border-color: var(--eswl-primary-hover);
	color: #ffffff;
}

.eswl-btn-icon {
	font-size: 1.15em;
	line-height: 1;
	transition: transform var(--eswl-transition);
}

.eswl-view-wishlist-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.65rem 1.25rem;
	background-color: var(--eswl-bg-alt);
	color: var(--eswl-secondary);
	border: 2px solid var(--eswl-secondary);
	border-radius: var(--eswl-border-radius);
	font-size: var(--eswl-font-size);
	font-weight: 500;
	text-decoration: none;
	transition:
		background-color var(--eswl-transition),
		color var(--eswl-transition);
}

.eswl-button-wrap .eswl-view-wishlist-btn:hover,
.eswl-button-wrap .eswl-view-wishlist-btn:focus {
	background-color: var(--eswl-secondary);
	color: #ffffff;
	outline: none;
	text-decoration: none;
}

.eswl-view-wishlist-btn:focus-visible {
	outline: 3px solid var(--eswl-secondary);
	outline-offset: 2px;
}

/* Stato di caricamento AJAX */
.eswl-wishlist-btn.eswl-loading {
	opacity: 0.7;
	cursor: wait;
	pointer-events: none;
}

.eswl-wishlist-container {
	max-width: 1260px;
	margin: 0 auto;
	font-size: var(--eswl-font-size);
	color: var(--eswl-text);
	padding-left: 15px;
   padding-right: 15px;
   margin-bottom: 50px;
}
.eswl-panel .eswl-wishlist-container {
	padding: 0;
}

.eswl-wishlist-header {
	margin-bottom: 2rem;
	padding-bottom: 1.5rem;
	border-bottom: 2px solid var(--eswl-border);
}

.eswl-wishlist-title {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--eswl-text);
	margin: 0 0 1.25rem;
}

.eswl-count-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 25px;
	height: 25px;
	padding: 0 0.4rem;
	background-color: var(--eswl-primary);
	color: var(--eswl-bg);
	border-radius: 999px;
	font-size: 13px;
	font-weight: 700;
	line-height: 1;
}

.eswl-privacy-controls {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.eswl-privacy-toggle-wrap {
	display: flex;
	align-items: center;
	gap: 1rem;
	flex-wrap: wrap;
}

.eswl-privacy-label {
	font-size: var(--eswl-font-size-sm);
	color: var(--eswl-text-muted);
	font-weight: 500;
}

.eswl-privacy-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.45rem 1rem;
	border-radius: var(--eswl-border-radius);
	font-size: var(--eswl-font-size-sm);
	font-weight: 500;
	cursor: pointer;
	border: 2px solid transparent;
	transition:
		background-color var(--eswl-transition),
		border-color var(--eswl-transition),
		color var(--eswl-transition);
	-webkit-appearance: none;
	appearance: none;
}

.eswl-privacy-btn.eswl-privacy-public {
	background-color: var(--eswl-success-bg);
	color: var(--eswl-bg);
	border-color: var(--eswl-success);
}

.eswl-privacy-btn.eswl-privacy-public:hover,
.eswl-privacy-btn.eswl-privacy-public:focus {
	background-color: var(--eswl-success);
}

.eswl-privacy-btn.eswl-privacy-private {
	background-color: var(--eswl-bg-alt);
	color: var(--eswl-text-muted);
	border-color: var(--eswl-border);
}

.eswl-privacy-btn.eswl-privacy-private:hover,
.eswl-privacy-btn.eswl-privacy-private:focus {
	background-color: var(--eswl-text-muted);
	color: #ffffff;
}

.eswl-privacy-btn:focus-visible {
	outline: 3px solid var(--eswl-secondary);
	outline-offset: 2px;
}

.eswl-privacy-btn.eswl-loading {
	opacity: 0.6;
	cursor: wait;
	pointer-events: none;
}

.eswl-share-wrap {
	background-color: var(--eswl-bg-alt);
	border: 1px solid var(--eswl-border);
	border-radius: var(--eswl-border-radius);
	padding: 1rem 1.25rem;
}

.eswl-share-label {
	display: block;
	font-size: var(--eswl-font-size-sm);
	font-weight: 600;
	color: var(--eswl-text);
	margin-bottom: 0.5rem;
}

.eswl-share-link-row {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.eswl-share-input-group {
	display: flex;
	gap: 0.5rem;
}

.eswl-share-input {
	flex: 1;
	padding: 0.5rem 0.75rem;
	border: 1px solid var(--eswl-border);
	border-radius: var(--eswl-radius-sm);
	font-size: var(--eswl-font-size-sm);
	background-color: var(--eswl-bg);
	color: var(--eswl-text);
	min-width: 0; /* Permette all'input di restringersi correttamente */
}

.eswl-share-input:focus {
	outline: 2px solid var(--eswl-secondary);
	border-color: var(--eswl-secondary);
}

.eswl-copy-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.5rem 1rem;
	background-color: var(--eswl-secondary);
	color: #ffffff;
	border: none;
	border-radius: var(--eswl-radius-sm);
	font-size: var(--eswl-font-size-sm);
	font-weight: 500;
	cursor: pointer;
	white-space: nowrap;
	transition: background-color var(--eswl-transition);
	-webkit-appearance: none;
	appearance: none;
}

.eswl-copy-btn:hover,
.eswl-copy-btn:focus {
	background-color: var(--eswl-success-bg);
}

.eswl-copy-btn:focus-visible {
	outline: 3px solid var(--eswl-secondary);
	outline-offset: 2px;
}

.eswl-share-hint {
	font-size: 13px;
	color: var(--eswl-text-muted);
	margin: 0.5rem 0 0;
}

.eswl-tour-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.eswl-tour-item {
	margin: 0;
	padding: 0;
}

.eswl-tour-item.eswl-removing {
	opacity: 0;
	transform: translateX(-20px);
	transition:
		opacity var(--eswl-transition),
		transform var(--eswl-transition),
		max-height 0.3s ease;
	max-height: 0;
	overflow: hidden;
}

.eswl-tour-card {
	display: grid;
	grid-template-columns: 180px 1fr;
	gap: 1.25rem;
	background-color: var(--eswl-bg);
	border: 1px solid var(--eswl-border);
	border-radius: var(--eswl-border-radius);
	overflow: hidden;
	box-shadow: var(--eswl-shadow);
	transition: box-shadow var(--eswl-transition);
}

.eswl-tour-card:hover {
	box-shadow: var(--eswl-shadow-hover);
}

.eswl-tour-thumb-wrap {
	overflow: hidden;
	background-color: var(--eswl-bg-alt);
}

.eswl-tour-thumb-wrap a {
	display: block;
	height: 100%;
}

.eswl-tour-thumb {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.3s ease;
}

.eswl-tour-card:hover .eswl-tour-thumb {
	transform: scale(1.04);
}

.eswl-tour-info {
	padding: 1.25rem 1.25rem 1.25rem 0;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	gap: 0.75rem;
}

.eswl-tour-title {
	font-size: 1.15rem;
	font-weight: 700;
	margin: 0;
	line-height: 1.3;
}

.eswl-tour-title a {
	color: var(--eswl-text);
	text-decoration: none;
	transition: color var(--eswl-transition);
}

.eswl-tour-title a:hover,
.eswl-tour-title a:focus {
	color: var(--eswl-primary);
	text-decoration: underline;
}

.eswl-tour-date-added {
	font-size: var(--eswl-font-size-sm);
	color: var(--eswl-text-muted);
	margin: 0;
}

.eswl-remove-btn {
	align-self: flex-start;
	display: inline-flex;
	align-items: center;
	padding: 0.4rem 0.85rem;
	background-color: transparent;
	color: var(--eswl-error);
	border: 1px solid var(--eswl-error);
	border-radius: var(--eswl-radius-sm);
	font-size: var(--eswl-font-size-sm);
	font-weight: 500;
	cursor: pointer;
	transition:
		background-color var(--eswl-transition),
		color var(--eswl-transition);
	-webkit-appearance: none;
	appearance: none;
}

.eswl-remove-btn:hover,
.eswl-remove-btn:focus {
	background-color: var(--eswl-error);
	color: #ffffff;
}

.eswl-remove-btn:focus-visible {
	outline: 3px solid var(--eswl-error);
	outline-offset: 2px;
}

.eswl-remove-btn.eswl-loading {
	opacity: 0.6;
	cursor: wait;
	pointer-events: none;
}

.eswl-empty-state {
	text-align: center;
	padding: 3rem 1rem;
	background-color: var(--eswl-bg-alt);
	border-radius: var(--eswl-border-radius);
	border: 2px dashed var(--eswl-border);
}

.eswl-empty-icon {
	font-size: 3.5rem;
	display: block;
	margin-bottom: 1rem;
	opacity: 0.4;
}

.eswl-empty-text {
	font-size: 1.2rem;
	font-weight: 600;
	color: var(--eswl-text);
	margin: 0 0 0.5rem;
}

.eswl-empty-hint {
	font-size: var(--eswl-font-size-sm);
	color: var(--eswl-text-muted);
	margin: 0;
}

.eswl-notice {
	padding: 0.85rem 1.25rem;
	border-radius: var(--eswl-radius-sm);
	border-left: 4px solid transparent;
	margin-bottom: 1.25rem;
	font-size: var(--eswl-font-size-sm);
}

.eswl-notice p {
	margin: 0;
}

.eswl-notice-info {
	background-color: var(--eswl-info-bg);
	border-left-color: var(--eswl-info);
	color: var(--eswl-info);
}

.eswl-notice-error {
	background-color: var(--eswl-error-bg);
	border-left-color: var(--eswl-error);
	color: var(--eswl-error);
}

.eswl-notice-success {
	background-color: var(--eswl-success-bg);
	border-left-color: var(--eswl-success);
	color: var(--eswl-success);
}

.eswl-js-notice {
	padding: 0.65rem 1rem;
	border-radius: var(--eswl-radius-sm);
	font-size: var(--eswl-font-size-sm);
	margin-top: 0.75rem;
	transition: opacity var(--eswl-transition);
}

.eswl-js-notice.eswl-notice-success {
	background-color: var(--eswl-success-bg);
	color: var(--eswl-bg);
}

.eswl-js-notice.eswl-notice-error {
	background-color: var(--eswl-error-bg);
	color: var(--eswl-error);
}

.eswl-public-view .eswl-wishlist-header h2 {
	font-size: 1.5rem;
	color: var(--eswl-text);
}

.eswl-owner-name {
	color: var(--eswl-primary);
}

.eswl-hidden {
	display: none !important;
}

@media (prefers-reduced-motion: reduce) {
	.eswl-wishlist-btn,
	.eswl-tour-card,
	.eswl-tour-thumb,
	.eswl-privacy-btn,
	.eswl-remove-btn,
	.eswl-tour-item.eswl-removing {
		transition: none;
	}
}

@media (max-width: 640px) {
	.eswl-tour-card {
		grid-template-columns: 1fr;
	}

	.eswl-tour-thumb-wrap {
		height: 200px;
	}

	.eswl-tour-info {
		padding: 1rem;
	}

	.eswl-share-input-group {
		flex-direction: column;
	}

	.eswl-copy-btn {
		justify-content: center;
	}

	.eswl-privacy-toggle-wrap {
		flex-direction: column;
		align-items: flex-start;
	}
}

.eswl-panel {
	max-width: 1260px;
	margin: 0 auto;
	font-size: var(--eswl-font-size);
	color: var(--eswl-text);
	padding-left: 15px;
   padding-right: 15px;
   margin-bottom: 50px;
}

.eswl-tabs {
	display: flex;
	gap: 0;
	border-bottom: 2px solid var(--eswl-border);
	margin-bottom: 2rem;
}

.eswl-tabs .eswl-tab {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.75rem 1.5rem;
	background: transparent;
	border: none;
	border-bottom: 3px solid transparent;
	margin-bottom: -2px;
	font-size: var(--eswl-font-size);
	font-weight: 500;
	color: var(--eswl-text-muted);
	cursor: pointer;
	transition:
		color var(--eswl-transition),
		border-color var(--eswl-transition);
	-webkit-appearance: none;
	appearance: none;
}

.eswl-tab:hover,
.eswl-tab:focus {
	color: var(--eswl-primary);
	outline: none;
}

.eswl-tab:focus-visible {
	outline: 3px solid var(--eswl-primary);
	outline-offset: 2px;
}

.eswl-tab.eswl-tab-active {
	color: var(--eswl-primary);
	border-bottom-color: var(--eswl-primary);
	font-weight: 700;
}

.eswl-tab-panel {
	animation: eswlFadeIn 0.2s ease;
}

.eswl-tab-panel[hidden] {
	display: none;
}

@keyframes eswlFadeIn {
	from { opacity: 0; transform: translateY(6px); }
	to   { opacity: 1; transform: translateY(0); }
}

.eswl-account-header {
	display: flex;
	align-items: center;
	gap: 1.25rem;
	padding: 1.5rem;
	background: var(--eswl-bg-alt);
	border: 1px solid var(--eswl-border);
	border-radius: var(--eswl-border-radius);
	margin-bottom: 2rem;
}

.eswl-account-avatar {
	flex-shrink: 0;
}

.eswl-avatar-img {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid var(--eswl-border);
}

.eswl-account-name {
	font-size: 1.35rem;
	font-weight: 700;
	margin: 0 0 0.25rem;
	color: var(--eswl-text);
}

.eswl-account-email {
	font-size: var(--eswl-font-size-sm);
	color: var(--eswl-text-muted);
	margin: 0;
}

.eswl-account-info {
	flex: 1;
	min-width: 0;
}

.eswl-logout-btn {
	margin-left: auto;
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.45rem 1rem;
	background-color: transparent;
	color: var(--eswl-text-muted);
	border: 1px solid var(--eswl-border);
	border-radius: var(--eswl-border-radius);
	font-size: var(--eswl-font-size-sm);
	font-weight: 500;
	text-decoration: none;
	cursor: pointer;
	transition:
		background-color var(--eswl-transition),
		border-color var(--eswl-transition),
		color var(--eswl-transition);
	white-space: nowrap;
}

.eswl-logout-btn:hover,
.eswl-logout-btn:focus {
	background-color: var(--eswl-bg-alt);
	border-color: var(--eswl-text-muted);
	color: var(--eswl-text);
	outline: none;
}

.eswl-logout-btn:focus-visible {
	outline: 3px solid var(--eswl-secondary);
	outline-offset: 2px;
}

.eswl-form {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.eswl-form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1rem;
}

.eswl-form-group {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}

.eswl-form-group label {
	font-size: var(--eswl-font-size-sm);
	font-weight: 600;
	color: var(--eswl-text);
}

.eswl-optional {
	font-weight: 400;
	color: var(--eswl-text-muted);
	font-size: 0.8rem;
	margin-left: 0.25rem;
}

.eswl-required {
	color: var(--eswl-error);
}

.eswl-required-note {
	font-size: var(--eswl-font-size-sm);
	color: var(--eswl-text-muted);
	margin: 0;
}

.eswl-input {
	width: 100%;
	padding: 0.6rem 0.9rem;
	border: 1px solid var(--eswl-border);
	border-radius: var(--eswl-radius-sm);
	font-size: var(--eswl-font-size);
	color: var(--eswl-text);
	background-color: var(--eswl-bg);
	transition: border-color var(--eswl-transition), box-shadow var(--eswl-transition);
	box-sizing: border-box;
	-webkit-appearance: none;
	appearance: none;
}

.eswl-input:focus {
	outline: none;
	border-color: var(--eswl-secondary);
	box-shadow: 0 0 0 3px rgba(69, 123, 157, 0.15);
}

.eswl-input-wrap {
	position: relative;
	display: flex;
	align-items: center;
}

.eswl-input-wrap .eswl-input {
	padding-right: 2.8rem;
}

.eswl-toggle-password {
	position: absolute;
	right: 0.6rem;
	background: transparent;
	border: none;
	cursor: pointer;
	padding: 0.3rem;
	color: var(--eswl-text-muted);
	font-size: 1rem;
	display: flex;
	align-items: center;
	-webkit-appearance: none;
	appearance: none;
}

.eswl-toggle-password:hover {
	color: var(--eswl-text);
}

.eswl-toggle-password:focus-visible {
	outline: 2px solid var(--eswl-secondary);
	border-radius: var(--eswl-radius-sm);
}

/* ── Hint campo ── */
.eswl-field-hint {
	font-size: 0.8rem;
	color: var(--eswl-text-muted);
	margin: 0.25rem 0 0;
}

.eswl-optout-group {
	padding: 1rem 1.25rem;
	background: var(--eswl-bg-alt);
	border: 1px solid var(--eswl-border);
	border-radius: var(--eswl-border-radius);
}

.eswl-optout-fieldset {
	border: none;
	margin: 0;
	padding: 0;
}

.eswl-optout-legend {
	font-size: var(--eswl-font-size-sm);
	font-weight: 700;
	color: var(--eswl-text);
	margin-bottom: 0.75rem;
	padding: 0;
}

.eswl-checkbox-label {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	cursor: pointer;
	font-weight: 400 !important;
}

.eswl-checkbox-native {
	position: absolute;
	opacity: 0;
	width: 0;
	height: 0;
	pointer-events: none;
}

.eswl-checkbox-custom {
	flex-shrink: 0;
	width: 1.15rem;
	height: 1.15rem;
	border: 2px solid var(--eswl-border);
	border-radius: var(--eswl-radius-sm);
	background: var(--eswl-bg);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-top: 0.1rem;
	transition: border-color var(--eswl-transition), background-color var(--eswl-transition);
}

.eswl-checkbox-native:checked + .eswl-checkbox-custom {
	background-color: var(--eswl-primary);
	border-color: var(--eswl-primary);
}

.eswl-checkbox-native:checked + .eswl-checkbox-custom::after {
	content: '';
	display: block;
	width: 0.35rem;
	height: 0.6rem;
	border: 2px solid #fff;
	border-top: none;
	border-left: none;
	transform: rotate(45deg) translate(-1px, -1px);
}

.eswl-checkbox-native:focus-visible + .eswl-checkbox-custom {
	outline: 3px solid var(--eswl-secondary);
	outline-offset: 2px;
}

.eswl-checkbox-text {
	font-size: var(--eswl-font-size-sm);
	color: var(--eswl-text);
	line-height: 1.4;
}

.eswl-form-footer {
	display: flex;
	align-items: center;
	gap: 1.25rem;
	flex-wrap: wrap;
	padding-top: 0.5rem;
}

.eswl-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.4rem;
	padding: 0.65rem 1.5rem;
	border-radius: var(--eswl-border-radius);
	font-size: var(--eswl-font-size);
	font-weight: 600;
	cursor: pointer;
	border: 2px solid transparent;
	text-decoration: none;
	transition:
		background-color var(--eswl-transition),
		border-color var(--eswl-transition),
		color var(--eswl-transition);
	-webkit-appearance: none;
	appearance: none;
}

.eswl-btn-primary {
	background-color: var(--eswl-primary);
	border-color: var(--eswl-primary);
	color: #ffffff;
}

.eswl-btn-primary:hover,
.eswl-btn-primary:focus {
	background-color: var(--eswl-primary-hover);
	border-color: var(--eswl-primary-hover);
	color: #ffffff;
}

.eswl-btn-primary:focus-visible {
	outline: 3px solid var(--eswl-primary);
	outline-offset: 3px;
}

.eswl-btn.eswl-loading {
	opacity: 0.65;
	cursor: wait;
	pointer-events: none;
}

.eswl-link-muted {
	font-size: var(--eswl-font-size-sm);
	color: var(--eswl-text-muted);
	text-decoration: none;
}

.eswl-link-muted:hover {
	color: var(--eswl-secondary);
	text-decoration: underline;
}

.eswl-auth-panel .eswl-tabs {
	margin-bottom: 1.5rem;
}

@media (max-width: 640px) {
	.eswl-form-row {
		grid-template-columns: 1fr;
	}

	.eswl-account-header {
		flex-direction: column;
		text-align: center;
	}

	.eswl-logout-btn {
		margin-left: 0;
		align-self: center;
	}

	.eswl-tab {
		padding: 0.65rem 1rem;
		font-size: var(--eswl-font-size-sm);
	}

	.eswl-form-footer {
		flex-direction: column;
		align-items: stretch;
	}

	.eswl-btn {
		width: 100%;
	}
}
