.front-section--hero {
	display: flex;
	align-items: center;
	min-height: 100svh;
	padding-top: calc(4.75rem + var(--space-12));
	padding-bottom: var(--space-20);
}

.front-section--manifesto,
.front-section--consequences,
.front-section--about,
.front-section--cta {
	background: var(--color-black);
}

.front-section--problem,
.front-section--faq {
	background: var(--color-surface-alt);
}

.front-section--solution,
.front-section--audience {
	background: var(--color-background);
}

.front-section--process {
	background: var(--color-surface);
}

.front-section--manifesto {
	padding-block: var(--space-24) var(--space-20);
}

.front-section--interstitial {
	padding-block: var(--space-16);
}

.hero,
.manifesto,
.consequences,
.about {
	display: grid;
	gap: var(--space-12);
}

.hero {
	justify-items: center;
}

.hero__copy,
.about__content,
.faq,
.cta {
	display: grid;
}

.hero__copy {
	justify-items: center;
	text-align: center;
}

.hero__lead {
	display: grid;
	gap: var(--space-3);
	justify-items: center;
}

.hero__eyebrow-note {
	max-width: 45ch;
	margin-inline: auto;
	color: var(--color-text-soft);
	font-size: 0.82rem;
	font-weight: 500;
	letter-spacing: 0.08em;
	line-height: 1.6;
	text-transform: none;
	text-align: center;
}

.hero__title {
	display: grid;
	gap: var(--space-2);
	margin-top: var(--space-6);
	max-width: 16ch;
	margin-inline: auto;
	font-size: clamp(1.2rem, 11vw, 2.4rem);
	line-height: 0.88;
	text-wrap: balance;
	text-align: center;
}

.hero__title-soft {
	color: var(--color-background);
	font-style: normal;
	font-weight: bold;
  -webkit-text-stroke: 2px var(--color-text-muted); /* Товщина та колір контуру */
  paint-order: stroke fill; /* Виправляє накладання ліній */
  stroke-linejoin: round;
  stroke-linecap: round;
}
.hero__title-soft:hover {
  color: #ffffff; /* Текст стає повністю білим */
  transition: 0.4s ease; /* Плавний перехід */
}

.hero__slogan {
	margin-top: var(--space-4);
	color: rgba(255, 255, 255, 0.42);
	font-family: var(--font-headline);
	font-size: clamp(0.95rem, 2.2vw, 1.2rem);
	font-style: italic;
	font-weight: 400;
	letter-spacing: 0.08em;
	line-height: 1.4;
	text-transform: uppercase;
}

.hero__summary {
	max-width: 42rem;
	margin-top: var(--space-6);
	margin-inline: auto;
	color: rgba(255, 255, 255, 0.92);
	font-size: clamp(1.1rem, 2vw, 1.45rem);
	line-height: 1.6;
	text-align: center;
}

.hero__microcopy {
	max-width: 38rem;
	margin-top: var(--space-4);
	margin-inline: auto;
	color: var(--color-text-muted);
	font-size: 1rem;
	line-height: 1.8;
	text-align: center;
}

.hero__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--space-4);
	margin-top: var(--space-8);
	margin-bottom: var(--space-8);
}

.hero__actions .button {
	flex: 1 1 100%;
}

.hero__signals {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--space-3);
	margin-top: var(--space-7);
	list-style: none;
}

.hero__signals li {
	padding: 0.8rem 1rem;
	border: 1px solid var(--color-line);
	background: rgba(255, 255, 255, 0.03);
	color: rgba(255, 255, 255, 0.74);
	font-size: 0.66rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

.hero__aside {
	display: grid;
	align-self: stretch;
	width: 100%;
}

.hero__panel {
	position: relative;
	display: grid;
	justify-items: center;
	gap: var(--space-4);
	overflow: hidden;
	padding: var(--space-6);
	border: 1px solid var(--color-line);
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.02), rgba(255, 255, 255, 0.01));
	isolation: isolate;
	text-align: center;
}

.hero__panel::after {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at top right, rgba(59, 130, 246, 0.18), transparent 35%);
	z-index: 0;
}

.hero__panel > * {
	position: relative;
	z-index: 1;
}

.hero__panel-image {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: grayscale(1);
	opacity: 0.12;
}

.hero__panel-grid {
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(rgba(59, 130, 246, 0.08) 1px, transparent 1px),
		linear-gradient(90deg, rgba(59, 130, 246, 0.08) 1px, transparent 1px);
	background-size: 28px 28px;
	opacity: 0.55;
	z-index: 0;
}

.hero__panel-meta {
	position: static;
	color: rgba(59, 130, 246, 0.9);
	font-size: 0.62rem;
	font-weight: 700;
	letter-spacing: 0.2em;
	text-transform: uppercase;
}

.hero__protocol-label {
	max-width: 24rem;
	padding-right: 0;
}

.hero__flow {
	display: grid;
	gap: var(--space-4);
	margin-top: var(--space-4);
	width: min(100%, 58rem);
}

.hero__flow-item {
	position: relative;
	display: grid;
	gap: var(--space-2);
	padding-top: var(--space-4);
	padding-left: 0;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	justify-items: center;
	text-align: center;
}

.hero__flow-item::before {
	content: "";
	position: absolute;
	top: calc(var(--space-4) + 0.1rem);
	left: 50%;
	width: 0.65rem;
	height: 0.65rem;
	background: var(--color-primary);
	box-shadow: 0 0 0 0.35rem rgba(59, 130, 246, 0.14);
	transform: translateX(-50%);
}

.hero__flow-index {
	color: var(--color-primary);
	font-size: 0.65rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
}

.hero__flow-title {
	font-size: 1.05rem;
	letter-spacing: 0.04em;
}

.hero__flow-text {
	color: rgba(255, 255, 255, 0.74);
	font-size: 0.92rem;
	line-height: 1.7;
}

.hero__protocol-text {
	max-width: 40rem;
	padding-top: var(--space-4);
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	margin-inline: auto;
	color: var(--color-text-muted);
	font-size: 0.92rem;
	line-height: 1.75;
	text-transform: none;
	letter-spacing: 0.01em;
	text-align: center;
}

.manifesto__lead {
	font-size: 1.35rem;
	font-style: italic;
	color: var(--color-text);
}

.manifesto__check {
	margin-top: var(--space-5);
	color: var(--color-text-soft);
	font-size: 0.65rem;
	letter-spacing: 0.26em;
	text-transform: uppercase;
}

.problem-intro,
.audience-intro,
.faq-intro,
.interstitial__footer {
	display: grid;
	gap: var(--space-6);
}

.problem-intro,
.audience-intro {
	margin-bottom: var(--space-12);
}

.problem-intro__meta {
	display: grid;
	gap: var(--space-2);
	justify-items: start;
}

.problem-intro__code {
	font-family: var(--font-headline);
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1;
}

.consequences__intro {
	display: grid;
	gap: var(--space-6);
}

.consequence-item__body {
	max-width: 36rem;
}

.solution-intro {
	display: grid;
	gap: var(--space-6);
	margin-bottom: var(--space-10);
	max-width: 64rem;
}

.solution-intro__title {
	display: grid;
	gap: var(--space-2);
}

.solution-grid {
	display: grid;
	gap: var(--space-4);
}

.front-section--interstitial {
	background-color: var(--color-primary);
	color: var(--color-white);
}

.interstitial {
	display: grid;
	gap: var(--space-8);
}

.interstitial__title {
	max-width: 11ch;
	font-family: var(--font-headline);
	font-size: 2.35rem;
	font-weight: 700;
	line-height: 0.9;
	letter-spacing: -0.02em;
	text-transform: uppercase;
}

.interstitial__subtitle {
	font-family: var(--font-headline);
	font-size: 1.1rem;
	font-weight: 500;
	letter-spacing: 0.24em;
	text-transform: uppercase;
}

.interstitial__status {
	display: grid;
	gap: var(--space-2);
	color: rgba(255, 255, 255, 0.72);
	font-size: 0.65rem;
	letter-spacing: 0.24em;
	text-transform: uppercase;
}

.about__figure {
	position: relative;
	overflow: hidden;
	border: 1px solid var(--color-line);
	padding: var(--space-3);
	background: var(--color-surface);
	box-shadow: var(--shadow-soft);
}

.about__figure img {
	width: 100%;
	aspect-ratio: 3 / 4;
	object-fit: cover;
	object-position: center top;
	filter: grayscale(1);
	opacity: 0.92;
}

.about__figure-overlay {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(5, 5, 5, 0.12), transparent 35%),
		linear-gradient(0deg, rgba(5, 5, 5, 0.72), transparent 40%);
}

.about__pillars {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	margin-top: var(--space-5);
	list-style: none;
}

.about__pillars li {
	padding: 0.7rem 0.85rem;
	border: 1px solid var(--color-line);
	background: rgba(255, 255, 255, 0.02);
	color: var(--color-text-muted);
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.22em;
	text-transform: uppercase;
}

.about__text {
	margin: var(--space-6) 0;
	max-width: 35rem;
	font-size: 1.06rem;
	line-height: 1.8;
}

.about__support {
	margin-top: var(--space-5);
	max-width: 30rem;
	color: var(--color-text-muted);
	font-size: 0.98rem;
	line-height: 1.75;
}

.faq {
	gap: var(--space-10);
}

.faq-intro {
	margin-bottom: var(--space-10);
	align-items: end;
}

.faq-intro__title {
	font-size: 3.2rem;
	line-height: 0.85;
	color: rgba(255, 255, 255, 0.12);
}

.faq-intro__text {
	max-width: 30rem;
	color: var(--color-text-muted);
	font-size: 1rem;
	line-height: 1.75;
}

.faq .faq-grid {
	width: min(100%, 72rem);
	margin-inline: auto;
	gap: var(--space-4);
	background: none;
	grid-template-columns: 1fr;
}

.faq-item {
	padding: var(--space-6);
}

.faq-item__code {
	display: inline-flex;
	margin-bottom: var(--space-4);
}

.faq-item__title {
	margin: 0;
	font-size: clamp(1.15rem, 2vw, 1.45rem);
	line-height: 1.1;
}

.cta {
	display: grid;
	gap: var(--space-6);
	text-align: center;
}

.cta__lead {
	max-width: 42rem;
	margin-inline: auto;
	color: rgba(255, 255, 255, 0.9);
	font-size: 1.06rem;
	line-height: 1.75;
}

.cta__panel {
	width: min(100%, 54rem);
	margin-inline: auto;
}

.cta__support {
	max-width: 42rem;
	margin-inline: auto;
	color: var(--color-text-muted);
	font-size: 0.95rem;
	line-height: 1.7;
}

.cta__chips {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--space-4);
	color: var(--color-text-soft);
	font-size: 0.68rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
}

.cta__chips span {
	padding: 0.75rem 0.85rem;
	border: 1px solid var(--color-line);
	background: rgba(255, 255, 255, 0.02);
}

.wpcf7-form {
	display: grid;
	gap: var(--space-5);
	padding: var(--space-8);
	border: 1px solid var(--color-line);
	background: rgba(8, 8, 8, 0.82);
	text-align: left;
	backdrop-filter: blur(14px);
}

.wpcf7-form p {
	display: grid;
	gap: var(--space-2);
	margin: 0;
}

.wpcf7-form label {
	color: var(--color-text-soft);
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.22em;
	text-transform: uppercase;
}

.wpcf7-form-control-wrap {
	display: block;
}

.wpcf7-form input:not([type="submit"]),
.wpcf7-form textarea {
	width: 100%;
	padding: 0 0 var(--space-3);
	border: 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.18);
	background: transparent;
	color: var(--color-white);
	border-radius: 0;
}

.wpcf7-form textarea {
	min-height: 8rem;
	resize: vertical;
}

.wpcf7-form input:not([type="submit"]):focus,
.wpcf7-form textarea:focus {
	border-color: var(--color-primary);
	outline: 0;
	box-shadow: 0 1px 0 var(--color-primary);
}

.wpcf7-submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 3.25rem;
	padding: 0.8rem 1.35rem;
	border: 0;
	border-radius: var(--radius-sm);
	background: linear-gradient(135deg, #3b82f6, #2f6fe0);
	color: var(--color-white);
	font-family: var(--font-headline);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.28em;
	text-transform: uppercase;
	transition: transform var(--transition-fast), filter var(--transition-fast);
}

.wpcf7-submit:hover,
.wpcf7-submit:focus-visible {
	filter: brightness(1.06);
	transform: translateY(-1px);
}

.wpcf7-not-valid-tip,
.wpcf7-response-output {
	font-size: 0.8rem;
}

@media (min-width: 48rem) {
	.front-section {
		padding: var(--space-24) 0;
	}

	.hero__title {
		font-size: clamp(3.6rem, 8vw, 4.8rem);
	}

	.interstitial__title,
	.faq-intro__title {
		font-size: 5rem;
	}

	.solution-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.manifesto__lead,
	.about__text {
		font-size: 1.4rem;
	}

	.hero__actions .button {
		flex: 0 0 auto;
	}
}

@media (min-width: 64rem) {
	.front-section--hero {
		padding-top: calc(5.4rem + var(--space-20));
	}

	.manifesto,
	.about {
		grid-template-columns: minmax(0, 1.15fr) minmax(23rem, 0.78fr);
		align-items: stretch;
	}

	.hero {
		max-width: min(100%, 76rem);
		margin-inline: auto;
		justify-items: center;
	}

	.hero__title {
		font-size: clamp(4.6rem, 7vw, 6.6rem);
		max-width: 16ch;
	}

	.hero__copy {
		padding-right: 0;
		justify-items: center;
		text-align: center;
	}

	.hero__aside {
		min-width: 0;
		width: min(100%, 64rem);
	}

	.hero__panel {
		padding: var(--space-8);
	}

	.hero__flow {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		align-items: stretch;
	}

	.problem-intro,
	.audience-intro,
	.faq-intro,
	.interstitial__footer {
		grid-template-columns: minmax(0, 1fr) auto;
		align-items: end;
	}

	.consequences {
		grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
		align-items: start;
	}

	.consequences__intro {
		position: sticky;
		top: 7rem;
	}

	.solution-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.solution-card--offset {
		transform: translateY(var(--space-10));
	}

	.solution-card--wide {
		grid-column: span 2;
		transform: translateY(calc(var(--space-10) * -1));
	}

	.interstitial__title {
		font-size: 6rem;
	}

	.faq-intro__title {
		font-size: 6.5rem;
	}

	.about {
		grid-template-columns: minmax(19rem, 0.72fr) minmax(0, 1fr);
		align-items: center;
	}
}

@media (min-width: 80rem) {
	.hero__title {
		font-size: 7rem;
	}

	.interstitial__title {
		font-size: 7.2rem;
	}
}
