/* ========================================
   BLOCK: GLOBAL OVERLAYS (click-through) v1
   Dove: assets/css/style.css
   Scopo: overlay e sfera NON devono catturare click/touch
========================================= */
.bg-overlay,
.sphere-stage,
.sphere-stage * {
	pointer-events: none;
}
/* ========================================
   /BLOCK: GLOBAL OVERLAYS (click-through) v1
========================================= */

/* ========================================
   BLOCK: SITE HEADER (layering) v1
   Dove: assets/css/style.css
   Scopo: header sempre cliccabile sopra ogni section/overlay
========================================= */
.site-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 9999;
	pointer-events: auto;
}

/* opzionale ma utile: evita che l'header "stringa" con width strani */
.site-header__inner {
	position: relative;
	z-index: 1;
}

/* il bottone deve poter ricevere click sempre */
.site-header__menu-toggle {
	pointer-events: auto;
}
/* ========================================
   /BLOCK: SITE HEADER (layering) v1
========================================= */


/* ========================================
   BLOCK: WP HOME CLEANUP (visual) v1
   Scopo: nascondere tutto ciò che viene stampato fuori dal wrapper
========================================= */
/* Full-page mode (compat): richiede classe sul <body> */
body.smoothie-home.smoothie-home--isolate > :not(#smoothie-home):not(#site-menu):not(#wpadminbar) {
	display: none !important;
}

/* ========================================
   BLOCK: WP TYPOGRAPHY/RESET SHIELD v1
   Scopo: neutralizzare reset globali del tema dentro il blocco homepage
========================================= */
#smoothie-home :is(
	.hero__headline,
	.flavor__headline,
	.feature__headline,
	.feature__text,
	.oasis__headline,
	.oasis__text,
	.prosecco__headline,
	.prosecco__text,
	.nobo__headline,
	.nobo__text,
	.cta-dark__headline,
	.clients__intro,
	.what-we-do__words,
	.mission__headline,
	.cta__headline,
	.site-footer__title,
	.site-footer__subtitle,
	.site-footer__office-title,
	.site-footer__office-text,
	.site-footer__email-link,
	.site-footer__copy
) {
	text-transform: none !important;
}
/* ========================================
   /BLOCK: WP TYPOGRAPHY/RESET SHIELD v1
========================================= */

/* ========================================
   BLOCK: RESET BASE
   Descrizione: reset minimale per layout coerente
======================================== */
*,
*::before,
*::after {
	box-sizing: border-box;
}

html,
body {
	margin: 0;
	padding: 0;
}

:root {
	--font-primary: "area-normal", system-ui, -apple-system, "Segoe UI", sans-serif;
	--font-display: "swear-display", "Times New Roman", serif;
}

/* ========================================
   BLOCK: TYPO WEIGHTS (GLOBAL) v1
   Regola:
   - font primary -> 600
   - font display -> 100
======================================== */
#smoothie-home :where(
	h1, h2, h3, h4, h5, h6,
	p, a, li, span, button, label,
	input, textarea, small, strong, em
) {
	font-family: var(--font-primary);
	font-weight: 600 !important;
}

#smoothie-home :where(
	.hero__headline-accent,
	.hero__headline-script,
	.hero__scroll-emphasis
) {
	font-family: var(--font-display);
	font-weight: 100 !important;
}

/* Body copy sections: peso testo a 400 */
#smoothie-home :is(
	.feature__text,
	.oasis__text,
	.prosecco__text,
	.nobo__text
) {
	font-weight: 400 !important;
}
/* /BLOCK: TYPO WEIGHTS (GLOBAL) v1 */

body {
	min-height: 100vh;
	font-family: var(--font-primary);
	background-color: #f2f2f3; /* sfondo unico di pagina */
	color: #111111;
	position: relative; /* per eventuali overlay globali */
}

#smoothie-home {
	overflow-x: clip;
}

@supports not (overflow: clip) {
	#smoothie-home {
		overflow-x: hidden;
	}
}

:is(
	.hero__headline,
	.flavor__headline,
	.feature__headline,
	.oasis__headline,
	.prosecco__headline,
	.nobo__headline,
	.cta-dark__headline,
	.cta__headline,
	.site-footer__title
) {
	color: transparent !important;
	background-image: linear-gradient(90deg, #000000 0%, #4a4a4a 100%) !important;
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}

/* ========================================
   BLOCK: HEADLINE ANTI-CLIPPING (global) v1
   Scopo: prevenire taglio superiore glyph su headline con gradient clip
======================================== */
:is(
	.flavor__headline,
	.feature__headline,
	.prosecco__headline,
	.nobo__headline,
	.cta-dark__headline,
	.cta__headline,
	.site-footer__title
) {
	line-height: 1.1;
	display: block;
	overflow: visible;
	padding-block: 0.04em;
}

#smoothie-home h1.hero__headline {
	line-height: 1.1 !important;
	overflow: visible !important;
	padding-block: 0.04em !important;
}

#smoothie-home h2.flavor__headline {
	line-height: 1.1 !important;
	overflow: visible !important;
	display: block !important;
	padding-block: 0.04em !important;
}

#smoothie-home h2.feature__headline {
	line-height: 1.1 !important;
	overflow: visible !important;
	display: block !important;
	padding-block: 0.04em !important;
}

#smoothie-home h2.prosecco__headline {
	line-height: 1.1 !important;
	overflow: visible !important;
	display: block !important;
	padding-block: 0.04em !important;
}

#smoothie-home h2.nobo__headline {
	line-height: 1.1 !important;
	overflow: visible !important;
	display: block !important;
	padding-block: 0.04em !important;
}

#smoothie-home h2.cta-dark__headline {
	line-height: 1.1 !important;
	overflow: visible !important;
	display: block !important;
	padding-block: 0.04em !important;
}

#smoothie-home h2.cta__headline {
	line-height: 1.1 !important;
	overflow: visible !important;
	display: block !important;
	padding-block: 0.04em !important;
}

#smoothie-home h2.site-footer__title {
	line-height: 1.1 !important;
	overflow: visible !important;
	display: block !important;
	padding-block: 0.04em !important;
}
/* /BLOCK: RESET BASE */


/* ========================================
   BLOCK: SITE HEADER v1
   Descrizione: header fisso con logo + bottone menu
======================================== */

.site-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	padding: 24px 40px;
	z-index: 20;
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.site-header__logo {
	text-decoration: none;
	color: #111111;
}

.site-header__logo span {
	font-size: 1.4rem;
	font-weight: 400 !important;
}

/* Bottone menu hamburger */
.site-header__menu-toggle {
	border: none;
	background: transparent;
	cursor: pointer;
	padding: 8px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

/* Contenitore delle due linee */
.menu-icon {
	display: inline-flex;
	flex-direction: column;
	gap: 6px;
}

/* Le due linee */
.menu-icon__line {
	width: 24px;
	height: 2px;
	background-color: #222222;
	display: block;
}

/* /BLOCK: SITE HEADER v1 */


/* ========================================
   BLOCK: HERO SECTION v1
======================================== */

.hero {
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;

	/* padding più pulito ? niente sbilanciamenti */
	padding: 96px 16px 64px;
}

.hero__inner {
	width: 100%;
	max-width: 1700px;

	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;

	text-align: center;
	position: relative;
}

/* ===============================
   BUBBLE (1.5x + centrata)
================================ */

.hero__bubble {
	position: relative;
	
	width: min(90vw, 860px);
	aspect-ratio: 1 / 1;

	display: flex;
	align-items: center;
	justify-content: center;

	margin: 0 auto;
}

/* Sfera */
.hero__bubble-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 50%;
	display: block;

	transform: translate(0, 0); /* reset esplicito */
	will-change: transform, opacity;
}

/* ===============================
   TESTO (più grande)
================================ */

.hero__headline {
	position: absolute;
	inset: 0;

	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;

	/* più grande */
	font-size: clamp(3.6rem, 4.2vw, 4.7rem);
	line-height: 1.1;
	letter-spacing: -0.015em;
	font-weight: 500 !important;

	padding: 0 32px;
}

.hero__headline-line {
	display: block;
}

.hero__headline-accent,
.hero__headline-script {
	font-style: italic;
}

.hero__headline-accent,
.hero__headline-script,
.hero__scroll-emphasis {
	font-family: var(--font-display);
}

/* ===============================
   SCROLL HINT
================================ */

.hero__scroll {
	position: absolute;
	bottom: -16px;
	left: 50%;
	transform: translateX(-50%);

	font-size: 1.3rem;
	color: #000;
	opacity: 0.9;
	user-select: none;
	font-weight: 500 !important;
}

.hero__scroll-emphasis {
	font-style: italic;

}

/* ===============================
   MOBILE
================================ */

@media (max-width: 520px) {
	.hero__bubble {
		width: 92vw;
	}

	.hero__headline {
		font-size: clamp(1.6rem, 4.8vw, 2.1rem);
		line-height: 1.12;
	}
}

/* ========================================
   BLOCK: FLAVOR SECTION (layout + style)
   File: main.css (o equivalente)
========================================= */

.flavor {
	position: relative;
	min-height: 100vh;
	padding: 0;
	background-color: transparent;
	overflow: hidden;
}

.flavor__inner {
	--flavor-media-y-offset: -2;
	position: relative;
	width: min(1700px, calc(100% - clamp(40px, 6vw, 140px)));
	margin-inline: auto;
	height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
}

.flavor__content {
	position: relative;
	z-index: 2;
	text-align: center;
	max-width: 460px;
}

.flavor__headline {
	font-size: clamp(2.8rem, 3.7vw, 3.8rem);
	line-height: 1.1;
	font-weight: 500 !important;
	color: #222222;
	margin-bottom: 2rem;
}

.flavor__headline-strong {
	font-weight: 600 !important;
}

.flavor__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.65rem 1.6rem;
	border-radius: 999px;
	border: none;
	cursor: pointer;
	font-size: 1.1rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	font-weight: 500 !important;
	color: #ffffff;
	background-image: linear-gradient(
		90deg,
		#ed766f 0%,
		#d0718c 20%,
		#a469ba 42%,
		#8864d6 62%,
		#8097db 82%,
		#89c9ef 100%
	);
	box-shadow: 0 12px 25px rgba(0, 0, 0, 0.16);
	transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
}

.flavor__cta:hover {
	transform: translateY(-2px);
	box-shadow: 0 16px 30px rgba(0, 0, 0, 0.18);
	filter: brightness(1.05);
}

/* ========================================
   POSIZIONAMENTO CARD (Figma ? CSS)
========================================= */

.flavor__media {
	position: absolute;
	left: calc(var(--x, 0) * 1%);
	top: calc((var(--y, 0) + var(--flavor-media-y-offset, 0)) * 1%);
	width: calc(var(--w, 10) * 1%);
	height: calc(var(--h, 10) * 1%);
	margin: 0;
	border-radius: 14px;
	overflow: hidden;
	background-color: transparent;
	box-shadow: none;
	will-change: transform;
}

/* ? Media dentro le card: IMG e VIDEO */
.flavor__media img,
.flavor__media video {
	width: 100%;
	height: 100%;
	display: block;

	/* ? riempie la card: niente "immagine più piccola del wrapper" */
	object-fit: cover;
	border-radius: inherit;
	background-color: transparent;

	/* evita selezione/drag */
	user-select: none;
	-webkit-user-drag: none;
}

/* 1) Top-right */
.flavor__media--top-right {
	--x: 74;
	--y: 14;
	--w: 16;
	--h: 44;
	aspect-ratio: 258 / 462;
	height: auto;
	box-shadow: none;
	background: transparent;
	border-radius: 14px;
}

.flavor__media--top-right .flavor__media-image {
	box-shadow: 0 16px 30px rgba(0, 0, 0, 0.18);
	border-radius: inherit;
	object-fit: cover;
}

.feature__visual-target .flavor__media-image {
	box-shadow: 0 16px 30px rgba(0, 0, 0, 0.18);
	border-radius: 14px;
	object-fit: cover;
}

/* 2) Top-center */
.flavor__media--top-center {
	--x: 31;
	--y: 10;
	--w: 10;
	--h: 18;
}

/* 3) Top-left */
.flavor__media--top-left {
	--x: 6;
	--y: 31;
	--w: 15;
	--h: 29;
}

/* 4) Middle-left */
.flavor__media--middle-left {
	--x: 54;
	--y: 18;
	--w: 8;
	--h: 14;
}

/* 5) Middle-right */
.flavor__media--middle-right {
	--x: 58;
	--y: 66;
	--w: 12;
	--h: 20;
}

/* 6) Bottom-left */
.flavor__media--bottom-left {
	--x: 0;
	--y: 69;
	--w: 24;
	--h: 28;
}

/* 7) Bottom-right */
.flavor__media--bottom-right {
	--x: 81;
	--y: 72;
	--w: 15;
	--h: 27;
}

/* ========================================
   RESPONSIVE
========================================= */

/* Laptop 1280 */
@media (max-width: 1360px) {
	.flavor__media--top-right { --x: 72; --y: 15; --w: 18; --h: 43; }
	.flavor__media--top-center { --x: 29; --y: 11; --w: 11; --h: 18; }
	.flavor__media--top-left { --x: 5; --y: 32; --w: 17; --h: 29; }
	.flavor__media--middle-left { --x: 52; --y: 20; --w: 9; --h: 14; }
	.flavor__media--middle-right { --x: 56; --y: 67; --w: 14; --h: 20; }
	.flavor__media--bottom-left { --x: -2; --y: 70; --w: 27; --h: 27; }
	.flavor__media--bottom-right { --x: 79; --y: 73; --w: 17; --h: 25; }
}

/* Desktop compatto 1080 */
@media (max-width: 1120px) {
	.flavor__inner {
		width: min(1700px, calc(100% - clamp(28px, 4vw, 64px)));
	}

	.flavor__media--top-right { --x: 69; --y: 17; --w: 21; --h: 41; }
	.flavor__media--top-center { --x: 25; --y: 13; --w: 12; --h: 17; }
	.flavor__media--top-left { --x: 3; --y: 34; --w: 19; --h: 28; }
	.flavor__media--middle-left { --x: 48; --y: 23; --w: 10; --h: 13; }
	.flavor__media--middle-right { --x: 53; --y: 69; --w: 16; --h: 19; }
	.flavor__media--bottom-left { --x: -4; --y: 72; --w: 31; --h: 24; }
	.flavor__media--bottom-right { --x: 76; --y: 75; --w: 20; --h: 22; }
}

/* Mobile */
@media (max-width: 767px) {
	.flavor__inner {
		width: calc(100% - 28px);
	}

	.flavor__content {
		max-width: min(82vw, 320px);
	}

	.flavor__headline {
		font-size: clamp(2rem, 8.2vw, 2.8rem);
	}

	.flavor__media--middle-left {
		display: none;
	}

	.flavor__media--top-right { --x: 71; --y: 18; --w: 25; --h: 39; }
	.flavor__media--top-center { --x: 30; --y: 10; --w: 20; --h: 17; }
	.flavor__media--top-left { --x: 2; --y: 33; --w: 30; --h: 27; }
	.flavor__media--middle-right { --x: 53; --y: 63; --w: 29; --h: 19; }
	.flavor__media--bottom-left { --x: -5; --y: 70; --w: 49; --h: 23; }
	.flavor__media--bottom-right { --x: 72; --y: 72; --w: 23; --h: 24; }
}

/* /BLOCK: FLAVOR SECTION (layout + style) */


/* ========================================
   BLOCK: FLAVOR ? FEATURE SCENE (layout) v2
   Descrizione:
   - #flavor e #feature vivono nello stesso viewport dentro un wrapper pinned
   - #feature è hidden di default (evita “rettangolo statico” visibile sotto)
========================================= */

.flavor-feature-scene {
	position: relative;
	min-height: 100vh;
	overflow: hidden;
	background: transparent;
}

/* Le due section ora sono "pagine" sovrapposte nel wrapper */
.flavor-feature-scene #flavor,
.flavor-feature-scene #feature {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	min-height: 100vh;
}

/* Flavor sopra all'inizio */
.flavor-feature-scene #flavor { z-index: 2; }
.flavor-feature-scene #feature { z-index: 1; }

/* ? IMPORTANT: la feature NON deve vedersi prima dello swap */
.flavor-feature-scene #feature {
	opacity: 0;
	visibility: hidden;
}

/* /BLOCK: FLAVOR ? FEATURE SCENE (layout) v2 */

/* ========================================
   BLOCK: FEATURE SECTION (layout) v4
   Descrizione:
   - Media non clippato (img/video sempre visibile interamente)
   - Nessun border-radius / shadow
========================================= */

.feature {
	position: relative;
	min-height: 100vh;
	overflow: hidden;
	background-color: transparent;
}

.feature__clone-layer {
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: 25;
}

.feature__inner {
	position: relative;
	max-width: 1700px;
	margin-inline: auto;
	height: 100vh;
	display: flex;
	align-items: center;
	padding: 0 8px;
}

.feature__stage {
	width: 100%;
	display: grid;
	grid-template-columns: 1fr 1fr;
	align-items: center;
	column-gap: 80px;
}

.feature__visual {
	display: flex;
	justify-content: flex-start;
}

/* ?? niente clipping */
.feature__visual-target {
	width: min(640px, 48vw);
	aspect-ratio: 258 / 462;
	border-radius: 0;
	overflow: visible;       /* ? come Flavor */
	background: transparent;
	box-shadow: none;
	margin: 0;
}

/* ? img e video: stessi identici comportamenti di Flavor */
.feature__visual-target img,
.feature__visual-target video {
	width: 100%;
	height: 100%;
	display: block;

	object-fit: contain;     /* ? mostra tutto */
	object-position: center;

	user-select: none;
	-webkit-user-drag: none;
}

/* hidden by default (reveal via GSAP) */
.feature__visual-image {
	opacity: 0;
	visibility: hidden;
}

.feature__content {
	max-width: 520px;
	opacity: 0;
	visibility: hidden;
	transform: translateY(16px);
}

.feature__headline {
	margin: 0 0 28px;
	font-size: clamp(3rem, 4.3vw, 3.8rem);
	line-height: 1.02;
	font-weight: 500 !important;
	color: #111111;
}

.feature__text {
	margin: 3.5em 0 -3.5em;
	font-size: 1.4rem;
	line-height: 1.2;
	color: #000000;
	max-width: 46ch;
}

.feature__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.7rem 1.9rem;
	border-radius: 999px;
	border: none;
	cursor: pointer;
	font-size: 0.9rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	font-weight: 500 !important;
	color: #ffffff;
	background-image: linear-gradient(90deg, #f48bb8, #7f8bff);
	box-shadow: 0 12px 25px rgba(0, 0, 0, 0.16);
}

/* /BLOCK: FEATURE SECTION (layout) v4 */



/* ========================================
   BLOCK: SECTION #4 (OASIS) v1 (layout)
========================================= */
.oasis {
	position: relative;
	min-height: 100vh;
	padding: clamp(32px, 6vh, 64px) 0;
	background: transparent;
	display: flex;
	align-items: center;
}

.oasis__inner {
	width: min(1700px, calc(100% - clamp(64px, 8vw, 180px)));
	height: 100%;
	margin: 0 auto;
}

.oasis__grid {
	--oasis-media-shift-x: clamp(64px, 8vw, 120px);
	display: grid;
	grid-template-columns: 1.05fr 0.95fr;
	align-items: center;
	gap: clamp(16px, 3.2vw, 40px);
	min-height: 100%;
}

.oasis__content {
	max-width: 640px;
}

.oasis__headline {
	margin: 0 0 18px;
	font-size: clamp(52px, 4.6vw, 76px);
	line-height: 1.1;
	letter-spacing: -0.02em;
	font-weight: 600 !important;
	color: #111;
	display: block;
	overflow: visible;
	padding-block: 0.04em;
}

/* Hard override: previene clipping se il parent forza metriche headline. */
#smoothie-home h2.oasis__headline {
	line-height: 1.1 !important;
	overflow: visible !important;
	display: block !important;
	padding-block: 0.04em !important;
}

.oasis__text {
	margin: 3.5em 0 -3.5em;
	font-size: 20px;
	line-height: 1.6;
	color: #000000;
	max-width: 600px;
}

/* ---- Collage media ---- */
.oasis__media {
	position: relative;
	min-height: clamp(420px, 42vw, 560px);
	transform: translateX(calc(-1 * var(--oasis-media-shift-x)));
}

.oasis__card {
	position: absolute;
	overflow: hidden;
	border-radius: 10px;
	background: #f2f2f2;
	transform: translateZ(0);
}

.oasis__img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
}

.oasis__img--round {
	transform: none;
	object-position: center;
}

/* Geometrie simili alla reference */
.oasis__card--hero {
	left: 20%;
	top: 8%;
	width: clamp(280px, 28vw, 440px);
	height: clamp(360px, 32vw, 520px);
}

.oasis__card--small-vert {
	top: 45%;
	left: -7%;
	width: clamp(120px, 12vw, 200px);
	height: clamp(230px, 22vw, 340px);
}

.oasis__card--round {
	right: -13%;
	top: 40%;
	width: clamp(120px, 12vw, 200px);
	height: clamp(120px, 12vw, 200px);
	border-radius: 10px;
}

/* Desktop 1080p class (FHD and similar) */
@media (min-width: 861px) and (max-width: 2199px) {
	.oasis__inner {
		width: min(1700px, calc(100% - clamp(56px, 7vw, 160px)));
	}

	.oasis__grid {
		--oasis-media-shift-x: clamp(72px, 12vw, 250px);
		gap: clamp(12px, 2.4vw, 22px);
	}

	.oasis__headline {
		font-size: clamp(42px, 4.2vw, 64px);
	}

	.oasis__text {
		font-size: 18px;
		max-width: 520px;
	}

	.oasis__media {
		min-height: clamp(360px, 36vw, 480px);
	}

	.oasis__card--hero {
		left: 20%;
		top: 8%;
		width: clamp(240px, 24vw, 380px);
		height: clamp(310px, 28vw, 460px);
	}

	.oasis__card--small-vert {
		top: 50%;
		left: -3%;
		width: clamp(100px, 10vw, 170px);
		height: clamp(190px, 18vw, 290px);
	}

	.oasis__card--round {
		right: -1%;
		top: 40%;
		width: clamp(100px, 10vw, 170px);
		height: clamp(100px, 10vw, 170px);
	}
}

/* Mobile */
@media (max-width: 860px) {
	.oasis__grid {
		--oasis-media-shift-x: 20px;
		grid-template-columns: 1fr;
	}
	.oasis__content {
		max-width: 640px;
	}
	.oasis__media {
		min-height: 360px;
	}
	.oasis__card--hero {
		left: 52%;
	}
	.oasis__card--round {
		top: 12%;
		right: -14%;
	}
	.oasis__card--small-vert {
		left: -10%;
		top: 48%;
	}
}

/* ========================================
   BLOCK: SECTION #5 (PROSECCO) v1 (layout)
========================================= */
.prosecco {
	position: relative;
	background: transparent;
	min-height: 100vh;
	--prosecco-pad-top: clamp(92px, 11vh, 136px);
	--prosecco-pad-bottom: clamp(34px, 6vh, 72px);
	padding: var(--prosecco-pad-top) 0 var(--prosecco-pad-bottom);
	display: flex;
	align-items: center;
}

.prosecco__inner {
	width: min(1700px, calc(100% - clamp(64px, 8vw, 180px)));
	margin: 0 auto;
	min-height: calc(100vh - var(--prosecco-pad-top) - var(--prosecco-pad-bottom));
	display: grid;
	grid-template-rows: auto auto;
	gap: clamp(32px, 5vh, 60px);
	align-content: center;
}

.prosecco__top {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(24px, 4vw, 64px);
	align-items: center;
	margin-bottom: 0;
}

.prosecco__headline {
	margin: 0;
	font-size: clamp(42px, 3.9vw, 64px);
	line-height: 1.02;
	letter-spacing: -0.02em;
	font-weight: 500 !important;
	color: #111;
}

.prosecco__headline-strong {
	display: inline;
	font-weight: 700 !important;
}

.prosecco__text {
	margin: 0;
	max-width: clamp(480px, 40vw, 640px);
	font-size: clamp(18px, 1.05vw, 20px);
	line-height: 1.45;
	color: rgba(17, 17, 17, 0.86);
}

/* Marquee */
.prosecco__marquee {
	position: relative;
	overflow: hidden;
	width: 100%;
	align-self: start;
	padding-bottom: clamp(6px, 1.4vh, 18px);
}

.prosecco__track {
	display: flex;
	align-items: center;
	gap: clamp(4px, 0.35vw, 6px);
	width: max-content;
	will-change: transform;
	transform: translate3d(0, 0, 0);
}

.prosecco__item {
	--item-w: clamp(130px, 11.5vw, 200px);
	--item-h: clamp(160px, 14.5vw, 230px);
	flex: 0 0 auto;
	width: var(--item-w);
	height: var(--item-h);
	border-radius: 10px;
	overflow: hidden;
	background: #eaeaea;
	transform: translateZ(0);
}

.prosecco__item:nth-child(odd) {
	--item-w: clamp(120px, 10vw, 175px);
	--item-h: clamp(190px, 16.5vw, 280px);
}

.prosecco__item:nth-child(even) {
	--item-w: clamp(130px, 12vw, 205px);
	--item-h: clamp(130px, 12vw, 205px);
}

.prosecco__img {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
}

/* Mobile */
@media (max-width: 860px) {
	.prosecco {
		--prosecco-pad-top: clamp(84px, 12vh, 110px);
		--prosecco-pad-bottom: clamp(26px, 5vh, 48px);
		min-height: auto;
	}
	.prosecco__inner {
		min-height: auto;
		grid-template-rows: auto auto;
		gap: clamp(24px, 5vh, 36px);
	}
	.prosecco__top {
		grid-template-columns: 1fr;
		gap: clamp(20px, 4vh, 28px);
	}
	.prosecco__headline {
		font-size: clamp(38px, 10.2vw, 54px);
	}
	.prosecco__text {
		max-width: 100%;
		font-size: clamp(14px, 3.2vw, 18px);
		line-height: 1.45;
	}
	.prosecco__track {
		gap: 6px;
	}
	.prosecco__item:nth-child(odd) {
		--item-w: clamp(118px, 30vw, 160px);
		--item-h: clamp(170px, 42vw, 240px);
	}
	.prosecco__item:nth-child(even) {
		--item-w: clamp(116px, 30vw, 168px);
		--item-h: clamp(116px, 30vw, 168px);
	}
}

/* ========================================
   BLOCK: SECTION #6 (STUDIO NOBO) FINAL (layout)
========================================= */
.nobo {
	position: relative;
	padding: clamp(140px, 18vh, 260px) 0;
	background: transparent;
	text-align: center;
}

.nobo__inner {
	width: min(1700px, calc(100% - 8px));
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.nobo__headline {
	margin: 0 0 clamp(56px, 6vh, 88px);
	font-size: clamp(44px, 4.4vw, 76px);
	line-height: 1.05;
	letter-spacing: -0.03em;
	font-weight: 500 !important;
	color: #111;
}

.nobo__panel {
	width: 100%;
	max-width: 1040px;
	aspect-ratio: 16 / 9;
	background: transparent;
	overflow: hidden;
	border-radius: 18px;
	margin-bottom: clamp(44px, 5vh, 72px);
}

.nobo__video {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;

	/* IMPORTANT: nessun forcing GPU */
	transform: none;
	will-change: auto;
	backface-visibility: visible;
}

.nobo__text {
	max-width: 760px;
	margin: 0;
	font-size: clamp(18px, 1.3vw, 21px);
	line-height: 1.7;
	color: #000000;
}

/* Mobile */
@media (max-width: 768px) {
	.nobo {
		padding: clamp(96px, 14vh, 160px) 0;
	}

	.nobo__headline {
		margin-bottom: 40px;
		font-size: clamp(32px, 7.6vw, 48px);
	}

	.nobo__panel {
		aspect-ratio: 16 / 9;
		border-radius: 14px;
		margin-bottom: 32px;
	}

	.nobo__text {
		font-size: 18px;
		line-height: 1.75;
	}
}

/* Assicura che i contenuti stiano sopra l’overlay */
/*.site-header,
main,
.site-menu {
	position: relative;
	z-index: 1;
}*/

/* ========================================
   BLOCK: GLOBAL BACKGROUND OVERLAY v1
========================================= */
.bg-overlay {
	position: fixed;
	inset: 0;
	background: #000;
	opacity: 0;
	pointer-events: none;
	z-index: 0; /* sotto i contenuti */
}

/* ========================================
   BLOCK: SECTION (CTA DARK TRIGGER) v1 (layout)
========================================= */
.cta-dark {
	position: relative;
	padding: clamp(120px, 18vh, 220px) 0;
	background: transparent; /* IMPORTANT: non è nera di suo */
	text-align: center;
}

.cta-dark__inner {
	width: min(1600px, calc(100% - 8px));
	margin: 0 auto;
	display: grid;
	gap: 22px;
	justify-items: center;
}

.cta-dark__headline {
	margin: 0;
	font-size: clamp(34px, 4vw, 56px);
	line-height: 1.05;
	letter-spacing: -0.02em;
	font-weight: 500 !important;
	color: #ffffff !important;
	background-image: none !important;
	-webkit-background-clip: initial !important;
	background-clip: initial !important;
	-webkit-text-fill-color: #ffffff !important;
}

/* Bottone “pill” bicolore */
.cta-dark__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 34px;
	padding: 0 16px;
	border-radius: 999px;
	text-decoration: none;
	font-size: 12px;
	letter-spacing: 0.02em;
	color: #ffffff;
	background-image: linear-gradient(
		90deg,
		#ed766f 0%,
		#d0718c 20%,
		#a469ba 42%,
		#8864d6 62%,
		#8097db 82%,
		#89c9ef 100%
	);
}

/* Hover leggero (opzionale) */
.cta-dark__cta:hover {
	transform: translateY(-1px);
}

/* ========================================
   BLOCK: SECTION #7 (CLIENTS) v2 (layout)
========================================= */
.clients {
	position: relative;
	padding: clamp(36px, 6vh, 72px) 0;
	background: transparent; /* IMPORTANTE: nessuno sfondo */
}

.clients__inner {
	width: min(1700px, calc(100% - 8px));
	margin: 0 auto;
	text-align: center;
}

.clients__label {
	display: inline-block;
	margin-bottom: 18px;
	padding: 8px 20px;
	border: 1px solid rgba(17, 17, 17, 0.25);
	border-radius: 999px;
	font-size: clamp(12px, 2vw, 15px);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: #000;
}

.clients__intro {
	margin: 0 0 56px;
	font-size: clamp(16px, 2.1vw, 20px);
	line-height: 1.4;
	color: #111;
}

/* Marquee */
.clients__marquee {
	position: relative;
	overflow: hidden;
	width: 100%;
	/* niente sfondi, niente maschere: pulito */
}

.clients__track {
	display: flex;
	align-items: center;
	gap: clamp(12px, 1.4vw, 24px);
	width: max-content;
	will-change: transform;
	transform: translate3d(0, 0, 0);
	padding: 6px 0;
}

.clients__item {
	flex: 0 0 auto;
	width: clamp(190px, 14vw, 280px);
	height: clamp(130px, 10vw, 210px);
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	margin: 0;
	padding: 0;
	line-height: 0;
	overflow: visible;
}

.clients__logo {
	display: block !important;
	width: auto !important;
	height: auto !important;
	max-width: 100% !important;
	max-height: 100% !important;
	object-fit: contain !important;
	object-position: center !important;
	margin: auto !important;
	border-radius: 0 !important;
	opacity: 0.9;
}

/* Mobile: resta 1 riga, solo gap/altezza già clampati */
@media (max-width: 520px) {
	.clients__inner {
		width: min(1700px, calc(100% - 8px));
	}
}

/* ========================================
   BLOCK: SPHERE STAGE (GLOBAL) (container) v3
========================================= */
.sphere-stage {
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: 20;
	overflow: hidden;
	overflow: clip;

	/* default OFF: la sfera si accende solo durante la sequenza */
	opacity: 0;
	visibility: hidden;
}

.sphere-stage__inner {
	position: absolute;
	inset: 0;
}

/* ========================================
   BLOCK: SPHERE STAGE (GLOBAL) (layout) v3
   Update:
   - sfera più in alto in Section A (posizione iniziale)
========================================= */
.sphere-stage__svg {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, 8%) scale(1); /* Section A: sfera leggermente più in alto */
	transform-origin: 50% 50%;
	width: min(1600px, 160vw);
	height: auto;
	will-change: transform;
}

/* Evita overflow orizzontale su desktop FHD e simili */
@media (max-width: 1600px) {
	.sphere-stage__svg {
		width: min(1400px, 132vw);
	}
}

.sphere-stage__rotor {
	width: 100%;
	height: auto;
	transform-origin: 50% 50%;
	will-change: transform;
	transform-box: fill-box;
}

.sphere-stage__rotor svg {
	display: block;
	width: 100%;
	height: auto;
}

/* ========================================
   BLOCK: SECTION A (WHAT WE DO / KEYWORDS) (layout) v2
   Update:
   - testo (words) più in alto
   - pill più in basso
========================================= */
.what-we-do {
	position: relative;
	min-height: 100vh;
	background: transparent;
	z-index: 10; /* deve stare sotto la sfera (z-index 20) */
}

.what-we-do__inner {
	min-height: 100vh;
	display: grid;
	place-items: center;
	padding: 10vh 6vw 18vh; /* + bottom padding per "respiro" */
	text-align: center;
}

.what-we-do__pill {
	position: absolute;
	top: 12vh; /* era 8vh -> più GIU' */
	left: 50%;
	transform: translateX(-50%);
	padding: 6px 14px;
	border: 1px solid rgba(0,0,0,0.35);
	border-radius: 999px;
	font-size: 12px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	background: rgba(242,242,242,0.6);
	backdrop-filter: blur(4px);
}

.what-we-do__words {
	margin: 0;
	font-size: clamp(40px, 6vw, 86px);
	line-height: 1;
	letter-spacing: 0.02em;
	color: #111;
	background-image: none !important;
	-webkit-text-fill-color: currentColor;
	overflow: visible;
	padding-block: 0.08em;

	/* >>> testo più in alto */
	transform: translateY(-9vh);
}

.what-we-do__word {
	display: block !important;
	opacity: 0;
	font-weight: 700;
	line-height: 1;
	padding-block: 0.04em;
	overflow: visible !important;
	will-change: auto;
	color: #111111;
	-webkit-text-fill-color: currentColor;
}

/* Hard override: annulla qualunque display/line-height del parent theme su h2 span. */
#smoothie-home h2.what-we-do__words {
	line-height: 1 !important;
	overflow: visible !important;
}

#smoothie-home h2.what-we-do__words > .what-we-do__word {
	display: block !important;
	width: auto !important;
	line-height: 1 !important;
	overflow: visible !important;
}

@supports ((-webkit-background-clip: text) or (background-clip: text)) {
	.what-we-do__word {
		color: transparent;
		background-image: linear-gradient(90deg, #000000 0%, #4a4a4a 100%);
		-webkit-background-clip: text;
		background-clip: text;
		-webkit-text-fill-color: transparent;
	}
}


/* ========================================
   BLOCK: SECTION B (MISSION) (layout) v6
========================================= */
.mission {
	position: relative;
	min-height: 100vh;
	background: transparent; /* non deve coprire la sfera */

	/* Mission sopra la sfera (sphere-stage è z-index:20) */
	z-index: 30;
}

.mission__inner {
	position: relative;
	z-index: 1;

	min-height: 100vh;
	display: grid;
	place-content: center;
	justify-items: center;

	padding: 8vh 6vw;
	transform: translateY(-4vh);

	text-align: center;
}

.mission__pill {
	display: inline-block;
	margin-bottom: 18px;
	padding: 6px 14px;

	/* stile richiesto: solo bianco, niente background */
	background: transparent;
	border: 1px solid rgba(255,255,255,0.65);
	color: #fff;

	border-radius: 999px;
	font-size: 12px;
	letter-spacing: 0.08em;
	text-transform: uppercase;

	opacity: 0;
	transform: translateY(14px);
	will-change: transform, opacity;
}

.mission__headline {
	margin: 0;

	/* per ora lasciamo bianco come da stile Mission */
	color: #fff;

	font-size: clamp(26px, 4.2vw, 56px);
	line-height: 1.05;
	letter-spacing: -0.01em;

	opacity: 0;
	transform: translateY(14px);
	will-change: transform, opacity;
}

/* ========================================
   BLOCK: SECTION C (CTA) (layout) v2
========================================= */
.cta {
	position: relative;
	min-height: 100vh;

	/* non deve coprire la sfera */
	background: transparent;

	/* IMPORTANT: CTA sopra la sfera (sphere-stage è z-index:20) */
	z-index: 10;
}

.cta__inner {
	position: relative;
	z-index: 1;

	min-height: 100vh;
	display: grid;

	/* centra il gruppo headline+button come blocco */
	place-content: center;
	justify-items: center;

	/* spazi simili a Mission */
	padding: 8vh 6vw;
	transform: none;

	gap: 36px;
	text-align: center;
}

.cta__headline {
	margin: 0;
	color: #111;
	font-size: clamp(34px, 5.2vw, 74px);
	line-height: 0.95;
	letter-spacing: -0.02em;
	opacity: 1;
	transform: none;
	will-change: auto;
}

.cta__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 34px;
	padding: 0 18px;
	border-radius: 999px;
	background-image: linear-gradient(
		90deg,
		#ed766f 0%,
		#d0718c 20%,
		#a469ba 42%,
		#8864d6 62%,
		#8097db 82%,
		#89c9ef 100%
	);
	color: #fff;
	font-size: 12px;
	text-decoration: none;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	opacity: 0;
	transform: translateY(10px);
	will-change: transform, opacity;
}

/* ========================================
   BLOCK: FOOTER (LET'S TALK) (layout) v3
   Fix:
   - footer sopra la CTA per essere cliccabile durante reveal
========================================= */

.site-footer {
	position: relative;  /* <<< necessario per z-index */
	z-index: 50;         /* <<< sopra .cta (30) */
	color: #0b0b0b;
	padding: clamp(28px, 4vw, 56px) 0 18px;

	/* opzionale ma consigliato: layer solido per click + leggibilità */
	/*background: #f2f2f2;*/
}

.site-footer__inner {
	width: min(1700px, calc(100% - 8px));
	margin: 0 auto;
}

.site-footer__top {
	display: grid;
	grid-template-columns: 1.2fr 0.8fr;
	gap: clamp(22px, 3vw, 56px);
	align-items: start;
}

.site-footer__title {
	margin: 0;
	font-size: clamp(44px, 6vw, 86px);
	line-height: 0.95;
	letter-spacing: -0.03em;
	font-weight: 500 !important;
}

.site-footer__subtitle {
	margin: 10px 0 18px;
	font-size: 16px;
	line-height: 1.4;
	color: #1b1b1b;
}

.site-footer__newsletter {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
}

.site-footer__input {
	width: min(320px, 70vw);
	height: 44px;
	padding: 0 16px;
	border-radius: 999px;
	border: 1px solid #0b0b0b;
	background: #0b0b0b;
	color: #ffffff;
	outline: none;
}

.site-footer__input::placeholder {
	color: rgba(255, 255, 255, 0.75);
}

.site-footer__btn {
	height: 44px;
	padding: 0 18px;
	border-radius: 999px;
	border: 1px solid #0b0b0b;
	background: transparent;
	color: #0b0b0b;
	cursor: pointer;
	white-space: nowrap;
}

.site-footer__btn:hover {
	background: rgba(0, 0, 0, 0.06);
}

.site-footer__right {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(18px, 2vw, 44px);
	justify-content: end;
}

.site-footer__office-title {
	margin: 0 0 10px;
	font-size: 18px;
	font-weight: 600 !important;
}

.site-footer__office-text {
	margin: 0 0 8px;
	font-size: 14px;
	line-height: 1.45;
	color: #1b1b1b;
}

.site-footer__email {
	margin-top: clamp(18px, 2.5vw, 28px);
}

.site-footer__email-link {
	color: #0b0b0b;
	text-decoration: underline;
	text-underline-offset: 4px;
	font-size: 14px;
}

.site-footer__bottom {
	margin-top: clamp(18px, 2.5vw, 28px);
	padding-top: 14px;
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 12px;
}

.site-footer__backtop,
.site-footer__follow {
	color: #0b0b0b;
	text-decoration: none;
	font-size: 14px;
}

.site-footer__backtop:hover,
.site-footer__follow:hover {
	text-decoration: underline;
	text-underline-offset: 4px;
}

.site-footer__follow {
	justify-self: end;
}

.site-footer__copy {
	text-align: center;
	font-size: 13px;
	color: rgba(0, 0, 0, 0.42);
}

.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

@media (max-width: 860px) {
	.site-footer__top { grid-template-columns: 1fr; }
	.site-footer__right { grid-template-columns: 1fr 1fr; }
	.site-footer__bottom { grid-template-columns: 1fr; text-align: left; }
	.site-footer__follow { justify-self: start; }
	.site-footer__copy { text-align: left; }
}

@media (max-width: 520px) {
	.site-footer__right { grid-template-columns: 1fr; }
	.site-footer__input,
	.site-footer__btn { width: 100%; }
	.site-footer__newsletter { width: 100%; }
}

/* ========================================
   /BLOCK: FOOTER (LET'S TALK) (layout) v3
========================================= */

/*Aggiungi qui nuove sections*/

/* ========================================
   BLOCK: OFF-CANVAS MENU v1
   Descrizione: overlay + pannello laterale destro
======================================== */

.site-menu {
	position: fixed;
	inset: 0;
	pointer-events: none;           /* chiuso di default */
	z-index: 30;
	background: rgba(0, 0, 0, 0);   /* overlay trasparente */
	transition: background 0.3s ease;
	overflow: hidden;
	overflow: clip;
}

.site-menu__panel {
	position: absolute;
	top: 24px;
	right: 0;
	width: min(420px, 100%);
	height: calc(100% - 48px);
	background: #ffffff;
	backdrop-filter: blur(20px);
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
	border: 1px solid rgba(0, 0, 0, 0.2);
	border-radius: 18px 0 0 18px;
	padding: 28px 32px 36px;
	transform: translateX(100%);    /* nascosto a destra */
	transition: transform 0.4s ease;

	display: flex;
	flex-direction: column;
}

.site-menu__panel::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: 18px 0 0 18px;
	pointer-events: none;
}

/* Stato APERTO: classe che aggiunge il JS */
.site-menu--open {
	pointer-events: auto;
	background: rgba(0, 0, 0, 0.18);   /* overlay scuro */
}

.site-menu--open .site-menu__panel {
	transform: translateX(0);          /* pannello visibile */
}

/* bottone chiudi */
.site-menu__close {
	position: absolute;
	top: 18px;
	right: 18px;
	border: none;
	background: transparent;
	cursor: pointer;
	font-size: 0;
	line-height: 1;
}

.site-menu__close-icon {
	display: inline-block;
	position: relative;
	width: 24px;
	height: 24px;
}

.site-menu__close-icon::before,
.site-menu__close-icon::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 22px;
	height: 1px;
	background: #111111;
	transform-origin: center;
}

.site-menu__close-icon::before {
	transform: translate(-50%, -50%) rotate(45deg);
}

.site-menu__close-icon::after {
	transform: translate(-50%, -50%) rotate(-45deg);
}

/* lista link */
.site-menu__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 12px;
	flex: 1;
	justify-content: center; /* centrati in altezza */
	padding-top: 16px; /* lieve spinta verso il basso */
}

.site-menu__item + .site-menu__item {
	margin-top: 0;
}

.site-menu__link {
	text-decoration: none;
	color: #111111;
	font-size: 2rem;
	letter-spacing: 0.02em;
	line-height: 1.1;
	font-weight: 600 !important;
	transition: color 0.2s ease, background-position 0.35s ease;
}

.site-menu__link--current {
	font-weight: 600 !important;
}

/* Hover gradient for links (exclude "Follow us" because it's not a link) */
.site-menu__link:hover,
.site-menu__link:focus-visible,
.site-menu__social-link:hover,
.site-menu__social-link:focus-visible {
	background-image: linear-gradient(90deg, #ff7aa8 0%, #8b7bff 55%, #7fd7ff 100%);
	background-size: 200% 100%;
	background-position: 0 50%;
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	animation: site-menu-gradient-shift 1.6s ease-in-out infinite;
}

@keyframes site-menu-gradient-shift {
	0% { background-position: 0% 50%; }
	50% { background-position: 100% 50%; }
	100% { background-position: 0% 50%; }
}

/* social */
.site-menu__social-title {
	margin: 0 0 8px;
	font-size: 0.9rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.site-menu__social {
	margin-top: auto; /* attacca i social al fondo del pannello */
}

.site-menu__social-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

/* qui il margine tra i link lo puoi meglio dare ai <li>, ma lascio la tua struttura */
.site-menu__social-link {
	text-decoration: none;
	color: #222222;
	font-size: 0.95rem;
}

/* /BLOCK: OFF-CANVAS MENU v1 */


/* ========================================
   BLOCK: RESPONSIVE BASE v1
   Descrizione: aggiustamenti per viewport >= 768px
======================================== */

@media (min-width: 768px) {
	.site-header {
		padding-inline: 56px;
	}

	.hero {
		padding-top: 96px;
	}

	.hero__headline {
		font-size: clamp(3.6rem, 4.2vw, 4.7rem);
	}
}

/* /BLOCK: RESPONSIVE BASE v1 */
img {
	border-radius: 6px;
}

/* 1) FOOTER: il parent impone height fisso (120px) e taglia tutto */
/*#smoothie-home footer,
    #smoothie-home .footer {
    height: auto !important;
    min-height: 0 !important;
    }*/

/* Se il parent usa anche line-height/padding strani e senti ancora “taglio”,
   spesso è perché c'è overflow hidden sul footer o su un wrapper */
/*#smoothie-home footer,
#smoothie-home .footer {
  overflow: visible !important;
}*/

/* FIX display: table SOLO sulle heading Smoothie che ti interessano */
#smoothie-home .cta__headline span,
#smoothie-home .hero__headline span,
#smoothie-home .flavor__headline-strong{
	display: inline !important;  /* oppure inline-block, vedi sotto */
	width: auto !important;
}

/* Se usi spans come "righe" (es. due righe controllate), puoi usare inline-block:
#smoothie-home h1 span,
#smoothie-home h2 span { display: inline-block !important; }
*/





/* ========================================
   BLOCK: SMOOTHIE WP OVERRIDES (parent theme fixes) v3
   Dove: in fondo a assets/css/home.css
========================================= */

/* 0) FOOTER: parent impone height e text-align */
#smoothie-home footer,
#smoothie-home .footer {
	height: auto !important;        /* annulla height:120px */
	min-height: 0 !important;
	overflow: visible !important;   /* evita tagli */
	text-align: left !important;    /* <— cambia in center se vuoi davvero center */
}

/* Se dentro il footer vuoi parti centrate, fallo tu mirato:
#smoothie-home footer .footer__inner { text-align: center; }
*/

/* 1) h2: il parent forza font-weight:500 su tutti gli h2 */
#smoothie-home h2 {
	/*font-weight: inherit !important;*/ /* oppure metti un valore tuo: 400/600 ecc */
}

/* 2) h2 span: il parent forza display: table (rompe wrapping/allineamenti) */
#smoothie-home h2 span {
	/*display: inherit !important;*/      /* oppure inline-block se ti serve */
	width: auto !important;
}

/* 3) uppercase-text h2: line-height fisso 110% (spesso sballa box e baseline) */
#smoothie-home .uppercase-text h2 {
	line-height: inherit !important; /* oppure una tua: 1.05 / 1.1 / 1.2 */
}
