/* sections.css — stili specifici per ogni sezione homepage.
   Convenzione BEM: .nome-sezione__elemento--modifier.
   Approccio: desktop-base con override mobile-first sotto.
   Breakpoint principali: 860px (tablet), 480px (mobile), 380px (small).
   Tutti i colori vengono dai tokens (assets/css/tokens.css). */

/* Scroll offset per ancore (nav e' fixed) */
section[id] { scroll-margin-top: 80px; }

/* ──────────────────────────────────────────────────────────────────── */
/* HERO — claim statico SX + diagnostic rotation DX, viewport-fit       */
/* ──────────────────────────────────────────────────────────────────── */

@keyframes if-fade-in {
	from { opacity: 0; transform: translateY(8px); }
	to   { opacity: 1; transform: none; }
}

.hero { position: relative; background: var(--ivory); overflow: hidden; }
.hero__eyebrow {
	display: flex;
	align-items: center;
	gap: 12px;
}
.hero__eyebrow .caps { color: var(--green-deep); }
.hero__title {
	font-family: var(--sans);
	font-weight: 900;
	font-size: clamp(40px, 4.4vw, 68px);
	line-height: 1.02;
	letter-spacing: -0.03em;
	color: var(--ink);
	margin: 0;
}
.hero__title em.serif-italic { color: var(--green-deep); font-weight: 300; letter-spacing: -0.02em; }
.hero__lead {
	font-size: clamp(15px, 1.1vw, 17px);
	line-height: 1.55;
	color: var(--ink-soft);
	font-weight: 400;
	max-width: 520px;
	margin: 0;
}
.hero__cta {
	display: flex;
	gap: 12px;
	align-items: center;
	flex-wrap: wrap;
	margin-top: 4px;
}
.hero__cta .btn-primary,
.hero__cta .btn-ghost { padding: 14px 22px; font-size: 12px; }
/* .hero__cta-note: disponibile per microcopy sotto la CTA (es. "Senza
   impegno, senza vendite.") quando il copy sara' approvato da Isabella. */
.hero__cta-note {
	font-size: 12px;
	color: var(--muted);
	font-style: italic;
	letter-spacing: 0.02em;
}
/* Fallback mobile (Vanta non viene caricato sotto 861px): gradient
   animato CSS, zero KB. Disattivato con prefers-reduced-motion. */
@keyframes if-hero-gradient {
	0%, 100% { background-position: 0% 50%; }
	50%      { background-position: 100% 50%; }
}
@media (max-width: 480px) {
	.hero__title { font-size: 28px; }
	.hero__lead { font-size: 14px; }
	.hero__cta { flex-direction: column; align-items: stretch; gap: 10px; }
	.hero__cta a { justify-content: center; }
}

/* Stage: scena media full-bleed dietro a tutto */
.hero__stage { position: absolute; inset: 0; z-index: 0; overflow: hidden; background: var(--ivory); }
.hero__media {
	position: absolute; inset: 0;
	opacity: 0; visibility: hidden;
	transition: opacity 0.9s ease, visibility 0s linear 0.9s;
}
.hero__media.is-active { opacity: 1; visibility: visible; transition: opacity 0.9s ease; }
.hero__media picture { display: contents; }
.hero__media-img,
.hero__media-poster,
.hero__media-video {
	position: absolute; inset: 0;
	width: 100%; height: 100%;
	object-fit: cover;
	object-position: var(--pos-d, 50% 50%);
}
/* il video copre il poster solo quando sta davvero riproducendo */
.hero__media-video { opacity: 0; transition: opacity 0.6s ease; }
.hero__media-video.is-playing { opacity: 1; }

/* Vanta (slide Team): canvas + fallback gradient animato (mobile/reduced/pre-load) */
.hero__media-vanta {
	position: absolute; inset: 0; overflow: hidden;
	background:
		radial-gradient(135% 95% at 72% 8%, rgba(96,168,130,0.55) 0%, rgba(96,168,130,0) 54%),
		linear-gradient(155deg, #2D6A4F 0%, #225C43 50%, #173E2D 100%);
}
.hero__media-vanta canvas { display:block; width:100% !important; height:100% !important; position:absolute !important; inset:0 !important; }

/* Scrim: fonde media e testo. Desktop = orizzontale (ivory a sinistra). */
.hero__scrim {
	position: absolute; inset: 0; z-index: 1; pointer-events: none;
	background:
		linear-gradient( to right,
			rgba(240,240,240,0.98) 0%,
			rgba(240,240,240,0.96) 30%,
			rgba(240,240,240,0.82) 44%,
			rgba(240,240,240,0.40) 56%,
			rgba(240,240,240,0.06) 70%,
			rgba(240,240,240,0) 84%
		);
}
.hero__scrim::after {
	content: ''; position: absolute; inset: 0;
	background: linear-gradient( to right, transparent 62%, rgba(15,42,31,0.16) 100% );
}

/* Inner: colonna sinistra (claim alto + rotator basso) */
.hero__inner {
	position: relative; z-index: 2;
	min-height: 100svh; max-height: 960px;
	display: flex; flex-direction: column; justify-content: center;
	gap: clamp(20px, 3.5vh, 44px);
	padding: 100px clamp(32px,4vw,56px) 44px max(28px, calc((100vw - 1320px) / 2));
}

@media (prefers-reduced-motion: reduce) {
	.hero__media-vanta { animation: none; }
	.hero__media { transition: none; }
}

/* ── Desktop (>=861): Opzione A — card offerta a destra sopra il media ── */
@media (min-width: 861px) {
	.hero__inner {
		display: grid;
		grid-template-columns: minmax(0, 1.02fr) minmax(0, 0.98fr);
		align-items: stretch;
		gap: clamp(24px, 3vw, 56px);
	}
}

/* ── Mobile (<=860): media in alto, testo su ivory in basso ── */
@media (max-width: 860px) {
	.hero__stage { height: 50vh; bottom: auto; }
	.hero__scrim {
		height: 56vh; bottom: auto;
		background: linear-gradient( to bottom,
			rgba(240,240,240,0) 38%,
			rgba(240,240,240,0.70) 76%,
			var(--ivory) 100% );
	}
	.hero__scrim::after { display: none; }
	.hero__media-img, .hero__media-poster, .hero__media-video { object-position: var(--pos-m, 50% 20%); }
	.hero__inner {
		min-height: 0; max-height: none; justify-content: flex-start;
		gap: 22px;
		padding: 44vh var(--gutter) 36px;
	}
}
@media (max-width: 480px) {
	.hero__title { font-size: 30px; }
	.hero__lead { font-size: 14px; }
	.hero__cta { flex-direction: column; align-items: stretch; gap: 10px; }
	.hero__cta a { justify-content: center; }
}

/* ──────────────────────────────────────────────────────────────────── */
/* HERO — "2 territori" con effetto specchio (post-call 23 giu)         */
/* Riusa .hero__stage/.hero__media/.hero__media-* del Concept B; override */
/* dello scrim (direzionale) e layout proprio (.hero__frame/.hero__col). */
/* ──────────────────────────────────────────────────────────────────── */

.hero--territories { position: relative; isolation: isolate; min-height: 100svh; }

/* Crossfade pulito: l'uscente sparisce in fretta (niente foto che indugia
   sulla scena Vanta), l'entrante sale piano dall'ivory dello stage. */
.hero--territories .hero__media { transition: opacity 0.3s ease, visibility 0s linear 0.3s; }
.hero--territories .hero__media.is-active { opacity: 1; visibility: visible; z-index: 1; transition: opacity 0.7s ease; }

/* Scrim direzionale DENTRO ogni layer media: viaggia col crossfade, così la
   foto non viene mai "scoperta" sul lato sbagliato quando il testo flippa
   (niente flash di Isabella sul lato Vanta). Lo scrim standalone resta solo
   per il mobile (fade verticale, dove non c'è mirror). */
.hero--territories .hero__scrim::after { display: none; }
.hero--territories .hero__scrim { background: none; }
.hero--territories .hero__media::after { content: ''; position: absolute; inset: 0; pointer-events: none; }
.hero--territories .hero__media[data-side="left"]::after {
	background: linear-gradient( to right,
		rgba(240,240,240,0.98) 0%, rgba(240,240,240,0.95) 30%, rgba(240,240,240,0.80) 44%,
		rgba(240,240,240,0.35) 58%, rgba(240,240,240,0.04) 72%, rgba(240,240,240,0) 86% );
}
.hero--territories .hero__media[data-side="right"]::after {
	background: linear-gradient( to left,
		rgba(240,240,240,0.98) 0%, rgba(240,240,240,0.95) 30%, rgba(240,240,240,0.80) 44%,
		rgba(240,240,240,0.35) 58%, rgba(240,240,240,0.04) 72%, rgba(240,240,240,0) 86% );
}

.hero__frame {
	position: relative; z-index: 2;
	min-height: 100svh; max-height: 980px;
	display: flex; align-items: center;
	padding: 104px max(28px, calc((100vw - 1320px) / 2)) 56px;
}
.hero__col {
	width: 100%; max-width: 580px;
	display: flex; flex-direction: column; gap: clamp(20px, 3vh, 34px);
}
.hero--territories.is-text-left  .hero__col { margin-right: auto; text-align: left; }
.hero--territories.is-text-right .hero__col { margin-left: auto; text-align: right; }

.hero__umbrella { display: flex; align-items: center; gap: 12px; margin: 0; }
.hero--territories.is-text-right .hero__umbrella { flex-direction: row-reverse; }
.hero__umbrella-rule { width: 30px; height: 1.5px; background: var(--gold); flex: 0 0 auto; }
.hero__umbrella .caps { color: var(--gold-deep); font-size: 11px; }

.hero__scenes { position: relative; }
.hero__terr { display: none; }
.hero__terr.is-active {
	display: flex; flex-direction: column; gap: 16px;
	animation: if-fade-in 0.5s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.hero__terr-eyebrow { color: var(--green-deep); font-size: 11px; }
.hero__terr-q {
	font-family: var(--sans); font-weight: 900;
	font-size: clamp(34px, 4vw, 58px); line-height: 1.04; letter-spacing: -0.03em;
	color: var(--ink); margin: 0;
}
.hero__terr-line { font-size: clamp(15px, 1.15vw, 18px); line-height: 1.55; color: var(--ink-soft); margin: 0; max-width: 30em; }
.hero--territories.is-text-right .hero__terr-line { margin-left: auto; }
.hero__terr-cta {
	display: inline-flex; align-items: center; gap: 12px; align-self: flex-start;
	padding: 14px 24px; background: var(--green-deep); color: var(--white);
	font-family: var(--sans); font-weight: 700; font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase;
	text-decoration: none; transition: background 0.25s, gap 0.25s;
}
.hero--territories.is-text-right .hero__terr-cta { align-self: flex-end; }
.hero__terr-cta:hover { background: var(--green); gap: 16px; }

.hero__dots { display: flex; gap: 18px; }
.hero--territories.is-text-right .hero__dots { justify-content: flex-end; }
.hero__dot { display: flex; align-items: center; gap: 9px; background: transparent; border: 0; padding: 0; cursor: pointer; font-family: var(--sans); }
.hero__dot-track { width: 28px; height: 4px; border-radius: 2px; background: rgba(44,62,80,0.18); position: relative; overflow: hidden; transition: background 0.3s; }
.hero__dot.is-active .hero__dot-track { background: rgba(44,62,80,0.28); }
.hero__dot-bar { position: absolute; inset: 0; background: var(--gold); transform: translateX(-100%); }
.hero__dot.is-active .hero__dot-bar { animation: if-dot-fill 5s linear forwards; }
.hero--territories.is-paused .hero__dot-bar { animation-play-state: paused; }
@keyframes if-dot-fill { from { transform: translateX(-100%); } to { transform: translateX(0); } }
.hero__dot-label { font-size: 10px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-soft); opacity: 0.55; white-space: nowrap; transition: opacity 0.3s, color 0.3s; }
.hero__dot.is-active .hero__dot-label { color: var(--green-deep); opacity: 1; }
.hero__dot:hover .hero__dot-label { opacity: 1; }

@media (prefers-reduced-motion: reduce) {
	.hero--territories .hero__media { transition: none; }
	.hero__dot-bar { animation: none !important; }
}

/* Mobile (<=860): niente mirror — media in alto, testo su ivory a sinistra. */
@media (max-width: 860px) {
	.hero--territories { min-height: 0; }
	.hero--territories .hero__stage { height: 50vh; bottom: auto; }
	.hero--territories .hero__media::after { display: none; } /* niente scrim orizzontale su mobile */
	.hero--territories .hero__scrim,
	.hero--territories.is-text-left .hero__scrim,
	.hero--territories.is-text-right .hero__scrim {
		height: 56vh; bottom: auto;
		background: linear-gradient( to bottom, rgba(240,240,240,0) 38%, rgba(240,240,240,0.70) 76%, var(--ivory) 100% );
	}
	.hero--territories .hero__media-img { object-position: var(--pos-m, 50% 12%); }
	.hero__frame { min-height: 0; max-height: none; align-items: flex-start; padding: 44vh var(--gutter) 36px; }
	.hero--territories.is-text-left .hero__col,
	.hero--territories.is-text-right .hero__col { max-width: none; margin: 0; text-align: left; }
	.hero--territories.is-text-right .hero__umbrella { flex-direction: row; }
	.hero--territories.is-text-right .hero__terr-line { margin-left: 0; }
	.hero--territories.is-text-right .hero__terr-cta { align-self: flex-start; }
	.hero--territories.is-text-right .hero__dots { justify-content: flex-start; }
	.hero--territories .hero__dots {
		margin-top: 30px; padding-top: 24px;
		border-top: 1px solid rgba(44,62,80,0.14);
	}
}
@media (max-width: 480px) {
	.hero__terr-q { font-size: 30px; }
	.hero__terr-cta { width: 100%; justify-content: center; }
}

/* Onde animate per la scena Cambiamento su mobile (Vanta e desktop-only):
   pseudo-elementi con onda SVG che scorre. Niente WebGL, ~0 KB. */
@keyframes if-wave-x { from { transform: translateX(0); } to { transform: translateX(25%); } }
@media (max-width: 860px) {
	.hero--territories .hero__frame { padding-top: 52vh; }
	.hero--territories .hero__media-vanta::before,
	.hero--territories .hero__media-vanta::after {
		content: ''; position: absolute; left: -50%; right: -50%; bottom: 0; height: 70%;
		background-repeat: repeat-x; background-position: 0 bottom; background-size: 50% 100%;
		background-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120' preserveAspectRatio='none'><path d='M0,60 C150,100 350,20 600,60 C850,100 1050,20 1200,60 L1200,120 L0,120 Z' fill='%23ffffff'/></svg>");
		opacity: 0.12; animation: if-wave-x 14s linear infinite;
	}
	.hero--territories .hero__media-vanta::after { height: 52%; opacity: 0.08; animation-duration: 22s; animation-direction: reverse; }
}
@media (prefers-reduced-motion: reduce) {
	.hero--territories .hero__media-vanta::before,
	.hero--territories .hero__media-vanta::after { animation: none; }
}

/* ──────────────────────────────────────────────────────────────────── */
/* MANIFESTO                                                            */
/* ──────────────────────────────────────────────────────────────────── */

.manifesto {
	background: var(--green-deep);
	color: var(--ivory);
	position: relative;
	overflow: hidden;
}
.manifesto__watermark { position: absolute; right: -120px; top: 60px; opacity: 0.06; pointer-events: none; }
.manifesto__grid {
	display: grid;
	grid-template-columns: 0.4fr 1.6fr;
	gap: clamp(40px, 6vw, 96px);
	align-items: start;
	position: relative;
}
.manifesto__tag { color: var(--gold-text); }
.manifesto__pitch {
	margin-top: 28px;
	font-size: clamp(20px, 1.6vw, 22px);
	line-height: 1.45;
	color: var(--ivory-deep);
	font-weight: 300;
	max-width: 260px;
}
.manifesto__title {
	font-size: clamp(36px, 5vw, 80px);
	line-height: 1.02;
	font-weight: 200;
	color: var(--white);
	letter-spacing: -0.02em;
}
.manifesto__title em.serif-italic { color: var(--gold-text); }
.manifesto__statement {
	margin-top: 36px;
	font-size: clamp(19px, 1.6vw, 23px);
	line-height: 1.5;
	color: var(--ivory);
	max-width: 760px;
	font-weight: 300;
	font-style: italic;
}
.manifesto__statement-highlight { font-style: normal; color: var(--gold-text); }
.manifesto__pillars {
	margin-top: 64px;
	padding-top: 36px;
	border-top: 1px solid rgba(240, 240, 240, 0.22);
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 48px;
}
.manifesto__pillar-key { color: var(--gold-text); margin-bottom: 14px; }
.manifesto__pillar-value { font-size: 16px; line-height: 1.6; color: var(--ivory); font-weight: 300; }
.manifesto__footer {
	margin-top: 48px;
	display: flex;
	gap: 18px;
	align-items: center;
	flex-wrap: wrap;
}
.manifesto__cta {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	padding: 14px 22px;
	border: 1.5px solid var(--gold-text);
	color: var(--gold-text);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	transition: background 0.25s, color 0.25s, gap 0.25s;
}
.manifesto__cta:hover { background: var(--gold); border-color: var(--gold); color: var(--green-ink); gap: 18px; }
.manifesto__hint { color: var(--ivory-deep); opacity: 0.65; }

@media (max-width: 860px) {
	.manifesto__grid { grid-template-columns: 1fr; }
	.manifesto__pillars { grid-template-columns: 1fr; gap: 28px; }
}

/* ──────────────────────────────────────────────────────────────────── */
/* SINTOMI                                                              */
/* ──────────────────────────────────────────────────────────────────── */

.sintomi { background: var(--paper); position: relative; }
.sintomi::before {
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: clamp(120px, 16vw, 200px);
	height: 3px;
	background: linear-gradient(90deg, transparent, var(--green), transparent);
	opacity: 0.6;
}
.sintomi__card { background: var(--white); }
.sintomi__card:hover { background: var(--ivory); }
.sintomi__header {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(40px, 6vw, 96px);
	margin-bottom: clamp(36px, 4vw, 56px);
	align-items: end;
}
.sintomi__title {
	margin-top: 24px;
	font-size: clamp(40px, 5.2vw, 84px);
	line-height: 1.02;
	font-weight: 200;
	color: var(--ink);
	letter-spacing: -0.02em;
}
.sintomi__title em.serif-italic { color: var(--green); }
.sintomi__intro {
	font-size: 17px;
	line-height: 1.65;
	color: var(--ink-soft);
	max-width: 460px;
	justify-self: end;
	padding-bottom: 8px;
}
.sintomi__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	border-top: 1px solid var(--rule);
	border-left: 1px solid var(--rule);
}
.sintomi__card {
	padding: clamp(28px, 3.5vw, 52px);
	border-right: 1px solid var(--rule);
	border-bottom: 1px solid var(--rule);
	background: var(--white);
	color: inherit;
	text-decoration: none;
	transition: background 0.3s, transform 0.35s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.35s, border-color 0.35s;
	position: relative;
	min-height: 320px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	gap: 28px;
	cursor: pointer;
}
.sintomi__card::after {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 3px;
	background: var(--green);
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.sintomi__card:hover,
.sintomi__card:focus-visible {
	background: var(--ivory);
	transform: translateY(-6px);
	box-shadow: 0 14px 40px rgba(15, 42, 31, 0.12);
	border-color: var(--green);
	z-index: 1;
	outline: none;
}
.sintomi__card:hover::after,
.sintomi__card:focus-visible::after { transform: scaleX(1); }
.sintomi__card-head { display: flex; align-items: baseline; justify-content: space-between; }
.sintomi__card-n {
	font-size: clamp(56px, 5.5vw, 92px);
	font-weight: 200;
	font-style: italic;
	color: var(--green);
	line-height: 0.9;
	letter-spacing: -0.04em;
	transition: color 0.3s;
}
.sintomi__card:hover .sintomi__card-n { color: var(--green-deep); }
.sintomi__card-tag { color: var(--muted); }
.sintomi__card-headline {
	font-size: clamp(22px, 2.4vw, 32px);
	font-weight: 400;
	color: var(--ink);
	line-height: 1.15;
	letter-spacing: -0.01em;
	transition: color 0.3s;
}
.sintomi__card:hover .sintomi__card-headline { color: var(--green-deep); }
.sintomi__card-text { margin-top: 16px; font-size: 15px; line-height: 1.65; color: var(--ink-soft); }
.sintomi__card-link {
	opacity: 0.45;
	transform: translateX(0);
	transition: opacity 0.3s, transform 0.3s, gap 0.3s;
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: var(--green);
	font-weight: 700;
}
.sintomi__card:hover .sintomi__card-link,
.sintomi__card:focus-visible .sintomi__card-link {
	opacity: 1;
	gap: 14px;
}
.sintomi__footer {
	margin-top: 56px;
	padding-top: 24px;
	border-top: 1px solid var(--rule);
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 16px;
}
.sintomi__footer-text { font-size: 19px; color: var(--green); font-weight: 400; }
.sintomi__footer-cta { background: var(--green); }
.sintomi__footer-cta:hover { background: var(--green-deep); }

/* 6a cella: card CTA invertita (verde pieno). Chiude la griglia 2-col
   senza cella vuota E aggiunge un punto di conversione. */
.sintomi__card--cta {
	background: var(--green-deep);
	color: var(--ivory);
	justify-content: center;
	gap: 18px;
}
.sintomi__card--cta:hover,
.sintomi__card--cta:focus-visible {
	background: var(--green-ink);
	border-color: var(--green-ink);
}
.sintomi__card--cta .sintomi__card-tag { color: var(--gold-text); }
.sintomi__card--cta .sintomi__card-headline { color: var(--white); }
.sintomi__card--cta:hover .sintomi__card-headline { color: var(--white); }
.sintomi__card--cta .sintomi__card-text { color: rgba(255, 255, 255, 0.82); }
.sintomi__card--cta .sintomi__card-link { color: var(--gold-text); opacity: 1; }

@media (max-width: 860px) {
	.sintomi__header { grid-template-columns: 1fr; }
	.sintomi__intro { justify-self: start; }
	.sintomi__grid { grid-template-columns: 1fr; }
}

/* Feedback al tocco dove non c'e' hover (mobile/tablet) */
@media (hover: none) {
	.sintomi__card:active,
	.case-histories__card:active,
	.blog-card:active,
	.team-others__card:active,
	.valori-page__card:active { transform: scale(0.985); transition-duration: 0.15s; }
}

/* ──────────────────────────────────────────────────────────────────── */
/* SERVIZI (accordion)                                                  */
/* ──────────────────────────────────────────────────────────────────── */

.servizi {
	/* Verde brand (come la sezione Contatti), non il --green-deep "premuto":
	   era l'unica sezione su un verde piu' scuro delle altre. */
	background: var(--green);
	color: var(--ivory);
	position: relative;
	overflow: hidden;
}
.servizi__watermark { position: absolute; left: -60px; bottom: -40px; opacity: 0.04; pointer-events: none; }
.servizi__header {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	flex-wrap: wrap;
	gap: 40px;
	margin-bottom: clamp(50px, 7vw, 90px);
	position: relative;
}
.servizi__tag { color: var(--gold-text); }
.servizi__title {
	margin-top: 24px;
	font-size: clamp(40px, 5.6vw, 88px);
	line-height: 1;
	font-weight: 200;
	color: var(--white);
	letter-spacing: -0.02em;
}
.servizi__title em.serif-italic { color: var(--gold-text); }
.servizi__intro {
	font-size: 17px;
	line-height: 1.6;
	color: var(--ivory-deep);
	max-width: 380px;
	font-weight: 300;
}
.servizi__list {
	border-top: 1px solid rgba(240, 240, 240, 0.22);
	position: relative;
}
.servizi__row {
	border-bottom: 1px solid rgba(240, 240, 240, 0.22);
	transition: background 0.35s;
}
.servizi__row.is-open { background: rgba(255, 255, 255, 0.04); }
.servizi__row-header {
	width: 100%;
	display: grid;
	grid-template-columns: 90px 1fr 1.6fr 80px;
	gap: clamp(16px, 2vw, 36px);
	align-items: center;
	padding: clamp(22px, 2.6vw, 36px) clamp(16px, 2vw, 32px);
	background: transparent;
	border: 0;
	text-align: left;
	color: inherit;
	cursor: pointer;
}
.servizi__row-n-wrap {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 8px;
}
.servizi__row-n {
	font-size: clamp(44px, 4.2vw, 64px);
	font-weight: 200;
	font-style: italic;
	color: var(--ivory-deep);
	line-height: 0.9;
	transition: color 0.3s;
}
.servizi__row.is-open .servizi__row-n { color: var(--gold-text); }
.servizi__row-title { color: var(--white); margin-bottom: 6px; }
.servizi__row-tag { color: rgba(255, 255, 255, 0.82); font-size: 16px; font-weight: 400; }
/* Leggibilità aumentata su richiesta cliente (call 7 giu: "incrementare
   dimensione e spessore dei testi nei pannelli descrittivi"). */
.servizi__row-desc {
	font-size: 15px;
	line-height: 1.6;
	color: var(--white);
	opacity: 0.92;
	font-weight: 400;
}
.servizi__row-toggle {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: transparent;
	border: 1.5px solid rgba(240, 240, 240, 0.4);
	color: var(--ivory);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: all 0.3s;
	font-size: 22px;
	font-weight: 200;
	line-height: 1;
	justify-self: end;
}
.servizi__row.is-open .servizi__row-toggle {
	background: var(--gold);
	border-color: var(--gold);
	color: var(--green-ink);
	transform: rotate(45deg);
}
/* Pannello: grid-template-rows 0fr -> 1fr anima QUALSIASI altezza di
   contenuto (il vecchio max-height: 600px tagliava i pannelli alti su
   mobile). Il wrapper -clip fa da finestra, l'inner tiene il padding. */
.servizi__row-panel {
	display: grid;
	grid-template-rows: 0fr;
	transition: grid-template-rows 0.6s var(--ease), visibility 0.6s;
	visibility: hidden;
}
.servizi__row.is-open .servizi__row-panel {
	grid-template-rows: 1fr;
	visibility: visible;
}
.servizi__row-panel-clip { overflow: hidden; min-height: 0; }
.servizi__row-panel-inner {
	padding: 8px clamp(16px, 2vw, 32px) 36px;
	display: grid;
	grid-template-columns: 90px 1fr 1.6fr 80px;
	gap: clamp(16px, 2vw, 36px);
}
.servizi__outcomes-title { color: var(--gold-text); margin-bottom: 14px; }
.servizi__outcomes-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.servizi__outcomes-list li {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	font-size: 15px;
	line-height: 1.55;
	color: var(--ivory);
	font-weight: 400;
}
.servizi__meta { display: flex; flex-direction: column; gap: 22px; }
.servizi__meta-label { color: var(--gold-text); margin-bottom: 8px; }
.servizi__meta-value { font-size: 22px; color: var(--white); font-weight: 300; font-style: italic; }
.servizi__meta-mini { font-size: 14px; color: rgba(255, 255, 255, 0.82); font-weight: 400; }
.servizi__meta-cta {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	padding-top: 12px;
	border-top: 1px solid rgba(240, 240, 240, 0.3);
	color: var(--white);
	align-self: flex-start;
}
.servizi__footer {
	margin-top: 40px;
	padding-top: 28px;
	border-top: 1px solid rgba(240, 240, 240, 0.22);
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 16px;
}
.servizi__footer-text { font-size: 18px; color: rgba(255, 255, 255, 0.82); font-weight: 400; max-width: 480px; }
.servizi__footer-cta {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	padding: 14px 22px;
	background: var(--gold);
	color: var(--green-ink);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	transition: background 0.25s, gap 0.25s;
}
.servizi__footer-cta:hover { background: var(--gold-text); gap: 18px; }

@media (max-width: 860px) {
	.servizi__row-header { grid-template-columns: 60px 1fr 48px; padding: clamp(20px, 3vw, 28px) clamp(16px, 3vw, 24px); }
	.servizi__row-desc { display: none; }
	.servizi__row-panel-inner { grid-template-columns: 1fr; padding: 8px clamp(16px, 3vw, 24px) 32px; }
}

/* ──────────────────────────────────────────────────────────────────── */
/* METODO (PONTE)                                                       */
/* ──────────────────────────────────────────────────────────────────── */

.metodo { background: var(--paper); position: relative; overflow: hidden; }
.metodo__header {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(40px, 6vw, 96px);
	margin-bottom: clamp(36px, 4vw, 56px);
	align-items: end;
}
.metodo__title {
	margin-top: 24px;
	font-size: clamp(40px, 5.6vw, 84px);
	line-height: 1;
	font-weight: 200;
	color: var(--ink);
	letter-spacing: -0.02em;
}
.metodo__title em.serif-italic { color: var(--green); }
.metodo__intro { padding-bottom: 8px; }
.metodo__intro-text { font-size: 17px; line-height: 1.65; color: var(--ink-soft); max-width: 480px; }
.metodo__intro-text em.serif-italic { color: var(--green); }
.metodo__meta {
	margin-top: 24px;
	display: flex;
	gap: 24px;
	align-items: center;
	flex-wrap: wrap;
}
.metodo__meta-label { color: var(--green); margin-bottom: 4px; }
.metodo__meta-value { font-size: 20px; color: var(--ink); }
.metodo__meta-divider { width: 1px; height: 36px; background: var(--rule); }
.metodo__flow {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	border-top: 2px solid var(--rule);
	border-bottom: 1px solid var(--rule);
	align-items: stretch;
	position: relative;
}
.metodo__progress {
	position: absolute;
	top: -2px;
	left: 0;
	right: 0;
	height: 2px;
	pointer-events: none;
}
.metodo__progress-fill {
	display: block;
	height: 100%;
	background: var(--green);
	transform: scaleX(0);
	transform-origin: left center;
	/* Niente transition: scaleX e' scrubbed da ScrollTrigger (motion.js),
	   una transition qui farebbe inseguire lo scroll invece di seguirlo. */
}
.metodo__card { opacity: 0.45; transition: opacity 0.5s, transform 0.5s; }
.metodo__card.is-active { opacity: 1; }
.metodo__card.is-active .metodo__card-letter { color: var(--green-deep); }
.metodo__card.is-active .metodo__card-phase { opacity: 1; }
/* Su mobile / reduced-motion: tutte le card visibili */
@media (max-width: 819px) { .metodo__card { opacity: 1; } }
.metodo__card {
	padding: clamp(20px, 2vw, 32px) clamp(16px, 1.6vw, 24px);
	border-right: 1px solid var(--rule);
	position: relative;
	display: flex;
	flex-direction: column;
	min-height: 320px;
}
.metodo__card.is-last { border-right: none; }
.metodo__card-top {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	margin-bottom: 18px;
}
.metodo__card-phase { color: var(--green); opacity: 0.7; }
.metodo__card-arrow {
	position: absolute;
	right: -12px;
	top: 50%;
	transform: translateY(-50%);
	z-index: 1;
}
.metodo__card-letter {
	font-family: var(--sans);
	font-weight: 900;
	font-size: clamp(72px, 8vw, 140px);
	line-height: 0.86;
	color: var(--green);
	letter-spacing: -0.04em;
}
.metodo__card-word {
	margin-top: 16px;
	font-size: clamp(20px, 1.8vw, 26px);
	color: var(--ink);
	font-weight: 400;
}
.metodo__card-caption {
	margin-top: 14px;
	font-size: 13.5px;
	line-height: 1.55;
	color: var(--muted);
	flex: 1;
}
.metodo__footer {
	margin-top: 32px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 16px;
}
.metodo__footer-side { color: var(--green); }
.metodo__footer-trail { display: flex; gap: 6px; align-items: center; opacity: 0.6; }

/* Sub-head delle due letture di PONTE (fasi / principi) */
.metodo__subhead { margin: clamp(28px, 3.5vw, 44px) 0 24px; max-width: 640px; }
.metodo__subhead--alt { margin-top: clamp(40px, 5vw, 64px); }
.metodo__subhead-k { display: block; color: var(--green); font-size: 11px; margin-bottom: 10px; }
.metodo__subhead-title { font-size: clamp(26px, 3vw, 38px); color: var(--ink); line-height: 1.1; }
.metodo__subhead-text { margin-top: 12px; font-size: 16px; line-height: 1.6; color: var(--ink-soft); }

/* Flow dei principi: card sempre piene (niente progressione JS, niente frecce) */
.metodo__flow--principi .metodo__card { opacity: 1; }
.metodo__flow--principi .metodo__card-letter { color: var(--green-deep); }
.metodo__flow--principi .metodo__card-phase { opacity: 1; }

@media (max-width: 860px) {
	.metodo__header { grid-template-columns: 1fr; }
	.metodo__flow { grid-template-columns: 1fr; }
	.metodo__card { border-right: 0; border-bottom: 1px solid var(--rule); }
	.metodo__card.is-last { border-bottom: 0; }
	.metodo__card-arrow { display: none; }
}

/* ──────────────────────────────────────────────────────────────────── */
/* NUMERI                                                               */
/* ──────────────────────────────────────────────────────────────────── */

.numeri { background: var(--ivory); border-top: 1px solid var(--rule); }
.numeri__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: clamp(20px, 3vw, 60px);
}
.numeri__block { padding-left: clamp(20px, 3vw, 60px); border-left: 1px solid var(--rule); }
.numeri__block.is-first { padding-left: 0; border-left: none; }
.numeri__value {
	font-size: clamp(56px, 6.5vw, 104px);
	font-weight: 200;
	font-style: italic;
	color: var(--green);
	line-height: 0.95;
	letter-spacing: -0.04em;
}
.numeri__suffix { color: var(--gold-deep); }
.numeri__label { margin-top: 14px; font-size: 14px; line-height: 1.5; color: var(--muted); max-width: 200px; }

@media (max-width: 860px) {
	.numeri__grid { grid-template-columns: repeat(2, 1fr); }
	.numeri__block:nth-child(3) { padding-left: 0; border-left: 0; }
}
@media (max-width: 480px) {
	.numeri__grid { grid-template-columns: 1fr; }
	.numeri__block { padding-left: 0; border-left: 0; }
}

/* ──────────────────────────────────────────────────────────────────── */
/* CHI SONO                                                             */
/* ──────────────────────────────────────────────────────────────────── */

.chi-sono { background: var(--ivory); position: relative; }
.chi-sono__grid {
	display: grid;
	grid-template-columns: 0.9fr 1.1fr;
	gap: clamp(40px, 6vw, 100px);
	align-items: start;
}
.chi-sono__photo {
	position: relative;
	aspect-ratio: 4 / 5;
	overflow: hidden;
	max-height: 720px;
	margin: 0;
	background: var(--paper);
}
.chi-sono__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 30%;
}
/* Collage editoriale (3 ritratti): verticale grande a sx + 2 impilate a dx,
   stesso ingombro 4:5 della vecchia foto singola. */
.chi-sono__collage {
	display: grid;
	grid-template-columns: 1.12fr 0.88fr;
	grid-template-rows: 1fr 1fr;
	gap: 12px;
	aspect-ratio: 4 / 5;
	max-height: 720px;
}
.chi-sono__collage-item {
	position: relative; overflow: hidden; margin: 0;
	min-width: 0; min-height: 0; background: var(--paper);
}
.chi-sono__collage-item img { width: 100%; height: 100%; object-fit: cover; display: block; }
.chi-sono__collage-item--main { grid-row: 1 / 3; }
.chi-sono__collage-item--main img { object-position: 50% 20%; }
.chi-sono__collage-item--top img  { object-position: 62% 38%; }
.chi-sono__collage-item--bot img  { object-position: 50% 42%; }
@media (max-width: 480px) { .chi-sono__collage { gap: 8px; } }
.chi-sono__photo-pin {
	position: absolute;
	top: 24px;
	left: 24px;
	padding: 8px 14px;
	background: var(--green);
}
.chi-sono__photo-pin .caps { color: var(--white); }
.chi-sono__quote {
	margin-top: 28px;
	padding-top: 24px;
	border-top: 1px solid var(--rule);
	display: flex;
	align-items: baseline;
	gap: 18px;
	flex-wrap: wrap;
}
.chi-sono__quote-text {
	font-size: 28px;
	color: var(--green);
	line-height: 1;
	font-weight: 300;
	letter-spacing: -0.02em;
}
.chi-sono__quote-author { color: var(--muted); }
.chi-sono__title {
	margin-top: 24px;
	font-size: clamp(40px, 5.4vw, 84px);
	line-height: 1;
	font-weight: 200;
	color: var(--ink);
	letter-spacing: -0.02em;
}
.chi-sono__title em.serif-italic { color: var(--green); }
.chi-sono__bio {
	margin-top: 32px;
	font-size: clamp(17px, 1.4vw, 19px);
	line-height: 1.6;
	color: var(--ink-soft);
	font-weight: 300;
	max-width: 580px;
}
.chi-sono__bio p + p { margin-top: 18px; }
.chi-sono__bio em.serif-italic { color: var(--green); }
.chi-sono__bio-drop {
	font-size: clamp(56px, 5vw, 72px);
	float: left;
	line-height: 0.82;
	margin-right: 10px;
	margin-top: 4px;
	color: var(--green);
	font-style: italic;
	font-weight: 200;
}
.chi-sono__certs { margin-top: 36px; display: flex; flex-wrap: wrap; gap: 8px; }
.chi-sono__cert {
	display: inline-block;
	padding: 7px 14px;
	border: 1px solid var(--rule);
	background: var(--paper);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.05em;
	color: var(--ink-soft);
	text-transform: uppercase;
}
.chi-sono__badges { margin-top: 36px; padding-top: 28px; border-top: 1px solid var(--rule); }
.chi-sono__badges-eyebrow { color: var(--green); margin-bottom: 18px; }
.chi-sono__badges-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.chi-sono__badge {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 14px 18px;
	background: var(--paper);
	border: 1px solid var(--rule);
	color: var(--green-deep);
	transition: background 0.25s, transform 0.25s, border-color 0.25s, color 0.25s;
}
.chi-sono__badge:hover { background: var(--green); color: var(--white); border-color: var(--green); transform: translateY(-2px); }
.chi-sono__badge svg { flex-shrink: 0; }
.chi-sono__badge-text { display: flex; flex-direction: column; line-height: 1.25; }
.chi-sono__badge-text strong { font-size: 13px; font-weight: 700; letter-spacing: 0.03em; }
.chi-sono__badge-text span { font-size: 11px; color: var(--muted); transition: color 0.25s; }
.chi-sono__badge:hover .chi-sono__badge-text span { color: var(--ivory); }
@media (max-width: 480px) { .chi-sono__badges-grid { grid-template-columns: 1fr; } }

.chi-sono__valori { margin-top: 56px; padding-top: 36px; border-top: 1px solid var(--rule); }
.chi-sono__valori-eyebrow { color: var(--green); margin-bottom: 24px; }
.chi-sono__valori-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.chi-sono__valore-word {
	font-size: 22px;
	color: var(--ink);
	font-weight: 400;
	font-style: italic;
	letter-spacing: -0.01em;
}
.chi-sono__valore-sub { margin-top: 8px; font-size: 13px; line-height: 1.5; color: var(--muted); }

@media (max-width: 860px) {
	.chi-sono__grid { grid-template-columns: 1fr; }
	.chi-sono__valori-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
	.chi-sono__valori-grid { grid-template-columns: 1fr; }
}

/* Testimonianze: sezione rimossa (cliente specializzata in conflitti,
   le aziende non vogliono esporsi pubblicamente). Riattivabile quando
   avremo permessi espliciti di citazione. */

/* ──────────────────────────────────────────────────────────────────── */
/* CASE HISTORIES                                                       */
/* ──────────────────────────────────────────────────────────────────── */

.case-histories { background: var(--paper); position: relative; }
.case-histories__header {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	flex-wrap: wrap;
	gap: 32px;
	margin-bottom: clamp(50px, 7vw, 80px);
}
.case-histories__title {
	margin-top: 24px;
	font-size: clamp(40px, 5.4vw, 80px);
	line-height: 1;
	font-weight: 200;
	color: var(--ink);
	letter-spacing: -0.02em;
}
.case-histories__title em.serif-italic { color: var(--green); }
.case-histories__intro { font-size: 16px; line-height: 1.55; color: var(--muted); max-width: 360px; }
.case-histories__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(20px, 2.5vw, 40px);
}
.case-histories__card {
	background: var(--white);
	color: var(--ink);
	border: 1px solid var(--rule);
	padding: clamp(28px, 2.8vw, 40px);
	display: flex;
	flex-direction: column;
	gap: 24px;
	min-height: 380px;
	transition: background 0.4s, color 0.4s, border-color 0.4s, transform 0.4s;
	cursor: pointer;
}
.case-histories__card:hover {
	background: var(--green-deep);
	color: var(--ivory);
	border-color: var(--green-deep);
	transform: translateY(-4px);
}
.case-histories__card-top { display: flex; align-items: baseline; justify-content: space-between; }
.case-histories__card-tag { color: var(--green); transition: color 0.4s; }
.case-histories__card:hover .case-histories__card-tag { color: var(--gold-text); }
.case-histories__card-arrow { transition: transform 0.3s; }
.case-histories__card:hover .case-histories__card-arrow { transform: translateX(4px); }
.case-histories__card:hover .case-histories__card-arrow svg path { fill: var(--gold-text); }
.case-histories__card-title {
	font-size: clamp(26px, 2.6vw, 36px);
	font-weight: 400;
	line-height: 1.05;
	letter-spacing: -0.01em;
	color: var(--ink);
	transition: color 0.4s;
}
.case-histories__card:hover .case-histories__card-title { color: var(--white); }
.case-histories__card-sector { margin-top: 8px; font-size: 15px; color: var(--green); transition: color 0.4s; }
.case-histories__card:hover .case-histories__card-sector { color: var(--gold-text); }
.case-histories__card-desc { font-size: 14px; line-height: 1.55; color: var(--ink-soft); transition: color 0.4s; }
.case-histories__card:hover .case-histories__card-desc { color: var(--ivory-deep); }
.case-histories__card-impact {
	margin-top: auto;
	padding-top: 20px;
	border-top: 1px solid var(--rule);
	transition: border-color 0.4s;
}
.case-histories__card:hover .case-histories__card-impact { border-top-color: rgba(240, 240, 240, 0.2); }
.case-histories__card-impact-label { color: var(--green); opacity: 0.8; margin-bottom: 6px; transition: color 0.4s; }
.case-histories__card:hover .case-histories__card-impact-label { color: var(--gold-text); }
.case-histories__card-impact-value { font-size: 15px; font-weight: 700; color: var(--ink); transition: color 0.4s; }
.case-histories__card:hover .case-histories__card-impact-value { color: var(--white); }

@media (max-width: 860px) {
	.case-histories__grid { grid-template-columns: 1fr; }
}

/* ──────────────────────────────────────────────────────────────────── */
/* CONTATTI                                                             */
/* ──────────────────────────────────────────────────────────────────── */

.contatti {
	background: var(--green);
	color: var(--white);
	position: relative;
	overflow: hidden;
}
.contatti__watermark {
	position: absolute;
	top: -10%;
	right: -8%;
	opacity: 0.08;
	transform: rotate(-12deg);
	pointer-events: none;
}
.contatti__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(40px, 6vw, 100px);
	align-items: start;
	position: relative;
}
.contatti__tag { color: var(--gold-text); }
.contatti__title {
	margin-top: 28px;
	font-family: var(--sans);
	font-weight: 900;
	font-size: clamp(56px, 7vw, 116px);
	line-height: 0.92;
	color: var(--white);
	letter-spacing: -0.04em;
}
.contatti__title em.serif-italic { color: var(--gold-text); font-weight: 300; letter-spacing: -0.02em; }
.contatti__lead {
	margin-top: 24px;
	font-size: clamp(18px, 1.5vw, 22px);
	line-height: 1.5;
	color: var(--ivory);
	max-width: 520px;
	font-weight: 300;
}
.contatti__channels {
	margin-top: 48px;
	padding-top: 28px;
	border-top: 1px solid rgba(255, 255, 255, 0.28);
	display: flex;
	flex-direction: column;
	gap: 18px;
}
.contatti__channel {
	display: grid;
	grid-template-columns: 90px 1fr auto;
	align-items: baseline;
	gap: 16px;
	padding-bottom: 14px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.16);
	transition: transform 0.3s;
}
.contatti__channel:hover { transform: translateX(4px); }
.contatti__channel-label { color: rgba(255, 255, 255, 0.7); }
.contatti__channel-value { font-size: 17px; font-weight: 700; color: var(--white); word-break: break-all; }
.contatti__channel.is-primary .contatti__channel-label { color: var(--gold-text); }
.contatti__channel.is-primary .contatti__channel-value { font-size: 22px; font-weight: 900; }
.contatti__sla { margin-top: 32px; display: flex; align-items: center; gap: 12px; }
.contatti__sla .caps { color: var(--gold-text); }

.contatti__form {
	background: var(--ivory);
	color: var(--ink);
	padding: clamp(28px, 3vw, 44px);
	box-shadow: 0 24px 60px rgba(0, 0, 0, 0.18);
	display: flex;
	flex-direction: column;
	gap: 18px;
}
.contatti__form-eyebrow { color: var(--green); margin-bottom: 8px; }
.contatti__form-title { font-size: 24px; font-weight: 400; font-style: italic; color: var(--ink); line-height: 1.2; }
.contatti__form-row { display: grid; gap: 14px; }
.contatti__form-row--2 { grid-template-columns: 1fr 1fr; }
.contatti__field { display: flex; flex-direction: column; gap: 6px; }
.contatti__field-label { color: var(--green); font-size: 10px; }
.contatti__field-required { color: var(--gold-deep); margin-left: 4px; }
.contatti__field input,
.contatti__field select,
.contatti__field textarea {
	width: 100%;
	padding: 12px 14px;
	border: 1px solid var(--rule);
	background: var(--white);
	color: var(--ink);
	font-size: 15px;
	font-family: var(--sans);
	font-weight: 400;
	outline: none;
	border-radius: 0;
	transition: border-color 0.2s;
}
.contatti__field input:focus,
.contatti__field select:focus,
.contatti__field textarea:focus { border-color: var(--green); }
.contatti__field select {
	appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='%232D6A4F' d='M0 0l5 6 5-6z'/></svg>");
	background-repeat: no-repeat;
	background-position: right 14px center;
	padding-right: 30px;
}
.contatti__field textarea { resize: vertical; min-height: 100px; font-family: inherit; }
.contatti__form-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 14px;
	margin-top: 4px;
}
.contatti__form-gdpr { font-size: 12px; color: var(--muted); line-height: 1.4; max-width: 280px; }
.contatti__form-submit { background: var(--green); }
.contatti__form-submit:hover { background: var(--green-deep); }

@media (max-width: 860px) {
	.contatti__grid { grid-template-columns: 1fr; }
	.contatti__form-row--2 { grid-template-columns: 1fr; }
}

/* ──────────────────────────────────────────────────────────────────── */
/* BLOG — archive, card, single post, related, author bio              */
/* ──────────────────────────────────────────────────────────────────── */

.blog-hero { background: var(--paper); padding: clamp(32px, 5vw, 64px) 0 clamp(40px, 6vw, 80px); }
.blog-hero__inner { max-width: 880px; }
.blog-hero__title {
	margin-top: 24px;
	font-size: clamp(36px, 5vw, 72px);
	line-height: 1.05;
	font-weight: 200;
	color: var(--ink);
	letter-spacing: -0.02em;
}
.blog-hero__subtitle { margin-top: 10px; font-size: clamp(20px, 2.4vw, 30px); line-height: 1.2; color: var(--gold-deep); }
.blog-hero__desc { margin-top: 20px; font-size: 17px; line-height: 1.6; color: var(--ink-soft); max-width: 640px; }

.blog-archive { padding: clamp(40px, 6vw, 80px) 0 clamp(80px, 10vw, 140px); }
.blog-archive__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(24px, 3vw, 48px);
}
.blog-archive__nav {
	margin-top: clamp(40px, 6vw, 80px);
	display: flex;
	justify-content: center;
}
.blog-archive__nav .page-numbers {
	display: inline-flex;
	padding: 10px 16px;
	margin: 0 4px;
	border: 1px solid var(--rule);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--ink-soft);
	transition: background 0.2s, color 0.2s;
}
.blog-archive__nav .page-numbers.current { background: var(--green); color: var(--white); border-color: var(--green); }
.blog-archive__nav .page-numbers:hover:not(.current) { background: var(--paper); color: var(--ink); }
.blog-archive__empty { padding: 80px 0; font-size: 18px; color: var(--muted); text-align: center; }

.blog-card { display: flex; flex-direction: column; gap: 18px; background: var(--white); border: 1px solid var(--rule); padding: 0; transition: transform 0.4s, border-color 0.4s; }
.blog-card:hover { transform: translateY(-4px); border-color: var(--green); }
.blog-card__thumb { display: block; aspect-ratio: 16 / 9; overflow: hidden; background: var(--paper); }
.blog-card__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s; }
.blog-card:hover .blog-card__thumb img { transform: scale(1.04); }
.blog-card__body { padding: clamp(20px, 2vw, 28px) clamp(20px, 2vw, 28px) clamp(24px, 2.4vw, 32px); display: flex; flex-direction: column; gap: 14px; }
.blog-card__cat { color: var(--green); }
.blog-card__title {
	font-size: clamp(22px, 2vw, 28px);
	line-height: 1.2;
	font-weight: 400;
	color: var(--ink);
	letter-spacing: -0.01em;
}
.blog-card__title a:hover { color: var(--green); }
.blog-card__excerpt { font-size: 15px; line-height: 1.6; color: var(--ink-soft); }
.blog-card__meta { font-size: 12px; color: var(--muted); display: flex; gap: 8px; letter-spacing: 0.05em; text-transform: uppercase; font-weight: 700; }

/* Collane (14 giu): badge oro "Episodio X di Y" / "Collana · N episodi" */
.blog-card__series { color: var(--gold-deep); }
.blog-card--series { border-top: 3px solid var(--gold); }
.blog-card--series:hover { border-color: var(--gold); border-top-color: var(--gold); }
.blog-card__series-cta {
	margin-top: auto;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: var(--gold-deep);
	transition: gap 0.25s;
}
.blog-card__series-cta:hover { gap: 14px; }

/* Barra filtri archivio blog */
.blog-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-bottom: clamp(28px, 4vw, 48px);
}
.blog-filters__chip {
	display: inline-flex;
	align-items: center;
	padding: 9px 16px;
	border: 1px solid var(--rule);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ink-soft);
	transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.blog-filters__chip:hover { color: var(--ink); border-color: var(--ink); }
.blog-filters__chip--series { border-color: rgba(173, 148, 31, 0.45); color: var(--gold-deep); }
.blog-filters__chip--series:hover { border-color: var(--gold); }
.blog-filters__chip.is-active { background: var(--green); color: var(--white); border-color: var(--green); }
.blog-filters__chip--series.is-active { background: var(--gold); border-color: var(--gold); color: var(--green-ink); }

.single-post { padding-top: clamp(32px, 5vw, 64px); }
.single-post__header { max-width: 800px; padding-bottom: clamp(32px, 4vw, 56px); }
.single-post__cat { color: var(--green); display: inline-block; margin-bottom: 18px; }
.single-post__title {
	font-size: clamp(36px, 5vw, 64px);
	line-height: 1.08;
	font-weight: 200;
	color: var(--ink);
	letter-spacing: -0.02em;
}
.single-post__meta { margin-top: 20px; display: flex; gap: 10px; font-size: 13px; color: var(--muted); letter-spacing: 0.05em; text-transform: uppercase; font-weight: 700; }
.single-post__hero { margin: 0 auto clamp(40px, 5vw, 64px); max-width: 1320px; aspect-ratio: 21 / 9; overflow: hidden; }
.single-post__hero img { width: 100%; height: 100%; object-fit: cover; }
.single-post__body { max-width: 760px; font-size: 18px; line-height: 1.8; color: var(--ink); }
.single-post__body h2 { font-family: var(--serif); font-weight: 400; font-size: clamp(28px, 3vw, 40px); margin-top: 48px; margin-bottom: 16px; color: var(--ink); }
.single-post__body h3 { font-family: var(--serif); font-weight: 400; font-size: clamp(22px, 2.2vw, 28px); margin-top: 36px; margin-bottom: 14px; color: var(--ink); }
.single-post__body p { margin-bottom: 22px; }
.single-post__body a { color: var(--green); border-bottom: 1px solid currentColor; }
.single-post__body a:hover { background: var(--green-wash); }
.single-post__body blockquote {
	margin: 32px 0;
	padding: 24px 28px;
	border-left: 3px solid var(--green);
	background: var(--paper);
	font-family: var(--serif);
	font-style: italic;
	font-size: 20px;
	line-height: 1.6;
	color: var(--ink);
}
.single-post__body ul, .single-post__body ol { margin: 0 0 22px 20px; padding-left: 16px; }
.single-post__body li { margin-bottom: 8px; }
.single-post__body code { background: var(--paper); padding: 2px 6px; font-size: 0.92em; }
.single-post__body img { margin: 32px 0; }
.single-post__footer { max-width: 760px; padding: clamp(40px, 5vw, 64px) 0; }
.single-post__tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 48px; }
.single-post__tag {
	padding: 6px 12px;
	border: 1px solid var(--rule);
	font-size: 12px;
	font-weight: 700;
	color: var(--muted);
	letter-spacing: 0.04em;
	transition: background 0.2s, color 0.2s;
}
.single-post__tag:hover { background: var(--green); color: var(--white); border-color: var(--green); }

.author-bio {
	display: grid;
	grid-template-columns: 120px 1fr;
	gap: clamp(20px, 3vw, 32px);
	padding: clamp(28px, 3vw, 40px);
	background: var(--paper);
	border-left: 3px solid var(--green);
	align-items: start;
}
.author-bio__photo {
	width: 120px;
	height: 120px;
	overflow: hidden;
	border-radius: 50%;
	background: var(--ivory);
}
.author-bio__photo img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 30%; }
.author-bio__eyebrow { color: var(--green); margin-bottom: 6px; }
.author-bio__name { font-size: clamp(22px, 2vw, 28px); color: var(--ink); margin-bottom: 8px; }
.author-bio__role { font-size: 15px; line-height: 1.55; color: var(--ink-soft); margin-bottom: 16px; }
.author-bio__cta { display: flex; gap: 16px; flex-wrap: wrap; }
.author-bio__cta a { color: var(--green); transition: opacity 0.2s; }
.author-bio__cta a:hover { opacity: 0.7; }

.related-posts { padding: clamp(60px, 8vw, 100px) 0; border-top: 1px solid var(--rule); }
.related-posts__head { margin-bottom: clamp(32px, 4vw, 56px); }
.related-posts__title {
	margin-top: 16px;
	font-size: clamp(28px, 3.4vw, 48px);
	line-height: 1.1;
	font-weight: 200;
	color: var(--ink);
	letter-spacing: -0.02em;
}
.related-posts__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(24px, 3vw, 40px);
}

@media (max-width: 860px) {
	.blog-archive__grid { grid-template-columns: 1fr; }
	.related-posts__grid { grid-template-columns: 1fr; }
	.author-bio { grid-template-columns: 80px 1fr; }
	.author-bio__photo { width: 80px; height: 80px; }
}

/* ──────────────────────────────────────────────────────────────────── */
/* MOBILE OVERRIDES — schermi piccoli (480px e sotto)                  */
/* I clamp() fluidi reggono fino a circa 360px; sotto serve override.   */
/* ──────────────────────────────────────────────────────────────────── */

@media (max-width: 480px) {
	/* Container piu' stretto su mobile */
	.container { padding-left: 20px; padding-right: 20px; }
	.hero__poster { padding: 32px 20px; }
	.hero__title { font-size: 32px; line-height: 1.05; }
	.hero__lead { font-size: 15px; }
	.hero__cta { flex-direction: column; align-items: stretch; gap: 10px; }
	.hero__cta a { justify-content: center; }
	.hero__poster-mission { font-size: 22px; }
	.hero__poster-stats { gap: 12px; }
	.hero__poster-stat-n { font-size: 18px; }

	/* Manifesto */
	.manifesto__title { font-size: 32px; }
	.manifesto__statement { font-size: 17px; }
	.manifesto__pillars { padding-top: 24px; gap: 24px; }

	/* Sintomi — un sintomo per riga, padding ridotto */
	.sintomi__title { font-size: 32px; }
	.sintomi__intro { font-size: 15px; padding-bottom: 0; }
	.sintomi__card { padding: 24px 20px; min-height: 260px; gap: 20px; }
	.sintomi__card-n { font-size: 48px; }
	.sintomi__card-headline { font-size: 20px; }
	.sintomi__card-text { font-size: 14px; }
	.sintomi__footer-text { font-size: 16px; }

	/* Servizi accordion — toggle in alto a destra */
	.servizi__title { font-size: 32px; }
	.servizi__row-header { grid-template-columns: 50px 1fr 40px; gap: 12px; padding: 18px 0; }
	.servizi__row-n { font-size: 36px; }
	.servizi__row-title { font-size: 11px; }
	.servizi__row-tag { font-size: 13px; }
	.servizi__row-toggle { width: 32px; height: 32px; font-size: 18px; }
	.servizi__outcomes-list li { font-size: 14px; }
	.servizi__meta-value { font-size: 18px; }
	.servizi__footer-cta { padding: 12px 16px; font-size: 11px; }

	/* Metodo PONTE */
	.metodo__title { font-size: 32px; }
	.metodo__card { min-height: 240px; padding: 24px 20px; }
	.metodo__card-letter { font-size: 64px; }
	.metodo__card-word { font-size: 20px; }

	/* Numeri */
	.numeri__value { font-size: 48px; }

	/* Chi sono */
	.chi-sono__title { font-size: 32px; }
	.chi-sono__bio { font-size: 16px; }
	.chi-sono__quote-text { font-size: 22px; }

	/* Case histories */
	.case-histories__title { font-size: 32px; }
	.case-histories__card { padding: 24px 20px; min-height: 320px; }
	.case-histories__card-title { font-size: 22px; }

	/* Contatti */
	.contatti__title { font-size: 44px; line-height: 0.95; }
	.contatti__lead { font-size: 16px; }
	.contatti__channel { grid-template-columns: 1fr; gap: 6px; }
	.contatti__channel.is-primary .contatti__channel-value { font-size: 18px; }
	.contatti__form { padding: 24px 20px; }
	.contatti__form-title { font-size: 19px; }
	.contatti__form-footer { flex-direction: column; align-items: stretch; }
	.contatti__form-submit { justify-content: center; }

	/* Blog */
	.blog-hero__title { font-size: 32px; }
	.blog-card__title { font-size: 20px; }
	.single-post { padding-top: 100px; }
	.single-post__title { font-size: 32px; }
	.single-post__body { font-size: 17px; line-height: 1.7; }
	.single-post__body h2 { font-size: 24px; margin-top: 36px; }
	.single-post__body blockquote { padding: 18px 20px; font-size: 17px; }

	/* Footer */
	.site-footer { padding: 48px 20px 24px; }

	/* Nav */
	.nav-inner { padding: 14px 20px; }
}

/* ──────────────────────────────────────────────────────────────────── */
/* CONSENT checkbox nel form contatti                                   */
/* ──────────────────────────────────────────────────────────────────── */

.contatti__consent {
	display: flex;
	gap: 10px;
	align-items: flex-start;
	font-size: 13px;
	line-height: 1.5;
	color: var(--ink-soft);
}
.contatti__consent input[type="checkbox"] {
	margin-top: 3px;
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	accent-color: var(--green);
}
.contatti__consent a { color: var(--green); text-decoration: underline; }

/* Honeypot anti-bot: fuori schermo (NON display:none, cosi' i bot lo riempiono). */
.contatti__hp {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}
/* Notice d'errore: compare solo dopo un invio fallito (?contact_error=...). */
.contatti__notice {
	margin-bottom: 18px;
	padding: 12px 16px;
	border-radius: 10px;
	background: #FBEAEA;
	border-left: 3px solid #C0473F;
	color: #7A241E;
	font-size: 13px;
	line-height: 1.5;
}

/* ──────────────────────────────────────────────────────────────────── */
/* Thank-you page /grazie/ (conferma invio form contatti)               */
/* ──────────────────────────────────────────────────────────────────── */
.grazie__hero { text-align: center; }
.grazie__inner {
	max-width: 640px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 18px;
}
.grazie__check { display: inline-flex; line-height: 0; }
.grazie__tag { margin: 0; }
.grazie__title {
	font-size: clamp(32px, 5vw, 52px);
	line-height: 1.1;
	color: var(--ink);
	margin: 0;
}
.grazie__lead {
	font-size: clamp(16px, 1.4vw, 19px);
	line-height: 1.6;
	color: var(--ink-soft);
	max-width: 540px;
	margin: 0;
}
.grazie__hint { font-size: 15px; color: var(--muted); margin: 0; }
.grazie__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	align-items: center;
	justify-content: center;
	margin-top: 10px;
}
.grazie__back { color: var(--green); text-decoration: underline; font-size: 15px; }

/* ──────────────────────────────────────────────────────────────────── */
/* COOKIEYES override — restyling banner CookieYes con palette brand    */
/* Selettori basati su markup CookieYes v3.x (.cky-*).                  */
/* Se la classe non esiste piu', non rompe nulla (nessun lato JS).      */
/* ──────────────────────────────────────────────────────────────────── */

.cky-consent-container,
.cky-consent-bar {
	font-family: var(--sans) !important;
	background: var(--ink) !important;
	color: var(--ivory) !important;
	border-top: 3px solid var(--gold) !important;
	border-radius: 0 !important;
	box-shadow: 0 -12px 40px rgba(0, 0, 0, 0.25) !important;
}
.cky-title,
.cky-notice-des,
.cky-notice-des * {
	color: var(--ivory) !important;
	font-family: var(--sans) !important;
	font-size: 13px !important;
	line-height: 1.55 !important;
}
.cky-title { font-size: 14px !important; font-weight: 700 !important; letter-spacing: 0.05em !important; text-transform: uppercase !important; color: var(--gold-text) !important; }
.cky-notice-des a,
.cky-notice-des a:hover { color: var(--gold-text) !important; text-decoration: underline !important; }

.cky-btn,
button.cky-btn {
	font-family: var(--sans) !important;
	font-size: 11px !important;
	font-weight: 700 !important;
	letter-spacing: 0.14em !important;
	text-transform: uppercase !important;
	border-radius: 0 !important;
	padding: 10px 18px !important;
	transition: background 0.2s, color 0.2s !important;
}
.cky-btn-customize,
.cky-btn-reject {
	background: transparent !important;
	color: var(--ivory) !important;
	border: 1px solid rgba(240, 240, 240, 0.3) !important;
}
.cky-btn-customize:hover,
.cky-btn-reject:hover {
	background: rgba(240, 240, 240, 0.1) !important;
	border-color: var(--ivory) !important;
}
.cky-btn-accept {
	background: var(--gold) !important;
	color: var(--green-ink) !important;
	border: 0 !important;
}
.cky-btn-accept:hover {
	background: var(--white) !important;
}

/* Modal "Customize" CookieYes */
.cky-modal,
.cky-modal-open {
	font-family: var(--sans) !important;
}
.cky-prefrence-center {
	border-radius: 0 !important;
}
.cky-prefrence-title,
.cky-accordion-header-des,
.cky-accordion-content {
	font-family: var(--sans) !important;
}
.cky-prefrence-btn-wrapper .cky-btn-accept,
.cky-prefrence-btn-wrapper .cky-btn-preferences {
	background: var(--green) !important;
	color: var(--white) !important;
}

/* ──────────────────────────────────────────────────────────────────── */
/* COOKIE BANNER fallback custom (solo se CookieYes non attivo)         */
/* ──────────────────────────────────────────────────────────────────── */

.cookie-banner {
	position: fixed;
	bottom: 16px;
	left: 16px;
	right: 16px;
	z-index: 150;
	background: var(--ink);
	color: var(--ivory);
	padding: 16px 20px;
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.25);
	border-top: 3px solid var(--gold);
	animation: cookie-in 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.cookie-banner[hidden] { display: none; }
@keyframes cookie-in {
	from { opacity: 0; transform: translateY(20px); }
	to   { opacity: 1; transform: none; }
}
.cookie-banner__inner {
	max-width: var(--container);
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	flex-wrap: wrap;
}
.cookie-banner__text { font-size: 13px; line-height: 1.5; flex: 1; min-width: 280px; }
.cookie-banner__text a { color: var(--gold-text); text-decoration: underline; }
.cookie-banner__actions { display: flex; gap: 10px; flex-wrap: wrap; }
.cookie-banner__btn {
	padding: 10px 16px;
	font-family: var(--sans);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	cursor: pointer;
	border: 0;
	transition: background 0.2s, color 0.2s;
}
.cookie-banner__btn--reject { background: transparent; color: var(--ivory); border: 1px solid rgba(240, 240, 240, 0.3); }
.cookie-banner__btn--reject:hover { background: rgba(240, 240, 240, 0.1); }
.cookie-banner__btn--accept { background: var(--gold); color: var(--green-ink); }
.cookie-banner__btn--accept:hover { background: var(--gold-text); }

@media (max-width: 480px) {
	.cookie-banner { bottom: 0; left: 0; right: 0; }
	.cookie-banner__inner { flex-direction: column; align-items: stretch; }
	.cookie-banner__actions { justify-content: stretch; }
	.cookie-banner__btn { flex: 1; }
}

@media (max-width: 380px) {
	.hero__title { font-size: 28px; }
	.contatti__title { font-size: 36px; }
	.sintomi__title,
	.servizi__title,
	.metodo__title,
	.chi-sono__title,
	.case-histories__title,
	.blog-hero__title,
	.single-post__title { font-size: 28px; }
	.numeri__value { font-size: 40px; }
}

/* ──────────────────────────────────────────────────────────────────── */
/* PAGINE INTERNE — intro generica + valori grid                       */
/* ──────────────────────────────────────────────────────────────────── */

.page-intro { background: var(--paper); padding: clamp(28px, 4vw, 48px) 0 clamp(28px, 4vw, 48px); }
.page-intro__inner { max-width: 880px; }
.page-intro__title {
	margin-top: 24px;
	font-size: clamp(36px, 5vw, 72px);
	line-height: 1.05;
	font-weight: 200;
	color: var(--ink);
	letter-spacing: -0.02em;
}
.page-intro__title em.serif-italic { color: var(--green); }
.page-intro__lead { margin-top: 20px; font-size: 17px; line-height: 1.6; color: var(--ink-soft); max-width: 640px; }

/* ── Variante "strumento" (landing survey): piu' aria su lead e CTA ─── */
.page-intro--tool { padding-top: clamp(56px, 8vw, 116px); padding-bottom: clamp(20px, 3vw, 44px); }
.page-intro--tool .page-intro__lead { margin-top: clamp(22px, 2.8vw, 34px); max-width: 600px; }
.page-intro--tool .page-intro__cta { display: inline-flex; margin-top: clamp(30px, 3.6vw, 48px); }

/* ── Processo orizzontale animato (come funziona, sx -> dx su 3 punti) ─
   Failsafe: senza la classe .motion (no GSAP / reduced-motion) la linea e'
   piena e i pallini sono tutti accesi. Con .motion partono spenti e si
   accendono allo scroll (handler "process" in motion.js, scrubbed). */
.process-section { background: var(--gray-light); padding: clamp(20px, 3vw, 40px) 0 clamp(28px, 4vw, 52px); }

/* Sezione survey: banda cromatica distinta (verde-wash) + header che
   chiarisce che e' uno strumento interattivo. La card della survey
   (bianca) e' stilata nel plugin (survey.css). */
.survey-section { background: var(--green-wash); padding: clamp(28px, 4vw, 56px) 0 clamp(48px, 6vw, 92px); }
.survey-head { text-align: center; max-width: 620px; margin: 0 auto clamp(18px, 2.5vw, 30px); }
.survey-head__kicker { color: var(--gold-deep); font-weight: 700; letter-spacing: 0.18em; font-size: 12px; margin: 0; }
.process { position: relative; }
.process__track {
	position: absolute;
	top: 23px;
	left: 16.67%;
	right: 16.67%;
	height: 2px;
	background: var(--rule);
	overflow: hidden;
}
.process__fill {
	position: absolute;
	inset: 0;
	background: var(--gold);
	transform-origin: left center;
}
.motion .process__fill { transform: scaleX(0); }
.process__steps {
	position: relative;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(16px, 3vw, 40px);
	list-style: none;
	margin: 0;
	padding: 0;
}
.process__step { text-align: center; }
.process__dot {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: var(--green);
	border: 2px solid var(--gold);
	color: var(--white);
	position: relative;
	z-index: 1;
	transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease), color var(--dur) var(--ease);
}
.process__n { font-size: 18px; font-weight: 700; line-height: 1; }
/* Sotto .motion i pallini non ancora raggiunti dalla linea sono neutri */
.motion .process__step:not(.is-active) .process__dot {
	background: var(--white);
	border-color: var(--rule);
	color: var(--green);
}
.process__tag { display: block; margin-top: 18px; color: var(--muted); }
.process__head { margin-top: 8px; font-size: clamp(19px, 1.7vw, 23px); font-weight: 400; color: var(--ink); }
.process__text { margin-top: 8px; font-size: 14.5px; line-height: 1.6; color: var(--ink-soft); max-width: 34ch; margin-left: auto; margin-right: auto; }

@media (max-width: 820px) {
	.process__track { display: none; }
	.process__steps { grid-template-columns: 1fr; gap: 22px; }
	.process__step { display: grid; grid-template-columns: auto 1fr; gap: 16px; text-align: left; align-items: start; }
	.process__tag { margin-top: 0; }
	.process__text { margin-left: 0; margin-right: 0; }
}

/* ── Team others: bio Francesco + Federica (page /chi-sono/) ───────── */
.team-others { background: var(--white); }
.team-others__header {
	max-width: 720px;
	margin: 0 auto clamp(40px, 5vw, 64px);
	text-align: center;
}
.team-others__header .section-tag { justify-content: center; }
.team-others__title {
	font-size: clamp(28px, 3.6vw, 44px);
	line-height: 1.1;
	margin-top: 18px;
	color: var(--ink);
}
/* 14 giu 2026: card team ridisegnate larghe a tutta riga (foto a sx, bio a dx
   con molto piu' spazio orizzontale) per evitare la colonna di testo
   verticale infinita ("epitaffio") segnalata dalla cliente. */
.team-others__grid {
	display: grid;
	grid-template-columns: 1fr;
	max-width: 820px;
	margin: 0 auto;
	gap: clamp(20px, 3vw, 28px);
}
.team-others__card {
	display: grid;
	grid-template-columns: 190px 1fr;
	gap: clamp(24px, 3vw, 40px);
	align-items: center;
	padding: clamp(22px, 2.5vw, 32px);
	background: var(--gray-light);
	border: 1px solid var(--rule);
	transition: border-color 0.3s, transform 0.3s;
}
.team-others__card:hover { border-color: var(--green); transform: translateY(-3px); }
.team-others__photo {
	margin: 0;
	width: 190px;
	height: 230px;
	overflow: hidden;
	background: var(--gray);
}
.team-others__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center top;
	display: block;
}
.team-others__photo-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--green-deep), var(--green-ink));
	color: var(--gray);
}
.team-others__photo-placeholder span {
	font-size: 56px;
	font-style: italic;
	font-weight: 200;
	letter-spacing: -0.02em;
}
.team-others__body { display: flex; flex-direction: column; gap: 10px; }
.team-others__name {
	font-size: clamp(22px, 2vw, 28px);
	font-style: italic;
	font-weight: 400;
	color: var(--ink);
	margin: 0;
	line-height: 1.15;
}
.team-others__role {
	font-size: 11px;
	color: var(--green);
	font-weight: 700;
	letter-spacing: 0.18em;
}
.team-others__bio {
	font-size: 15px;
	line-height: 1.55;
	color: var(--ink-soft);
}
.team-others__bio p { margin: 0 0 10px; }
.team-others__bio p:last-child { margin-bottom: 0; }
.team-others__linkedin {
	margin-top: 6px;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.18em;
	color: var(--green);
	border-bottom: 1.5px solid currentColor;
	padding-bottom: 2px;
	transition: color 0.25s;
	align-self: flex-start;
}
.team-others__linkedin:hover { color: var(--green-deep); }
@media (max-width: 640px) {
	.team-others__card {
		grid-template-columns: 1fr;
		justify-items: center;
		gap: 20px;
		text-align: left;
	}
	.team-others__photo { width: 180px; height: 220px; }
	.team-others__body { width: 100%; }
}

/* ── Partner / alleanze (pagina Team) ──────────────────────────────── */
/* Muro di loghi collassabile: riga = logo + nome (chiuso), pannello con la
   storia della partnership (aperto). Accordion CSS (grid-template-rows
   0fr->1fr come i servizi). Mobile-first: tap target a tutta riga. */
.partners { background: var(--paper); }
.partners__header {
	max-width: 720px;
	margin: 0 auto clamp(36px, 4.5vw, 56px);
	text-align: center;
}
.partners__header .section-tag { justify-content: center; }
.partners__title {
	font-size: clamp(28px, 3.6vw, 44px);
	line-height: 1.1;
	margin-top: 18px;
	color: var(--ink);
}
.partners__intro {
	margin-top: 16px;
	font-size: 17px;
	line-height: 1.6;
	color: var(--ink-soft);
}
.partners__list {
	max-width: 880px;
	margin: 0 auto;
	border-top: 1px solid var(--rule);
}
.partners__row { border-bottom: 1px solid var(--rule); }
.partners__heading { margin: 0; padding: 0; font-weight: inherit; font-size: inherit; }

/* Stato chiuso: logo prominente a sx, nome al centro, chevron a dx */
.partners__head {
	width: 100%;
	display: grid;
	grid-template-columns: clamp(110px, 18vw, 180px) 1fr auto;
	align-items: center;
	gap: clamp(14px, 3vw, 32px);
	padding: clamp(18px, 2.2vw, 28px) clamp(4px, 1vw, 12px);
	background: transparent;
	border: 0;
	text-align: left;
	cursor: pointer;
	color: var(--ink);
	font-family: inherit;
}
.partners__logo {
	display: flex;
	align-items: center;
	height: clamp(38px, 5vw, 58px);
}
.partners__logo img {
	max-height: 100%;
	max-width: 100%;
	width: auto;
	height: auto;
	object-fit: contain;
	object-position: left center;
	filter: grayscale(100%) opacity(0.78);
	transition: filter 0.35s;
}
.partners__row.is-open .partners__logo img,
.partners__head:hover .partners__logo img { filter: grayscale(0) opacity(1); }
.partners__logo-text {
	font-family: var(--serif);
	font-size: 21px;
	font-style: italic;
	color: var(--green);
}
.partners__head-meta { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.partners__name {
	font-family: var(--serif);
	font-size: clamp(18px, 1.6vw, 22px);
	font-style: italic;
	color: var(--ink);
	line-height: 1.15;
}
.partners__role {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--green);
}
.partners__chevron {
	display: flex;
	color: var(--muted);
	transition: transform 0.4s var(--ease), color 0.3s;
}
.partners__row.is-open .partners__chevron { transform: rotate(180deg); color: var(--green); }

/* Pannello: grid-template-rows 0fr->1fr. -clip fa da finestra (overflow,
   niente padding verticale), -inner tiene il padding. */
.partners__panel {
	display: grid;
	grid-template-rows: 0fr;
	transition: grid-template-rows 0.55s var(--ease), visibility 0.55s;
	visibility: hidden;
}
.partners__row.is-open .partners__panel {
	grid-template-rows: 1fr;
	visibility: visible;
}
.partners__panel-clip { overflow: hidden; min-height: 0; }
.partners__panel-inner {
	padding: 4px clamp(4px, 1vw, 12px) clamp(28px, 3vw, 40px);
	display: grid;
	grid-template-columns: 1fr;
	gap: 20px;
	max-width: 760px;
}
.partners__photos { display: flex; flex-wrap: wrap; gap: 14px; }
.partners__photo {
	margin: 0;
	width: 76px;
	height: 76px;
	border-radius: 50%;
	overflow: hidden;
	background: var(--gray);
	flex: 0 0 auto;
	border: 2px solid var(--white);
	box-shadow: 0 2px 10px rgba(15, 42, 31, 0.12);
}
.partners__photo img { width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block; }
.partners__tagline {
	margin: 0;
	font-size: clamp(18px, 2vw, 22px);
	color: var(--green);
	line-height: 1.3;
}
.partners__body { font-size: 16px; line-height: 1.65; color: var(--ink-soft); }
.partners__body h3 {
	font-family: var(--sans);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--gold-deep);
	margin: 4px 0 8px;
}
.partners__body h3:not(:first-child) { margin-top: 22px; }
.partners__body p { margin: 0 0 12px; }
.partners__body p:last-child { margin-bottom: 0; }
.partners__quote {
	margin: 0;
	padding: 18px 22px;
	border-left: 3px solid var(--gold);
	background: var(--green-wash);
}
.partners__quote p { margin: 0; font-family: var(--serif); font-style: italic; font-size: 18px; line-height: 1.5; color: var(--ink); }
.partners__quote cite { display: block; margin-top: 10px; font-style: normal; font-size: 12px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--green); }
/* Riga foto + link: avatar a sinistra, icone sito/LinkedIn a destra, stessa linea */
.partners__topline {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 16px;
}
.partners__links { display: flex; flex-wrap: wrap; gap: 10px; margin-left: auto; }
.partners__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	color: var(--green);
	border: 1px solid var(--green);
	border-radius: 50%;
	transition: background 0.25s, color 0.25s, border-color 0.25s;
}
.partners__link:hover { background: var(--green); color: var(--white); }
.partners__cta { text-align: center; margin-top: clamp(36px, 4vw, 56px); }

@media (max-width: 600px) {
	.partners__head {
		grid-template-columns: clamp(72px, 28vw, 110px) 1fr auto;
		gap: 14px;
	}
	.partners__logo { height: 36px; }
}

/* ── Trust bar: loghi clienti (homepage) ───────────────────────────── */
.trust-bar { background: var(--gray-light); padding: clamp(40px, 6vw, 80px) 0; }
.trust-bar__header {
	text-align: center;
	margin-bottom: clamp(28px, 3.5vw, 48px);
}
.trust-bar__header .section-tag { justify-content: center; }
.trust-bar__title {
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--muted);
	margin-top: 12px;
}
.trust-bar__personas {
	margin-top: 10px;
	font-family: var(--serif);
	font-style: italic;
	font-size: 17px;
	color: var(--ink-soft);
}
/* Marquee: anello di loghi a scorrimento continuo. Il track contiene 2 copie
   identiche dei loghi; l'animazione trasla di meta' track + meta' gap, cosi'
   il punto di ripartenza coincide pixel-perfect (loop chiuso senza stacco). */
.trust-bar__marquee {
	position: relative;
	overflow: hidden;
	margin-top: clamp(28px, 3.5vw, 48px);
	-webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
	        mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.trust-bar__track {
	--gap: clamp(40px, 6vw, 96px);
	display: flex;
	width: max-content;
	align-items: center;
	gap: var(--gap);
	animation: trust-marquee 45s linear infinite;
}
.trust-bar__marquee:hover .trust-bar__track { animation-play-state: paused; }
@keyframes trust-marquee {
	from { transform: translateX(0); }
	to   { transform: translateX(calc(-50% - var(--gap) / 2)); }
}
.trust-bar__logo {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	justify-content: center;
	height: clamp(40px, 5vw, 64px);
	filter: grayscale(100%) opacity(0.7);
	transition: filter 0.35s;
}
.trust-bar__logo:hover { filter: grayscale(0) opacity(1); }
.trust-bar__logo img {
	max-height: 100%;
	max-width: clamp(130px, 16vw, 190px);
	width: auto;
	height: auto;
	object-fit: contain;
	display: block;
}
/* Su touch non c'e' hover che "accende" i loghi: vanno leggibili subito. */
@media (max-width: 860px) {
	.trust-bar__logo { filter: grayscale(40%) opacity(0.9); }
}
/* Reduced motion: niente scorrimento, l'anello diventa una striscia scrollabile. */
@media (prefers-reduced-motion: reduce) {
	.trust-bar__track { animation: none; }
	.trust-bar__marquee { overflow-x: auto; }
}
.trust-bar__footnote {
	text-align: center;
	margin-top: clamp(24px, 3vw, 40px);
	font-size: 13px;
	color: var(--muted);
	font-style: italic;
}

/* ── Purpose: triade vision/mission/purpose (sopra carta dei valori) ── */
.purpose { background: var(--white); }
.purpose__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(20px, 2.5vw, 36px);
}
.purpose__card {
	padding: clamp(28px, 3vw, 44px);
	background: var(--green);
	color: var(--white);
	display: flex;
	flex-direction: column;
	gap: 18px;
	min-height: 220px;
}
/* 14 giu 2026: la card 3 ("Il senso") era su --green-ink (#0F2A1F, quasi nero =
   "lugubre" per la cliente). Ri-scalato il gradiente delle 3 card su tre verdi
   monotoni chiaro->scuro che si fermano a --green-deep, senza toccare il nero. */
.purpose__card:nth-child(1) { background: var(--green-soft); }
.purpose__card:nth-child(2) { background: var(--green); }
.purpose__card:nth-child(3) { background: var(--green-deep); }
.purpose__label {
	color: var(--gray);
	font-weight: 700;
	font-size: 11px;
	letter-spacing: 0.22em;
}
.purpose__text {
	font-size: clamp(20px, 1.6vw, 24px);
	line-height: 1.4;
	font-style: italic;
	font-weight: 300;
	color: var(--white);
	margin: 0;
}
@media (max-width: 860px) {
	.purpose__grid { grid-template-columns: 1fr; }
}

.valori-page { background: var(--ivory); }
.valori-page__intro { max-width: 720px; margin: 0 auto clamp(40px, 5vw, 72px); text-align: center; }
.valori-page__intro .section-tag { justify-content: center; }
.valori-page__title { font-size: clamp(32px, 4vw, 52px); line-height: 1.1; margin-top: 18px; color: var(--ink); }
.valori-page__lead { margin-top: 18px; font-size: 17px; line-height: 1.6; color: var(--ink-soft); }
.valori-page__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(24px, 3vw, 48px);
}
.valori-page__card {
	background: var(--paper);
	padding: clamp(28px, 3vw, 40px);
	border: 1px solid var(--rule);
	display: flex;
	flex-direction: column;
	gap: 14px;
	min-height: 320px;
	transition: transform 0.4s, border-color 0.4s;
}
/* ── Hover premium coordinato sulle card (revisione grafica giu 2026) ── */
.sintomi__card,
.case-histories__card,
.blog-card,
.team-others__card,
.purpose__card,
.valori-page__card {
	transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.sintomi__card:hover,
.case-histories__card:hover,
.blog-card:hover,
.team-others__card:hover,
.purpose__card:hover,
.valori-page__card:hover {
	transform: translateY(-6px);
	box-shadow: 0 26px 54px -26px rgba(15, 42, 31, 0.38);
	border-color: var(--green);
}
@media (prefers-reduced-motion: reduce) {
	.sintomi__card:hover,
	.case-histories__card:hover,
	.blog-card:hover,
	.team-others__card:hover,
	.purpose__card:hover,
	.valori-page__card:hover { transform: none; box-shadow: none; }
}
.valori-page__n {
	font-size: clamp(36px, 3.6vw, 52px);
	color: var(--green);
	font-style: italic;
	font-weight: 200;
	line-height: 1;
}
.valori-page__word {
	font-size: clamp(17px, 1.7vw, 21px);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.02em;
	color: var(--ink);
	line-height: 1.25;
	margin: 0;
}
.valori-page__sub { font-size: 18px; color: var(--green); line-height: 1.45; font-weight: 400; margin-top: auto; }
.valori-page__title-card { font-size: 14px; color: var(--muted); letter-spacing: 0.04em; text-transform: uppercase; font-weight: 700; margin-top: auto; }

@media (max-width: 860px) {
	.valori-page__grid { grid-template-columns: 1fr; }
}

/* ──────────────────────────────────────────────────────────────────── */
/* ULTIME NEWS in home (editoriale, lista verticale numerata)          */
/* ──────────────────────────────────────────────────────────────────── */

.ultime-news { background: var(--ivory); position: relative; }
.ultime-news__header {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	flex-wrap: wrap;
	gap: 24px;
	margin-bottom: clamp(40px, 5vw, 64px);
}
.ultime-news__title {
	margin-top: 24px;
	font-size: clamp(36px, 5vw, 72px);
	line-height: 1.05;
	font-weight: 200;
	color: var(--ink);
	letter-spacing: -0.02em;
}
.ultime-news__title em.serif-italic { color: var(--green); }
.ultime-news__all {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: var(--green);
	transition: gap 0.25s;
}
.ultime-news__all:hover { gap: 14px; }

.ultime-news__list {
	list-style: none;
	padding: 0;
	margin: 0;
	border-top: 1px solid var(--rule);
}
.ultime-news__item { border-bottom: 1px solid var(--rule); }
.ultime-news__link {
	display: grid;
	grid-template-columns: 80px 1fr 40px;
	gap: clamp(20px, 3vw, 40px);
	align-items: center;
	padding: clamp(24px, 3vw, 40px) 0;
	transition: background 0.3s, padding-left 0.3s;
}
.ultime-news__link:hover { background: var(--paper); padding-left: 16px; padding-right: 16px; }
.ultime-news__n {
	font-size: clamp(40px, 4.4vw, 64px);
	font-weight: 200;
	font-style: italic;
	color: var(--green);
	line-height: 0.9;
	letter-spacing: -0.04em;
}
.ultime-news__body { min-width: 0; }
.ultime-news__cat { color: var(--green); display: inline-block; margin-bottom: 8px; }
.ultime-news__article-title {
	font-size: clamp(22px, 2.2vw, 30px);
	line-height: 1.18;
	font-weight: 400;
	color: var(--ink);
	letter-spacing: -0.01em;
	margin-bottom: 10px;
}
.ultime-news__link:hover .ultime-news__article-title { color: var(--green); }
.ultime-news__excerpt { font-size: 15px; line-height: 1.55; color: var(--ink-soft); margin-bottom: 10px; max-width: 760px; }
.ultime-news__meta { font-size: 12px; color: var(--muted); letter-spacing: 0.04em; text-transform: uppercase; font-weight: 700; display: flex; gap: 8px; }
.ultime-news__arrow {
	font-size: 22px;
	color: var(--green);
	opacity: 0;
	transform: translateX(-8px);
	transition: opacity 0.3s, transform 0.3s;
	justify-self: end;
}
.ultime-news__link:hover .ultime-news__arrow { opacity: 1; transform: none; }

@media (max-width: 720px) {
	.ultime-news__link { grid-template-columns: 56px 1fr; gap: 16px; }
	.ultime-news__n { font-size: 36px; }
	.ultime-news__arrow { display: none; }
	.ultime-news__link:hover { padding-left: 0; padding-right: 0; }
}

/* ──────────────────────────────────────────────────────────────────── */
/* PAGE-STATIC — pagine long-form editoriali (Privacy, Cookie, Terms)  */
/* Variant modifier disponibili: --narrow, --centered (via post_class) */
/* ──────────────────────────────────────────────────────────────────── */

/* ──────────────────────────────────────────────────────────────────── */
/* BREADCRUMB                                                           */
/* ──────────────────────────────────────────────────────────────────── */
.breadcrumb { padding-top: 100px; padding-bottom: 16px; background: transparent; }
.breadcrumb .breadcrumb__list {
	max-width: var(--container);
	margin: 0 auto;
	padding: 0 var(--gutter);
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	font-size: 12px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	font-weight: 700;
	color: var(--muted);
}
.breadcrumb__item { display: inline-flex; align-items: center; gap: 6px; }
.breadcrumb__link { color: var(--muted); transition: color 0.2s; }
.breadcrumb__link:hover { color: var(--green); }
.breadcrumb__sep { color: var(--rule); margin: 0 2px; }
.breadcrumb__current { color: var(--ink); }
.page-static .breadcrumb,
.faq-archive .breadcrumb,
.blog-archive .breadcrumb,
.single-post .breadcrumb { padding-top: 96px; }

.page-static { background: var(--ivory); }
.page-static__header {
	background: var(--paper);
	padding: clamp(32px, 5vw, 64px) 0 clamp(36px, 5vw, 64px);
	border-bottom: 1px solid var(--rule);
}
.page-static__header-inner { max-width: 880px; }
.page-static__eyebrow { color: var(--green); }
.page-static__title {
	margin-top: 20px;
	font-size: clamp(36px, 5vw, 64px);
	line-height: 1.05;
	font-weight: 200;
	color: var(--ink);
	letter-spacing: -0.02em;
}
.page-static__meta {
	margin-top: 18px;
	font-size: 13px;
	color: var(--muted);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	font-weight: 700;
}

.page-static__body { padding: clamp(48px, 7vw, 96px) 0 clamp(80px, 10vw, 140px); }
.page-static__body-inner {
	max-width: 760px;
	font-size: 17px;
	line-height: 1.75;
	color: var(--ink);
}

/* Typography long-form */
.page-static__body-inner h2 {
	font-family: var(--serif);
	font-weight: 400;
	font-size: clamp(26px, 3vw, 36px);
	line-height: 1.15;
	color: var(--ink);
	letter-spacing: -0.01em;
	margin: 56px 0 18px;
	padding-top: 32px;
	border-top: 1px solid var(--rule);
}
.page-static__body-inner h2:first-child { margin-top: 0; padding-top: 0; border-top: 0; }
.page-static__body-inner h3 {
	font-family: var(--serif);
	font-weight: 400;
	font-size: clamp(20px, 2.2vw, 26px);
	line-height: 1.2;
	color: var(--green-deep);
	letter-spacing: -0.005em;
	margin: 40px 0 14px;
}
.page-static__body-inner h4 {
	font-family: var(--sans);
	font-weight: 700;
	font-size: 15px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--ink-soft);
	margin: 32px 0 10px;
}
.page-static__body-inner p { margin: 0 0 18px; }
.page-static__body-inner p + p,
.page-static__body-inner ul + p,
.page-static__body-inner ol + p { margin-top: 0; }
.page-static__body-inner strong { color: var(--ink); font-weight: 700; }
.page-static__body-inner em { font-style: italic; }

.page-static__body-inner a {
	color: var(--green);
	border-bottom: 1px solid currentColor;
	transition: background 0.15s, color 0.15s;
}
.page-static__body-inner a:hover { background: var(--green-wash); color: var(--green-deep); }

/* Liste */
.page-static__body-inner ul,
.page-static__body-inner ol { margin: 0 0 22px; padding-left: 24px; }
.page-static__body-inner li { margin-bottom: 8px; }
.page-static__body-inner ul li::marker { color: var(--green); }
.page-static__body-inner ol li::marker { color: var(--green); font-weight: 700; }

/* Blockquote (per "Nota:" o citazioni legali) */
.page-static__body-inner blockquote {
	margin: 32px 0;
	padding: 20px 24px;
	border-left: 3px solid var(--green);
	background: var(--paper);
	font-family: var(--serif);
	font-style: italic;
	font-size: 18px;
	line-height: 1.65;
	color: var(--ink-soft);
}

/* Code inline */
.page-static__body-inner code {
	font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
	background: var(--paper);
	padding: 2px 6px;
	font-size: 0.92em;
	border: 1px solid var(--rule);
	color: var(--green-deep);
}

/* Variant modifiers */
.page-static--narrow .page-static__body-inner { max-width: 640px; }
.page-static--centered .page-static__body-inner { text-align: center; }

@media (max-width: 720px) {
	.page-static__body-inner { font-size: 16px; line-height: 1.7; }
	.page-static__body-inner h2 { margin-top: 40px; padding-top: 24px; }
}

/* ──────────────────────────────────────────────────────────────────── */
/* FAQ — archive accordion + filters + single + related                 */
/* ──────────────────────────────────────────────────────────────────── */

.faq-archive { background: var(--ivory); }
.faq-archive__filters {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
	margin-bottom: clamp(32px, 4vw, 48px);
	padding-bottom: 24px;
	border-bottom: 1px solid var(--rule);
}
.faq-archive__filters-label { color: var(--muted); margin-right: 6px; }
.faq-archive__filter {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 14px;
	border: 1px solid var(--rule);
	color: var(--ink-soft);
	transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.faq-archive__filter:hover { background: var(--paper); color: var(--green); border-color: var(--green); }
.faq-archive__filter.is-active { background: var(--green); color: var(--white); border-color: var(--green); }
.faq-archive__filter small { font-weight: 400; opacity: 0.7; }
.faq-archive__empty { padding: 80px 0; font-size: 18px; color: var(--muted); text-align: center; }

.faq-list { display: flex; flex-direction: column; gap: 0; max-width: 880px; margin: 0 auto; }
.faq-item {
	border-bottom: 1px solid var(--rule);
	transition: background 0.3s;
}
.faq-item:first-child { border-top: 1px solid var(--rule); }
.faq-item[open] { background: var(--paper); }
.faq-item__summary {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 24px;
	padding: clamp(20px, 2.5vw, 32px) clamp(0px, 2vw, 24px);
	cursor: pointer;
	list-style: none;
	transition: padding 0.3s;
}
.faq-item__summary::-webkit-details-marker { display: none; }
.faq-item__question {
	font-size: clamp(18px, 1.8vw, 22px);
	line-height: 1.3;
	color: var(--ink);
	font-weight: 400;
	letter-spacing: -0.005em;
	flex: 1;
	transition: color 0.2s;
}
.faq-item:hover .faq-item__question,
.faq-item[open] .faq-item__question { color: var(--green-deep); }
.faq-item__toggle {
	width: 32px;
	height: 32px;
	border: 1.5px solid var(--rule);
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--green);
	font-size: 20px;
	font-weight: 200;
	line-height: 1;
	flex-shrink: 0;
	transition: transform 0.3s, background 0.3s, border-color 0.3s, color 0.3s;
}
.faq-item[open] .faq-item__toggle {
	background: var(--green);
	border-color: var(--green);
	color: var(--white);
	transform: rotate(45deg);
}
.faq-item__answer {
	padding: 0 clamp(0px, 2vw, 24px) clamp(20px, 2.5vw, 32px);
	max-width: 760px;
	font-size: 16px;
	line-height: 1.7;
	color: var(--ink-soft);
}
.faq-item__answer p { margin: 0 0 14px; }
.faq-item__answer p:last-child { margin-bottom: 0; }
.faq-item__answer a { color: var(--green); border-bottom: 1px solid currentColor; }
.faq-item__answer ul, .faq-item__answer ol { margin: 0 0 16px 20px; padding-left: 16px; }
.faq-item__answer li { margin-bottom: 6px; }
.faq-item__pillar { padding: 0 clamp(0px, 2vw, 24px) clamp(20px, 2.5vw, 32px); }
.faq-item__pillar .caps { color: var(--muted); font-size: 10px; }

.faq-archive__cta {
	margin-top: clamp(48px, 6vw, 80px);
	padding: clamp(32px, 4vw, 56px);
	background: var(--paper);
	border-left: 3px solid var(--green);
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 24px;
	max-width: 880px;
	margin-left: auto;
	margin-right: auto;
}
.faq-archive__cta-text {
	font-size: clamp(20px, 2vw, 26px);
	color: var(--ink);
	font-weight: 400;
	line-height: 1.3;
}
.faq-archive__cta-text em.serif-italic { color: var(--green); }

/* Single FAQ "Altre domande" */
.faq-related { padding: clamp(48px, 6vw, 80px) 0 clamp(60px, 8vw, 100px); max-width: 880px; }
.faq-related__title {
	font-size: clamp(22px, 2.4vw, 30px);
	font-weight: 400;
	color: var(--ink);
	margin-bottom: 24px;
	letter-spacing: -0.01em;
}
.faq-related__list { list-style: none; padding: 0; margin: 0; border-top: 1px solid var(--rule); }
.faq-related__list li { border-bottom: 1px solid var(--rule); }
.faq-related__list a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 18px 0;
	transition: padding-left 0.3s;
}
.faq-related__list a:hover { padding-left: 12px; }
.faq-related__q { font-size: 17px; color: var(--ink); }
.faq-related__list a:hover .faq-related__q { color: var(--green); }
.faq-related__arrow { color: var(--green); opacity: 0.5; transition: opacity 0.3s, transform 0.3s; }
.faq-related__list a:hover .faq-related__arrow { opacity: 1; transform: translateX(4px); }

@media (max-width: 720px) {
	.faq-archive__filters { gap: 8px; }
	.faq-archive__filter { padding: 6px 10px; font-size: 11px; }
	.faq-archive__cta { flex-direction: column; align-items: stretch; text-align: left; }
}

/* ──────────────────────────────────────────────────────────────────── */
/* FAQ-SECTION — blocco FAQ riusabile in coda alle pagine               */
/* (template-parts/_faq-section.php; riusa .faq-list / .faq-item)       */
/* ──────────────────────────────────────────────────────────────────── */

.faq-section { background: var(--white); border-top: 1px solid var(--rule); }
.faq-section__header {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	flex-wrap: wrap;
	gap: 20px;
	max-width: 880px;
	margin: 0 auto clamp(28px, 3.5vw, 48px);
}
.faq-section__title {
	margin-top: 16px;
	font-size: clamp(28px, 3.4vw, 48px);
	line-height: 1.1;
	font-weight: 200;
	color: var(--ink);
	letter-spacing: -0.02em;
}
.faq-section__title em.serif-italic { color: var(--green); }
.faq-section__all {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: var(--green);
	transition: gap 0.25s;
}
.faq-section__all:hover { gap: 14px; }

/* ──────────────────────────────────────────────────────────────────── */
/* MIRROR — pagina AI Mirror Method (/ai-mirror-method/)                */
/* Schema del percorso: traduzione web della slide 15 del PPT revisione */
/* ──────────────────────────────────────────────────────────────────── */

/* Flow a 3 colonne per i tre passi (riusa .metodo__card) */
.metodo__flow--tre { grid-template-columns: repeat(3, 1fr); }

/* Pain points: griglia 3 card bianche */
.mirror-pains {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(20px, 2.5vw, 40px);
}
.mirror-pain {
	background: var(--white);
	border: 1px solid var(--rule);
	padding: clamp(24px, 2.6vw, 36px);
	display: flex;
	flex-direction: column;
	gap: 12px;
	transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.mirror-pain:hover {
	transform: translateY(-6px);
	box-shadow: 0 26px 54px -26px rgba(15, 42, 31, 0.38);
	border-color: var(--green);
}
.mirror-pain__n {
	font-size: clamp(40px, 4vw, 60px);
	font-weight: 200;
	font-style: italic;
	color: var(--green);
	line-height: 0.9;
	letter-spacing: -0.04em;
}
.mirror-pain__title {
	font-size: clamp(19px, 1.8vw, 24px);
	font-weight: 400;
	color: var(--ink);
	line-height: 1.2;
	letter-spacing: -0.01em;
}
.mirror-pain__text { font-size: 15px; line-height: 1.6; color: var(--ink-soft); }

/* Schema del percorso: step numerati con rail animata.
   La linea oro si "disegna" allo scroll (scaleY scrubbed da motion.js,
   handler mirrorSchema) e gli step si accendono al passaggio, come il
   flow PONTE ma in verticale. Senza motion: tutto visibile, rail nascosta. */
.mirror-steps { border-top: 2px solid var(--rule); position: relative; }
.mirror-steps__rail {
	position: absolute;
	left: 44px; /* centro della colonna numeri (90px) */
	top: 0;
	bottom: 0;
	width: 2px;
	background: rgba(45, 106, 79, 0.15);
	z-index: 0;
}
.mirror-steps__rail-fill {
	display: block;
	width: 100%;
	height: 100%;
	background: var(--gold);
	transform: scaleY(0);
	transform-origin: center top;
}
html:not(.motion) .mirror-steps__rail { display: none; }
/* Dim SOLO sul contenuto, mai sull'intero step: opacity sullo step
   creerebbe uno stacking context che rende semitrasparente anche la
   maschera ivory dietro il numero (= rail visibile attraverso la cifra). */
html.motion .mirror-step > div:last-child { opacity: 0.35; transition: opacity 0.6s var(--ease); }
html.motion .mirror-step.is-active > div:last-child { opacity: 1; }
html.motion .mirror-step__n { color: var(--gray); }
html.motion .mirror-step.is-active .mirror-step__n { color: var(--gold-deep); }
.mirror-step {
	display: grid;
	grid-template-columns: 90px 1fr;
	gap: clamp(20px, 3vw, 48px);
	padding: clamp(28px, 3.5vw, 48px) 0;
	border-bottom: 1px solid var(--rule);
	align-items: start;
}
.mirror-step__n {
	font-family: var(--serif);
	font-size: clamp(44px, 4.4vw, 68px);
	font-weight: 200;
	font-style: italic;
	color: var(--green);
	line-height: 0.9;
	letter-spacing: -0.04em;
	/* Cifra centrata sulla rail; il box ivory full-width maschera la
	   linea dietro la cifra (stesso bg della sezione). */
	text-align: center;
	position: relative;
	z-index: 1;
	background: var(--ivory);
	padding: 6px 0 12px;
	transition: color 0.4s;
}
.mirror-step__title {
	font-size: clamp(24px, 2.6vw, 34px);
	color: var(--ink);
	line-height: 1.12;
	letter-spacing: -0.01em;
}
.mirror-step__text {
	margin-top: 12px;
	font-size: 16px;
	line-height: 1.65;
	color: var(--ink-soft);
	max-width: 680px;
}
/* Le 4 aree di lavoro (card verdi come nella slide), con la fase
   di appartenenza come occhiello oro */
.mirror-aree {
	margin-top: 24px;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: clamp(14px, 1.6vw, 24px);
}
.mirror-area {
	background: var(--green-deep);
	color: var(--white);
	padding: clamp(22px, 2.4vw, 34px);
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.mirror-area__fase { color: var(--gold-text); font-size: 10px; }
.mirror-area__title {
	font-size: clamp(19px, 1.8vw, 24px);
	font-weight: 400;
	color: var(--white);
	line-height: 1.2;
}
.mirror-area__text { font-size: 15px; line-height: 1.55; color: rgba(255, 255, 255, 0.88); }

/* Modulo manager: banda evidenziata */
.mirror-manager {
	margin-top: 24px;
	/* 14 giu 2026: era --green-ink (quasi nero = "lugubre"), portato a --green-deep. */
	background: var(--green-deep);
	color: var(--white);
	border-left: 3px solid var(--gold);
	padding: clamp(24px, 3vw, 40px);
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.mirror-manager__statement {
	font-family: var(--serif);
	font-style: italic;
	font-size: clamp(20px, 2vw, 26px);
	line-height: 1.4;
	font-weight: 300;
	color: var(--white);
	max-width: 720px;
}

/* Cosa ottieni + meta su banda verde (riusa servizi__outcomes/meta) */
.mirror-ottieni {
	display: grid;
	grid-template-columns: 1.5fr 1fr;
	gap: clamp(32px, 5vw, 80px);
	align-items: start;
}

/* Questionario: box CTA con bordo oro */
.mirror-quiz {
	background: var(--paper);
	border-left: 3px solid var(--gold);
	padding: clamp(32px, 4vw, 56px);
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 24px;
}
.mirror-quiz__title {
	font-size: clamp(22px, 2.4vw, 32px);
	color: var(--ink);
	font-weight: 400;
	line-height: 1.25;
	max-width: 560px;
}
.mirror-quiz__title em.serif-italic { color: var(--green); }
.mirror-quiz__note { margin-top: 8px; font-size: 13px; color: var(--muted); font-style: italic; }

@media (max-width: 860px) {
	.mirror-pains { grid-template-columns: 1fr; }
	.mirror-aree { grid-template-columns: 1fr; }
	.mirror-step { grid-template-columns: 56px 1fr; gap: 16px; }
	.mirror-steps__rail { left: 27px; }
	.mirror-ottieni { grid-template-columns: 1fr; }
	.mirror-quiz { flex-direction: column; align-items: stretch; }
}

/* ──────────────────────────────────────────────────────────────────── */
/* PAGINA SERVIZIO AI (v2) — elementi propri (bozza)                    */
/* ──────────────────────────────────────────────────────────────────── */

/* 4 — dato/È normale fare fatica */
.ai-stat { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(28px, 5vw, 72px); align-items: start; }
.ai-stat__claim { font-size: clamp(26px, 3vw, 40px); line-height: 1.12; color: var(--ink); font-weight: 300; margin: 14px 0 0; letter-spacing: -0.02em; }
.ai-stat__claim em { color: var(--gold-deep); }
.ai-stat__text { font-size: clamp(15px, 1.1vw, 17px); line-height: 1.6; color: var(--ink-soft); margin: 0; }

/* 5 — segnali: 4 card in 2x2 (la mirror-pains base e' a 3 col) */
.ai-segnali { grid-template-columns: repeat(2, 1fr); }
.ai-segnale__source {
	margin: 14px 0 0; padding-top: 12px; border-top: 1px solid var(--rule);
	font-size: 12.5px; line-height: 1.5; color: var(--muted); font-style: italic;
}
.ai-segnali__cta { margin-top: clamp(28px, 4vw, 44px); font-size: 16px; color: var(--ink-soft); }
.ai-segnali__cta a { color: var(--green-deep); font-weight: 700; white-space: nowrap; margin-left: 6px; }
.ai-segnali__cta a svg { vertical-align: middle; }

/* 7 — cosa costruiamo (3 elementi) */
.ai-build { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(24px, 3vw, 40px); margin-top: clamp(32px, 4vw, 52px); }
.ai-build__item { border-top: 2px solid var(--gold); padding-top: 22px; }
.ai-build__n { font-size: 22px; font-style: italic; color: var(--gold-deep); font-weight: 300; }
.ai-build__word { font-size: clamp(22px, 2vw, 28px); color: var(--green-deep); margin: 6px 0 10px; letter-spacing: -0.01em; }
.ai-build__lead { font-size: 15px; font-weight: 700; color: var(--ink); margin: 0 0 8px; line-height: 1.4; }
.ai-build__text { font-size: 14.5px; line-height: 1.6; color: var(--ink-soft); margin: 0; }

/* 8 — formati (su .servizi, fondo verde) */
.ai-offerte { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(20px, 2.4vw, 32px); margin-top: clamp(32px, 4vw, 52px); }
.ai-offer { background: rgba(255,255,255,0.06); border: 1px solid rgba(217,194,90,0.28); border-radius: 4px; padding: clamp(22px, 2vw, 30px); }
.ai-offer__name { font-size: clamp(20px, 1.8vw, 25px); color: var(--white); margin: 0 0 10px; letter-spacing: -0.01em; }
.ai-offer__who { font-size: 14px; color: var(--gold-text); margin: 0 0 12px; line-height: 1.45; font-weight: 600; }
.ai-offer__text { font-size: 14.5px; line-height: 1.6; color: rgba(255,255,255,0.82); margin: 0; }
.ai-offerte__foot { margin: clamp(28px, 3vw, 40px) 0 0; max-width: 760px; color: rgba(255,255,255,0.82); font-size: 15px; line-height: 1.6; font-style: italic; }

/* Pagina Cambiamento — bussola a 4 direzioni (dalla ricerca 2025) */
.cambio-bussola { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(20px, 2.4vw, 32px); margin-top: clamp(32px, 4vw, 52px); }
.cambio-bussola__item { border-top: 2px solid var(--gold); padding-top: 18px; }
.cambio-bussola__word { font-size: clamp(20px, 1.8vw, 24px); color: var(--green-deep); margin: 0 0 8px; letter-spacing: -0.01em; }
.cambio-bussola__sub { font-size: 14px; line-height: 1.55; color: var(--ink-soft); margin: 0; }

@media (max-width: 860px) {
	.ai-stat { grid-template-columns: 1fr; gap: 20px; }
	.ai-segnali { grid-template-columns: 1fr; }
	.ai-build { grid-template-columns: 1fr; }
	.ai-offerte { grid-template-columns: 1fr; }
	.cambio-bussola { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
	.cambio-bussola { grid-template-columns: 1fr; }
}

/* ── Infografiche HTML (dal documento di Isabella) ── */

/* Paradosso dell'AI in Italia (pagina AI, sez. 4) */
.ai-paradox { max-width: 900px; margin: 0 auto; text-align: center; }
.ai-paradox__title { font-size: clamp(28px, 3.2vw, 44px); color: var(--ink); margin: 12px 0 4px; letter-spacing: -0.02em; }
.ai-paradox__sub { font-family: var(--serif); font-style: italic; font-size: clamp(16px, 1.4vw, 20px); color: var(--gold-deep); margin: 0 0 clamp(28px, 4vw, 48px); }
.ai-paradox__row { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr; align-items: start; gap: clamp(6px, 1.4vw, 18px); }
.ai-paradox__n { font-family: var(--serif); font-size: clamp(40px, 6vw, 76px); font-weight: 300; font-style: italic; color: var(--green-deep); line-height: 1; }
.ai-paradox__stat--alert .ai-paradox__n { color: var(--gold-deep); }
.ai-paradox__stat p { font-size: 14px; color: var(--ink-soft); line-height: 1.45; margin: 8px auto 0; max-width: 16em; }
.ai-paradox__arrow { color: var(--gold); font-size: 22px; align-self: center; }
.ai-paradox__small { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(20px, 3vw, 44px); align-items: center; text-align: left; margin: clamp(28px, 4vw, 52px) 0; padding: clamp(22px, 3vw, 34px); background: var(--ivory); border-radius: 4px; }
.ai-paradox__small-k { display: block; color: var(--gold-deep); font-size: 11px; margin-bottom: 4px; }
.ai-paradox__small-stat .ai-paradox__n { font-size: clamp(34px, 5vw, 58px); }
.ai-paradox__small-stat p { font-size: 13px; color: var(--ink-soft); margin: 6px 0 0; line-height: 1.45; }
.ai-paradox__small-note strong { display: block; color: var(--green-deep); font-size: 16px; margin-bottom: 6px; }
.ai-paradox__small-note p { font-size: 14px; color: var(--ink-soft); line-height: 1.5; margin: 0; }
.ai-paradox__claim { font-size: clamp(18px, 1.9vw, 25px); line-height: 1.4; color: var(--ink); max-width: 660px; margin: 0 auto; }
.ai-paradox__claim em { color: var(--green-deep); }
.ai-paradox__src { font-size: 11px; color: var(--muted); font-style: italic; margin-top: 18px; }
@media (max-width: 720px) {
	.ai-paradox__row { grid-template-columns: 1fr; gap: 2px; }
	.ai-paradox__arrow { transform: rotate(90deg); margin: 2px 0; }
	.ai-paradox__small { grid-template-columns: 1fr; text-align: center; }
}

/* AI Mirror Method — lo specchio coi 3 passi (pagina AI, sez. 7) */
.ai-mirror { display: flex; flex-direction: column; align-items: center; margin: clamp(28px, 4vw, 48px) auto clamp(12px, 2vw, 28px); }
.ai-mirror__glass {
	width: min(100%, 400px); aspect-ratio: 1; border-radius: 50%;
	border: 2px solid var(--gold);
	background: radial-gradient(circle at 50% 32%, #ffffff, var(--ivory) 78%);
	box-shadow: 0 30px 70px -30px rgba(15, 42, 31, 0.35), inset 0 0 60px rgba(255, 255, 255, 0.6);
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	gap: clamp(8px, 1.8vh, 16px); padding: clamp(28px, 5vw, 44px); text-align: center;
}
.ai-mirror__step { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.ai-mirror__icon { color: var(--green-deep); opacity: 0.85; }
.ai-mirror__step:nth-child(5) .ai-mirror__icon { color: var(--gold-deep); opacity: 1; }
.ai-mirror__label { font-family: var(--sans); font-weight: 700; font-size: clamp(13px, 1.3vw, 16px); letter-spacing: 0.02em; color: var(--green-deep); line-height: 1.2; max-width: 12em; }
.ai-mirror__sep { width: 5px; height: 5px; border-radius: 50%; background: var(--gold); opacity: 0.6; }
.ai-mirror__cap { color: var(--gold-deep); font-size: 11px; margin: 18px 0 4px; }
.ai-mirror__note { font-size: 14px; color: var(--ink-soft); max-width: 30em; line-height: 1.5; margin: 0; text-align: center; }

/* Sotto-punti delle card "cosa costruiamo" (pagina AI, sez. 7) */
.ai-build__sub { list-style: none; margin: 14px 0 0; padding: 0; display: grid; gap: 10px; }
.ai-build__sub li { font-size: 13.5px; line-height: 1.5; color: var(--ink-soft); padding-left: 14px; border-left: 2px solid var(--gold); }
.ai-build__sub strong { color: var(--green-deep); font-weight: 700; }

/* Bussola del cambiamento — diagramma circolare (pagina Cambiamento, sez. 2) */
.cambio-compass { max-width: 660px; margin: clamp(28px, 4vw, 52px) auto 0; text-align: center; }
.cambio-compass__intro { color: var(--gold-deep); font-size: 11px; margin: 0 0 clamp(20px, 3vw, 36px); }
/* Layout assoluto: i 4 nodi ai bordi, l'anello tratteggiato nel vuoto tra
   core e testi (niente sovrapposizione testo/linee). */
.cambio-compass__diagram { position: relative; height: clamp(400px, 52vw, 470px); max-width: 680px; margin: 0 auto; }
.cambio-compass__ring { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: clamp(210px, 30vw, 250px); aspect-ratio: 1; border: 1.5px dashed var(--gold); border-radius: 50%; opacity: 0.5; }
.cambio-compass__core { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 2; width: clamp(104px, 13.5vw, 132px); aspect-ratio: 1; border-radius: 50%; background: var(--green-deep); color: var(--white); display: flex; align-items: center; justify-content: center; box-shadow: 0 16px 40px -16px rgba(15, 42, 31, 0.6); }
.cambio-compass__core span { font-size: clamp(10px, 1.05vw, 12px); font-weight: 700; text-transform: uppercase; letter-spacing: 0.015em; text-align: center; padding: 0 8px; }
.cambio-compass__node { position: absolute; z-index: 1; width: clamp(150px, 22vw, 188px); }
.cambio-compass__node--top    { top: 0; left: 50%; transform: translateX(-50%); text-align: center; }
.cambio-compass__node--bottom { bottom: 0; left: 50%; transform: translateX(-50%); text-align: center; }
.cambio-compass__node--left   { left: 0; top: 50%; transform: translateY(-50%); text-align: left; }
.cambio-compass__node--right  { right: 0; top: 50%; transform: translateY(-50%); text-align: right; }
.cambio-compass__node-word { display: block; font-size: clamp(15px, 1.6vw, 19px); color: var(--green-deep); letter-spacing: -0.01em; }
.cambio-compass__node-sub { display: block; font-size: 12.5px; color: var(--ink-soft); line-height: 1.4; margin-top: 4px; }
.cambio-compass__foot { font-size: 14px; color: var(--ink-soft); font-style: italic; max-width: 540px; margin: clamp(24px, 3vw, 40px) auto 0; line-height: 1.5; }
@media (max-width: 640px) {
	.cambio-compass__diagram { height: auto; display: flex; flex-direction: column; align-items: center; gap: 22px; }
	.cambio-compass__ring { display: none; }
	.cambio-compass__core,
	.cambio-compass__node { position: static; transform: none; width: auto; max-width: 360px; text-align: center; }
	.cambio-compass__core { order: -1; }
	.cambio-compass__node--left, .cambio-compass__node--right { text-align: center; }
}

.metodo__subhead--second { margin-top: clamp(40px, 5vw, 68px); }

/* Home: "Due sfide, un'unica bussola" — manifesto + 2 territori (banda) */
.territori { background: var(--ivory); }
.territori__head { max-width: 760px; margin: 0 auto clamp(36px, 5vw, 56px); text-align: center; }
.territori__manifesto { margin-top: 16px; }
.territori__lead { font-size: clamp(20px, 2.2vw, 28px); line-height: 1.35; color: var(--ink); font-weight: 300; margin: 0 0 16px; letter-spacing: -0.01em; }
.territori__manifesto p:not(.territori__lead) { font-size: clamp(15px, 1.1vw, 17px); line-height: 1.6; color: var(--ink-soft); margin: 0 auto 12px; max-width: 660px; }
.territori__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(20px, 2.5vw, 32px); }
.territori__card { background: var(--white); border-top: 3px solid var(--green); border-radius: 4px; padding: clamp(26px, 3vw, 40px); display: flex; flex-direction: column; box-shadow: 0 24px 60px -36px rgba(15, 42, 31, 0.3); }
.territori__card:last-child { border-top-color: var(--gold); }
.territori__card-k { color: var(--green-deep); font-size: 11px; }
.territori__card:last-child .territori__card-k { color: var(--gold-deep); }
.territori__card-q { font-size: clamp(22px, 2.2vw, 30px); line-height: 1.12; color: var(--ink); margin: 12px 0 14px; letter-spacing: -0.02em; }
.territori__card-p { font-size: 15px; line-height: 1.6; color: var(--ink-soft); margin: 0 0 12px; }
.territori__card-cta { margin-top: auto; padding-top: 16px; display: inline-flex; align-items: center; gap: 10px; align-self: flex-start; color: var(--green-deep); font-family: var(--sans); font-weight: 700; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; text-decoration: none; transition: gap 0.25s; }
.territori__card:last-child .territori__card-cta { color: var(--gold-deep); }
.territori__card-cta:hover { gap: 14px; }
@media (max-width: 760px) { .territori__grid { grid-template-columns: 1fr; } }

/* Chip cliente (logo) nel caso studio */
.case-client { display: flex; align-items: center; gap: 16px; margin: 0 0 22px; flex-wrap: wrap; }
.case-client__k { color: var(--gold-text); font-size: 10px; }
.case-client__logo { display: inline-flex; align-items: center; background: var(--white); border-radius: 4px; padding: 10px 18px; }
.case-client__logo img { height: 30px; width: auto; display: block; }
