/* ImpulsoFuturo Survey — stile frontend.
   Mappa il tema SurveyJS sui token del brand (con fallback se il tema del sito
   non e' attivo) e stila restituzione, profili, CTA e PDF.
   Token: var(--green) ecc. da tokens.css del tema; fallback hard-coded. */

.ifs {
	--ifs-green:      var(--green, #2D6A4F);
	--ifs-green-deep: var(--green-deep, #1F4F39);
	--ifs-gold:       var(--gold, #AD941F);
	--ifs-ink:        var(--ink, #2C3E50);
	--ifs-white:      var(--white, #FFFFFF);
	--ifs-wash:       var(--green-wash, #E8EFE9);
	--ifs-rule:       rgba(45, 106, 79, 0.16);
	--ifs-sans:       var(--sans, "Lato", system-ui, sans-serif);
	--ifs-serif:      var(--serif, "Newsreader", Georgia, serif);

	/* SurveyJS theme variables */
	--sjs-font-family: var(--ifs-sans);
	--sjs-corner-radius: 12px;
	--sjs-base-unit: 9px;
	--sjs-primary-backcolor: var(--ifs-green);
	--sjs-primary-backcolor-dark: var(--ifs-green-deep);
	--sjs-primary-backcolor-light: rgba(45, 106, 79, 0.10);
	--sjs-primary-forecolor: #ffffff;
	--sjs-general-backcolor: #ffffff;
	--sjs-general-backcolor-dim: #f6f8f6;
	--sjs-general-backcolor-dim-light: #ffffff;
	--sjs-general-forecolor: var(--ifs-ink);
	--sjs-general-forecolor-light: #5A6671;

	max-width: 880px;
	margin: 0 auto;
	font-family: var(--ifs-sans);
	color: var(--ifs-ink);
}

/* Lo statico vive nel DOM (SEO/GEO) ma e' nascosto: visibile solo via noscript. */
.ifs [data-ifs-static] { display: none; }
.ifs [data-ifs-report][hidden] { display: none; }

/* ── SurveyJS: ritocchi brand ─────────────────────────────────────── */
/* La survey vive in una card bianca: si stacca dalla sezione tinta e
   comunica "strumento interattivo". */
.ifs .sd-root-modern {
	background: var(--ifs-white);
	border: 1px solid var(--ifs-rule);
	border-radius: 18px;
	padding: clamp(18px, 3vw, 40px);
	box-shadow: 0 20px 54px -32px rgba(15, 42, 31, 0.32);
}
.ifs .sd-title .sd-title__text,
.ifs .sd-question__title {
	font-family: var(--ifs-serif);
	font-weight: 600;
	color: var(--ifs-ink);
}
.ifs .sd-question__title { font-size: 1.18rem; line-height: 1.3; }
.ifs .sd-element__title { letter-spacing: .1px; }

/* Risposte (radiogroup) come pill orizzontali */
.ifs .sd-selectbase { gap: 8px; }
.ifs .sd-item--radio .sd-item__decorator { border-color: var(--ifs-rule); }
.ifs .sd-item--checked .sd-item__decorator { background: var(--ifs-green); }
.ifs .sd-radio--checked .sd-radio__decorator:after { background: #fff; }

.ifs .sd-btn--action,
.ifs .sd-navigation__complete-btn {
	background: var(--ifs-green);
	border-radius: 999px;
	font-weight: 700;
	letter-spacing: .2px;
}
.ifs .sd-btn--action:hover,
.ifs .sd-navigation__complete-btn:hover { background: var(--ifs-green-deep); }

.ifs .ifs-intro { margin-bottom: 4px; }
.ifs .ifs-intro__head {
	font-family: var(--ifs-serif);
	font-size: clamp(1.3rem, 3vw, 1.7rem);
	line-height: 1.2;
	color: var(--ifs-ink);
	margin: 0 0 .6em;
}
.ifs .ifs-intro p, .ifs .ifs-note p { color: #45525c; line-height: 1.6; }
.ifs .ifs-note { margin-top: 6px; font-style: italic; }

/* Step zero "Inizia": schermata di avvio (firstPageIsStarted) */
.ifs .ifs-start { text-align: center; padding: clamp(4px, 2vw, 14px) 0 clamp(10px, 2vw, 22px); }
.ifs .ifs-start__title {
	font-family: var(--ifs-serif);
	font-size: clamp(1.45rem, 3.6vw, 2.15rem);
	line-height: 1.18;
	color: var(--ifs-ink);
	margin: 0 auto .5em;
	max-width: 20ch;
}
.ifs .ifs-start__text { color: #45525c; line-height: 1.6; font-size: 1.05rem; max-width: 46ch; margin: 0 auto; }
.ifs .ifs-start__meta {
	margin: 18px auto 0;
	color: var(--ifs-green);
	font-weight: 700;
	font-size: 12px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}
.ifs .sd-navigation__start-btn {
	background: var(--ifs-green);
	color: #ffffff !important;
	border-radius: 999px;
	font-weight: 700;
	letter-spacing: .3px;
	padding-left: 34px;
	padding-right: 34px;
}
.ifs .sd-navigation__start-btn:hover { background: var(--ifs-green-deep); color: #ffffff !important; }
/* Centra SOLO la barra che contiene il pulsante Inizia (non le domande) */
.ifs .sd-action-bar:has(.sd-navigation__start-btn) { justify-content: center; }

/* ── Restituzione ─────────────────────────────────────────────────── */
.ifs-report { outline: none; }
.ifs-report__inner {
	background: var(--ifs-white);
	border: 1px solid var(--ifs-rule);
	border-radius: 18px;
	padding: clamp(24px, 4vw, 44px);
	box-shadow: 0 18px 50px -28px rgba(15, 42, 31, 0.35);
}
.ifs-report__brand {
	font-family: var(--ifs-serif);
	font-weight: 700;
	letter-spacing: .5px;
	color: var(--ifs-green);
	font-size: .95rem;
	margin-bottom: 18px;
}
.ifs-report__head {
	font-family: var(--ifs-serif);
	font-size: clamp(1.5rem, 4vw, 2.2rem);
	line-height: 1.15;
	margin: 0 0 .5em;
	color: var(--ifs-ink);
}
.ifs-report__lead { font-size: 1.05rem; line-height: 1.6; color: #45525c; margin: 0 0 1.4em; }
.ifs-report__reflect {
	font-family: var(--ifs-serif);
	font-style: italic;
	font-size: 1.1rem;
	color: var(--ifs-green-deep);
	border-left: 3px solid var(--ifs-gold);
	padding-left: 16px;
	margin: 1.2em 0;
}
.ifs-report__closing {
	font-family: var(--ifs-serif);
	font-size: 1.15rem;
	line-height: 1.5;
	color: var(--ifs-green-deep);
	margin: 1.4em 0 0.4em;
}

/* Recap delle riflessioni scritte (lo specchio rimanda ciò che hai scritto). */
.ifs-recap { display: grid; gap: 12px; margin: 0.6em 0 1.6em; }
.ifs-recap__item { border-left: 3px solid var(--ifs-gold); padding-left: 16px; }
.ifs-recap__q { margin: 0 0 .25em; font-weight: 700; color: var(--ifs-ink); line-height: 1.45; }
.ifs-recap__a { margin: 0; color: #45525c; line-height: 1.55; white-space: pre-wrap; }
.ifs-recap__a.is-empty { color: #9aa3ab; font-style: italic; }

.ifs-profiles { display: grid; gap: 14px; margin: 1.2em 0; }
@media (min-width: 620px) { .ifs-profiles { grid-template-columns: 1fr 1fr; } }
.ifs-profiles--top { grid-template-columns: 1fr !important; }
.ifs-profile {
	background: #f7faf8;
	border: 1px solid var(--ifs-rule);
	border-radius: 14px;
	padding: 18px 20px;
}
/* Lettura piu' vicina alle risposte: card evidenziata con accento oro */
.ifs-profile--top {
	background: #ffffff;
	border-color: var(--ifs-gold);
	box-shadow: 0 12px 34px -20px rgba(173, 148, 31, 0.55);
}
.ifs-profile__badge {
	display: inline-block;
	margin-bottom: 12px;
	color: var(--ifs-green-deep);
	background: rgba(173, 148, 31, 0.14);
	border: 1px solid var(--ifs-gold);
	border-radius: 999px;
	padding: 4px 12px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.08em;
}
.ifs-profiles__others-label {
	margin: 1.8em 0 0.6em;
	color: #5A6671;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.12em;
}
/* Letture secondarie come lista verticale: simmetrica con qualsiasi numero */
.ifs-others { border: 1px solid var(--ifs-rule); border-radius: 14px; background: #fff; overflow: hidden; }
.ifs-other { padding: 16px 20px; border-top: 1px solid var(--ifs-rule); }
.ifs-other:first-child { border-top: none; }
.ifs-other__name { font-family: var(--ifs-serif); font-size: 1.05rem; font-weight: 600; color: var(--ifs-ink); margin: 0 0 .35em; }
.ifs-other__desc { margin: 0 0 .4em; line-height: 1.5; color: #45525c; font-size: .95rem; }
.ifs-other__pillar { margin: 0; font-size: .9rem; }
.ifs-profile__name {
	font-family: var(--ifs-serif);
	font-size: 1.15rem;
	margin: 0 0 .4em;
	color: var(--ifs-ink);
}
.ifs-profile__desc { margin: 0 0 .7em; line-height: 1.55; color: #45525c; }
.ifs-profile__rec { margin: 0 0 .7em; line-height: 1.55; color: var(--ifs-ink); }
.ifs-profile__rec em { color: var(--ifs-green-deep); font-style: normal; font-weight: 700; }
.ifs-profile__pillar { margin: 0; font-size: .95rem; }

.ifs-link { color: var(--ifs-green); font-weight: 700; text-decoration: underline; text-underline-offset: 3px; }
.ifs-link:hover { color: var(--ifs-green-deep); }

.ifs-report__frame {
	margin: 1.6em 0 1.2em;
	padding: 18px 22px;
	background: var(--ifs-wash);
	border-radius: 14px;
}
.ifs-report__frame p { margin: 0 0 .6em; font-size: 1.05rem; color: var(--ifs-ink); }

.ifs-actions { display: flex; flex-wrap: wrap; gap: 12px; margin: 1.4em 0 1em; }
.ifs-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 13px 24px;
	border-radius: 999px;
	font-family: var(--ifs-sans);
	font-weight: 700;
	font-size: 1rem;
	cursor: pointer;
	text-decoration: none;
	border: 1.5px solid transparent;
	transition: background .25s ease, color .25s ease, border-color .25s ease;
}
.ifs-btn--primary { background: var(--ifs-green); color: #fff; }
.ifs-btn--primary:hover { background: var(--ifs-green-deep); color: #fff; }
.ifs-btn--ghost { background: transparent; color: var(--ifs-green); border-color: var(--ifs-green); }
.ifs-btn--ghost:hover { background: var(--ifs-green); color: #fff; }

.ifs-report__note { margin: .6em 0 0; font-size: .9rem; color: #6b7680; }

@media (prefers-reduced-motion: reduce) {
	.ifs-btn { transition: none; }
}
