/* ============================================================
   MSS Blocks — hero, section, carousel, contatti
   ============================================================ */

:root {
	--mss-magenta: #b10055;
	--mss-plum: #2a0a1c;
	--mss-teal: #0087a8;
	--mss-teal-dark: #006b86;
	--mss-navy: #0a1a4a;
	--mss-navy-deep: #05102e;
	--mss-pad: clamp(1.25rem, 6vw, 168px);
	--mss-content: 1200px;
	/* Left edge of the text cage (constrained container) at any viewport width. */
	--mss-cage-left: calc( max( (100vw - var(--mss-content)) / 2, 0px ) + var(--mss-pad) );
	--mss-slide-w: min(868px, 82vw);
}

/* Full-bleed helper for section wrappers rendered inside constrained content */
.mss-hero,
.mss-carousel,
.mss-contatti {
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	box-sizing: border-box;
}

.mss-container {
	max-width: var(--mss-content);
	margin-inline: auto;
	padding-inline: var(--mss-pad);
	box-sizing: border-box;
}

/* ---------- Button ---------- */
.mss-btn {
	display: inline-block;
	background: var(--mss-teal);
	color: #fff;
	font-family: "Barlow", sans-serif;
	font-weight: 500;
	font-size: 1.25rem;
	line-height: 1;
	text-decoration: none;
	text-align: center;
	padding: .85rem 3.6rem;
	border-radius: 5px;
	border: 0;
	cursor: pointer;
	transition: background .2s ease, transform .2s ease;
}
.mss-btn:hover { background: var(--mss-teal-dark); transform: translateY(-1px); }
.mss-btn--small { font-size: .95rem; padding: .6rem 1.6rem; }
/* Secondo pulsante hero: contorno bianco */
.mss-btn--outline { background: transparent; border: 2px solid rgba(255, 255, 255, .7); color: #fff; }
.mss-btn--outline:hover { background: rgba(255, 255, 255, .08); border-color: #fff; }
.mss-hero__actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 2rem; }
.mss-hero__actions .mss-btn { margin: 0; }

/* ---------- Hero ---------- */
.mss-hero {
	position: relative;
	background: transparent; /* lo sfondo è a livello pagina (featured image) */
	color: #fff;
	padding: calc(var(--mss-header-h, 172px) + 4rem) 0 7rem;
}
.mss-hero__inner { position: relative; z-index: 2; }
.mss-hero__title {
	font-family: "Barlow", sans-serif;
	font-weight: 800;
	text-transform: uppercase;
	line-height: .98;
	font-size: clamp(2.6rem, 7vw, 6.25rem);
	margin: 0 0 2rem;
	max-width: 16ch;
}
.mss-hero__text {
	max-width: 933px;
	font-size: 1.05rem;
	line-height: 1.7;
	margin-bottom: 2.5rem;
}
.mss-hero__text p { margin: 0 0 1rem; }

/* ---------- Section ---------- */
.mss-section {
	background: transparent; /* lascia passare lo sfondo pagina (gradiente) */
	color: #fff;
	padding: 4.5rem 0;
}
.mss-section__title {
	font-family: "Barlow", sans-serif;
	font-weight: 800;
	text-transform: uppercase;
	line-height: 1;
	font-size: clamp(2.2rem, 5vw, 3.75rem);
	margin: 0 0 1.75rem;
}
.mss-section__text { max-width: 933px; font-size: 1.05rem; line-height: 1.7; }
.mss-section__text p { margin: 0 0 1rem; }
.mss-section .mss-btn { margin-top: 1.5rem; }

/* Core separator block (wp:separator): white line kept inside the text cage.
   Selector kept more specific than core's :not() rules so the cage width wins. */
.mss-main hr.wp-block-separator:not(.is-style-dots) {
	border: 0;
	height: 1px;
	background-color: #fff;
	color: #fff;
	opacity: .6;
	width: 100%;
	max-width: calc(var(--mss-content) - 2 * var(--mss-pad));
	margin-block: 1.25rem;
	margin-inline: auto;
}

/* ---------- Carousel ---------- */
.mss-carousel {
	position: relative;
	background: transparent; /* lascia passare lo sfondo pagina */
	padding: 2rem 0 5rem;
	display: flex;
	align-items: stretch;
	gap: 1rem;
}
.mss-carousel__track {
	display: flex;
	gap: 2rem;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	/* Every snapped card aligns to the main text cage. The right padding gives
	   the LAST card enough scroll room to park at the cage too. */
	scroll-padding-left: var(--mss-cage-left);
	padding: 1rem max(var(--mss-pad), calc(100vw - var(--mss-cage-left) - var(--mss-slide-w))) 2rem var(--mss-cage-left);
	scrollbar-width: none;
	flex: 1 1 auto;
}
.mss-carousel__track::-webkit-scrollbar { display: none; }

.mss-slide {
	scroll-snap-align: start;
	flex: 0 0 var(--mss-slide-w);
	min-height: 560px;
	background: linear-gradient(160deg, #0a1a4a 0%, #05102e 100%);
	border-radius: 24px;
	padding: 3rem;
	display: grid;
	grid-template-columns: minmax(0, 55fr) minmax(0, 45fr); /* testo 55% · immagine 45% */
	gap: 2rem;
	align-items: center;
	color: #fff;
	box-shadow: 0 24px 60px rgba(0,0,0,.25);
	position: relative;
	overflow: hidden;
}
.mss-slide__title {
	font-family: "Barlow", sans-serif;
	font-weight: 800;
	text-transform: uppercase;
	font-size: clamp(1.6rem, 3vw, 2.4rem);
	line-height: 1.05;
	margin: 0 0 1.25rem;
	max-width: 18ch;
}
.mss-slide__text { font-size: .92rem; line-height: 1.6; opacity: .92; }
.mss-slide__text p { margin: 0 0 .8rem; }
.mss-slide__cta { margin-top: 1.5rem; }
.mss-slide__body { align-self: center; }
.mss-slide__media {
	align-self: stretch;
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 0;
}
.mss-slide__media img {
	width: 100%;
	max-height: 420px;
	height: auto;
	object-fit: contain;
	border-radius: 12px;
	display: block;
}
.mss-slide--placeholder .mss-slide__media {
	background: rgba(255,255,255,.08);
	border-radius: 12px;
	min-height: 220px;
}

.mss-carousel__arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 3;
	width: clamp(28px, 4vw, 46px);
	border: 0;
	background: none;
	color: var(--mss-teal);
	cursor: pointer;
	padding: 0;
	display: grid;
	place-items: center;
	transition: color .2s ease, opacity .2s ease, transform .2s ease;
}
.mss-chevron {
	width: 100%;
	height: auto;
	display: block;
	filter: drop-shadow(6px 0 3px rgba(0,0,0,.22));
}
/* Desktop: the peeking (non-snapped) slide blends into the page background */
@media (min-width: 901px) {
	/* No transition here on purpose: mix-blend-mode is not animatable, so a
	   fading opacity next to an instant blend switch flashes dark plum. */
	.mss-slide:not(.is-active) {
		mix-blend-mode: multiply;
		opacity: .75;
	}
}

.mss-carousel__arrow:hover { color: var(--mss-teal-dark); }
.mss-carousel__arrow--next:hover { transform: translateY(-50%) translateX(3px); }
.mss-carousel__arrow--prev:hover { transform: translateY(-50%) translateX(-3px); }
.mss-carousel__arrow:disabled { opacity: .3; cursor: default; }
.mss-carousel__arrow--prev { left: clamp(.5rem, 3vw, 3rem); }
.mss-carousel__arrow--next { right: clamp(.5rem, 3vw, 3rem); }

/* ---------- Contatti ---------- */
/* Background comes from the block: a coloured gradient (top → transparent),
   set inline. Default is transparent so the magenta page shows through. */
.mss-contatti {
	background: transparent;
	color: #fff;
	padding: 5rem 0;
	position: relative;
	/* The operator cut-out may poke out above the section (photo sits on the
	   form box top border) — the section stacks above its siblings. */
	overflow: visible;
	z-index: 2;
}
.mss-contatti > .mss-container { position: relative; z-index: 2; }
/* Operator cut-out photo: anchored to the form box, its base sits exactly
   on the box top border and the figure grows upward, overflowing the block. */
.mss-contatti__foto {
	position: absolute;
	bottom: 100%;
	right: 0;
	/* -15% rispetto alla taglia originale clamp(200,24vw,350). */
	width: var(--mss-foto-w, clamp(170px, 20.4vw, 297px));
	height: auto;
	z-index: 3;
	pointer-events: none;
	filter: drop-shadow(0 20px 40px rgba(0,0,0,.25));
}
/* Title + info never run under the photo: cap their width to the space
   left of the cut-out (photo width + breathing room). */
@media (min-width: 981px) {
	.mss-contatti--has-foto .mss-contatti__title,
	.mss-contatti--has-foto .mss-contatti__info {
		max-width: calc(100% - var(--mss-foto-w, clamp(170px, 20.4vw, 297px)) - 3rem);
	}
}
@media (max-width: 980px) {
	/* On narrow screens the operator cut-out goes away entirely (deliberate). */
	.mss-contatti__foto { display: none; }
}
.mss-contatti__title {
	font-family: "Barlow", sans-serif;
	font-weight: 800;
	text-transform: uppercase;
	line-height: 1;
	font-size: clamp(2.2rem, 5vw, 3.75rem);
	margin: 0 0 2.5rem;
	max-width: 14ch;
}
.mss-contatti__grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; }
.mss-contatti__info h3 { font-weight: 800; text-transform: uppercase; margin: 0 0 .35rem; }
.mss-contatti__info p { margin: 0; line-height: 1.3; font-size: 1.05rem; } /* come .mss-section__text */
.mss-contatti__info > p:first-of-type { margin-bottom: 1.3em; } /* gap fra intro e blocco E./T. come da Figma */
.mss-contatti__info a { color: #fff; text-decoration: underline; }

/* Form — box bordo bianco netto (Figma Rectangle 34), niente effetto glass. */
.mss-form {
	background: transparent;
	border: 0;
	padding: 0;
}
.mss-hp { position: absolute; left: -9999px; width: 1px; height: 1px; }
.mss-form__grid {
	display: grid;
	grid-template-columns: 53% 1fr;
	gap: 0;
	border: 1px solid #fff;
	border-radius: 8px;
	position: relative; /* ancora per la foto centralinista (bottom:100%) */
}
.mss-form__left { padding: 2.2rem 2.4rem 1.6rem; }
.mss-form__right {
	padding: 2.2rem 2rem 1.6rem;
	border-left: 1px solid #fff; /* divisore interno verticale (Figma Line 12) */
	display: flex;
	flex-direction: column;
}
/* Riga orizzontale piena sotto i checkbox (Figma Line 15). */
.mss-form__sep { border: 0; border-top: 1px solid #fff; margin: .6rem -2rem 1.5rem; }
.mss-field { display: flex; flex-direction: column; gap: .3rem; margin-bottom: 1.25rem; }
.mss-field > span { font-size: .85rem; opacity: .9; }
.mss-field input,
.mss-field textarea {
	background: transparent;
	border: 0;
	border-bottom: 1px solid #fff;
	color: #fff;
	font-family: "Barlow", sans-serif;
	font-size: 1rem;
	padding: .4rem 0;
	outline: none;
}
.mss-field input:focus { border-bottom-width: 2px; }
.mss-field input::placeholder { color: rgba(255,255,255,.5); }
/* Textarea "invisibile": solo label, nessun bordo/fondo (Figma). */
.mss-field textarea {
	border: 0;
	border-radius: 0;
	padding: 0;
	resize: none;
	min-height: 120px;
}
.mss-field--note { flex: 1; margin-bottom: 0; }
.mss-field--note textarea { flex: 1; }

.mss-checks { border: 0; padding: 0; margin: 0 0 .5rem; display: flex; flex-direction: column; gap: 1.1rem; }
.mss-check { display: flex; align-items: flex-start; gap: .8rem; font-size: .9rem; line-height: 1.3; cursor: pointer; }
/* Checkbox custom: quadrato 17px bordo bianco netto, spunta teal su fondo bianco. */
.mss-check input {
	appearance: none;
	-webkit-appearance: none;
	width: 17px;
	height: 17px;
	flex: 0 0 17px;
	margin-top: .05rem;
	border: 1.5px solid #fff;
	border-radius: 3px;
	background: transparent;
	cursor: pointer;
	display: inline-grid;
	place-content: center;
}
.mss-check input:checked { background: #fff; }
.mss-check input:checked::before {
	content: "";
	width: 11px;
	height: 11px;
	background: var(--mss-teal);
	clip-path: polygon(14% 44%, 0 65%, 40% 100%, 100% 16%, 80% 0%, 38% 62%);
}
.mss-check input:focus-visible { outline: 2px solid #fff; outline-offset: 2px; }
.mss-check--consent { margin: 1.25rem 0; }

.mss-form__privacy p { font-size: .72rem; line-height: 1.5; opacity: .8; margin: 1.5rem 0 0; }
.mss-form__submit { margin-top: .5rem; }

.mss-form__notice { padding: .75rem 1rem; border-radius: 8px; margin: 0 0 1.25rem; font-weight: 600; }
.mss-form__notice--ok { background: rgba(0,135,168,.9); }
.mss-form__notice--err { background: rgba(177,0,85,.9); }

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
	.mss-form__grid { grid-template-columns: 1fr; gap: 0; }
	.mss-form__left { padding: 1.6rem 1.4rem .8rem; }
	.mss-form__right { padding: 1.2rem 1.4rem 1.6rem; border-left: 0; border-top: 1px solid #fff; }
	.mss-form__sep { margin-left: -1.4rem; margin-right: -1.4rem; }

	/* Tighter vertical rhythm: desktop paddings are sized for the Figma
	   desktop layout and look huge on a phone. The hero top clears the
	   (much shorter) mobile header, not the desktop badge. */
	.mss-hero { padding: 8rem 0 2.5rem; }
	.mss-hero__title { margin-bottom: 1.25rem; }
	.mss-hero__text { margin-bottom: 1.5rem; }
	.mss-section { padding: 2.25rem 0; }
	.mss-carousel { padding: 1rem 0 1.5rem; }
	/* Section text followed by its carousel (e.g. Prodotti): pull them together */
	.mss-section:has(+ .mss-carousel) { padding-bottom: .75rem; }
	.mss-section + .mss-carousel { padding-top: 0; }
	.mss-section + .mss-carousel .mss-carousel__track { padding-top: .5rem; }
	.mss-contatti { padding: 2.5rem 0; }
	.mss-contatti__title { margin-bottom: 1.5rem; }

	/* Carousel: card centered in the viewport (symmetric 7vw side peek),
	   arrows visible at the screen edges. Cards snap to center, so the
	   cage-left scroll-padding must go (it would shift the snapport). */
	.mss-carousel__track {
		gap: 1rem;
		padding: 1rem 7vw 2rem;
		scroll-padding: 0;
	}
	.mss-slide {
		scroll-snap-align: center;
		flex-basis: min(440px, 86vw);
		grid-template-columns: 1fr;
		align-items: start;
		padding: 1.75rem;
		min-height: 0;
		gap: 1.25rem;
	}
	.mss-slide__media { align-self: center; }
	.mss-slide__media img { max-height: 240px; margin-inline: auto; }
	.mss-carousel__arrow { width: 30px; }
	.mss-carousel__arrow--prev { left: 2px; }
	.mss-carousel__arrow--next { right: 2px; }

	.mss-main hr.wp-block-separator:not(.is-style-dots) { margin-block: .75rem; }
}

/* ---------- Editor tweaks ---------- */
.editor-styles-wrapper .mss-hero,
.editor-styles-wrapper .mss-carousel,
.editor-styles-wrapper .mss-contatti {
	width: auto;
	max-width: none;
	margin-left: 0;
	margin-right: 0;
}

/* ---------- Lavora con noi (Figma 2011:328) ---------- */
/* Primo blocco della pagina: il titolo deve liberare l'header overlay. */
.entry-content > .mss-lavora:first-child { padding-top: calc(var(--mss-header-h, 172px) + 3rem); }
.mss-lavora__intro { max-width: 933px; margin: 0 0 2.5rem; font-size: 1.05rem; line-height: 1.3; }
.mss-lavora__intro p { margin: 0 0 .5rem; }
.mss-lavora__wrap { scroll-margin-top: 120px; }

/* Titolo Lavora: stessa scala del titolo hero della home. */
.mss-lavora__title { font-size: clamp(2.6rem, 7vw, 6.25rem); line-height: .98; max-width: none; }

/* Switch: bottoni pieni. Selezionato = teal pieno in rilievo; non
   selezionato = smorzato (opacità + niente ombra) così la scelta è chiara. */
.mss-lavora__switch {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 431px));
	gap: clamp(1rem, 4vw, 3.5rem);
	margin-bottom: 3rem;
}
.mss-lavora__tab {
	font-family: "Barlow", sans-serif;
	font-weight: 600;
	font-size: 1.05rem;
	text-transform: uppercase;
	letter-spacing: .02em;
	color: #fff;
	background: var(--mss-teal);
	border: 0;
	border-radius: 5px;
	padding: .8rem 1rem;
	cursor: pointer;
	opacity: .4;
	box-shadow: none;
	transition: opacity .2s ease, background .2s ease, box-shadow .2s ease, transform .2s ease;
}
.mss-lavora__tab:hover { opacity: .7; }
.mss-lavora__tab[aria-selected="true"] {
	opacity: 1;
	background: var(--mss-teal);
	box-shadow: 0 8px 22px rgba(0,135,168,.45);
	transform: translateY(-1px);
}

/* Regioni: label + linea, poi griglia 4 colonne in ordine verticale. */
.mss-regioni { border: 0; padding: 0; margin: 0 0 3rem; }
.mss-regioni legend { font-size: .85rem; opacity: .9; padding: 0; }
.mss-regioni__line { border: 0; border-top: 1px solid #fff; margin: .9rem 0 1.6rem; }
.mss-regioni__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	grid-template-rows: repeat(5, auto);
	grid-auto-flow: column;
	gap: 1rem 1.25rem;
}
.mss-regioni .mss-check { font-size: .8rem; align-items: center; }
.mss-regioni .mss-check span { text-transform: uppercase; letter-spacing: .02em; }

/* Allega CV: input file nascosto, riga label + icona (Figma). */
.mss-cv {
	display: flex;
	align-items: center;
	gap: 1rem;
	cursor: pointer;
	padding: .2rem 0 .6rem;
}
.mss-cv__label { font-size: .85rem; opacity: .9; }
.mss-cv__icon { color: #fff; flex: 0 0 28px; }
.mss-cv:hover .mss-cv__icon { color: rgba(255,255,255,.75); }
.mss-cv__file { font-size: .78rem; opacity: .7; }
.mss-cv__file--set { opacity: 1; font-weight: 600; }
.mss-cv__input {
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(0 0 0 0);
	white-space: nowrap;
}

/* INVIA allineato a destra (Figma, contatti e lavora). */
.mss-form__submit { display: block; margin-left: auto; }

@media (max-width: 900px) {
	.mss-lavora__switch { grid-template-columns: 1fr; gap: .8rem; margin-bottom: 2rem; }
	.mss-regioni__grid {
		grid-template-columns: 1fr 1fr;
		grid-template-rows: repeat(10, auto);
		gap: .8rem 1rem;
	}
}

/* ---------- Scroll reveal (classi applicate da reveal.js) ---------- */
.mss-anim .mss-reveal {
	opacity: 0;
	transform: translateY(26px);
	transition: opacity .65s ease, transform .65s cubic-bezier(.22, 1, .36, 1);
	transition-delay: var(--mss-reveal-d, 0ms);
	will-change: opacity, transform;
}
.mss-anim .mss-reveal.is-in {
	opacity: 1;
	transform: none;
	will-change: auto;
}
@media (prefers-reduced-motion: reduce) {
	.mss-anim .mss-reveal { opacity: 1; transform: none; transition: none; }
}

/* ============================================================
   PAGINA PRODOTTO — bande colorate, griglia card, split, CTA
   (skin allineata al design index-mss v3)
   ============================================================ */
:root {
	--mss-ink: #171219;
	--mss-text-dark: #4c454f;
	--mss-azure-1: #f4fbfd;
	--mss-azure-2: #dbeef5;
	--mss-line: #e7dfe4;
	--mss-line-cool: #d3e6ec;
	--mss-card-navy: linear-gradient(160deg, #0a1a4a 0%, #05102e 100%);
	--mss-shadow-card: 0 16px 40px rgba(15, 3, 20, .10);
	--mss-shadow-strong: 0 18px 45px rgba(15, 3, 20, .24);
}

/* Full-bleed per le sezioni colorate (stesso trucco di .mss-hero) */
.mss-cardsec,
.mss-section--bianco, .mss-section--azzurro, .mss-section--magenta,
.is-style-band-white, .is-style-band-azure, .is-style-band-magenta {
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	box-sizing: border-box;
}

/* Sfondi banda + colore testo (condivisi tra blocchi PHP e gruppi core) */
.mss-cardsec--bianco, .mss-section--bianco, .is-style-band-white { background: #fff; color: var(--mss-ink); }
.mss-cardsec--azzurro, .mss-section--azzurro, .is-style-band-azure { background: linear-gradient(165deg, var(--mss-azure-1) 0%, var(--mss-azure-2) 100%); color: var(--mss-ink); }
.mss-cardsec--magenta, .mss-section--magenta, .is-style-band-magenta { background: linear-gradient(135deg, var(--mss-magenta) 0%, #7a003a 100%); color: #fff; }
.mss-cardsec--trasparente { background: transparent; color: #fff; }

.mss-cardsec { padding: clamp(3rem, 6vw, 5.5rem) 0; }
/* Bande contigue dello stesso colore = un blocco unico (niente doppio padding) */
.mss-cardsec--bianco + .mss-cardsec--bianco,
.mss-cardsec--azzurro + .mss-cardsec--azzurro { padding-top: 0; }

/* Gruppo core usato come banda: padding + gabbia dei figli diretti */
.is-style-band-white, .is-style-band-azure, .is-style-band-magenta { padding-block: clamp(3rem, 6vw, 5.5rem); }
.is-style-band-white > *, .is-style-band-azure > *, .is-style-band-magenta > * {
	max-width: var(--mss-content);
	margin-inline: auto;
	padding-inline: var(--mss-pad);
	box-sizing: border-box;
}

/* Titolo sezione card */
.mss-cardsec__title {
	font-family: "Barlow", sans-serif;
	font-weight: 800;
	text-transform: uppercase;
	line-height: 1.04;
	font-size: clamp(1.75rem, 3.6vw, 3.25rem);
	margin: 0 0 2rem;
	max-width: 22ch;
}
.mss-cardsec--bianco .mss-cardsec__title, .mss-cardsec--azzurro .mss-cardsec__title { color: var(--mss-ink); }
.mss-cardsec--magenta .mss-cardsec__title, .mss-cardsec--trasparente .mss-cardsec__title { color: #fff; }

/* Link leggibili sulle bande chiare */
.mss-cardsec--bianco a, .mss-cardsec--azzurro a,
.mss-section--bianco a, .mss-section--azzurro a,
.is-style-band-white a, .is-style-band-azure a { color: var(--mss-teal-dark); }

/* ---------- Griglia card ---------- */
.mss-cards { display: grid; gap: 20px; }
.mss-cards--cols-2 { grid-template-columns: repeat(2, 1fr); }
.mss-cards--cols-3 { grid-template-columns: repeat(3, 1fr); }
.mss-cards--cols-4 { grid-template-columns: repeat(4, 1fr); }
.mss-card {
	background: #fff;
	color: var(--mss-plum);
	border: 1px solid var(--mss-line);
	border-radius: 16px;
	padding: 26px;
	box-shadow: var(--mss-shadow-card);
}
.mss-cardsec--azzurro .mss-card { border-color: var(--mss-line-cool); }
.mss-card__title { font-family: "Barlow", sans-serif; font-weight: 800; text-transform: uppercase; font-size: 1.2rem; line-height: 1.15; margin: .2rem 0 .5rem; color: var(--mss-plum); }
.mss-card__text { font-size: 1rem; line-height: 1.55; color: #5a4650; }
.mss-card__text p { margin: 0 0 .6rem; }
.mss-card__text p:last-child { margin-bottom: 0; }

/* Variante NAVY */
.mss-cards--navy .mss-card { background: var(--mss-card-navy); border: 0; border-top: 5px solid var(--mss-teal); box-shadow: var(--mss-shadow-strong); }
.mss-cards--navy .mss-card__title { color: #fff; }
.mss-cards--navy .mss-card__text { color: rgba(255, 255, 255, .85); }
.mss-cards--navy .mss-card__num { display: block; font-weight: 800; font-size: 1.35rem; color: #38b7d4; margin-bottom: .4rem; }

/* Variante METRICA */
.mss-cards--metrica .mss-card__metric { font-family: "Barlow", sans-serif; font-weight: 800; font-size: clamp(2rem, 3.4vw, 3.1rem); line-height: 1; letter-spacing: -.03em; color: var(--mss-teal-dark); margin: .1rem 0 .6rem; }
.mss-cards--metrica .mss-card__metric small { font-size: .34em; color: #7a6a72; font-weight: 700; text-transform: uppercase; letter-spacing: .02em; }

/* Variante STUDIO */
.mss-cards--studio .mss-card { position: relative; padding-left: 46px; }
.mss-cards--studio .mss-card::before { content: ""; position: absolute; left: 24px; top: 32px; width: 13px; height: 13px; border-radius: 50%; background: var(--mss-teal); box-shadow: 0 0 0 6px rgba(0, 135, 168, .14); }
.mss-cards--studio .mss-card__ref { display: block; font-weight: 800; text-transform: uppercase; letter-spacing: .02em; font-size: .98rem; color: var(--mss-plum); margin-bottom: .35rem; }

/* Variante STEP */
.mss-cards--step .mss-card { position: relative; padding-top: 30px; min-height: 200px; border-color: var(--mss-line-cool); }
.mss-cards--step .mss-card__num { position: absolute; top: 18px; right: 20px; font-weight: 800; font-size: 1.5rem; color: var(--mss-teal); opacity: .95; }

/* Nota evidenziata sotto la griglia */
.mss-cardsec__nota {
	margin-top: 2rem;
	background: #fff;
	color: var(--mss-plum);
	border: 1px solid var(--mss-line-cool);
	border-left: 6px solid var(--mss-teal);
	border-radius: 0 16px 16px 0;
	padding: 22px 26px;
	box-shadow: var(--mss-shadow-card);
}
.mss-cardsec__nota strong { color: var(--mss-magenta); }
.mss-cardsec__nota p { margin: 0; }

/* ---------- mss-section: varianti sfondo + CTA ---------- */
.mss-section--bianco .mss-section__title, .mss-section--azzurro .mss-section__title { color: var(--mss-ink); }
.mss-section--magenta .mss-section__title { color: #fff; }
.mss-section--bianco .mss-section__text, .mss-section--azzurro .mss-section__text { color: var(--mss-text-dark); }
.mss-section--bianco .mss-section__text ol, .mss-section--bianco .mss-section__text ul { padding-left: 1.25rem; }
.mss-section--bianco .mss-section__text li { margin: .7rem 0; }
/* Sotto-titolo dentro il wysiwyg su banda chiara (es. "Studi e documenti…") */
.mss-section--bianco .mss-section__text :is(h2, h3),
.mss-section--azzurro .mss-section__text :is(h2, h3) {
	color: var(--mss-ink);
	font-family: "Barlow", sans-serif;
	font-weight: 800;
	text-transform: uppercase;
	line-height: 1.1;
	font-size: clamp(1.35rem, 2.4vw, 1.9rem);
	margin: 2.6rem 0 1rem;
}

.mss-section--cta { position: relative; overflow: hidden; }
.mss-section__cta { display: grid; grid-template-columns: 1.15fr .85fr; gap: 2rem; align-items: center; }
.mss-section__cta-main { position: relative; z-index: 1; }
.mss-section__cta-side { position: relative; z-index: 1; }
.mss-section--magenta .mss-section__cta-side .mss-btn { background: #fff; color: var(--mss-magenta); }
.mss-section--magenta .mss-section__cta-side .mss-btn:hover { background: #f1e7ec; }
.mss-section--cta.mss-section--magenta::after { content: ""; position: absolute; right: -6%; top: -45%; width: 44%; height: 190%; border: 38px solid rgba(0, 135, 168, .16); border-radius: 50%; pointer-events: none; }

/* ---------- Split Razionale (core group banda + HTML) ---------- */
.mss-split { display: grid; grid-template-columns: .95fr 1.05fr; gap: clamp(2rem, 4vw, 3.5rem); align-items: center; }
.mss-split > div:first-child h2 { font-family: "Barlow", sans-serif; font-weight: 800; text-transform: uppercase; line-height: 1.04; font-size: clamp(1.75rem, 3.6vw, 3.25rem); margin: 0 0 1rem; color: var(--mss-ink); }
.mss-split p { color: var(--mss-text-dark); line-height: 1.7; margin: 0 0 1rem; }
.mss-device-imgs { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; align-items: center; }
.mss-device-imgs img { border-radius: 10px; display: block; width: 100%; height: auto; }

/* ---------- Block-style CORE ---------- */
.is-style-panel { background: #fff; border: 1px solid var(--mss-line-cool); border-radius: 20px; padding: 26px; box-shadow: var(--mss-shadow-strong); color: var(--mss-plum); }
.is-style-panel p { color: #5a4650; }
ul.is-style-pills { list-style: none; margin: 1.2rem 0 0; padding: 0; display: flex; flex-wrap: wrap; gap: 10px; }
ul.is-style-pills li { border: 1.5px solid var(--mss-teal); background: rgba(0, 135, 168, .08); color: var(--mss-teal-dark); border-radius: 4px; padding: .5rem .85rem; font-weight: 700; font-size: .85rem; text-transform: uppercase; letter-spacing: .03em; }
.is-style-clinical-note { background: #fff; color: var(--mss-plum); border-left: 6px solid var(--mss-teal); border-radius: 0 16px 16px 0; padding: 22px 26px; box-shadow: var(--mss-shadow-card); }
.is-style-fineprint { font-size: .85rem; color: #8a7a82; }

/* ---------- Responsive pagina prodotto ---------- */
@media (max-width: 900px) {
	.mss-cards--cols-3, .mss-cards--cols-4 { grid-template-columns: repeat(2, 1fr); }
	.mss-section__cta { grid-template-columns: 1fr; gap: 1.4rem; }
	.mss-section--cta.mss-section--magenta::after { display: none; }
	.mss-split { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
	.mss-cards--cols-2, .mss-cards--cols-3, .mss-cards--cols-4 { grid-template-columns: 1fr; }
}
