/**
 * article.css - Stili per le pagine articolo (trips/food/experiences)
 */

.itinerary-hero {
	position: relative;
	min-height: 65vh;
	height: auto;
	display: grid;
	place-items: center;
	background: var(--primary-blue);
	color: var(--text-light);
	/* overflow-y: visible: evita che Safari iOS rompa backdrop-filter sul pulsante indietro */
	overflow-x: hidden;
	overflow-y: visible;
	background-size: cover;
	background-position: center;
	padding: 40px 0;
}

/* Accento categoria (galleria, link markdown, ecc.): il body ha già data-itinerary-profile */
body[data-itinerary-profile="trips"] {
	--article-accent: var(--cat-trips-accent);
}

body[data-itinerary-profile="food"] {
	--article-accent: var(--cat-food-accent);
}

body[data-itinerary-profile="experiences"] {
	--article-accent: var(--cat-experiences-accent);
}

body[data-itinerary-profile] {
	background: var(--background);
	/* Allineato all’altezza reale della nav (70px sotto 576px in style.css) */
	--itinerary-nav-h: var(--header-nav-height, 72px);
}

html:has(body[data-itinerary-profile]) {
	min-height: 100vh;
	min-height: 100dvh;
	background: var(--background);
	scroll-padding-top: calc(env(safe-area-inset-top, 0px) + var(--header-nav-height, 72px));
}

main#main-content {
	background-color: var(--background);
}

.itinerary-hero .hero-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
	background:
		radial-gradient(
			ellipse 92% 68% at 50% 50%,
			rgba(0, 0, 0, 0.62) 0%,
			rgba(0, 0, 0, 0) 72%
		),
		rgba(0, 0, 0, 0.48);
}

.itinerary-hero .hero-content {
	position: relative;
	z-index: 2;
	text-align: center;
	max-width: 900px;
	padding-left: max(var(--page-gutter, 1.35rem), env(safe-area-inset-left, 0px));
	padding-right: max(var(--page-gutter, 1.35rem), env(safe-area-inset-right, 0px));
}

.itinerary-hero .hero-content h1 {
	font-size: clamp(2.5rem, 8vw, 4.5rem);
	margin-top: 0;
	margin-bottom: 20px;
	color: #fff;
	line-height: 1.15;
	text-shadow:
		0 1px 2px rgba(0, 0, 0, 0.92),
		0 2px 24px rgba(0, 0, 0, 0.58);
}

.itinerary-hero .hero-meta {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	align-items: center;
	column-gap: 14px;
	row-gap: 8px;
	width: fit-content;
	max-width: calc(100% - 2 * var(--page-gutter, 1.35rem));
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 0;
	font-size: clamp(0.85rem, 2.5vw, 1rem);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 700;
	/* Chip scuro: contrasto stabile su qualsiasi foto */
	background: rgba(0, 0, 0, 0.52);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	padding: 12px 22px;
	border-radius: 999px;
	box-shadow:
		0 2px 14px rgba(0, 0, 0, 0.35),
		inset 0 1px 0 rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.14);
}

/* Icone come le card (arancione); testo bianco per massima leggibilità */
.itinerary-hero .hero-meta-item {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	min-width: 0;
	color: rgba(255, 255, 255, 0.97);
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.88);
}

.itinerary-hero .hero-meta-item i {
	flex-shrink: 0;
	color: var(--article-accent, var(--accent-orange));
	font-size: 0.88em;
	text-shadow:
		0 1px 2px rgba(0, 0, 0, 0.85),
		0 0 10px rgba(0, 0, 0, 0.4);
}

.itinerary-hero .hero-meta-sep {
	color: rgba(255, 255, 255, 0.38);
	font-weight: 700;
	text-shadow: none;
	user-select: none;
}

body[data-itinerary-profile] header {
	padding-top: env(safe-area-inset-top, 0px);
}

/*
 * Indietro: fixed sotto l’header; vetro “premium” (speculare, ombre stratificate, lift al hover).
 */
body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover {
	position: fixed;
	top: calc(env(safe-area-inset-top, 0px) + var(--itinerary-nav-h) + 10px);
	left: max(var(--page-gutter, 1.35rem), env(safe-area-inset-left, 0px));
	z-index: 990;
	width: 38px;
	height: 38px;
	min-width: 38px;
	min-height: 38px;
	margin: 0;
	padding: 0;
	border-radius: 50%;
	aspect-ratio: 1;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 0.88rem;
	line-height: 1;
	font-family: inherit;
	overflow: hidden;
	-webkit-tap-highlight-color: transparent;
	touch-action: manipulation;
	appearance: none;
	-webkit-appearance: none;
	isolation: isolate;
	border: 1px solid color-mix(in srgb, rgba(255, 255, 255, 0.52) 72%, rgba(0, 0, 0, 0.1));
	background:
		linear-gradient(
			168deg,
			rgba(255, 255, 255, 0.44) 0%,
			rgba(255, 255, 255, 0.22) 38%,
			rgba(255, 255, 255, 0.12) 68%,
			rgba(255, 255, 255, 0.07) 100%
		);
	color: rgba(255, 255, 255, 0.98);
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.42),
		inset 0 -0.5px 0 rgba(255, 255, 255, 0.06),
		0 0 0 1px rgba(0, 0, 0, 0.1),
		0 2px 4px rgba(0, 0, 0, 0.05),
		0 6px 16px rgba(0, 0, 0, 0.12),
		0 14px 36px rgba(0, 0, 0, 0.14);
	backdrop-filter: blur(26px) saturate(1.22);
	-webkit-backdrop-filter: blur(26px) saturate(1.22);
	/* Stato iniziale: visibile ma più opaco (leggibilità titolo dietro).
	 * JS aggiunge --visible quando si scrolla; hover/focus riportano a stato "pieno". */
	opacity: 0.52;
	pointer-events: auto;
	transform: translate3d(0, 0, 0) scale(1);
	transition:
		opacity 0.44s cubic-bezier(0.18, 0.88, 0.22, 1),
		color 0.28s cubic-bezier(0.22, 1, 0.36, 1),
		background 0.28s cubic-bezier(0.22, 1, 0.36, 1),
		border-color 0.28s cubic-bezier(0.22, 1, 0.36, 1),
		box-shadow 0.32s cubic-bezier(0.22, 1, 0.36, 1),
		transform 0.52s cubic-bezier(0.28, 1.18, 0.42, 1);
}

body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover.itinerary-nav-back--visible {
	opacity: 1;
	pointer-events: auto;
	transform: translate3d(0, 0, 0) scale(1);
	animation: itineraryBackPop 0.26s cubic-bezier(0.22, 1, 0.36, 1);
}

body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:hover,
body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:focus-visible {
	opacity: 1;
}

@keyframes itineraryBackPop {
	0% {
		transform: translate3d(0, 0, 0) scale(0.94);
	}
	60% {
		transform: translate3d(0, 0, 0) scale(1.06);
	}
	100% {
		transform: translate3d(0, 0, 0) scale(1);
	}
}

body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover::before {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: inherit;
	pointer-events: none;
	z-index: 0;
	opacity: 0.55;
	background: linear-gradient(
		118deg,
		rgba(255, 255, 255, 0.65) 0%,
		rgba(255, 255, 255, 0.12) 38%,
		transparent 52%
	);
	transition: opacity 0.32s cubic-bezier(0.22, 1, 0.36, 1);
}

@supports not ((-webkit-backdrop-filter: blur(1px)) or (backdrop-filter: blur(1px))) {
	body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover {
		background: linear-gradient(
			168deg,
			rgba(255, 255, 255, 0.78) 0%,
			rgba(244, 246, 250, 0.86) 100%
		);
		border-color: rgba(255, 255, 255, 0.45);
		box-shadow:
			inset 0 1px 0 rgba(255, 255, 255, 0.55),
			0 0 0 1px rgba(0, 0, 0, 0.08),
			0 6px 20px rgba(0, 0, 0, 0.12);
	}

	body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover::before {
		opacity: 0.4;
	}
}

body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover i {
	position: relative;
	z-index: 1;
	pointer-events: none;
	transition: transform 0.28s cubic-bezier(0.22, 1, 0.36, 1), filter 0.28s ease;
	filter:
		drop-shadow(0 0 1.5px rgba(0, 0, 0, 0.5))
		drop-shadow(0 1px 2px rgba(0, 0, 0, 0.32));
}

body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:hover,
body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:focus-visible {
	border-color: color-mix(in srgb, rgba(255, 255, 255, 0.68) 78%, rgba(0, 0, 0, 0.08));
	background:
		linear-gradient(
			168deg,
			rgba(255, 255, 255, 0.52) 0%,
			rgba(255, 255, 255, 0.28) 36%,
			rgba(255, 255, 255, 0.14) 70%,
			rgba(255, 255, 255, 0.09) 100%
		);
	color: #fff;
	box-shadow:
		inset 0 1px 0 rgba(255, 255, 255, 0.52),
		inset 0 -0.5px 0 rgba(255, 255, 255, 0.08),
		0 0 0 1px rgba(0, 0, 0, 0.08),
		0 4px 8px rgba(0, 0, 0, 0.06),
		0 10px 24px rgba(0, 0, 0, 0.14),
		0 20px 44px rgba(0, 0, 0, 0.16);
}

body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:hover::before,
body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:focus-visible::before {
	opacity: 0.78;
}

@media (prefers-reduced-motion: no-preference) {
	body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:hover,
	body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:focus-visible {
		transform: translateY(-1px);
	}
}

body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:hover i,
body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:focus-visible i {
	transform: translateX(-1px);
}

body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--article-accent, var(--accent-orange)) 55%, rgba(255, 255, 255, 0.5));
	outline-offset: 3px;
}

body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:active {
	transform: translateY(0) scale(0.96);
}

body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:active::before {
	opacity: 0.45;
}

body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:active i {
	transform: translateX(-2px);
}

/*
 * Mobile: press = entrata rapida in :active; rilascio = uscita morbida (curva ~inversa).
 * Stesso schema su bottone e freccia.
 */
@media (max-width: 992px) {
	body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover {
		transition:
			opacity 0.44s cubic-bezier(0.18, 0.88, 0.22, 1),
			color 0.22s ease,
			background 0.22s ease,
			border-color 0.22s ease,
			box-shadow 0.22s ease,
			transform 0.44s cubic-bezier(0.22, 0.95, 0.28, 1);
	}

	body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:active {
		transition:
			color 0.12s ease,
			background 0.12s ease,
			border-color 0.12s ease,
			box-shadow 0.12s ease,
			transform 0.14s cubic-bezier(0.55, 0.05, 0.75, 0.45);
		transform: translateY(0) scale(0.9);
	}

	body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover i {
		transition: transform 0.42s cubic-bezier(0.22, 0.95, 0.28, 1);
	}

	body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:active i {
		transition: transform 0.14s cubic-bezier(0.55, 0.05, 0.75, 0.45);
		transform: translateX(-3px);
	}
}

@media (prefers-reduced-motion: reduce) {
	body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover {
		transition:
			opacity 0.2s ease,
			color 0.2s ease,
			background 0.2s ease,
			border-color 0.2s ease,
			box-shadow 0.2s ease;
		transform: none;
	}

	body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover.itinerary-nav-back--visible {
		animation: none;
	}

	body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover::before {
		transition: none;
	}

	body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover i {
		transition: none;
	}

	body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:hover i,
	body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:focus-visible i,
	body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:active i {
		transform: none;
	}

	body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover:active {
		transform: none;
	}
}

/*
 * Torna in cima: stesso breakpoint del menu hamburger; compare scrollando verso l’alto (JS).
 * Il FAB .scroll-to-top-btn di common.js non va usato qui (z-index 9999 copriva il pulsante vetro).
 */
body[data-itinerary-profile] .scroll-to-top-btn {
	display: none !important;
	visibility: hidden !important;
	pointer-events: none !important;
	opacity: 0 !important;
}

/* Torna in cima: stesso breakpoint del menu hamburger; compare scrollando verso l’alto (JS) */
body[data-itinerary-profile] .itinerary-scroll-top {
	display: none;
}

/* Hide affidabile su WebKit mobile: transizione su class-remove spesso non parte → keyframes + classe --hiding */
@keyframes itineraryFabHide {
	from {
		opacity: 1;
		transform: translate3d(0, 0, 0) scale(1);
	}
	to {
		opacity: 0;
		transform: translate3d(0, 24px, 0) scale(0.8);
	}
}

@keyframes itineraryFabHideReduced {
	from {
		opacity: 1;
	}
	to {
		opacity: 0;
	}
}

@media (max-width: 992px) {
	body[data-itinerary-profile] .itinerary-scroll-top {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		position: fixed;
		right: max(var(--page-gutter, 1.35rem), env(safe-area-inset-right, 0px));
		bottom: max(1.1rem, env(safe-area-inset-bottom, 0px));
		z-index: 1002;
		width: 44px;
		height: 44px;
		min-width: 44px;
		min-height: 44px;
		margin: 0;
		padding: 0;
		border-radius: 50%;
		aspect-ratio: 1;
		cursor: pointer;
		overflow: hidden;
		-webkit-tap-highlight-color: transparent;
		touch-action: manipulation;
		appearance: none;
		-webkit-appearance: none;
		font-family: inherit;
		font-size: 0.95rem;
		line-height: 1;
		border: 1px solid var(--border-subtle);
		background: color-mix(in srgb, var(--surface-raised) 82%, transparent);
		color: var(--text-primary);
		box-shadow: none;
		backdrop-filter: blur(14px) saturate(1.2);
		-webkit-backdrop-filter: blur(14px) saturate(1.2);
		opacity: 0;
		pointer-events: none;
		transform: translate3d(0, 24px, 0) scale(0.8);
		-webkit-backface-visibility: hidden;
		backface-visibility: hidden;
		/* Uscita: più lunga e fluida (stesso bottone “scivola” giù invece di sparire) */
		transition: opacity 0.46s cubic-bezier(0.55, 0.08, 0.2, 0.98), transform 0.52s cubic-bezier(0.52, 0.02, 0.25, 1), background 0.22s ease, border-color 0.22s ease, color 0.22s ease !important;
	}

	body[data-itinerary-profile] .itinerary-scroll-top.itinerary-scroll-top--visible {
		opacity: 1;
		pointer-events: auto;
		transform: translate3d(0, 0, 0) scale(1);
		/* Entrata: più lunga, leggero “settling” (overshoot minimo sulla scala) */
		transition: opacity 0.48s cubic-bezier(0.18, 0.88, 0.22, 1), transform 0.58s cubic-bezier(0.28, 1.18, 0.42, 1), background 0.22s ease, border-color 0.22s ease, color 0.22s ease !important;
	}

	/* Durante hide: animazione al posto della transition (fix Safari iOS) */
	body[data-itinerary-profile] .itinerary-scroll-top.itinerary-scroll-top--hiding {
		transition: none !important;
		animation: itineraryFabHide 0.52s cubic-bezier(0.55, 0.08, 0.2, 0.98) forwards;
		pointer-events: none !important;
	}

	body[data-itinerary-profile] .itinerary-scroll-top.itinerary-scroll-top--hiding i {
		transition: none !important;
		transform: translate3d(0, 0, 0);
		opacity: 1;
	}

	body[data-itinerary-profile] .itinerary-scroll-top i {
		pointer-events: none;
		display: block;
		transform: translate3d(0, 6px, 0);
		opacity: 0;
	}

	/* Icona: uscita allineata al hide del bottone (niente taglio brusco) */
	body[data-itinerary-profile] .itinerary-scroll-top:not(.itinerary-scroll-top--visible) i {
		transition:
			transform 0.48s cubic-bezier(0.52, 0.02, 0.28, 1),
			opacity 0.42s cubic-bezier(0.55, 0.08, 0.2, 0.98);
		transition-delay: 0s;
	}

	body[data-itinerary-profile] .itinerary-scroll-top.itinerary-scroll-top--visible i {
		transform: translate3d(0, 0, 0);
		opacity: 1;
		transition:
			transform 0.48s cubic-bezier(0.26, 1.1, 0.4, 1),
			opacity 0.4s cubic-bezier(0.18, 0.88, 0.22, 1);
		transition-delay: 0.08s, 0.05s;
	}

	body[data-itinerary-profile] .itinerary-scroll-top:active {
		background: color-mix(in srgb, var(--surface-raised) 92%, transparent);
		border-color: var(--border-strong);
		transform: translate3d(0, 0, 0) scale(0.96);
	}

	body[data-itinerary-profile] .itinerary-scroll-top:focus-visible {
		outline: 2px solid var(--article-accent, var(--accent-orange));
		outline-offset: 3px;
	}

	body.lightbox-open .itinerary-scroll-top {
		opacity: 0 !important;
		pointer-events: none !important;
	}
}

@media (max-width: 992px) and (prefers-reduced-motion: reduce) {
	body[data-itinerary-profile] .itinerary-scroll-top.itinerary-scroll-top--hiding {
		animation: itineraryFabHideReduced 0.22s ease forwards;
	}

	body[data-itinerary-profile] .itinerary-scroll-top {
		transition: opacity 0.2s ease, background 0.2s ease, border-color 0.2s ease, color 0.2s ease !important;
		transform: none;
	}

	body[data-itinerary-profile] .itinerary-scroll-top.itinerary-scroll-top--visible {
		transform: none;
		transition: opacity 0.22s ease, background 0.2s ease, border-color 0.2s ease, color 0.2s ease !important;
	}

	body[data-itinerary-profile] .itinerary-scroll-top:not(.itinerary-scroll-top--visible) i,
	body[data-itinerary-profile] .itinerary-scroll-top.itinerary-scroll-top--visible i {
		transform: none;
		transition: opacity 0.2s ease;
		transition-delay: 0s;
	}

	body[data-itinerary-profile] .itinerary-scroll-top:active {
		transform: none;
	}
}

@supports not ((-webkit-backdrop-filter: blur(1px)) or (backdrop-filter: blur(1px))) {
	@media (max-width: 992px) {
		body[data-itinerary-profile] .itinerary-scroll-top {
			background: color-mix(in srgb, var(--surface-raised) 94%, transparent);
		}
	}
}

.itinerary-meta {
	margin-top: 10px;
	margin-bottom: 10px;
	padding: 0;
	display: flex;
	justify-content: center;
	background-color: var(--background);
}

.itinerary-meta__box {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	column-gap: 14px;
	row-gap: 10px;
	padding: 0;
	margin: 0 auto;
	background: transparent;
	border: none;
	box-shadow: none;
	color: var(--heading-color);
	text-transform: none;
	letter-spacing: 0.02em;
	font-weight: 600;
	font-size: clamp(0.95rem, 2.2vw, 1.05rem);
}

.itinerary-meta__item {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	min-width: 0;
}

.itinerary-meta__item i {
	color: var(--article-accent, var(--accent-orange));
	font-size: 0.95em;
}

.itinerary-meta__sep {
	color: rgba(0, 51, 102, 0.28);
}

.itinerary-meta__duration {
	display: inline-flex;
	align-items: center;
	column-gap: 14px;
}

@media (max-width: 640px) {
	.itinerary-meta__box {
		gap: 10px;
		font-size: 0.98rem;
	}
}

.itinerary-content {
	padding-top: 0;
	padding-bottom: 24px;
	max-width: 1040px;
	margin: 0 auto;
	position: relative;
	margin-bottom: 12px;
	background-color: var(--background);
	/* Richiamo categoria: solo linea superiore, stesso sfondo della home */
	border-top: 2px solid color-mix(in srgb, var(--article-accent) 45%, #cfd8e3);
}

.itinerary-content > * {
	position: relative;
	z-index: 1;
}

/* Pagina itinerario: stesso sfondo su main, meta, galleria e articolo; i discendenti ereditano il colore. */
body[data-itinerary-profile] main#main-content {
	background-color: var(--background);
}

body[data-itinerary-profile] .itinerary-meta,
body[data-itinerary-profile] .gallery-section {
	background-color: var(--background);
}

.itinerary-section-divider.container {
	max-width: 1040px;
	padding: 0;
	margin-top: 18px;
	margin-bottom: 22px;
	border-top: 2px solid color-mix(in srgb, var(--article-accent) 45%, #cfd8e3);
}

body[data-itinerary-profile] article#markdown-content.markdown-body {
	background-color: var(--background) !important;
}

body[data-itinerary-profile] #markdown-content.markdown-body *:not(img):not(video):not(canvas):not(picture):not(svg) {
	background-color: inherit !important;
}

body[data-itinerary-profile] #markdown-content.markdown-body pre {
	background-color: rgba(0, 51, 102, 0.07) !important;
}

/* --- Itinerario strutturato: Giorno / parti / immagine alternata --- */
/* Wrapper giorni; spazio tra un giorno e l’altro = padding-top sulla section del giorno successivo. */
.itinerary-days {
	display: block;
}

#markdown-content > .itinerary-days {
	margin-top: 2.75rem;
}

.itinerary-day {
	margin-top: 0;
	margin-bottom: 0;
	padding-top: 0;
	padding-bottom: 0;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	align-items: stretch;
}

.itinerary-days > .itinerary-day:not(:first-child) {
	padding-top: 2.75rem;
}

.itinerary-day__label {
	display: block;
	text-align: left;
	margin: 0 0 1.35rem 0;
	padding: 0 0 0.5rem 0;
	font-family: Montserrat, system-ui, sans-serif;
	font-size: clamp(1.35rem, 4.2vw, 1.95rem);
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--article-accent, var(--accent-orange));
	line-height: 1.2;
	border-bottom: 3px solid color-mix(in srgb, var(--article-accent, var(--accent-orange)) 35%, transparent);
}

/* Vince su .markdown-body p (margin-bottom) da style.css */
body[data-itinerary-profile] #markdown-content .itinerary-day__label {
	margin-top: 0 !important;
	margin-bottom: 1.35rem !important;
}

.itinerary-day__parts {
	display: flex;
	flex-direction: column;
	gap: 2rem;
	min-height: 0;
}

/* Esperienze: stessi blocchi ### degli itinerari/giorni, ma senza wrapper giorno → serve gap esplicito */
.itinerary-experience-parts {
	display: flex;
	flex-direction: column;
	gap: 2rem;
	min-height: 0;
}

.itinerary-part {
	margin: 0;
	padding: 0;
	border: none;
}

.itinerary-part__title {
	margin: 0 0 0.85rem 0;
	font-family: 'Playfair Display', serif;
	font-size: clamp(1.2rem, 3.2vw, 1.45rem);
	font-weight: 700;
	color: var(--primary-blue);
	line-height: 1.25;
}

.itinerary-part--text-only .itinerary-part__body {
	max-width: none;
}

/* Flex row: thumbnail e colonna testo sempre centrati in altezza (anche con h3 sopra la riga). */
.itinerary-part--with-media .itinerary-part__grid {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	gap: clamp(0.85rem, 2.5vw, 1.35rem);
	min-width: 0;
}

.itinerary-part--with-media.itinerary-part--odd .itinerary-part__media {
	order: 1;
	flex-shrink: 0;
}

.itinerary-part--with-media.itinerary-part--odd .itinerary-part__body {
	order: 2;
	flex: 1 1 0;
	min-width: 0;
	padding-inline-start: clamp(1rem, 3.5vw, 2.25rem);
	box-sizing: border-box;
}

.itinerary-part--with-media.itinerary-part--even .itinerary-part__body {
	order: 1;
	flex: 1 1 0;
	min-width: 0;
	display: flex;
	flex-direction: column;
	/*
	 * Non usare flex-end: con `width: fit-content` sui paragrafi, le righe corte
	 * (es. titoletti “Info pratiche”) finivano a destra mentre liste e blocchi
	 * “stretch” restavano a sinistra → disallineamento visivo (bug segnalato su Zoom Torino).
	 */
	align-items: stretch;
	box-sizing: border-box;
}

.itinerary-part--with-media.itinerary-part--even .itinerary-part__body > p,
.itinerary-part--with-media.itinerary-part--even .itinerary-part__body > h1,
.itinerary-part--with-media.itinerary-part--even .itinerary-part__body > h2,
.itinerary-part--with-media.itinerary-part--even .itinerary-part__body > h3,
.itinerary-part--with-media.itinerary-part--even .itinerary-part__body > h4 {
	max-width: min(100%, 42rem);
	width: 100%;
	box-sizing: border-box;
}

.itinerary-part--with-media.itinerary-part--even .itinerary-part__body > ul,
.itinerary-part--with-media.itinerary-part--even .itinerary-part__body > ol {
	width: min(100%, 42rem);
	max-width: 100%;
	align-self: stretch;
	box-sizing: border-box;
}

.itinerary-part--with-media.itinerary-part--even .itinerary-part__media {
	order: 2;
	flex-shrink: 0;
}

/*
 * Miniatura: il wrapper ha dimensioni fisse (evita colonna grid "auto" larga come l'intrinseco).
 * style.css definisce anche `img { max-width:100%; height:auto }`: con !important su pagina itinerario.
 */
.itinerary-part__media.itinerary-part__thumb {
	margin: 0;
	flex: 0 0 300px;
	min-width: 0;
	box-sizing: border-box;
	width: 300px;
	height: 300px;
	max-width: 300px;
	max-height: 300px;
	overflow: hidden;
	border-radius: 10px;
	box-shadow: 0 4px 14px rgba(0, 51, 102, 0.14);
}

.itinerary-part__thumb-inner {
	width: 100%;
	height: 100%;
	overflow: hidden;
	display: block;
	box-sizing: border-box;
	border-radius: 10px;
}

body[data-itinerary-profile] .itinerary-part__thumb[data-itinerary-thumb] {
	flex: 0 0 300px !important;
	width: 300px !important;
	height: 300px !important;
	max-width: 300px !important;
	max-height: 300px !important;
	min-width: 0 !important;
	box-sizing: border-box !important;
	overflow: hidden !important;
}

#markdown-content .itinerary-part__thumb img[data-itinerary-thumb-img],
#markdown-content .itinerary-part__thumb-inner img[data-itinerary-thumb-img],
#markdown-content .itinerary-part__thumb-img[data-itinerary-thumb-img],
body[data-itinerary-profile] .itinerary-part__thumb img[data-itinerary-thumb-img],
body[data-itinerary-profile] .itinerary-part__thumb-inner img[data-itinerary-thumb-img],
body[data-itinerary-profile] .itinerary-part__thumb-img[data-itinerary-thumb-img] {
	display: block !important;
	box-sizing: border-box !important;
	width: 300px !important;
	height: 300px !important;
	max-width: 300px !important;
	max-height: 300px !important;
	min-width: 0 !important;
	margin: 0 !important;
	object-fit: cover !important;
	object-position: center center !important;
	border-radius: 10px;
	box-shadow: none !important;
	cursor: pointer;
	touch-action: manipulation;
	-webkit-user-select: none;
	user-select: none;
}

/* Tablet / finestra stretta: thumb più piccola così resta spazio al testo */
@media (max-width: 1100px) and (min-width: 769px) {
	.itinerary-part__media.itinerary-part__thumb {
		flex: 0 0 240px;
		width: 240px;
		height: 240px;
		max-width: 240px;
		max-height: 240px;
	}

	body[data-itinerary-profile] .itinerary-part__thumb[data-itinerary-thumb] {
		flex: 0 0 240px !important;
		width: 240px !important;
		height: 240px !important;
		max-width: 240px !important;
		max-height: 240px !important;
	}

	#markdown-content .itinerary-part__thumb img[data-itinerary-thumb-img],
	#markdown-content .itinerary-part__thumb-inner img[data-itinerary-thumb-img],
	#markdown-content .itinerary-part__thumb-img[data-itinerary-thumb-img],
	body[data-itinerary-profile] .itinerary-part__thumb img[data-itinerary-thumb-img],
	body[data-itinerary-profile] .itinerary-part__thumb-inner img[data-itinerary-thumb-img],
	body[data-itinerary-profile] .itinerary-part__thumb-img[data-itinerary-thumb-img] {
		width: 240px !important;
		height: 240px !important;
		max-width: 240px !important;
		max-height: 240px !important;
	}
}

.itinerary-part__body.markdown-body > p:last-child {
	margin-bottom: 0;
}

.itinerary-part__body.markdown-body > *:first-child {
	margin-top: 0;
}

@media (max-width: 768px) {
	#markdown-content > .itinerary-days {
		margin-top: 2.25rem;
	}

	.itinerary-days > .itinerary-day:not(:first-child) {
		padding-top: 2.25rem;
	}

	/* .markdown-body p (768px): specificità alta su margin; titolo giorno resta compatto */
	body[data-itinerary-profile] #markdown-content .itinerary-day__label {
		margin-top: 0 !important;
		margin-bottom: 1.1rem !important;
		font-size: clamp(1.2rem, 5.5vw, 1.65rem);
		padding-bottom: 0.45rem;
		border-bottom-width: 2px;
	}

	.itinerary-day__parts {
		gap: 1.65rem;
	}

	/* Mobile: immagine sopra il testo */
	.itinerary-part--with-media .itinerary-part__grid {
		display: flex;
		flex-direction: column;
		flex-wrap: nowrap;
		align-items: stretch;
		gap: 0.85rem;
	}

	.itinerary-part--with-media.itinerary-part--odd .itinerary-part__media,
	.itinerary-part--with-media.itinerary-part--even .itinerary-part__media {
		order: 1;
		flex-shrink: 0;
		align-self: stretch;
		width: 100%;
		max-width: 100%;
	}

	.itinerary-part--with-media.itinerary-part--odd .itinerary-part__body,
	.itinerary-part--with-media.itinerary-part--even .itinerary-part__body {
		order: 2;
		width: 100%;
		max-width: none;
		display: block;
	}

	.itinerary-part--with-media.itinerary-part--odd .itinerary-part__body {
		padding-inline-start: 0;
	}

	.itinerary-part--with-media.itinerary-part--even .itinerary-part__body > p,
	.itinerary-part--with-media.itinerary-part--even .itinerary-part__body > h1,
	.itinerary-part--with-media.itinerary-part--even .itinerary-part__body > h2,
	.itinerary-part--with-media.itinerary-part--even .itinerary-part__body > h3,
	.itinerary-part--with-media.itinerary-part--even .itinerary-part__body > h4,
	.itinerary-part--with-media.itinerary-part--even .itinerary-part__body > ul,
	.itinerary-part--with-media.itinerary-part--even .itinerary-part__body > ol {
		width: auto;
		max-width: none;
	}

	/* Stessa logica per foto nel primo paragrafo (float su desktop da style.css) */
	body[data-itinerary-profile] article#markdown-content.markdown-body .itinerary-part--with-media .itinerary-part__body > p:first-child > img:only-child:not([data-itinerary-thumb-img]),
	body[data-itinerary-profile] article#markdown-content.markdown-body .itinerary-part--with-media .itinerary-part__body > p:first-child > a:only-child > img:only-child:not([data-itinerary-thumb-img]) {
		float: none;
		display: block;
		margin-left: auto !important;
		margin-right: auto !important;
		margin-top: 0 !important;
		margin-bottom: 0.75rem !important;
	}

	/* Quadrato a tutta larghezza del blocco (grid / section), altezza = larghezza */
	.itinerary-part__media.itinerary-part__thumb,
	body[data-itinerary-profile] .itinerary-part__thumb[data-itinerary-thumb] {
		position: relative;
		flex: 0 0 auto !important;
		width: 100% !important;
		max-width: 100% !important;
		height: auto !important;
		max-height: none !important;
		aspect-ratio: 1 / 1;
		border-radius: 12px;
	}

	.itinerary-part--with-media .itinerary-part__thumb-inner {
		position: absolute;
		inset: 0;
		width: 100%;
		height: 100%;
		border-radius: inherit;
	}

	#markdown-content .itinerary-part__thumb img[data-itinerary-thumb-img],
	#markdown-content .itinerary-part__thumb-inner img[data-itinerary-thumb-img],
	body[data-itinerary-profile] .itinerary-part__thumb img[data-itinerary-thumb-img],
	body[data-itinerary-profile] .itinerary-part__thumb-inner img[data-itinerary-thumb-img] {
		width: 100% !important;
		height: 100% !important;
		max-width: none !important;
		max-height: none !important;
		min-width: 0 !important;
		min-height: 0 !important;
		object-fit: cover !important;
		object-position: center center !important;
		border-radius: inherit;
		cursor: pointer;
		touch-action: manipulation;
		-webkit-user-select: none;
		user-select: none;
	}
}

.markdown-body {
	background-color: var(--background);
}

.markdown-body a {
	color: var(--article-accent, var(--accent-orange));
	font-weight: 600;
}

.markdown-body a:hover {
	color: var(--article-accent, var(--accent-orange));
	text-decoration: underline;
	text-decoration-thickness: 2px;
	text-underline-offset: 4px;
}

.markdown-body h1, .markdown-body h2 {
	margin-top: 50px;
	margin-bottom: 20px;
	font-family: var(--font-display);
	color: var(--heading-color);
}

.markdown-body h1 {
	font-size: clamp(2rem, 5vw, 2.5rem);
}

.markdown-body h2 {
	font-size: clamp(1.65rem, 4.5vw, 2rem);
}

.markdown-body h3 {
	font-size: clamp(1.35rem, 4vw, 1.65rem);
	margin-top: 40px;
	margin-bottom: 16px;
}

.markdown-body p {
	margin-bottom: 1.5rem;
}

/* Carosello Galleria (no shorthand padding orizzontale: altrimenti azzera il padding del .container) */
.gallery-section {
	margin-top: 24px;
	padding-block: 12px;
	margin-bottom: 24px;
	background: transparent;
	background-color: var(--background);
	border-radius: 0;
	box-shadow: none;
}

/* Stessa fascia utile del corpo articolo (.itinerary-content è max 1040px) */
body[data-itinerary-profile] #gallery-section.container {
	max-width: 1040px;
}

body[data-itinerary-profile] .itinerary-video-buttons {
	background-color: var(--background);
}

/* Fascia contatti: regole globali in main (.contact-section); qui solo ritmo verticale */
body[data-itinerary-profile] .contact-section {
	padding: 64px 0;
}

@media (max-width: 968px) {
	body[data-itinerary-profile] .contact-section {
		padding: 60px 0;
	}
}

@media (max-width: 768px) {
	body[data-itinerary-profile] .contact-section {
		padding: 70px 0;
	}
}

@media (max-width: 480px) {
	body[data-itinerary-profile] .contact-section {
		padding: 50px 0;
	}
}

/* Primo blocco del corpo: evita doppio spazio con margini globali .markdown-body h1/h2 */
body[data-itinerary-profile] .itinerary-content {
	padding-top: 10px;
}

body[data-itinerary-profile] #markdown-content > h1:first-child,
body[data-itinerary-profile] #markdown-content > h2:first-child,
body[data-itinerary-profile] #markdown-content > p:first-child {
	margin-top: 0;
}

.gallery-title {
	text-align: center;
	font-size: 1.2rem;
	color: var(--primary-blue);
	margin-bottom: 30px;
	font-family: 'Playfair Display', serif;
}

/* Articoli correlati (pagina esperienze): card come blog */
.itinerary-related-section {
	margin-top: 8px;
	padding-top: 28px;
	padding-bottom: 40px;
	background: var(--background);
}

/* Allineato al corpo articolo (.itinerary-content ha max-width 1040px, .container solo 1200px) */
#itinerary-related-articles.container {
	max-width: 1040px;
}

/* Carosello articoli correlati: card compatte + accenno prev/next ai lati.
   Desktop: track flush al .container. Mobile: padding sulla track (margine dai bordi schermo). */
#itinerary-related-articles {
	--related-carousel-gap: 10px;
	/* spazio “liberato” nel viewport così si intravede la card precedente/successiva */
	--related-peek-mobile: 3rem;
	--related-peek-desktop: 3.25rem;
	--related-track-pad-mobile: clamp(0.65rem, 3.2vw, 1.05rem);
	/* Fallback senza container queries: larghezza utile come .container della sezione (max 1040px) */
	--related-fallback-inner: calc(
		min(1040px, 100vw) - max(var(--page-gutter, 1.35rem), env(safe-area-inset-left, 0px)) -
			max(var(--page-gutter, 1.35rem), env(safe-area-inset-right, 0px))
	);
}

.itinerary-related-carousel {
	width: 100%;
	min-width: 0;
}

/* Container sul wrapper (non sullo scrollport): 100cqw = larghezza utile come titolo / articolo */
#itinerary-related-articles .itinerary-related-carousel {
	container-type: inline-size;
	container-name: related-carousel;
}

/* Sfumatura ai lati: overlay verso --background (non blocca scroll / scrollbar) */
.itinerary-related-carousel__fade {
	width: 100%;
	min-width: 0;
	position: relative;
	isolation: isolate;
}

.itinerary-related-nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	border: 0;
	background: transparent;
	box-shadow: none;
	color: var(--primary-blue);
	display: none;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	z-index: 4;
	padding: 6px 8px;
	line-height: 1;
	font-size: 28px;
	transition: transform 0.18s ease, opacity 0.18s ease, color 0.18s ease;
}

.itinerary-related-nav:hover {
	transform: translateY(-50%) scale(1.04);
	color: color-mix(in srgb, var(--primary-blue) 78%, var(--accent-orange));
}

.itinerary-related-nav:disabled {
	opacity: 0.35;
	cursor: default;
	transform: translateY(-50%);
}

.itinerary-related-nav:focus-visible {
	outline: 2px solid color-mix(in srgb, var(--primary-blue) 45%, transparent);
	outline-offset: 4px;
	border-radius: 6px;
}

.itinerary-related-nav--prev {
	left: 10px;
}

.itinerary-related-nav--next {
	right: 10px;
}

@media (min-width: 768px) {
	.itinerary-related-nav {
		display: inline-flex;
	}
}

.itinerary-related-carousel__fade::before,
.itinerary-related-carousel__fade::after {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	width: clamp(36px, 9vw, 80px);
	z-index: 3;
	pointer-events: none;
}

.itinerary-related-carousel__fade::before {
	left: 0;
	background: linear-gradient(
		90deg,
		var(--background) 0%,
		color-mix(in srgb, var(--background) 72%, transparent) 55%,
		transparent 100%
	);
	transition: opacity 0.28s ease;
}

.itinerary-related-carousel__fade::after {
	right: 0;
	background: linear-gradient(
		270deg,
		var(--background) 0%,
		color-mix(in srgb, var(--background) 72%, transparent) 55%,
		transparent 100%
	);
	transition: opacity 0.28s ease;
}

/* A inizio / fine lista: niente sfumatura sul bordo “esterno” (primo/ultimo tassello interi) */
.itinerary-related-carousel__fade--at-start::before {
	opacity: 0;
}

.itinerary-related-carousel__fade--at-end::after {
	opacity: 0;
}

@media (prefers-reduced-motion: reduce) {
	.itinerary-related-carousel__fade::before,
	.itinerary-related-carousel__fade::after {
		transition: none;
	}
}

.itinerary-related-carousel__viewport {
	width: 100%;
	min-width: 0;
	/* Spazio per translateY/shadow in hover: evita che il tassello sia tagliato in alto */
	padding-block: clamp(12px, 2.4vw, 18px);
	overflow-x: auto;
	overflow-y: hidden;
	scroll-behavior: auto;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
	scrollbar-color: color-mix(in srgb, var(--primary-blue) 35%, transparent) transparent;
	-ms-overflow-style: auto;
	overscroll-behavior-x: contain;
	touch-action: pan-x;
	position: relative;
	z-index: 1;
}

.itinerary-related-carousel__viewport::-webkit-scrollbar {
	height: 6px;
}

.itinerary-related-carousel__viewport::-webkit-scrollbar-track {
	background: rgba(0, 51, 102, 0.06);
	border-radius: 999px;
}

.itinerary-related-carousel__viewport::-webkit-scrollbar-thumb {
	background: color-mix(in srgb, var(--primary-blue) 38%, #cbd5e1);
	border-radius: 999px;
}

@media (prefers-reduced-motion: reduce) {
	.itinerary-related-carousel__viewport {
		scroll-behavior: auto;
	}
}

@media (max-width: 767px) {
	.itinerary-related-carousel__viewport {
		scrollbar-width: none;
		-ms-overflow-style: none;
	}

	.itinerary-related-carousel__viewport::-webkit-scrollbar {
		display: none;
	}

	#itinerary-related-articles .itinerary-related-carousel__track {
		padding-inline: var(--related-track-pad-mobile);
	}
}

/* Desktop: scrollbar nascosta; drag orizzontale via JS (cursor grab) */
@media (min-width: 768px) {
	#itinerary-related-articles .itinerary-related-carousel__track {
		padding-inline: 0;
	}

	#itinerary-related-articles .itinerary-related-carousel__viewport.itinerary-related-carousel__viewport--desk-drag {
		scrollbar-width: none;
		-ms-overflow-style: none;
		cursor: grab;
	}

	#itinerary-related-articles .itinerary-related-carousel__viewport.itinerary-related-carousel__viewport--desk-drag::-webkit-scrollbar {
		display: none;
		height: 0;
		width: 0;
	}

	#itinerary-related-articles .itinerary-related-carousel__viewport.itinerary-related-carousel__viewport--desk-drag.is-dragging {
		cursor: grabbing;
		user-select: none;
	}
}

.itinerary-related-carousel__track {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: stretch;
	gap: var(--related-carousel-gap);
	width: max-content;
	min-height: 1px;
}

#itinerary-related-articles .itinerary-related-carousel__track .card {
	flex-shrink: 0;
	min-height: 0;
	height: auto;
}

/* Mobile: card stretta = si vede l’inizio della successiva (e della precedente quando scrolli) */
@container related-carousel (max-width: 767px) {
	#itinerary-related-articles .itinerary-related-carousel__track .card {
		width: min(
			20.5rem,
			calc(100cqw - var(--related-peek-mobile) - 2 * var(--related-track-pad-mobile))
		);
		flex: 0 0 min(
			20.5rem,
			calc(100cqw - var(--related-peek-mobile) - 2 * var(--related-track-pad-mobile))
		);
		max-width: min(
			20.5rem,
			calc(100cqw - var(--related-peek-mobile) - 2 * var(--related-track-pad-mobile))
		);
	}

	#itinerary-related-articles .card-img-placeholder {
		height: 92px;
		min-height: 92px;
	}

	#itinerary-related-articles .card-info {
		padding: 8px 10px 6px;
		row-gap: 6px;
	}

	#itinerary-related-articles .card-head .card-tags {
		margin-bottom: 4px;
	}

	#itinerary-related-articles .card-tags .tag {
		font-size: 0.58rem;
		padding: 2px 6px;
		max-width: min(7rem, 34vw);
	}

	#itinerary-related-articles .card[data-type] .category {
		font-size: 0.6rem;
		padding: 2px 7px;
	}

	#itinerary-related-articles .card .card-info h3 {
		font-size: clamp(0.95rem, 3.6vw, 1.05rem);
		line-height: 1.18;
		-webkit-line-clamp: 2;
	}

	#itinerary-related-articles .card-meta {
		grid-template-rows: minmax(calc(0.7rem * 1.35), auto) minmax(calc(0.7rem * 1.35), auto);
	}

	#itinerary-related-articles .card-meta--empty {
		min-height: calc(2 * (0.7rem * 1.35) + 3px);
	}

	#itinerary-related-articles .card .card-location,
	#itinerary-related-articles .card .card-duration {
		font-size: 0.7rem;
	}

	#itinerary-related-articles .read-more {
		font-size: 0.7rem;
		padding-top: 0;
	}
}

/* Desktop: 3 card compatte; il peek fa intravedere la quarta (e la precedente) */
@container related-carousel (min-width: 768px) {
	#itinerary-related-articles {
		--related-carousel-gap: 12px;
	}

	#itinerary-related-articles .itinerary-related-carousel__track .card {
		width: calc((100cqw - 2 * var(--related-carousel-gap) - var(--related-peek-desktop)) / 3);
		flex: 0 0 calc((100cqw - 2 * var(--related-carousel-gap) - var(--related-peek-desktop)) / 3);
		max-width: calc((100cqw - 2 * var(--related-carousel-gap) - var(--related-peek-desktop)) / 3);
	}
}

/* Fallback senza container queries */
@supports not (container-type: inline-size) {
	@media (max-width: 767px) {
		#itinerary-related-articles .itinerary-related-carousel__track .card {
			width: min(
				20.5rem,
				calc(
					var(--related-fallback-inner) - var(--related-peek-mobile) -
						2 * var(--related-track-pad-mobile)
				)
			);
			flex: 0 0 min(
				20.5rem,
				calc(
					var(--related-fallback-inner) - var(--related-peek-mobile) -
						2 * var(--related-track-pad-mobile)
				)
			);
			max-width: min(
				20.5rem,
				calc(
					var(--related-fallback-inner) - var(--related-peek-mobile) -
						2 * var(--related-track-pad-mobile)
				)
			);
		}
	}

	@media (min-width: 768px) {
		#itinerary-related-articles .itinerary-related-carousel__viewport {
			width: 100%;
		}

		#itinerary-related-articles .itinerary-related-carousel__track .card {
			width: min(
				17.5rem,
				calc(
					(var(--related-fallback-inner) - 2 * var(--related-carousel-gap) - var(--related-peek-desktop)) / 3
				)
			);
			flex: 0 0 min(
				17.5rem,
				calc(
					(var(--related-fallback-inner) - 2 * var(--related-carousel-gap) - var(--related-peek-desktop)) / 3
				)
			);
			max-width: min(
				17.5rem,
				calc(
					(var(--related-fallback-inner) - 2 * var(--related-carousel-gap) - var(--related-peek-desktop)) / 3
				)
			);
		}
	}
}

#itinerary-related-articles .card {
	min-height: 0;
	height: 100%;
}

/* Hover più contenuto del blog (-8px / shadow-lg): meno altezza + ombra media, con padding-block sul viewport */
#itinerary-related-articles .card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-md);
	border-color: var(--accent-orange);
}

#itinerary-related-articles .card-img-placeholder {
	height: 118px;
	min-height: 118px;
	flex-shrink: 0;
}

#itinerary-related-articles .card-img-placeholder img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
}

/* Stesso schema del blog (.results-section): griglia + riga titolo 1fr → “Scopri di più” allineato in basso */
#itinerary-related-articles .card-info {
	padding: 10px 12px 8px;
	flex: 1;
	min-height: 0;
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	grid-template-rows: auto 1fr auto auto;
	row-gap: 7px;
	align-content: start;
}

#itinerary-related-articles .card-head {
	grid-row: 1;
	min-width: 0;
}

#itinerary-related-articles .card-head .card-tags {
	margin-bottom: 5px;
}

#itinerary-related-articles .card-head .category {
	margin-bottom: 0;
}

#itinerary-related-articles .card-tags {
	display: flex;
	flex-wrap: nowrap;
	align-items: center;
	gap: 6px;
	overflow-x: auto;
	overflow-y: hidden;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	-ms-overflow-style: none;
	padding-bottom: 2px;
}

#itinerary-related-articles .card-tags::-webkit-scrollbar {
	display: none;
}

#itinerary-related-articles .card-tags .tag {
	flex: 0 0 auto;
	font-size: 0.62rem;
	padding: 2px 7px;
	max-width: min(7.5rem, 36vw);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

#itinerary-related-articles .card[data-type] .category {
	padding: 2px 8px;
	font-size: 0.65rem;
	line-height: 1.2;
	display: inline-block;
}

#itinerary-related-articles .card-title-block {
	grid-row: 2;
	min-width: 0;
	align-self: start;
}

#itinerary-related-articles .card .card-info h3 {
	font-size: 0.98rem;
	line-height: 1.2;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

#itinerary-related-articles .card-meta {
	grid-row: 3;
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	/* Due righe fisse: luogo sempre in riga 1 (come le card con periodo), periodo in riga 2 */
	grid-template-rows: minmax(calc(0.74rem * 1.35), auto) minmax(calc(0.74rem * 1.35), auto);
	row-gap: 3px;
	column-gap: 0;
	align-items: start;
	min-width: 0;
	margin: 0;
	font-size: 0.74rem;
	line-height: 1.35;
}

#itinerary-related-articles .card-meta--empty {
	visibility: hidden;
	pointer-events: none;
	user-select: none;
	min-height: calc(2 * (0.74rem * 1.35) + 3px);
}

#itinerary-related-articles .card .card-location {
	grid-row: 1;
	grid-column: 1;
	margin: 0;
	font-size: 0.74rem;
	line-height: 1.35;
	color: var(--text-muted);
	display: flex;
	align-items: center;
	gap: 6px;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

#itinerary-related-articles .card .card-duration {
	grid-row: 2;
	grid-column: 1;
	margin: 0;
	font-size: 0.74rem;
	line-height: 1.35;
	color: var(--text-muted);
	display: flex;
	align-items: center;
	gap: 6px;
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

#itinerary-related-articles .card .card-location i,
#itinerary-related-articles .card .card-duration i {
	flex-shrink: 0;
	color: var(--card-accent, var(--accent-orange));
	font-size: 0.72rem;
}

#itinerary-related-articles .card p {
	margin-bottom: 0;
}

#itinerary-related-articles .read-more {
	grid-row: 4;
	display: inline-flex;
	align-items: center;
	gap: 0.35em;
	margin: 0;
	padding: 0;
	padding-top: 1px;
	min-height: 0;
	font-size: 0.74rem;
	font-weight: 700;
	color: var(--card-accent, var(--accent-orange));
	text-decoration: none;
	transition: gap 0.2s ease, color 0.2s ease;
	white-space: nowrap;
	justify-self: start;
	align-self: start;
}

#itinerary-related-articles .read-more:hover {
	gap: 0.55em;
	color: var(--card-accent, #d9621c);
}

/* Refinement mobile quando le container query non applicano (es. larghezza finestra) */
@media (max-width: 767px) {
	#itinerary-related-articles .itinerary-related-lead {
		margin-bottom: 18px;
		font-size: 0.88rem;
	}

	#itinerary-related-articles .itinerary-related-carousel__fade::before,
	#itinerary-related-articles .itinerary-related-carousel__fade::after {
		width: clamp(28px, 11vw, 56px);
	}
}

.itinerary-related-section[hidden] {
	display: none !important;
}

.itinerary-related-title {
	text-align: center;
	font-size: 1.2rem;
	color: var(--primary-blue);
	margin: 0 0 10px;
	font-family: 'Playfair Display', serif;
}

.itinerary-related-lead {
	text-align: center;
	color: var(--text-muted);
	font-size: 0.95rem;
	margin: 0 auto 28px;
	max-width: 36rem;
	line-height: 1.5;
}

.carousel-container {
	position: relative;
	max-width: 700px;
	margin: 0 auto;
	overflow: hidden;
	border-radius: 12px;
	box-shadow: none;
}

.carousel-viewport {
	width: 100%;
	overflow-x: auto;
	overflow-y: hidden;
	-webkit-overflow-scrolling: touch;
	overscroll-behavior-x: contain;
	touch-action: pan-x;
	scroll-snap-type: x mandatory;
	scrollbar-width: none;
	-ms-overflow-style: none;
	scroll-padding-inline: max(0px, env(safe-area-inset-left, 0px))
		max(0px, env(safe-area-inset-right, 0px));
}

.carousel-viewport::-webkit-scrollbar {
	display: none;
}

.carousel-track {
	display: flex;
	transition: none;
}

.carousel-slide {
	flex: 0 0 100%;
	min-width: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	scroll-snap-align: start;
	scroll-snap-stop: always;
}

.carousel-slide::after {
	content: '🔍';
	position: absolute;
	top: 16px;
	right: 16px;
	background: rgba(0, 0, 0, 0.7);
	color: white;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.2rem;
	opacity: 0;
	transition: opacity 0.3s ease;
	pointer-events: none;
	z-index: 10;
}

.carousel-slide:hover::after {
	opacity: 1;
}

.carousel-slide img {
	width: 100%;
	max-height: 380px;
	object-fit: cover;
	border-radius: 12px;
	cursor: pointer;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.carousel-slide img:hover {
	transform: scale(1.02);
	box-shadow: 0 8px 30px rgba(0, 51, 102, 0.2);
}

.carousel-btn {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background: transparent;
	border: none;
	color: #fff;
	font-size: 1.6rem;
	width: 40px;
	height: 40px;
	padding: 0;
	cursor: pointer;
	transition:
		transform var(--dur-med, 260ms) var(--ease-out-soft, cubic-bezier(0.16, 1, 0.3, 1)),
		color var(--dur-fast, 160ms) ease;
	z-index: 10;
	display: flex;
	align-items: center;
	justify-content: center;
	text-shadow:
		0 2px 8px rgba(0, 0, 0, 0.55),
		0 0 2px rgba(0, 0, 0, 0.4);
}

.carousel-btn:hover {
	background: transparent;
	color: var(--article-accent, var(--accent-orange));
	transform: translateY(-50%) scale(1.15);
}

.carousel-btn:active {
	transform: translateY(-50%) scale(0.92);
}

.carousel-btn.prev {
	left: 12px;
}

.carousel-btn.next {
	right: 12px;
}

.carousel-indicators {
	display: flex;
	justify-content: center;
	gap: 10px;
	margin-top: 25px;
}

.indicator {
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: var(--border-strong);
	cursor: pointer;
	transition:
		background-color var(--dur-fast, 160ms) ease,
		transform var(--dur-fast, 160ms) var(--ease-out-soft, cubic-bezier(0.16, 1, 0.3, 1)),
		width var(--dur-med, 260ms) var(--ease-out-soft, cubic-bezier(0.16, 1, 0.3, 1)),
		border-radius var(--dur-med, 260ms) var(--ease-out-soft, cubic-bezier(0.16, 1, 0.3, 1));
}

.indicator:hover {
	background: rgba(0, 102, 204, 0.5);
	transform: scale(1.15);
}

.indicator.active {
	background: var(--article-accent, var(--accent-orange));
	width: 30px;
	border-radius: 6px;
	position: relative;
	overflow: hidden;
}

.indicator.active::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 0%;
	background: rgba(0, 51, 102, 0.4);
	animation: autoplay-progress var(--gallery-autoplay-duration, 4.5s) linear;
}

.gallery-section.gallery-progress-paused .indicator.active::after {
	animation-play-state: paused;
}

@keyframes autoplay-progress {
	0% { width: 0%; }
	100% { width: 100%; }
}

.indicator:hover {
	background: var(--primary-blue);
}

@media (max-width: 768px) {
	/* style.css (<576px): border sulle section; qui solo le section figlie dirette di main (hero, meta, …). */
	body[data-itinerary-profile] main#main-content > section {
		border-bottom: none;
	}

	body[data-itinerary-profile] .itinerary-meta {
		margin-top: 0;
		margin-bottom: 0;
		padding-top: 14px;
		padding-bottom: 14px;
	}

	.itinerary-hero {
		min-height: 55vh;
		padding: 30px 0;
	}

	.itinerary-hero .hero-meta {
		gap: 12px;
		padding: 10px 18px;
	}
	
	body[data-itinerary-profile] .itinerary-content {
		padding-top: 8px;
		padding-bottom: 16px;
		margin-bottom: 8px;
	}
	
	.markdown-body {
		font-size: 1.05rem;
		line-height: 1.78;
	}
	
	.markdown-body h1, .markdown-body h2 {
		margin-top: 40px;
		margin-bottom: 16px;
	}

	body[data-itinerary-profile] #markdown-content > h1:first-child,
	body[data-itinerary-profile] #markdown-content > h2:first-child,
	body[data-itinerary-profile] #markdown-content > p:first-child {
		margin-top: 0;
	}
	
	.markdown-body h3 {
		margin-top: 32px;
		margin-bottom: 14px;
	}
	
	.markdown-body img:not([data-itinerary-thumb-img]) {
		margin: 1.5rem 0;
		border-radius: 12px;
	}
	
	.gallery-section {
		margin-top: 16px;
		padding-top: 8px;
		padding-bottom: 8px;
		margin-bottom: 16px;
	}

	.gallery-title {
		margin-bottom: 18px;
	}

	body[data-itinerary-profile] .itinerary-video-buttons {
		padding-bottom: 12px;
	}

	.carousel-slide img {
		max-height: 280px;
	}
	
	.carousel-btn {
		width: 44px;
		height: 44px;
		font-size: 1.5rem;
		background: transparent;
		border: none;
		box-shadow: none;
	}
	
	.carousel-btn.prev {
		left: 8px;
	}
	
	.carousel-btn.next {
		right: 8px;
	}
}

@media (max-width: 576px) {
	/* Section dentro l’articolo (es. .itinerary-day): stesso bordo globale, altrimenti fascia tra i giorni. */
	body[data-itinerary-profile] #markdown-content section {
		border-bottom: none;
	}

	.itinerary-hero {
		min-height: 50vh;
	}

	body[data-itinerary-profile] .itinerary-content {
		padding-top: 6px;
		padding-bottom: 12px;
		margin-bottom: 6px;
	}

	body[data-itinerary-profile] #markdown-content.markdown-body > h1:first-of-type {
		margin-top: 0;
	}
	
	.markdown-body {
		font-size: 1.05rem;
		line-height: 1.75;
	}
	
	.gallery-section {
		padding-top: 6px;
		padding-bottom: 6px;
		margin-top: 12px;
		margin-bottom: 12px;
	}

	.gallery-title {
		margin-bottom: 14px;
	}

	.carousel-slide img {
		max-height: 240px;
		border-radius: 10px;
	}
	
	.carousel-btn {
		width: 44px;
		height: 44px;
		font-size: 1.5rem;
		background: transparent;
		border: none;
		box-shadow: none;
	}
	
	.carousel-btn.prev {
		left: max(6px, env(safe-area-inset-left, 0px));
	}
	
	.carousel-btn.next {
		right: max(6px, env(safe-area-inset-right, 0px));
	}
	
	.carousel-indicators {
		margin-top: 20px;
		gap: 8px;
	}
	
	.indicator {
		width: 10px;
		height: 10px;
	}
	
	.indicator.active {
		width: 24px;
	}
}

/* ============================================
   LIGHTBOX MODAL
   ============================================ */
.lightbox-modal {
	display: none;
	position: fixed;
	z-index: 10000;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.95);
	animation: fadeIn 0.3s ease;
	overflow: hidden;
}

.lightbox-modal.active {
	display: flex;
	align-items: center;
	justify-content: center;
}

html.lightbox-open,
body.lightbox-open {
	overflow: hidden;
	scrollbar-width: none;
}

html.lightbox-open::-webkit-scrollbar,
body.lightbox-open::-webkit-scrollbar {
	width: 0;
	height: 0;
}

.lightbox-image {
	max-width: 90%;
	max-height: 90vh;
	object-fit: contain;
	user-select: none;
	will-change: transform;
}

/* Zoom solo all’apertura galleria (non a ogni cambio foto: altrimenti riparte al remove di --nav-slide) */
.lightbox-image--enter-zoom {
	animation: zoomIn 0.3s ease;
}

/* Slide tra foto: disabilita zoom-in CSS mentre si trascina / si anima */
.lightbox-image--dragging,
.lightbox-image--nav-slide {
	animation: none !important;
}

.lightbox-image--dragging {
	transition: none !important;
}

/* Preview da miniature nel testo: zoom più marcato + chiusura con zoom out (carosello invariato) */
.lightbox-modal--content-preview.active .lightbox-image {
	animation: lightboxContentZoomIn 0.28s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.lightbox-modal--content-preview.lightbox-modal--closing .lightbox-image {
	animation: lightboxContentZoomOut 0.24s cubic-bezier(0.4, 0, 1, 1) forwards;
}

@keyframes lightboxContentZoomIn {
	from {
		transform: scale(0.42);
		opacity: 0;
	}
	to {
		transform: scale(1);
		opacity: 1;
	}
}

@keyframes lightboxContentZoomOut {
	from {
		transform: scale(1);
		opacity: 1;
	}
	to {
		transform: scale(0.5);
		opacity: 0;
	}
}

.lightbox-close {
	position: absolute;
	top: 20px;
	right: 30px;
	color: #fff;
	font-size: 40px;
	font-weight: 300;
	cursor: pointer;
	transition: color 0.3s ease;
	z-index: 10001;
}

.lightbox-close:hover,
.lightbox-close:focus {
	color: #ff8c2e;
}

.lightbox-btn {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background: transparent;
	backdrop-filter: none;
	border: none;
	color: #fff;
	font-size: 2.2rem;
	width: 56px;
	height: 56px;
	padding: 0;
	cursor: pointer;
	border-radius: 0;
	transition:
		transform var(--dur-med, 260ms) var(--ease-out-soft, cubic-bezier(0.16, 1, 0.3, 1)),
		color var(--dur-fast, 160ms) ease;
	z-index: 10001;
	display: flex;
	align-items: center;
	justify-content: center;
}

.lightbox-btn:hover {
	color: #ff8c2e;
	transform: translateY(-50%) scale(1.06);
}

.lightbox-prev {
	left: 30px;
}

.lightbox-next {
	right: 30px;
}

.lightbox-counter {
	position: absolute;
	bottom: 30px;
	left: 50%;
	transform: translateX(-50%);
	color: #fff;
	font-size: 1rem;
	font-weight: 600;
	background: rgba(0, 0, 0, 0.6);
	padding: 10px 20px;
	border-radius: 20px;
	backdrop-filter: blur(10px);
}

@keyframes fadeIn {
	from { opacity: 0; }
	to { opacity: 1; }
}

@keyframes zoomIn {
	from {
		transform: scale(0.8);
		opacity: 0;
	}
	to {
		transform: scale(1);
		opacity: 1;
	}
}

@media (prefers-reduced-motion: reduce) {
	.lightbox-modal--content-preview.active .lightbox-image,
	.lightbox-modal--content-preview.lightbox-modal--closing .lightbox-image {
		animation: none !important;
	}

	.lightbox-image--dragging,
	.lightbox-image--nav-slide {
		transform: none !important;
		transition: none !important;
	}

	.lightbox-image--enter-zoom {
		animation: none !important;
	}
}

/* Mobile lightbox */
@media (max-width: 768px) {
	.lightbox-image {
		max-width: 95%;
		max-height: 85vh;
	}
	
	.lightbox-close {
		top: 12px;
		right: 12px;
		font-size: 32px;
		min-width: 48px;
		min-height: 48px;
		display: flex;
		align-items: center;
		justify-content: center;
		line-height: 1;
		padding: 8px;
		box-sizing: border-box;
	}
	
	.lightbox-btn {
		font-size: 2rem;
		width: 52px;
		height: 52px;
		min-width: 48px;
		min-height: 48px;
		padding: 0;
	}
	
	.lightbox-prev {
		left: 15px;
	}
	
	.lightbox-next {
		right: 15px;
	}
	
	.lightbox-counter {
		bottom: 20px;
		font-size: 0.9rem;
		padding: 8px 16px;
	}
}

/* ========== Hero: condivisione articolo + mappe + video social (Instagram / TikTok) ========== */

.itinerary-hero-actions {
	position: absolute;
	z-index: 3;
	bottom: max(1rem, env(safe-area-inset-bottom, 0px));
	right: max(var(--page-gutter, 1.35rem), env(safe-area-inset-right, 0px));
	max-width: calc(100% - 2 * var(--page-gutter, 1.35rem));
	pointer-events: none;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-end;
	align-items: flex-end;
	gap: 0.45rem;
}

.itinerary-hero-actions--left {
	right: auto;
	left: max(var(--page-gutter, 1.35rem), env(safe-area-inset-left, 0px));
	justify-content: flex-start;
}

@media (min-width: 769px) {
	.itinerary-hero-actions {
		gap: 0.5rem;
	}
}

/* Mobile: il blocco hero-actions non deve incollarsi ai bordi del viewport */
@media (max-width: 768px) {
	body[data-itinerary-profile] {
		--itinerary-hero-left-control-inset: max(1.25rem, calc(env(safe-area-inset-left, 0px) + 14px));
		--itinerary-hero-maps-btn-size: 1.95rem;
	}

	.itinerary-hero-actions {
		right: max(1.25rem, calc(env(safe-area-inset-right, 0px) + 14px));
		bottom: max(1rem, calc(env(safe-area-inset-bottom, 0px) + 12px));
		max-width: calc(
			100% - 2 * max(1.25rem, calc(env(safe-area-inset-right, 0px) + 14px))
		);
	}

	.itinerary-hero-actions--left {
		right: auto;
		left: var(--itinerary-hero-left-control-inset);
		max-width: calc(
			100% - 2 * var(--itinerary-hero-left-control-inset)
		);
	}

	/* Indietro: stessa verticale del trigger mappe (centri allineati, ingombri diversi). */
	body[data-itinerary-profile] .itinerary-hero .itinerary-nav-back--cover {
		left: calc(
			var(--itinerary-hero-left-control-inset) +
				(var(--itinerary-hero-maps-btn-size) - 38px) / 2
		);
	}
}

.itinerary-share,
.itinerary-maps {
	position: relative;
	pointer-events: auto;
	display: inline-block;
}

.itinerary-share__trigger,
.itinerary-maps__trigger {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.45rem;
	padding: 0.5rem 0.95rem;
	min-height: 2.55rem;
	border-radius: 999px;
	cursor: pointer;
	font-family: inherit;
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	text-decoration: none;
	color: rgba(255, 255, 255, 0.95);
	background: rgba(255, 255, 255, 0.14);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	border: 1px solid rgba(255, 255, 255, 0.32);
	box-shadow:
		0 4px 20px rgba(0, 0, 0, 0.25),
		inset 0 1px 0 rgba(255, 255, 255, 0.18);
	transition:
		background 0.28s ease,
		border-color 0.28s ease,
		box-shadow 0.28s ease,
		transform 0.2s ease;
}

.itinerary-share__trigger:hover,
.itinerary-share__trigger:focus-visible,
.itinerary-maps__trigger:hover,
.itinerary-maps__trigger:focus-visible {
	background: rgba(255, 255, 255, 0.22);
	border-color: rgba(255, 255, 255, 0.55);
	color: #fff;
	box-shadow:
		0 8px 28px rgba(0, 0, 0, 0.35),
		inset 0 1px 0 rgba(255, 255, 255, 0.25);
}

.itinerary-share__trigger:focus-visible,
.itinerary-maps__trigger:focus-visible {
	outline: 2px solid var(--accent-orange);
	outline-offset: 3px;
}

.itinerary-share__trigger:active,
.itinerary-maps__trigger:active {
	transform: scale(0.97);
}

.itinerary-share__trigger i,
.itinerary-maps__trigger i {
	font-size: 1.02rem;
	filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.45));
}

.itinerary-share__toast {
	position: absolute;
	right: 0;
	bottom: calc(100% + 0.45rem);
	left: auto;
	max-width: min(14rem, 85vw);
	padding: 0.5rem 0.75rem;
	border-radius: 10px;
	font-size: 0.8rem;
	font-weight: 600;
	color: #fff;
	background: rgba(34, 197, 94, 0.95);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
	z-index: 6;
	pointer-events: none;
}

.itinerary-hero-social-links {
	pointer-events: auto;
}

@media (max-width: 768px) {
	/*
	 * Ingombro dei wrapper (#itinerary-share-root, #itinerary-maps-root): compatto senza stringere il pulsante visibile.
	 * Il “corpo” cliccabile resta sul trigger; il div wrappa solo quel box + menu assoluti.
	 */
	.itinerary-share,
	.itinerary-maps {
		display: inline-flex;
		flex-direction: column;
		align-items: stretch;
		width: fit-content;
		max-width: 100%;
		padding: 0;
		margin: 0;
		line-height: 0;
		vertical-align: top;
	}

	.itinerary-share__trigger-label,
	.itinerary-maps__trigger-label {
		position: absolute;
		width: 1px;
		height: 1px;
		padding: 0;
		margin: -1px;
		overflow: hidden;
		clip: rect(0, 0, 0, 0);
		white-space: nowrap;
		border: 0;
	}

	/* Pulsante: allineato al .article-card-share/.article-card-maps su listing (main.css, max-width: 768px). */
	.itinerary-share__trigger,
	.itinerary-maps__trigger {
		box-sizing: border-box;
		width: 1.95rem;
		height: 1.95rem;
		min-width: 1.95rem;
		min-height: 1.95rem;
		max-width: 1.95rem;
		max-height: 1.95rem;
		aspect-ratio: 1;
		padding: 0;
		border-radius: 8px;
		border-width: 1px;
		overflow: visible;
		flex-shrink: 0;
		line-height: 1;
		backdrop-filter: blur(6px);
		-webkit-backdrop-filter: blur(6px);
		box-shadow:
			0 1px 4px rgba(0, 0, 0, 0.14),
			inset 0 1px 0 rgba(255, 255, 255, 0.1);
	}

	.itinerary-share__trigger:hover,
	.itinerary-share__trigger:focus-visible,
	.itinerary-maps__trigger:hover,
	.itinerary-maps__trigger:focus-visible {
		box-shadow:
			0 1px 6px rgba(0, 0, 0, 0.18),
			inset 0 1px 0 rgba(255, 255, 255, 0.12);
	}

	.itinerary-share__trigger i,
	.itinerary-maps__trigger i {
		font-size: 0.85rem;
		line-height: 1;
		filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.28));
	}

	#itinerary-share-root.itinerary-share .itinerary-share__toast {
		line-height: normal;
	}
}

@media (prefers-reduced-motion: reduce) {
	.itinerary-share__trigger,
	.itinerary-maps__trigger {
		transition: none;
	}

	.itinerary-share__trigger:active,
	.itinerary-maps__trigger:active {
		transform: none;
	}
}

.itinerary-hero-social__stack {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: flex-end;
	align-items: center;
	gap: 0.45rem;
	pointer-events: auto;
}

@media (min-width: 769px) {
	.itinerary-hero-social__stack {
		gap: 0.5rem;
	}
}

.itinerary-hero-social__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.45rem;
	padding: 0.5rem 0.95rem;
	min-height: 2.55rem;
	border-radius: 999px;
	text-decoration: none;
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	color: rgba(255, 255, 255, 0.9);
	background: rgba(255, 255, 255, 0.12);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	border: 1px solid rgba(255, 255, 255, 0.28);
	box-shadow:
		0 4px 20px rgba(0, 0, 0, 0.25),
		inset 0 1px 0 rgba(255, 255, 255, 0.18);
	transition:
		background 0.28s ease,
		border-color 0.28s ease,
		box-shadow 0.28s ease,
		color 0.28s ease,
		transform 0.2s ease;
}

.itinerary-hero-social__link .fab {
	font-size: 1.08rem;
	line-height: 1;
	filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.45));
}

.itinerary-hero-social__link--instagram:hover,
.itinerary-hero-social__link--instagram:focus-visible {
	color: #fff;
	background: linear-gradient(
		125deg,
		rgba(245, 133, 41, 0.95) 0%,
		rgba(221, 42, 123, 0.95) 42%,
		rgba(129, 52, 175, 0.95) 100%
	);
	border-color: rgba(255, 255, 255, 0.5);
	box-shadow:
		0 8px 32px rgba(221, 42, 123, 0.5),
		0 0 0 1px rgba(255, 255, 255, 0.12) inset;
}

.itinerary-hero-social__link--tiktok:hover,
.itinerary-hero-social__link--tiktok:focus-visible {
	color: #fff;
	background: linear-gradient(
		135deg,
		rgba(0, 242, 234, 0.45) 0%,
		rgba(14, 14, 18, 0.94) 48%,
		rgba(255, 0, 80, 0.55) 100%
	);
	border-color: rgba(0, 242, 234, 0.75);
	box-shadow:
		0 8px 32px rgba(255, 0, 80, 0.4),
		0 0 28px rgba(0, 242, 234, 0.22);
}

.itinerary-hero-social__link:focus-visible {
	outline: 2px solid var(--accent-orange);
	outline-offset: 3px;
}

.itinerary-hero-social__link:active {
	transform: scale(0.97);
}

@media (max-width: 768px) {
	.itinerary-hero-social__label {
		position: absolute;
		width: 1px;
		height: 1px;
		padding: 0;
		margin: -1px;
		overflow: hidden;
		clip: rect(0, 0, 0, 0);
		white-space: nowrap;
		border: 0;
	}

	.itinerary-hero-social__link {
		width: 3.05rem;
		height: 3.05rem;
		min-height: 0;
		padding: 0;
		border-radius: 14px;
	}

	.itinerary-hero-social__link .fab {
		font-size: 1.38rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	.itinerary-hero-social__link {
		transition: none;
	}

	.itinerary-hero-social__link:active {
		transform: none;
	}
}

/* VIDEO BUTTONS TRACK (link social / video; sopra la galleria, sotto il corpo — stesso ordine di article-experiences) */
.itinerary-video-buttons {
	padding-top: 0;
	padding-bottom: 16px;
	max-width: 800px;
	margin-top: 0;
}

.video-buttons__track {
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: center;
	gap: 12px;
	overflow: hidden;
	white-space: nowrap;
}

/* Evita a capo e usa layout orizzontale continuo per i link */
.itinerary-video-buttons .itinerary-hero-social__stack {
	display: flex;
	flex-wrap: nowrap;
	justify-content: center;
	gap: 12px;
	width: 100%;
	margin: 0 auto;
}

@media (max-width: 768px) {
	.video-buttons__track {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: thin;
	}
}

/* Dimensioni più grandi dei pulsanti in questa sezione */
.itinerary-video-buttons .itinerary-hero-social__link {
	padding: 18px 22px;
	min-height: 72px;
	font-size: 14px;
	font-weight: 500;
	gap: 12px;
	border-radius: 16px;
	color: #fff;
	border: none;
	box-shadow: none;
	flex: 1 1 0;
	min-width: 260px;
}

.itinerary-video-buttons .itinerary-hero-social__link .itinerary-hero-social__label {
	position: static;
	width: auto;
	height: auto;
	padding: 0;
	margin: 0;
	overflow: visible;
	clip: auto;
	white-space: nowrap;
	border: 0;
	font-weight: 500;
	font-size: 14px;
}

.itinerary-video-buttons .itinerary-hero-social__ext {
	font-size: 0.95em;
	line-height: 1;
	opacity: 0.9;
	transform: translateY(-1px);
}

@media (max-width: 640px) {
	.itinerary-video-buttons .itinerary-hero-social__stack {
		flex-direction: column;
		gap: 10px;
	}

	.itinerary-video-buttons .itinerary-hero-social__link {
		width: 100%;
		min-width: 0;
		min-height: 56px;
		padding: 14px 16px;
	}

	.itinerary-video-buttons .itinerary-hero-social__link .itinerary-hero-social__label {
		white-space: normal;
		line-height: 1.25;
	}
}

.itinerary-video-buttons .itinerary-hero-social__link--instagram:hover,
.itinerary-video-buttons .itinerary-hero-social__link--instagram:focus-visible,
.itinerary-video-buttons .itinerary-hero-social__link--tiktok:hover,
.itinerary-video-buttons .itinerary-hero-social__link--tiktok:focus-visible {
	opacity: 0.8;
}

.itinerary-video-buttons .itinerary-hero-social__link--instagram .fab {
	color: rgba(255, 255, 255, 0.98);
	font-size: 1.5rem;
}

.itinerary-video-buttons .itinerary-hero-social__link--tiktok .fab {
	color: rgba(255, 255, 255, 0.98);
	font-size: 1.5rem;
}

.itinerary-video-buttons .itinerary-hero-social__link .fab {
	filter: none;
}

.itinerary-video-buttons .itinerary-hero-social__link--instagram {
	background: linear-gradient(
		135deg,
		#f58529 0%,
		#dd2a7b 42%,
		#8134af 100%
	);
}

.itinerary-video-buttons .itinerary-hero-social__link--tiktok {
	background: #0b0b0f;
}

/* ========== Caricamento articolo: overlay + pagina finché contenuto non è pronto ========== */
body[data-itinerary-profile]:not(.itinerary-page--ready):not(.article-page--ready) main#main-content {
	visibility: hidden;
	opacity: 0;
	pointer-events: none;
}

body[data-itinerary-profile].itinerary-page--ready main#main-content,
body[data-itinerary-profile].article-page--ready main#main-content {
	visibility: visible;
	opacity: 1;
	pointer-events: auto;
	transition: opacity 0.4s ease;
}

@media (prefers-reduced-motion: reduce) {
	body[data-itinerary-profile].itinerary-page--ready main#main-content,
	body[data-itinerary-profile].article-page--ready main#main-content {
		transition: none;
	}
}

/* Dark theme: articoli / itinerari */
[data-theme="dark"] .itinerary-body,
[data-theme="dark"] .article-content,
[data-theme="dark"] .itinerary-sidebar__card,
[data-theme="dark"] .itinerary-facts,
[data-theme="dark"] .itinerary-toc,
[data-theme="dark"] .markdown-content blockquote {
	background: var(--surface-raised);
	color: var(--text-primary);
	border-color: var(--border-subtle);
}

[data-theme="dark"] .markdown-content a {
	color: color-mix(in srgb, var(--accent-orange) 75%, #ffd4a8 25%);
}

[data-theme="dark"] .markdown-content code {
	background: color-mix(in srgb, var(--surface) 80%, #000 20%);
	color: var(--text-primary);
}

[data-theme="dark"] .itinerary-hero__overlay {
	background: linear-gradient(
		180deg,
		rgba(13, 17, 23, 0.35) 0%,
		rgba(13, 17, 23, 0.72) 55%,
		rgba(13, 17, 23, 0.92) 100%
	);
}

[data-theme="dark"] .itinerary-sidebar__card {
	box-shadow: var(--shadow-md), inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

[data-theme="dark"] .itinerary-share__btn {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(255, 255, 255, 0.14);
}

[data-theme="dark"] .itinerary-share__toast {
	background: var(--surface-raised);
	color: var(--text-primary);
	border: 1px solid var(--border-subtle);
	box-shadow: var(--shadow-lg);
}
