/* FP Salient Theme — ritocchi minimi non esprimibili in theme.json. */

/* Focus visibile coerente col brand. */
:where(a, button, input, select, textarea, .wp-block-button__link):focus-visible {
	outline: 2px solid var(--wp--preset--color--gold);
	outline-offset: 2px;
}

/* Template FP Canvas: contenuto edge-to-edge, nessun padding di root.
   I componenti FP Salient Kit gestiscono internamente full-bleed e nav/footer.
   Il <main> è già alignfull (rompe il root padding); qui azzeriamo anche il
   padding del wrapper per non lasciare margini su hosting che non applicano
   il meccanismo alignfull, e togliamo eventuale block-gap del main. */
.page-template-page-canvas .wp-site-blocks,
.page-canvas .wp-site-blocks {
	padding-left: 0;
	padding-right: 0;
}

.page-template-page-canvas main.alignfull,
.page-canvas main.alignfull {
	margin-top: 0;
	margin-bottom: 0;
}

/* Immagini fluide di default. */
img {
	max-width: 100%;
	height: auto;
}

/* Tabelle core allineate al look FP: intestazione su accent, bordi su line.
   (Le celle non sono pilotabili da theme.json → qui.) */
.wp-block-table table {
	border-collapse: collapse;
	width: 100%;
}

.wp-block-table th,
.wp-block-table td {
	border: 1px solid var(--wp--preset--color--line);
	padding: var(--wp--preset--spacing--30) var(--wp--preset--spacing--40);
	text-align: left;
}

.wp-block-table thead th {
	background: var(--wp--preset--color--accent);
	color: var(--wp--preset--color--base);
	font-weight: 700;
}

.wp-block-table tbody tr:nth-child(even) td {
	background: var(--wp--preset--color--surface);
}

/* Citazione: l'attribuzione (cite) in muted, non corsivo. */
.wp-block-quote cite,
.wp-block-pullquote cite {
	display: block;
	margin-top: var(--wp--preset--spacing--20);
	font-style: normal;
	font-size: var(--wp--preset--font-size--small);
	color: var(--wp--preset--color--muted);
}

/* ==========================================================================
   Header — visiera "social · logo · hamburger", sticky (parità Salient).
   ========================================================================== */
.fpst-header {
	border-bottom: 1px solid var(--wp--preset--color--line);
	background: var(--wp--preset--color--base);
}

/* Auto-hide (headroom): l'header resta in cima, si nasconde scrollando giù e
   riappare scrollando su. Lo sticky va sul WRAPPER del template-part: il gruppo
   interno .fpst-header non ha spazio per "stickare" (il suo contenitore è alto
   quanto lui) — era il motivo per cui prima spariva e basta.
   La classe .fpst-header--hidden è gestita da reveal.js sullo scroll.
   GOTCHA overlay: un transform sull'header crea un containing-block per i
   discendenti position:fixed → l'overlay menu si ancorerebbe all'header invece
   che al viewport. Con menu aperto :has() forza transform:none così l'overlay
   torna full-screen. Niente will-change:transform (creerebbe lo stesso problema
   in modo permanente). */
.wp-site-blocks > header.wp-block-template-part {
	position: sticky;
	top: 0;
	z-index: 100;
	transition: transform 0.35s ease;
}
.wp-site-blocks > header.wp-block-template-part.fpst-header--hidden {
	transform: translateY(-100%);
}
.wp-site-blocks > header.wp-block-template-part:has(.fpst-nav-toggle:checked) {
	transform: none;
}

/* Griglia a 3 colonne: logo perfettamente centrato, social a sx, nav a dx. */
.fpst-header__bar {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: var(--wp--preset--spacing--40);
	width: 100%;
}

.fpst-header__social {
	justify-self: start;
	margin: 0;
	gap: 0.6rem;
}
.fpst-header__social .wp-social-link {
	color: var(--wp--preset--color--ink);
	opacity: 0.85;
	transition: opacity 0.15s ease, color 0.15s ease;
}
.fpst-header__social .wp-social-link:hover {
	opacity: 1;
	color: var(--wp--preset--color--gold);
}

.fpst-header__logo {
	justify-self: center;
	margin: 0;
}
.fpst-header__logo a,
.fpst-header__logo img {
	display: block;
}
.fpst-header__logo img {
	max-height: 56px;
	width: auto;
}

/* === Azioni header (switcher lingua + hamburger), cella destra della griglia === */
.fpst-header__actions {
	justify-self: end;
	display: flex;
	align-items: center;
	gap: 1.1rem;
}
/* Switcher lingua FP-Multilanguage reso compatto e on-brand nell'header.
   Sovrascrive frontend.css del plugin (pill blu #2271b1) con selettori più specifici. */
.fpst-header__actions .fpml-switcher { font-family: inherit; font-size: 0.82rem; line-height: 1; }
.fpst-header__actions .fpml-switcher--inline { gap: 0.15rem; }
.fpst-header__actions .fpml-switcher__item {
	color: #5f5a55; /* muted caldo, contrasto AA (~6:1) su sfondo chiaro */
	opacity: 1;
	background: none;
	border: 0;
	border-radius: 0;
	padding: 0.15rem 0.35rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	transition: color 0.15s ease;
}
.fpst-header__actions .fpml-switcher__item:hover {
	background: none;
	color: var(--wp--preset--color--gold);
}
.fpst-header__actions .fpml-switcher__item--current,
.fpst-header__actions .fpml-switcher__item--current:hover {
	background: none;
	border: 0;
	color: var(--wp--preset--color--gold);
	opacity: 1;
	font-weight: 700;
}
.fpst-header__actions .fpml-switcher__separator { color: var(--wp--preset--color--line); opacity: 0.7; }
@media (max-width: 600px) {
	.fpst-header__actions { gap: 0.7rem; }
	.fpst-header__actions .fpml-switcher { font-size: 0.72rem; }
	.fpst-header__actions .fpml-switcher__item { padding: 0.15rem 0.25rem; }
}

/* === Hamburger + overlay CUSTOM (toggle CSS-only, niente blocco Navigation core) === */
.fpst-nav-toggle {
	position: absolute;
	width: 1px;
	height: 1px;
	opacity: 0;
	pointer-events: none;
}
.fpst-burger {
	justify-self: end;
	display: inline-flex;
	flex-direction: column;
	justify-content: center;
	gap: 6px;
	width: 30px;
	height: 30px;
	cursor: pointer;
	z-index: 10001;
}
.fpst-burger span {
	display: block;
	width: 28px;
	height: 2px;
	background: var(--wp--preset--color--accent);
	border-radius: 2px;
	transition: transform 0.25s ease, opacity 0.2s ease, background 0.2s ease;
}
.fpst-nav-toggle:checked ~ .fpst-burger span:nth-child(1) { transform: translateY(8px) rotate(45deg); background: var(--wp--preset--color--accent); }
.fpst-nav-toggle:checked ~ .fpst-burger span:nth-child(2) { opacity: 0; }
.fpst-nav-toggle:checked ~ .fpst-burger span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); background: var(--wp--preset--color--accent); }
.fpst-nav-toggle:focus-visible ~ .fpst-burger { outline: 2px solid var(--wp--preset--color--gold); outline-offset: 4px; }

.fpst-overlay {
	position: fixed;
	top: var(--fpst-header-h, 88px);
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(225, 60, 42, 0.92);
	backdrop-filter: blur(3px);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow-y: auto;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s ease, visibility 0.3s ease;
	z-index: 90;
}
@media (max-width: 600px) {
	.fpst-overlay { top: var(--fpst-header-h, 74px); }
}
.fpst-nav-toggle:checked ~ .fpst-overlay {
	opacity: 1;
	visibility: visible;
}
.fpst-overlay__menu,
.fpst-overlay__menu ul {
	list-style: none;
	margin: 0;
	padding: 0;
	text-align: center;
}
.fpst-overlay__menu > li { margin: 0.35em 0; }
.fpst-overlay__menu > li > a,
.fpst-overlay__label {
	display: inline-block;
	color: var(--wp--preset--color--base);
	font-family: var(--wp--preset--font-family--serif);
	font-size: clamp(1.6rem, 4vw, 2.4rem);
	font-weight: 600;
	text-decoration: none;
	line-height: 1.25;
}
.fpst-overlay__menu > li > a:hover { color: var(--wp--preset--color--gold); }
.fpst-overlay__label { opacity: 0.65; font-style: italic; cursor: default; }
.fpst-overlay__group ul { margin-top: 0.2em; }
.fpst-overlay__group ul a {
	color: rgba(255, 255, 255, 0.8);
	font-family: var(--wp--preset--font-family--sans);
	font-size: 1.05rem;
	text-decoration: none;
	display: inline-block;
	padding: 0.18em 0;
}
.fpst-overlay__group ul a:hover { color: var(--wp--preset--color--gold); }
/* «Le Tenute» come box con loghi (come il menu originale). */
.fpst-overlay__tenute {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1.1rem 1.5rem;
	margin-top: 1.1rem;
}
.fpst-overlay__tenute > li { margin: 0; }
.fpst-overlay__tenute a {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.55rem;
	width: 104px;
	color: #fff;
	text-decoration: none;
}
.fpst-overlay__tenute img {
	width: 96px;
	height: 96px;
	object-fit: contain;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.06);
	padding: 10px;
	transition: transform 0.2s ease, background 0.2s ease;
}
.fpst-overlay__tenute a:hover img {
	transform: scale(1.07);
	background: rgba(255, 255, 255, 0.12);
}
.fpst-overlay__tenute span {
	font-family: var(--wp--preset--font-family--sans);
	font-size: 0.9rem;
	line-height: 1.2;
	color: rgba(255, 255, 255, 0.85);
}
.fpst-overlay__tenute a:hover span { color: var(--wp--preset--color--gold); }

/* Caption testuale sulle slide dello slider hero. */
.fp-salkit-slider .fp-salkit__slide { position: relative; }
.fpst-slide-cap {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 2;
	padding: clamp(1.4rem, 4vw, 3.2rem);
	/* Floor sul solo padding-bottom: la caption resta sempre sopra i dot
	   dello slider (.fp-salkit__slider-dots a bottom:18px), anche su mobile
	   dove il padding generale scende a 1.4rem e il testo li toccherebbe. */
	padding-bottom: max(3rem, clamp(1.4rem, 4vw, 3.2rem));
	background: linear-gradient(to top, rgba(0, 0, 0, 0.5), transparent);
	pointer-events: none;
	text-align: center;
}
.fpst-slide-cap span {
	color: #fff;
	font-family: var(--wp--preset--font-family--serif);
	font-weight: 600;
	font-size: clamp(1.4rem, 3.4vw, 2.6rem);
	line-height: 1.15;
	text-shadow: 0 2px 16px rgba(0, 0, 0, 0.45);
}

/* Mobile: logo un filo più piccolo, gap ridotto. */
@media (max-width: 600px) {
	.fpst-header__bar { gap: var(--wp--preset--spacing--30); }
	.fpst-header__logo img { max-height: 46px; }
}

/* =====================================================================
   POLISH GRAFICO — estetica «tenuta»: calda, editoriale, elegante.
   Scoped al tema (chrome .fpst-* + componenti Kit .fp-salkit-*); non tocca
   gli altri siti che usano il solo plugin Kit.
   ===================================================================== */

/* Sfondo pagina = token «shell» (crema caldo) definito in theme.json
   (styles.color.background) → sovrascrivibile per-sito via Global Styles.
   Header bianco e footer scuro mantengono il proprio sfondo. */

/* Overlay menu generico (default del tema): quando le voci arrivano dal blocco
   Navigation (siti senza override custom della chrome), eredita lo stile della
   versione hand-coded (.fpst-overlay__menu). */
.fpst-overlay .wp-block-navigation__container {
	flex-direction: column;
	align-items: center;
	gap: clamp(0.4rem, 2.2vw, 1rem);
}
.fpst-overlay .wp-block-navigation__container,
.fpst-overlay .wp-block-navigation-item__content {
	font-family: var(--wp--preset--font-family--serif);
	font-size: clamp(1.5rem, 4.5vw, 2.4rem);
	color: #fff;
}
.fpst-overlay .wp-block-navigation-item__content { opacity: 0.92; }
.fpst-overlay .wp-block-navigation-item__content:hover { opacity: 1; }

/* Reveal on scroll (fade-up). La classe .fpst-reveal viene aggiunta dal JS solo
   se IntersectionObserver è disponibile e l'utente non ha prefers-reduced-motion:
   senza JS, o con motion ridotto, i contenuti restano pienamente visibili. */
.fpst-reveal { opacity: 0; transform: translateY(26px);
	transition: opacity .85s ease, transform .85s cubic-bezier(.22, .7, .2, 1); }
.fpst-reveal.is-in { opacity: 1; transform: none; }

/* Titoli display in serif (Playfair) per il tono da tenuta. */
.fp-salkit__split-title,
.fp-salkit__heading,
.fp-salkit__prose-title { font-family: var(--wp--preset--font-family--serif); letter-spacing: -0.01em; }

/* Kicker dei blocchi split: filetto-guida oro prima del testo (editoriale). */
.fp-salkit-split .fp-salkit__kicker { display: inline-flex; align-items: center; }
.fp-salkit-split .fp-salkit__kicker::before {
	content: ""; width: 30px; height: 2px; margin-right: 0.8em;
	background: var(--wp--preset--color--gold);
}

/* Immagini dei blocchi split: cornice morbida + zoom lento all'hover. */
.fp-salkit__split-media {
	border-radius: 14px;
	box-shadow: 0 30px 60px -34px rgba(42, 39, 36, 0.5), 0 6px 18px -10px rgba(42, 39, 36, 0.28);
}
.fp-salkit__split-media .fp-salkit__split-img { transition: transform 1.2s cubic-bezier(0.2, 0.7, 0.2, 1); }
.fp-salkit-split:hover .fp-salkit__split-media .fp-salkit__split-img { transform: scale(1.06); }

/* Bande con immagine di sfondo (storia / tradizione): filetto oro sotto il titolo. */
.fp-salkit-section.has-bg-image .fp-salkit__heading::after {
	content: ""; display: block; width: 64px; height: 3px; border-radius: 2px;
	background: var(--wp--preset--color--gold); margin: 0.7em auto 0;
}

/* Caption dello slider: filetto oro sopra il testo. */
.fpst-slide-cap span { position: relative; display: inline-block; padding-top: 0.65em; }
.fpst-slide-cap span::before {
	content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%);
	width: 58px; height: 3px; border-radius: 2px; background: var(--wp--preset--color--gold);
}

@media (prefers-reduced-motion: reduce) {
	.fpst-reveal { opacity: 1 !important; transform: none !important; transition: none; }
	.fp-salkit-split:hover .fp-salkit__split-media .fp-salkit__split-img { transform: none; }
}

/* === Rifiniture home (riscontri review) === */

/* Bande full-bleed a FILO: rimuove il block-gap del flusso post-content tra le
   sezioni (ognuna ha già il proprio padding) e gli <p> vuoti lasciati da wpautop.
   Così non resta la fascia crema tra due bande scure consecutive. */
.entry-content.is-layout-flow > .fp-salkit-section,
.entry-content.is-layout-flow > section.fp-salkit-section { margin-block: 0; }
.entry-content.is-layout-flow > .fp-salkit-split { margin-block: clamp(52px, 7vw, 92px); }
/* wpautop lascia paragrafi spuri tra i blocchi top-level (il testo vero vive DENTRO
   le sezioni, non come figlio diretto): rimuovili → niente gap verticali incoerenti. */
.entry-content.is-layout-flow > p { display: none; }
.entry-content p:empty { display: none; margin: 0; }
.fp-salkit__section-inner > p:last-child:empty { display: none; }
/* Due sezioni CONTENUTE (senza sfondo) consecutive non raddoppiano il padding
   verticale: la prima dà già il respiro, la seconda parte a filo. Le bande full-bleed
   (has-bg-*) mantengono il proprio padding immersivo. */
.fp-salkit-section:not(.has-bg-image):not(.has-bg-color):not(.has-bg-video) + .fp-salkit-section:not(.has-bg-image):not(.has-bg-color):not(.has-bg-video) { padding-top: 0; }

/* Hero slider above the fold + responsive. Nello slider l'immagine è una
   <figure class="fp-salkit-image"> con <img class="fp-salkit__image-img">: vincolo
   l'altezza di track/slide/figure al viewport meno header (~89px) e un accenno della
   sezione successiva; la caption (overlay assoluto) resta sopra la piega. */
.fp-salkit-slider .fp-salkit__slider-track,
.fp-salkit-slider .fp-salkit__slide,
.fp-salkit-slider .fp-salkit-image {
	height: calc(100svh - 130px);
	min-height: 440px;
}
.fp-salkit-slider .fp-salkit-image {
	aspect-ratio: auto;
	margin: 0;
	max-width: none;
	border-radius: 0;
	box-shadow: none;
}
.fp-salkit-slider .fp-salkit__image-img { width: 100%; height: 100%; object-fit: cover; display: block; }
/* wpautop lascia <br>/<p> spuri dentro lo slider: nascondili per non sballare l'altezza. */
.fp-salkit-slider br,
.fp-salkit-slider .fp-salkit__slide > p:empty { display: none; }
@media (max-width: 600px) {
	.fp-salkit-slider .fp-salkit__slider-track,
	.fp-salkit-slider .fp-salkit__slide,
	.fp-salkit-slider .fp-salkit-image { height: calc(100svh - 110px); min-height: 380px; }
}

/* Scacchiera: tutte le immagini split alla STESSA altezza (ratio uniforme), così
   le righe sono allineate invece di seguire l'altezza naturale di ogni foto. */
.fp-salkit-split .fp-salkit__split-media { aspect-ratio: 4 / 3; overflow: hidden; }
.fp-salkit-split .fp-salkit__split-media .fp-salkit__split-img { width: 100%; height: 100%; object-fit: cover; }

/* Stats: tipografia editoriale (numeri serif oro) al posto dei badge scuri «amatoriali». */
.fp-salkit-stats .fp-salkit__statc { gap: 0.55rem; }
.fp-salkit-stats .fp-salkit__statc-n {
	min-width: 0;
	min-height: 0;
	width: auto;
	height: auto;
	padding: 0;
	border-radius: 0;
	background: none;
	box-shadow: none;
	color: var(--wp--preset--color--gold);
	font-family: var(--wp--preset--font-family--serif);
	font-weight: 700;
	font-size: clamp(2.4rem, 5vw, 3.4rem);
	line-height: 1;
}
.fp-salkit-stats .fp-salkit__statc-t {
	text-transform: uppercase;
	letter-spacing: 0.12em;
	font-size: 12px;
	font-weight: 600;
	color: var(--wp--preset--color--muted);
	max-width: 20ch;
}

/* ==========================================================================
   Footer — pannello brand, colonne brand/naviga/tenute + barra inferiore.
   ========================================================================== */
.fpst-footer a {
	color: var(--wp--preset--color--base);
	text-decoration: none;
	opacity: 0.85;
	transition: opacity 0.15s ease, color 0.15s ease;
}
.fpst-footer a:hover {
	opacity: 1;
	color: var(--wp--preset--color--gold);
}
.fpst-footer__brand {
	margin: 0 0 var(--wp--preset--spacing--20);
	color: var(--wp--preset--color--base);
}
.fpst-footer__tagline {
	max-width: 34ch;
	opacity: 0.7;
	margin: 0 0 var(--wp--preset--spacing--40);
}
.fpst-footer__social .wp-social-link { color: var(--wp--preset--color--base); }

.fpst-footer__h {
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: #d8b98a;
	margin: 0 0 var(--wp--preset--spacing--40);
	opacity: 0.95;
}
ul.fpst-footer__nav {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--30);
}
ul.fpst-footer__nav li { margin: 0; }
ul.fpst-footer__nav a { opacity: 0.85; text-decoration: none; }
ul.fpst-footer__nav a:hover { opacity: 1; text-decoration: underline; text-underline-offset: 3px; }

.fpst-footer__rule {
	width: 100%;
	max-width: none;
	margin: var(--wp--preset--spacing--60) 0 var(--wp--preset--spacing--40);
	opacity: 0.18;
}
.fpst-footer__bottom { opacity: 0.75; }
.fpst-footer__bottom p { margin: 0; }
.fpst-footer__legal a { text-decoration: underline; text-underline-offset: 3px; }

@media (max-width: 781px) {
	.fpst-footer__cols { gap: var(--wp--preset--spacing--50); }
}

/* ==========================================================================
   Blog — griglia contenuto + sidebar, widget, schede articolo.
   ========================================================================== */
.fpst-content-grid { gap: var(--wp--preset--spacing--70); }
.fpst-content-grid > .wp-block-column { min-width: 0; }

.fpst-postcard img { width: 100%; height: auto; }

.fpst-sidebar {
	position: sticky;
	top: 90px;
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--50);
}
.fpst-widget {
	background: var(--wp--preset--color--surface);
	border: 1px solid var(--wp--preset--color--line);
	border-radius: var(--wp--custom--radius);
	padding: var(--wp--preset--spacing--50);
}
.fpst-widget__title {
	margin: 0 0 var(--wp--preset--spacing--40);
	padding-bottom: var(--wp--preset--spacing--30);
	border-bottom: 2px solid var(--wp--preset--color--gold);
	display: inline-block;
}
.fpst-widget ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
.fpst-widget li {
	padding: var(--wp--preset--spacing--20) 0;
	border-bottom: 1px solid var(--wp--preset--color--line);
}
.fpst-widget li:last-child {
	border-bottom: 0;
}
.fpst-widget a {
	text-decoration: none;
}
.fpst-widget a:hover {
	color: var(--wp--preset--color--gold);
}
.fpst-widget__posts .wp-block-latest-posts__post-date {
	display: block;
	font-size: var(--wp--preset--font-size--small);
	color: var(--wp--preset--color--muted);
}

@media (max-width: 781px) {
	.fpst-sidebar { position: static; }
	.fpst-content-grid { gap: var(--wp--preset--spacing--60); }
}

/* === Croce di Malta — ornamento Terre dei Cavalieri (cluster) === */
@supports ((-webkit-mask-image: url()) or (mask-image: url())) {
	.fp-salkit__heading::before {
		content: "";
		display: block;
		width: 26px;
		height: 26px;
		margin: 0 auto 0.6em;
		background-color: #c5281a;
		-webkit-mask: center / contain no-repeat url(maltese-cross.svg);
		mask: center / contain no-repeat url(maltese-cross.svg);
		opacity: 0.92;
	}
	.fp-salkit-section.has-bg-image .fp-salkit__heading::before { background-color: #fff; }
}
.fpst-footer__umbrella svg { height: 56px; width: auto; }

/* === Rifiniture cluster Terre dei Cavalieri === */
/* Occhiello: niente filetto orizzontale (sezioni e split) — la croce di Malta è l'ornamento. */
.fp-salkit__kicker::before { display: none !important; }

/* Menu overlay: hover ben visibile sul fondo rosso brand. Il token "gold" del
   tema è #c5281a — lo stesso rosso dell'overlay — quindi l'hover era invisibile. */
.fpst-overlay__menu > li > a:hover,
.fpst-overlay__group ul a:hover { color: #f3dcab; }

/* Nessuna striscia crema tra l'ultimo contenuto e il footer (block-gap della root). */
.wp-site-blocks > footer { margin-block-start: 0; }

/* «Le Tenute» nel menu: i loghi contengono già il nome della tenuta → l'etichetta
   testuale resta solo per gli screen reader (evita il doppione e l'a-capo). */
.fpst-overlay__tenute a span {
	position: absolute !important;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden;
	clip: rect(0 0 0 0);
	white-space: nowrap;
	border: 0;
}

/* === Watermark croce di Malta — sfondo leggerissimo "carta intestata" ===
   Una grande croce FISSA dietro tutta la pagina: fa capolino attraverso le
   sezioni trasparenti chiare e scompare sotto le bande opache (immagine/scure/
   cream). Pseudo-elemento fixed sul body (z-0); .wp-site-blocks resta sopra
   (z-1, trasparente dove non ha sfondo) così la croce traspare.
   NB: .wp-site-blocks position:relative NON crea containing-block per i fixed
   (niente transform/filter) → l'overlay menu e l'header sticky restano integri. */
@supports ((-webkit-mask-image: url()) or (mask-image: url())) {
	body::before {
		content: "";
		position: fixed;
		inset: 0;
		z-index: 0;
		pointer-events: none;
		background-color: rgba(197, 40, 26, 0.045); /* brand #c5281a, tenue */
		-webkit-mask: center / min(66vmin, 580px) no-repeat url(maltese-cross.svg);
		        mask: center / min(66vmin, 580px) no-repeat url(maltese-cross.svg);
	}
	.wp-site-blocks { position: relative; z-index: 1; }
	/* Footer scuro: la croce rossa non si vedrebbe → un secondo watermark
	   bianco tenue nell'angolo, dietro le colonne. */
	.fpst-footer { position: relative; overflow: hidden; }
	.fpst-footer > * { position: relative; z-index: 1; }
	.fpst-footer::after {
		content: "";
		position: absolute;
		right: -5%;
		bottom: -22%;
		width: min(42vmin, 340px);
		aspect-ratio: 1;
		z-index: 0;
		pointer-events: none;
		background-color: rgba(255, 255, 255, 0.05);
		-webkit-mask: center / contain no-repeat url(maltese-cross.svg);
		        mask: center / contain no-repeat url(maltese-cross.svg);
	}
	@media (prefers-reduced-motion: no-preference) {
		body::before { transition: opacity 0.4s ease; }
	}
}
