:root {
	--pink: #f199bf;
	--pink-deep: #c84f88;
	--green: #8fc742;
	--mint: #d7f2e2;
	--sky: #a8dff2;
	--yellow: #ffd86b;
	--ink: #223048;
	--muted: #617084;
	--soft: #fafafa;
	--white: #ffffff;
	--line: rgba(49, 66, 92, 0.14);
	--shadow: 0 20px 50px rgba(42, 56, 82, 0.1);
	--headline-font: "Aptos Display", "Trebuchet MS", Arial, sans-serif;
	--body-font: "Glacial Indifference", "Aptos", "Segoe UI", Arial, sans-serif;
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	color: var(--ink);
	font-family: var(--body-font);
	background: var(--soft);
	letter-spacing: 0;
}

a {
	color: inherit;
	text-decoration: none;
}

img {
	max-width: 100%;
}

.site-shell {
	overflow: hidden;
	background: var(--soft);
}

.top-contact {
	position: relative;
	z-index: 5;
	background: var(--pink);
	color: #263247;
}

.top-contact .container-fluid {
	min-height: 58px;
	display: flex;
	align-items: center;
	gap: clamp(0.7rem, 2vw, 1.5rem);
	padding: 0.55rem clamp(1rem, 4vw, 3.5rem);
	white-space: nowrap;
}

.top-logo {
	width: 42px;
	height: 42px;
	object-fit: contain;
	border-radius: 50%;
	background: #fff;
	box-shadow: 0 7px 18px rgba(74, 45, 67, 0.16);
}

.top-item {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	min-width: 0;
	font-size: 0.95rem;
	font-weight: 800;
}

.top-item i {
	color: #fff;
}

.top-scroll {
	display: flex;
	align-items: center;
	gap: clamp(0.7rem, 2vw, 1.5rem);
	overflow-x: auto;
	scrollbar-width: none;
}

.top-scroll::-webkit-scrollbar {
	display: none;
}

.section {
	position: relative;
	padding: clamp(4rem, 7vw, 6.7rem) 0;
	background: var(--soft);
}

.section-pink {
	background: var(--pink);
}

.section-title {
	max-width: 880px;
}

.section-kicker {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	margin-bottom: 0.8rem;
	color: var(--pink-deep);
	font-size: 0.83rem;
	font-weight: 900;
	text-transform: uppercase;
}

.section-pink .section-kicker,
.confidence .section-kicker {
	color: #fff;
}

h1,
h2,
h3,
h4 {
	font-family: var(--headline-font);
	letter-spacing: 0;
}

.section-title h2,
.hero-title {
	margin: 0;
	color: #1f2e47;
	font-weight: 900;
	line-height: 1.03;
}

.section-title h2 {
	font-size: clamp(2rem, 4.3vw, 3.55rem);
}

.section-title p,
.hero-copy p,
.lead-copy {
	color: var(--muted);
	font-size: clamp(1rem, 1.4vw, 1.12rem);
	line-height: 1.68;
}

.hero {
	min-height: calc(100vh - 58px);
	display: flex;
	align-items: center;
	padding: clamp(3.5rem, 6vw, 6rem) 0 clamp(2.5rem, 5vw, 4.5rem);
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.82), rgba(250, 250, 250, 0.96)),
		var(--soft);
}

.hero-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.03fr) minmax(280px, 0.82fr);
	gap: clamp(2rem, 5vw, 4.5rem);
	align-items: center;
}

.hero-subtitle {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 1rem;
	color: #af4279;
	font-size: clamp(1rem, 1.6vw, 1.28rem);
	font-weight: 900;
}

.hero-title {
	max-width: 760px;
	font-size: clamp(2.55rem, 6vw, 5.55rem);
}

.hero-copy p {
	max-width: 680px;
	margin: 1.3rem 0 0;
}

.hero-actions {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 0.8rem;
	max-width: 680px;
	margin-top: 2rem;
}

.btn {
	min-height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	border-radius: 8px;
	font-weight: 900;
}

.btn-primary-sylpi {
	color: #fff;
	background: #bf4f86;
	border-color: #bf4f86;
	box-shadow: 0 14px 28px rgba(191, 79, 134, 0.24);
}

.btn-primary-sylpi:hover,
.btn-primary-sylpi:focus {
	color: #fff;
	background: #a83e73;
	border-color: #a83e73;
}

.btn-primary-sylpi:disabled,
.btn-primary-sylpi.disabled {
	color: rgba(255, 255, 255, 0.92);
	background: #d7a5bd;
	border-color: #d7a5bd;
	box-shadow: none;
	cursor: not-allowed;
	opacity: 0.72;
}

.btn-outline-sylpi {
	color: #263247;
	background: #fff;
	border-color: rgba(32, 48, 71, 0.22);
}

.hero-logo-wrap {
	position: relative;
	display: grid;
	place-items: center;
	min-height: 430px;
}

.hero-logo {
	position: relative;
	width: min(88%, 420px);
	object-fit: contain;
	filter: drop-shadow(0 28px 48px rgba(43, 58, 86, 0.16));
}

.divider-row {
	display: block;
	overflow: hidden;
	background: var(--soft);
	line-height: 0;
}

.divider-row img {
	display: block;
	width: calc(100vw + 16px);
	max-width: none;
	height: auto;
	margin-left: -8px;
	margin-bottom: -2px;
}

.divider-left img {
	margin-right: 0;
}

.divider-right img {
	margin-left: -8px;
}

.divider-center img {
	margin-right: 0;
	margin-left: -8px;
}

.divider-flush-next {
	margin-bottom: 0;
	background: var(--soft);
}

.divider-flush-next img {
	margin-right: 0;
	margin-left: -8px;
}

.problem-grid {
	display: grid;
	grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.15fr);
	gap: 1.2rem;
	margin-top: 2.2rem;
}

.panel {
	border: 1px solid var(--line);
	border-radius: 8px;
	background: #fff;
	box-shadow: var(--shadow);
}

.problem-panel,
.cause-panel {
	padding: clamp(1.1rem, 2vw, 1.5rem);
}

.panel-heading {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 1rem;
}

.panel-heading h3 {
	margin: 0;
	font-size: 1.15rem;
	font-weight: 900;
	text-transform: capitalize;
}

.mini-icon {
	display: inline-grid;
	width: 42px;
	height: 42px;
	place-items: center;
	flex: 0 0 42px;
	color: #24324a;
	border-radius: 8px;
	background: #fce8f1;
}

.cause-panel .mini-icon {
	background: #eff9e7;
}

.stack-list {
	display: grid;
	gap: 0.8rem;
	margin: 0;
	padding: 0;
	list-style: none;
}

.stack-list li {
	display: flex;
	gap: 0.75rem;
	align-items: flex-start;
	padding: 0.92rem;
	border: 1px solid rgba(49, 66, 92, 0.1);
	border-radius: 8px;
	background: #fff;
	color: #40516a;
	font-weight: 760;
	line-height: 1.42;
}

.stack-list i {
	margin-top: 0.15rem;
	color: var(--pink-deep);
}

.cause-panel .stack-list i {
	color: #6aa323;
}

.solution-layout {
	display: grid;
	grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
	gap: 2rem;
	align-items: center;
}

.pillar-list {
	display: grid;
	gap: 1rem;
}

.pillar {
	display: grid;
	grid-template-columns: 52px minmax(0, 1fr);
	gap: 1rem;
	align-items: flex-start;
	padding: 1.1rem;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: #fff;
	box-shadow: var(--shadow);
}

.pillar i {
	display: grid;
	width: 52px;
	height: 52px;
	place-items: center;
	color: #fff;
	border-radius: 8px;
	background: var(--pink-deep);
	font-size: 1.2rem;
}

.pillar:nth-child(2) i {
	background: #71a927;
}

.pillar:nth-child(3) i {
	background: #2d8fb0;
}

.pillar h3,
.benefit h3,
.feature-category h3,
.trust-item h3 {
	margin: 0;
	color: #26354e;
	font-size: 1.12rem;
	font-weight: 900;
}

.pillar p,
.benefit p,
.feature-item p,
.trust-item p {
	margin: 0.35rem 0 0;
	color: var(--muted);
	line-height: 1.58;
}

.benefits-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
	margin-top: 2rem;
}

.benefit {
	min-height: 210px;
	padding: 1.25rem;
	border: 1px solid rgba(255, 255, 255, 0.62);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.86);
	box-shadow: 0 16px 34px rgba(98, 45, 75, 0.12);
}

.benefit i {
	display: grid;
	width: 46px;
	height: 46px;
	place-items: center;
	margin-bottom: 1rem;
	color: #fff;
	border-radius: 8px;
	background: #bf4f86;
}

.section-pink .section-title h2,
.section-pink .section-title p {
	color: #263247;
}

.feature-groups {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
	margin-top: 2rem;
}

.feature-category {
	padding: 1.25rem;
	border: 1px solid var(--line);
	border-radius: 8px;
	background: #fff;
	box-shadow: var(--shadow);
}

.category-label {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin-bottom: 1rem;
	padding: 0.42rem 0.65rem;
	color: #24324a;
	border-radius: 8px;
	background: #fce8f1;
	font-weight: 900;
}

.feature-category:nth-child(2) .category-label {
	background: #eff9e7;
}

.feature-category:nth-child(3) .category-label {
	background: #e7f6fb;
}

.feature-item {
	padding: 1rem 0;
	border-top: 1px solid rgba(49, 66, 92, 0.1);
}

.feature-item h4 {
	margin: 0;
	font-size: 1rem;
	font-weight: 900;
}

.confidence {
	color: #263247;
}

.trust-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1rem;
	margin-top: 2rem;
}

.trust-item {
	padding: 1.35rem;
	border: 1px solid rgba(255, 255, 255, 0.62);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.86);
	box-shadow: 0 16px 34px rgba(98, 45, 75, 0.12);
}

.trust-item i {
	display: grid;
	width: 52px;
	height: 52px;
	place-items: center;
	margin-bottom: 1rem;
	color: #fff;
	border-radius: 8px;
	background: #263247;
	font-size: 1.18rem;
}

.contact-grid {
	display: grid;
	grid-template-columns: minmax(0, 0.9fr) minmax(320px, 1.1fr);
	gap: 2rem;
	align-items: center;
}

.contact-points {
	display: grid;
	gap: 0.8rem;
	margin-top: 1.5rem;
}

.contact-point {
	display: flex;
	gap: 0.75rem;
	align-items: center;
	color: #40516a;
	font-weight: 850;
}

.contact-point i {
	color: var(--pink-deep);
}

.contact-form {
	padding: clamp(1.2rem, 2.5vw, 1.7rem);
	border: 1px solid var(--line);
	border-radius: 8px;
	background: #fff;
	box-shadow: var(--shadow);
}

.form-label {
	color: #33445e;
	font-weight: 850;
}

.form-control,
.form-select {
	min-height: 48px;
	color: var(--ink);
	border-color: rgba(49, 66, 92, 0.18);
	border-radius: 8px;
	font-family: var(--body-font);
}

.form-control:focus,
.form-select:focus {
	border-color: var(--pink);
	box-shadow: 0 0 0 0.22rem rgba(241, 153, 191, 0.22);
}

textarea.form-control {
	min-height: 128px;
}

.button-microcopy {
	margin-top: 0.7rem;
	margin-bottom: 0;
	color: var(--muted);
	text-align: center;
	font-size: 0.92rem;
	line-height: 1.45;
}

.footer {
	padding: 1.3rem 0;
	color: #203047;
	background: var(--green);
	font-weight: 900;
}

@media (max-width: 991.98px) {
	.top-contact .container-fluid {
		align-items: flex-start;
	}

	.hero-grid,
	.problem-grid,
	.solution-layout,
	.contact-grid {
		grid-template-columns: 1fr;
	}

	.hero-logo-wrap {
		min-height: 300px;
	}

	.hero-logo {
		width: min(360px, 86vw);
	}

	.benefits-grid,
	.feature-groups,
	.trust-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 575.98px) {
	.top-contact .container-fluid {
		min-height: 54px;
		padding: 0.45rem 0.8rem;
	}

	.top-logo {
		width: 38px;
		height: 38px;
	}

	.top-item {
		font-size: 0.86rem;
	}

	.hero-actions .btn {
		width: 100%;
	}

	.benefits-grid,
	.feature-groups,
	.trust-grid {
		grid-template-columns: 1fr;
	}

	.pillar {
		grid-template-columns: 1fr;
	}

	.footer .container {
		text-align: center;
	}
}