:root {
	--sstw-blue: #052b4f;
	--sstw-blue-soft: #0d5c83;
	--sstw-turquoise: #0097a9;
	--sstw-sand: #f4ead7;
	--sstw-green: #4f7f61;
	--sstw-text: #25323a;
	--sstw-muted: #66727a;
	--sstw-white: #fff;
	--sstw-shadow: 0 18px 45px rgba(5, 43, 79, 0.13);
	--sstw-radius: 24px;
}

.sst-hero {
	position: relative;
	display: grid;
	place-items: center;
	background-size: cover;
	background-position: center;
	isolation: isolate;
	overflow: hidden;
}
.sst-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	background: rgba(0,0,0,.38);
}
.sst-hero__inner {
	width: min(1180px, calc(100vw - 40px));
	margin-inline: auto;
	padding: 120px 0 80px;
	display: flex;
}
.sst-hero--center-center .sst-hero__inner { justify-content: center; align-items: center; }
.sst-hero--center-left .sst-hero__inner { justify-content: flex-start; align-items: center; }
.sst-hero--bottom-left .sst-hero__inner { justify-content: flex-start; align-items: flex-end; }
.sst-hero--bottom-center .sst-hero__inner { justify-content: center; align-items: flex-end; }
.sst-hero__content { color: var(--sstw-white); }
.sst-hero__pretitle {
	margin: 0 0 12px;
	text-transform: uppercase;
	letter-spacing: .16em;
	font-weight: 800;
	font-size: clamp(.82rem, 1.4vw, 1rem);
}
.sst-hero__title {
	margin: 0;
	font-size: clamp(2.5rem, 8vw, 6.8rem);
	line-height: .95;
	font-weight: 850;
	letter-spacing: -.045em;
	text-wrap: balance;
}
.sst-hero__description {
	max-width: 720px;
	margin: 20px auto 0;
	font-size: clamp(1.12rem, 2.1vw, 1.55rem);
	line-height: 1.55;
	font-weight: 500;
}
.sst-hero__description p { margin: 0; }
.sst-hero__button,
.sst-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 13px 24px;
	margin-top: 26px;
	border-radius: 999px;
	background: var(--sstw-turquoise);
	color: #fff;
	text-decoration: none;
	font-weight: 800;
	box-shadow: 0 12px 26px rgba(0, 151, 169, .25);
	transition: transform 180ms ease, box-shadow 180ms ease, filter 180ms ease;
}
.sst-hero__button:hover,
.sst-button:hover {
	color: #fff;
	transform: translateY(-2px);
	filter: brightness(1.04);
	box-shadow: 0 16px 32px rgba(0, 151, 169, .30);
}
.sst-anim-fade-in .sst-hero__content,
.sst-anim-fade-in.sst-two-columns { animation: sstwFade .8s ease both; }
.sst-anim-slide-up .sst-hero__content,
.sst-anim-slide-up.sst-two-columns { animation: sstwSlideUp .8s ease both; }
@keyframes sstwFade { from { opacity: 0; } to { opacity: 1; } }
@keyframes sstwSlideUp { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }

.sst-quote {
	position: relative;
	margin: 72px auto;
	padding: 42px;
	border-radius: 28px;
	background: var(--sstw-sand);
	box-shadow: var(--sstw-shadow);
}
.sst-quote__icon {
	display: inline-block;
	font-size: 5rem;
	line-height: .6;
	color: var(--sstw-turquoise);
	font-family: Georgia, serif;
}
.sst-quote__text {
	margin: 0;
	font-size: clamp(1.25rem, 2.2vw, 2rem);
	line-height: 1.42;
	font-weight: 700;
	color: var(--sstw-blue);
}
.sst-quote__text p { margin: 0; }
.sst-quote__author { margin-top: 18px; font-weight: 800; color: var(--sstw-green); }

.sst-two-columns-wrap { background: #fff; }
.sst-two-columns {
	width: min(1180px, calc(100vw - 40px));
	margin-inline: auto;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	align-items: center;
	gap: 64px;
}
.sst-two-columns--image-right .sst-two-columns__media { order: 2; }
.sst-two-columns--image-right .sst-two-columns__content { order: 1; }
.sst-two-columns__image { margin: 0; }
.sst-two-columns__image img {
	display: block;
	width: 100%;
	aspect-ratio: 4/3;
	object-fit: cover;
	border-radius: 28px;
	box-shadow: var(--sstw-shadow);
}
.sst-two-columns__eyebrow {
	margin: 0 0 12px;
	letter-spacing: .14em;
	text-transform: uppercase;
	font-weight: 850;
	color: var(--sstw-turquoise);
}
.sst-two-columns__title {
	margin: 0;
	font-size: clamp(2rem, 4vw, 4rem);
	line-height: 1.04;
	letter-spacing: -.035em;
	color: var(--sstw-blue);
	text-wrap: balance;
}
.sst-two-columns__description {
	margin-top: 20px;
	color: var(--sstw-text);
	font-size: 1.04rem;
	line-height: 1.78;
}
.sst-two-columns__description p { margin: 0 0 1rem; }
.sst-two-columns__description p:last-child { margin-bottom: 0; }

.sst-map {
	position: relative;
	width: min(1180px, calc(100vw - 40px));
	margin: 52px auto;
	overflow: hidden;
	border-radius: var(--sstw-radius);
	box-shadow: var(--sstw-shadow);
	background: #eef5f6;
}
.sst-map iframe { display: block; width: 100%; border: 0; }
.sst-map-placeholder {
	display: grid;
	place-items: center;
	gap: 18px;
	padding: 24px;
	text-align: center;
	background: linear-gradient(135deg, rgba(5,43,79,.92), rgba(0,151,169,.78));
	color: #fff;
}
.sst-map-placeholder p { max-width: 680px; margin: 0; }
.sst-map-load-button {
	border: 0;
	border-radius: 999px;
	padding: 12px 22px;
	font-weight: 800;
	background: #fff;
	color: var(--sstw-blue);
	cursor: pointer;
}

.sst-nearby {
	width: min(1180px, calc(100vw - 40px));
	margin: 92px auto;
}
.sst-nearby__header { max-width: 780px; margin-bottom: 28px; }
.sst-nearby__title {
	margin: 0;
	font-size: clamp(2rem, 4vw, 4rem);
	line-height: 1.05;
	color: var(--sstw-blue);
}
.sst-nearby__description { margin: 14px 0 0; color: var(--sstw-muted); font-size: 1.08rem; }
.sst-nearby__filters {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: 26px;
}
.sst-nearby-filter {
	border: 0;
	padding: 10px 16px;
	border-radius: 999px;
	font-weight: 800;
	background: var(--sstw-sand);
	color: var(--sstw-blue);
	cursor: pointer;
	transition: background-color 180ms ease, color 180ms ease, transform 180ms ease;
}
.sst-nearby-filter:hover { transform: translateY(-1px); }
.sst-nearby-filter.is-active { color: #fff; background: var(--sstw-turquoise); }
.sst-nearby__grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; }
.sst-nearby-card {
	overflow: hidden;
	background: #fff;
	border: 1px solid rgba(37,50,58,.10);
	border-radius: 24px;
	box-shadow: 0 14px 36px rgba(5,43,79,.09);
	transition: transform 180ms ease, box-shadow 180ms ease;
}
.sst-nearby-card:hover { transform: translateY(-4px); box-shadow: var(--sstw-shadow); }
.sst-nearby-card.is-hidden { display: none; }
.sst-nearby-card__image { margin: 0; overflow: hidden; }
.sst-nearby-card__image img { display: block; width: 100%; height: 210px; object-fit: cover; }
.sst-nearby-card__body { padding: 16px 16px 18px; }
.sst-nearby-card__badge {
	display: inline-flex;
	align-items: center;
	border-radius: 999px;
	padding: 6px 10px;
	font-size: .82rem;
	font-weight: 850;
	background: var(--sstw-sand);
	color: var(--sstw-blue);
}
.sst-nearby-card__title { margin: 12px 0 8px; font-size: 1.24rem; line-height: 1.2; color: var(--sstw-blue); }
.sst-nearby-card__description { margin: 0 0 12px; color: var(--sstw-text); }
.sst-nearby-card__meta { margin: 8px 0; font-size: .94rem; color: var(--sstw-muted); }
.sst-nearby-card__map { margin-top: 12px; border-radius: 16px; overflow: hidden; }
.sst-nearby-card__map iframe { width: 100%; height: 180px; border: 0; }
.sst-nearby-card__actions { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 10px; margin-top: 16px; }
.sst-nearby-card__button {
	min-height: 46px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 14px;
	padding: 10px 12px;
	font-weight: 850;
	text-decoration: none;
	background: var(--sstw-turquoise);
	color: #fff;
}
.sst-nearby-card__button:hover { color: #fff; filter: brightness(1.04); }
.sst-nearby-card__button--ghost { background: rgba(0,151,169,.10); color: var(--sstw-blue); }
.sst-nearby-card__button--ghost:hover { color: var(--sstw-blue); }

.sst-info-box,
.sst-contact-info,
.sst-cf7-wrapper {
	background: #fff;
	border: 1px solid rgba(37,50,58,.10);
	border-radius: 26px;
	box-shadow: 0 14px 36px rgba(5,43,79,.09);
}
.sst-info-box { max-width: 980px; margin: 52px auto; padding: 36px; background: var(--sstw-sand); }
.sst-info-box__icon { font-size: 2rem; color: var(--sstw-turquoise); margin-bottom: 12px; }
.sst-info-box__title,
.sst-contact-info__title,
.sst-cf7-wrapper__title {
	margin: 0 0 14px;
	font-size: clamp(1.7rem, 3vw, 2.8rem);
	line-height: 1.08;
	color: var(--sstw-blue);
}
.sst-info-box__description { color: var(--sstw-text); }
.sst-info-box__description p { margin: 0 0 1rem; }
.sst-info-box__description p:last-child { margin-bottom: 0; }

.sst-contact-info { padding: 34px; font-style: normal; }
.sst-contact-info__intro { margin: 0 0 18px; color: var(--sstw-muted); }
.sst-contact-info__list { list-style: none; margin: 0; padding: 0; display: grid; gap: 14px; }
.sst-contact-info__list li { display: grid; grid-template-columns: 34px 1fr; gap: 10px; align-items: start; }
.sst-contact-info__icon { color: var(--sstw-turquoise); font-weight: 900; }
.sst-contact-info a { text-decoration: none; font-weight: 700; }

.sst-cf7-wrapper { padding: 34px; }
.sst-cf7-wrapper__description { margin: 0 0 22px; color: var(--sstw-muted); }
.sst-cf7-wrapper label { display: block; margin-bottom: 14px; font-weight: 750; }
.sst-cf7-wrapper input:not([type="submit"]),
.sst-cf7-wrapper textarea,
.sst-cf7-wrapper select {
	width: 100%;
	min-height: 48px;
	margin-top: 6px;
	border: 1px solid rgba(37,50,58,.14);
	border-radius: 14px;
	padding: 12px 14px;
	background: #f8fafb;
	color: var(--sstw-text);
}
.sst-cf7-wrapper textarea { min-height: 140px; resize: vertical; }
.sst-cf7-wrapper input[type="submit"],
.sst-cf7-wrapper button[type="submit"] {
	min-height: 50px;
	border: 0;
	border-radius: 999px;
	padding: 13px 24px;
	background: var(--sstw-turquoise);
	color: #fff;
	font-weight: 850;
	cursor: pointer;
}
.sst-admin-only-message { padding: 12px 14px; border-radius: 12px; background: #fff4c8; color: #4a3a00; }

.sst-policy {
	margin: 0 auto;
	padding: 90px 20px;
	color: var(--sstw-text);
}
.sst-policy h1 { margin: 0 0 24px; font-size: clamp(2.2rem, 4.5vw, 4.4rem); line-height: 1; color: var(--sstw-blue); }
.sst-policy h2 { margin: 50px 0 16px; font-size: clamp(1.6rem, 3vw, 2.6rem); line-height: 1.08; color: var(--sstw-blue); }
.sst-policy__anchors { display: flex; flex-wrap: wrap; gap: 10px; margin: 0 0 34px; }
.sst-policy__anchors a { border-radius: 999px; padding: 9px 14px; background: var(--sstw-sand); text-decoration: none; font-weight: 800; color: var(--sstw-blue); }
.sst-policy__section { scroll-margin-top: 120px; }

.elementor-section .elementor-container { max-width: min(1180px, calc(100vw - 40px)); }

@media (max-width: 900px) {
	.sst-hero__inner { width: min(100vw - 28px, 720px); padding: 110px 0 64px; }
	.sst-hero__description { margin-inline: 0; }
	.sst-quote { margin: 44px 14px; padding: 30px 22px; }
	.sst-two-columns { width: min(100vw - 28px, 720px); grid-template-columns: 1fr; gap: 34px; }
	.sst-two-columns--image-right .sst-two-columns__media,
	.sst-two-columns--image-right .sst-two-columns__content { order: initial; }
	.sst-map, .sst-nearby { width: min(100vw - 28px, 720px); margin: 42px auto; }
	.sst-nearby__grid { grid-template-columns: 1fr; }
	.sst-nearby-card__actions { grid-template-columns: 1fr; }
	.sst-info-box { margin: 42px auto; padding: 26px 20px; }
	.sst-contact-info, .sst-cf7-wrapper { padding: 24px 20px; }
}

@media (prefers-reduced-motion: reduce) {
	.sst-anim-fade-in .sst-hero__content,
	.sst-anim-fade-in.sst-two-columns,
	.sst-anim-slide-up .sst-hero__content,
	.sst-anim-slide-up.sst-two-columns { animation: none; }
	.sst-nearby-card, .sst-button, .sst-hero__button { transition: none; }
}

/* --------------------------------------------------------------------------
 * Hotfix widget 1.2.0: palette coerente e maggiore specificità su Elementor.
 * -------------------------------------------------------------------------- */
.elementor .sst-hero__title,
.elementor .sst-two-columns__title,
.elementor .sst-nearby__title,
.elementor .sst-policy__title,
.elementor .sst-contact-form__title,
.elementor .sst-contact-info__title,
.elementor .sst-info-box__title {
	color: var(--sstw-blue, #052b4f);
}
.elementor .sst-two-columns__eyebrow,
.elementor .sst-nearby-card__badge,
.elementor .sst-contact-info__icon {
	color: var(--sstw-turquoise, #0097a9);
}
.elementor .sst-two-columns__description,
.elementor .sst-nearby__description,
.elementor .sst-nearby-card__description,
.elementor .sst-policy__content,
.elementor .sst-contact-info__text,
.elementor .sst-info-box__description {
	color: var(--sstw-text, #25323a);
}
.elementor .sst-button,
.elementor .sst-hero__button,
.elementor .sst-nearby-card__button,
.elementor .sst-contact-form input[type="submit"],
.elementor .sst-contact-form button[type="submit"] {
	background: var(--sstw-turquoise, #0097a9);
	color: #ffffff !important;
}
.elementor .sst-nearby-card,
.elementor .sst-info-box,
.elementor .sst-contact-info,
.elementor .sst-contact-form,
.elementor .sst-policy,
.elementor .sst-quote {
	background-color: #ffffff;
}

/* --------------------------------------------------------------------------
 * Serrara Smart Tour v1.6.0 - riparazione grafica Elementor/layout.
 * Obiettivo: evitare pagine "rotte" anche quando Elementor/hosting servono CSS
 * parziale o in ritardo. Queste regole sono conservative e non bloccano i
 * controlli Elementor, perché Elementor genera selettori più specifici per i
 * singoli widget.
 * -------------------------------------------------------------------------- */
:root {
	--sst-blue: #052b4f;
	--sst-blue-soft: #0d5c83;
	--sst-turquoise: #0097a9;
	--sst-sand: #f4ead7;
	--sst-white: #ffffff;
	--sst-green: #4f7f61;
	--sst-anthracite: #25323a;
	--sst-muted: #66727a;
	--sst-border: rgba(37, 50, 58, 0.12);
	--sst-shadow: 0 18px 45px rgba(5, 43, 79, 0.13);
	--sst-radius: 22px;
	--sst-container: min(1180px, calc(100vw - 40px));
	--sstw-blue: #052b4f;
	--sstw-blue-soft: #0d5c83;
	--sstw-turquoise: #0097a9;
	--sstw-sand: #f4ead7;
	--sstw-green: #4f7f61;
	--sstw-text: #25323a;
	--sstw-muted: #66727a;
	--sstw-white: #ffffff;
	--sstw-shadow: 0 18px 45px rgba(5, 43, 79, 0.13);
	--sstw-radius: 24px;
}

body.serrara-smart-tour-theme,
body[class*="serrara"] {
	background: #ffffff;
	color: var(--sst-anthracite);
}

/* Fallback Elementor: se il CSS generato da Elementor non è rigenerato, le
   sezioni restano comunque ordinate e responsive. */
.entry-content > .elementor,
.elementor,
.elementor-section,
.elementor-section-wrap,
.elementor-widget-wrap,
.elementor-widget {
	box-sizing: border-box;
}
.elementor-section {
	position: relative;
	clear: both;
	width: 100%;
}
.elementor-section .elementor-container {
	position: relative;
	display: flex;
	margin-left: auto;
	margin-right: auto;
	max-width: min(1180px, calc(100vw - 40px));
	width: 100%;
}
.elementor-section.elementor-section-full_width > .elementor-container,
.elementor-section.elementor-section-stretched > .elementor-container {
	max-width: 100%;
}
.elementor-column {
	position: relative;
	min-height: 1px;
	display: flex;
}
.elementor-column.elementor-col-100 { width: 100%; }
.elementor-column.elementor-col-50 { width: 50%; }
.elementor-column.elementor-col-33 { width: 33.333%; }
.elementor-column.elementor-col-25 { width: 25%; }
.elementor-widget-wrap {
	position: relative;
	display: flex;
	width: 100%;
	flex-wrap: wrap;
	align-content: flex-start;
}
.elementor-widget {
	position: relative;
	width: 100%;
}
.elementor-widget:not(:last-child) {
	margin-bottom: 0;
}
.elementor-page .entry-content,
.entry-content > .elementor {
	margin: 0;
	padding: 0;
	max-width: none;
}

/* Spaziatura verticale coerente tra widget importati. */
.elementor-widget-serrara_quote_box,
.elementor-widget-serrara_two_columns_content,
.elementor-widget-serrara_google_map_embed,
.elementor-widget-serrara_nearby_places,
.elementor-widget-serrara_info_box,
.elementor-widget-serrara_contact_info,
.elementor-widget-serrara_contact_form_7_wrapper,
.elementor-widget-serrara_policy_content {
	padding-block: clamp(22px, 4vw, 44px);
}
.elementor-widget-serrara_hero_fullscreen {
	padding-block: 0;
}

/* Evita overflow nelle colonne Elementor: prima la mappa ereditava una width
   globale da 1180px e poteva uscire dalla colonna sinistra. */
.elementor-column .sst-map,
.elementor-widget-wrap .sst-map {
	width: 100%;
	max-width: 100%;
	margin: 0;
}
.elementor-column .sst-info-box,
.elementor-widget-wrap .sst-info-box,
.elementor-column .sst-contact-info,
.elementor-widget-wrap .sst-contact-info,
.elementor-column .sst-cf7-wrapper,
.elementor-widget-wrap .sst-cf7-wrapper {
	width: 100%;
	max-width: 100%;
	margin: 0;
}
.elementor-column .sst-map iframe,
.elementor-widget-wrap .sst-map iframe {
	max-width: 100%;
}

/* Mantiene i colori mediterranei corretti. L'hotfix precedente forzava alcune
   card a bianco e rendeva quote/info box visivamente sbagliati. */
.elementor .sst-quote { background: var(--sstw-sand, #f4ead7); }
.elementor .sst-info-box { background: var(--sstw-sand, #f4ead7); }
.elementor .sst-contact-info,
.elementor .sst-cf7-wrapper,
.elementor .sst-policy,
.elementor .sst-nearby-card { background: #ffffff; }
.elementor .sst-hero__title,
.elementor .sst-hero__description { color: #ffffff; }
.elementor .sst-hero__pretitle { color: var(--sstw-sand, #f4ead7); }
.elementor .sst-two-columns__title,
.elementor .sst-nearby__title,
.elementor .sst-policy h1,
.elementor .sst-policy h2,
.elementor .sst-contact-info__title,
.elementor .sst-cf7-wrapper__title,
.elementor .sst-info-box__title,
.elementor .sst-quote__text {
	color: var(--sstw-blue, #052b4f);
}
.elementor .sst-two-columns__eyebrow,
.elementor .sst-contact-info__icon,
.elementor .sst-quote__icon {
	color: var(--sstw-turquoise, #0097a9);
}
.elementor .sst-two-columns__description,
.elementor .sst-nearby__description,
.elementor .sst-nearby-card__description,
.elementor .sst-policy,
.elementor .sst-contact-info__intro,
.elementor .sst-info-box__description {
	color: var(--sstw-text, #25323a);
}
.elementor .sst-button,
.elementor .sst-hero__button,
.elementor .sst-nearby-card__button,
.elementor .sst-cf7-wrapper input[type="submit"],
.elementor .sst-cf7-wrapper button[type="submit"] {
	background: var(--sstw-turquoise, #0097a9);
	color: #ffffff !important;
}
.elementor .sst-nearby-card__button--ghost {
	background: rgba(0,151,169,.10);
	color: var(--sstw-blue, #052b4f) !important;
}

/* Layout più istituzionale e pulito sulle pagine interne. */
.sst-info-box,
.sst-contact-info,
.sst-cf7-wrapper,
.sst-nearby-card,
.sst-quote,
.sst-map,
.sst-two-columns__image img {
	border: 1px solid rgba(37,50,58,.10);
}
.sst-two-columns-wrap {
	padding-block: clamp(52px, 8vw, 100px);
}
.sst-two-columns-wrap + .sst-two-columns-wrap {
	padding-top: clamp(22px, 4vw, 48px);
}
.sst-two-columns {
	min-height: 0;
}
.sst-two-columns__content,
.sst-two-columns__media {
	min-width: 0;
}
.sst-map {
	min-height: 260px;
}
.sst-map iframe,
.sst-map-placeholder {
	width: 100%;
	min-height: 260px;
}

/* Header/dropdown ulteriormente stabilizzato sopra Elementor. */
.site-header {
	z-index: 99999;
}
.site-header .sub-menu {
	z-index: 100000;
}
.site-header .menu > li > a[href="#"] {
	cursor: pointer;
}

/* Mobile: niente overflow, card e pulsanti comodi. */
@media (max-width: 900px) {
	:root { --sst-container: min(100vw - 28px, 720px); }
	.elementor-section .elementor-container {
		flex-direction: column;
		max-width: min(100vw - 28px, 720px);
	}
	.elementor-column,
	.elementor-column.elementor-col-50,
	.elementor-column.elementor-col-33,
	.elementor-column.elementor-col-25,
	.elementor-column.elementor-col-100 {
		width: 100% !important;
	}
	.elementor-widget-serrara_quote_box,
	.elementor-widget-serrara_two_columns_content,
	.elementor-widget-serrara_google_map_embed,
	.elementor-widget-serrara_nearby_places,
	.elementor-widget-serrara_info_box,
	.elementor-widget-serrara_contact_info,
	.elementor-widget-serrara_contact_form_7_wrapper,
	.elementor-widget-serrara_policy_content {
		padding-block: 18px;
	}
	.sst-hero {
		min-height: 72vh;
	}
	.sst-hero__inner,
	.sst-two-columns,
	.sst-map,
	.sst-nearby {
		width: min(100vw - 28px, 720px);
	}
	.sst-hero__title {
		font-size: clamp(2.2rem, 13vw, 4.2rem);
		line-height: .98;
	}
	.sst-hero__description {
		font-size: 1.08rem;
	}
	.sst-two-columns-wrap {
		padding-block: 42px;
	}
	.sst-info-box,
	.sst-contact-info,
	.sst-cf7-wrapper,
	.sst-quote {
		border-radius: 22px;
	}
	.sst-nearby__grid {
		grid-template-columns: 1fr;
	}
}

/* Serrara Smart Tour v1.9.2 - default frontend values independent from Elementor generated CSS. */
.sst-hero { min-height: 92vh; }
.sst-hero__content { max-width: 850px; text-align: center; }
.sst-map iframe,
.sst-map-placeholder { height: 450px; }
@media (max-width: 1024px) { .sst-hero { min-height: 78vh; } }
@media (max-width: 767px) { .sst-hero { min-height: 72vh; } }

/* --------------------------------------------------------------------------
 * Serrara Smart Tour v1.9.2 - frontend/editor parity fix.
 * Supporta sia il vecchio DOM Elementor section/column sia il nuovo DOM
 * container/flexbox (.e-con), così il frontend pubblico non collassa quando
 * Elementor non carica correttamente i CSS documento.
 * -------------------------------------------------------------------------- */
.sst-elementor-standard-render,
.sst-elementor-standard-render > .elementor,
.entry-content > .elementor,
.entry-content > .sst-elementor-standard-render {
	width: 100%;
	max-width: none;
	margin: 0;
	padding: 0;
}
.elementor .e-con,
.elementor .e-con > .e-con-inner,
.elementor .elementor-section,
.elementor .elementor-container {
	box-sizing: border-box;
}
.elementor .e-con {
	position: relative;
	width: 100%;
	max-width: 100%;
}
.elementor .e-con.e-con-boxed > .e-con-inner {
	width: min(1180px, calc(100vw - 40px));
	max-width: 100%;
	margin-inline: auto;
}
.elementor .e-con.e-con-full,
.elementor .e-con.e-con-full > .e-con-inner {
	width: 100%;
	max-width: 100%;
}
.elementor .e-con > .e-con-inner,
.elementor .e-con.e-con-full {
	display: flex;
	gap: var(--gap, 0px);
}
.elementor .e-con.e-flex,
.elementor .e-con.e-flex > .e-con-inner {
	display: flex;
}
.elementor .e-child,
.elementor .e-con > .elementor-widget,
.elementor .e-con-inner > .elementor-widget {
	min-width: 0;
	max-width: 100%;
}
.elementor .elementor-widget-container {
	width: 100%;
}
.elementor .sst-hero,
.elementor .sst-two-columns-wrap,
.elementor .sst-quote,
.elementor .sst-map,
.elementor .sst-nearby,
.elementor .sst-info-box,
.elementor .sst-contact-info,
.elementor .sst-cf7-wrapper,
.elementor .sst-policy {
	visibility: visible !important;
}
.elementor .sst-hero {
	min-height: 72vh;
}
.elementor .sst-two-columns,
.elementor .sst-nearby__grid {
	min-width: 0;
}
@media (max-width: 900px) {
	.elementor .e-con > .e-con-inner,
	.elementor .e-con.e-con-full,
	.elementor .elementor-container {
		flex-direction: column;
	}
	.elementor .e-con.e-con-boxed > .e-con-inner {
		width: min(100vw - 28px, 720px);
	}
	.elementor .e-child,
	.elementor .elementor-column,
	.elementor .elementor-col-50,
	.elementor .elementor-col-33,
	.elementor .elementor-col-25,
	.elementor .elementor-col-100 {
		width: 100% !important;
		max-width: 100% !important;
	}
}

/* --------------------------------------------------------------------------
 * Serrara Smart Tour v1.9.2 - rifinitura widget per mobile.
 * -------------------------------------------------------------------------- */
@media (max-width: 900px) {
	body.serrara-smart-tour-theme .elementor .sst-two-columns,
	body.serrara-smart-tour-theme .sst-two-columns {
		grid-template-columns: 1fr !important;
		gap: 28px !important;
	}
	body.serrara-smart-tour-theme .elementor .sst-nearby__grid,
	body.serrara-smart-tour-theme .sst-nearby__grid {
		grid-template-columns: 1fr !important;
		gap: 18px !important;
	}
	body.serrara-smart-tour-theme .elementor .sst-hero__inner,
	body.serrara-smart-tour-theme .sst-hero__inner {
		padding-top: 74px !important;
		padding-bottom: 54px !important;
	}
	body.serrara-smart-tour-theme .elementor .sst-map iframe,
	body.serrara-smart-tour-theme .elementor .sst-map-placeholder,
	body.serrara-smart-tour-theme .sst-map iframe,
	body.serrara-smart-tour-theme .sst-map-placeholder {
		height: min(360px, 58svh) !important;
	}
}


/* Serrara Smart Tour v1.9.3 - filtri Nei dintorni senza bottone “Tutti”. */
.sst-nearby-filter[aria-pressed="true"] { color: #ffffff; background: var(--sstw-turquoise); }
.sst-nearby-filter:focus-visible { outline: 3px solid rgba(0,151,169,.35); outline-offset: 3px; }
@media (max-width: 900px) {
	.sst-nearby__filters { padding-bottom: 6px; scrollbar-width: thin; }
	.sst-nearby-filter { white-space: nowrap; }
}

/* v1.9.7 - fix dimensione icone Elementor e contatti mobile. */
body.serrara-smart-tour-theme .sst-info-box__icon,
body.serrara-smart-tour-theme .sst-contact-info__icon {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	flex: 0 0 auto !important;
	width: 44px !important;
	height: 44px !important;
	min-width: 44px !important;
	max-width: 44px !important;
	max-height: 44px !important;
	font-size: 1.35rem !important;
	line-height: 1 !important;
	border-radius: 14px !important;
	background: rgba(0, 151, 169, 0.12) !important;
	overflow: hidden !important;
}
body.serrara-smart-tour-theme .sst-info-box__icon svg,
body.serrara-smart-tour-theme .sst-contact-info__icon svg,
body.serrara-smart-tour-theme .sst-info-box__icon i,
body.serrara-smart-tour-theme .sst-contact-info__icon i {
	display: block !important;
	width: 1.15em !important;
	height: 1.15em !important;
	max-width: 26px !important;
	max-height: 26px !important;
	font-size: inherit !important;
	line-height: 1 !important;
}
body.sst-page-spiaggia .sst-info-box__icon {
	width: 48px !important;
	height: 48px !important;
	min-width: 48px !important;
	max-width: 48px !important;
	max-height: 48px !important;
	font-size: 1.45rem !important;
}
body.sst-page-spiaggia .sst-info-box__icon svg,
body.sst-page-spiaggia .sst-info-box__icon i {
	width: 24px !important;
	height: 24px !important;
	max-width: 24px !important;
	max-height: 24px !important;
}
body.sst-page-contattaci .sst-contact-info__list li {
	grid-template-columns: 48px minmax(0,1fr) !important;
}
@media (max-width: 900px) {
	body.sst-page-contattaci .sst-contact-info__list li {
		grid-template-columns: 46px minmax(0,1fr) !important;
	}
}
