:root {
	--green-primary: #60A630;
	--green-dark: #1E3A0F;
	--bg-light: #EDEEF3;
	--bg-pure: #FFFFFF;
	--text-main: #1C232B;
	--text-muted: #55606E;
	--border-color: #E0E5EE;
}

* {
	box-sizing: border-box;
}

body {
	font-family: 'Inter', sans-serif;
	color: var(--text-main);
	background: var(--bg-light);
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
}

h1,
h2,
h3,
h4,
h5,
h6,
.navbar-brand {
	font-family: 'Red Hat Display', sans-serif;
	font-weight: 200;
	color: var(--text-main);
}

/* ── NAVBAR ─────────────────────────────── */
.site-header {
	background: rgba(255, 255, 255, 0.96) !important;
	backdrop-filter: blur(12px);
	border-bottom: 1px solid var(--border-color);
}

.nav-link {
	font-size: 0.88rem;
	color: var(--text-muted) !important;
	font-weight: 500;
}

.nav-link:hover,
.nav-link.active {
	color: var(--text-main) !important;
}

.brand-logo {
	font-family: 'Red Hat Display', sans-serif;
	font-weight: 900;
	font-size: 1.5rem;
	color: var(--text-main);
}

.brand-logo span {
	color: var(--green-primary);
}

/* ── HERO ────────────────────────────────── */
.hero-section {
	min-height: 90vh;
	display: flex;
	align-items: center;
	background: var(--bg-light);
	position: relative;
	overflow: hidden;
}

.hero-hex-bg {
	position: absolute;
	inset: 0;
	background-image: url("data:image/svg+xml,%3Csvg width='80' height='92' viewBox='0 0 80 92' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M40 0L80 23V69L40 92L0 69V23L40 0Z' fill='%23C8CFDE' fill-opacity='0.22'/%3E%3C/svg%3E");
	background-size: 80px 92px;
	z-index: 0;
}

.hero-section .container {
	position: relative;
	z-index: 1;
}

.hero-h1 {
	font-size: clamp(6rem, 4vw, 4.5rem);
	line-height: 1.02;
	letter-spacing: -3px;
	font-weight: 400;
}

.hero-h1 .accent {
	color: var(--green-primary);
}

.hero-lead {
	font-size: 1.1rem;
	color: var(--text-muted);
	max-width: 600px;
	margin: 0 auto;
}

/* ── BTN ────────────────────────────────── */
.btn-primary {
	background: var(--green-primary) !important;
	border-color: var(--green-primary) !important;
	border-radius: 6px;
	font-weight: 600;
	font-size: 0.95rem;
}

.btn-primary:hover {
	background: #4e8a25 !important;
	border-color: #4e8a25 !important;
}

.btn-outline-secondary {
	border-radius: 6px;
	font-weight: 600;
	font-size: 0.95rem;
}

/* ── SECTIONS ───────────────────────────── */
.section {
	background: #fff;
}

.section-soft {
	background: var(--bg-light);
}

/* ── LARGE SECTION HEADINGS ─────────────── */
.section-h {
	font-size: clamp(2.4rem, 5vw, 4.8rem);
	line-height: 1.07;
	letter-spacing: -1.5px;
	font-weight: 300;
}

/* word-reveal wrappers */
.word-line {
	overflow: hidden;
	display: block;
}

.reveal-word {
	display: inline-block;
	opacity: 0;
	transform: translateY(105%);
	margin-right: 0.18em;
	will-change: transform, opacity;
}

.reveal-word.green {
	color: var(--green-primary);
}

.reveal-word.dim {
	color: #B0BAC8;
}

.reveal-word.serif-italic {
	font-style: italic;
}

/* ── UPGRADE SECTION ────────────────────── */
.upgrade-img {
	border-radius: 16px;
	overflow: hidden;
	background: #fff;
	border: 1px solid var(--border-color);
	padding: 1.5rem;
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.04);
}

.upgrade-img img {
	border-radius: 10px;
	width: 100%;
}

/* ── FEATURE GRID CARDS ─────────────────── */
.feat-card {
	background: #fff;
	border: 1px solid var(--border-color);
	border-radius: 14px;
	padding: 1.5rem;
	height: 100%;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.feat-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 14px 36px rgba(0, 0, 0, 0.07);
}

.feat-icon {
	width: 48px;
	height: 48px;
	border-radius: 10px;
	background: #EEF0FF;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1rem;
	color: #6E7CF8;
}

.feat-icon svg {
	width: 22px;
	height: 22px;
}

.feat-card h3 {
	font-size: 0.95rem;
	font-weight: 700;
	margin-bottom: 0.4rem;
}

.feat-card p {
	font-size: 0.85rem;
	color: var(--text-muted);
	margin: 0;
}

/* ── "WAY" CARDS (top 4) ─────────────────── */
.way-card {
	background: #fff;
	border: 1px solid var(--border-color);
	border-radius: 14px;
	padding: 1.75rem;
	height: 100%;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.way-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 14px 36px rgba(0, 0, 0, 0.07);
}

.way-card .card-icon {
	color: #8B8BF5;
	margin-bottom: 1.25rem;
}

/* ── SUPPORT SECTION ────────────────────── */
.support-list-item {
	padding: 1.1rem 1.5rem;
	border-left: 3px solid transparent;
	border-bottom: 1px solid var(--border-color);
	cursor: pointer;
	transition: all 0.25s ease;
	opacity: 0.45;
}

.support-list-item:first-child {
	border-top: 1px solid var(--border-color);
}

.support-list-item.active,
.support-list-item:hover {
	opacity: 1;
	border-left-color: var(--green-primary);
	background: rgba(96, 166, 48, 0.04);
}

.support-list-item .s-num {
	color: var(--green-primary);
	font-size: 0.8rem;
	font-weight: 700;
	margin-bottom: 0.15rem;
}

.support-list-item h4 {
	font-size: 1rem;
	margin-bottom: 0.2rem;
}

.support-list-item p {
	font-size: 0.85rem;
	color: var(--text-muted);
	margin: 0;
}

.support-img-wrap {
	border-radius: 16px;
	background: #EEF0FF;
	border: 1px solid var(--border-color);
	overflow: hidden;
	min-height: 360px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 2rem;
}

/* ── PRICING ────────────────────────────── */
.price-card {
	border-radius: 18px;
	padding: 2.5rem;
	height: 100%;
	border: 1px solid var(--border-color);
	background: #fff;
	transition: transform 0.3s ease;
}

.price-card:hover {
	transform: translateY(-5px);
}

.price-card.featured {
	background: var(--green-primary);
	border-color: var(--green-primary);
	color: #fff;
}

.price-card .tier {
	font-size: 1.3rem;
	font-weight: 800;
	margin-bottom: 0.4rem;
}

.price-card .amount {
	font-size: 3rem;
	font-weight: 900;
	line-height: 1;
}

.price-card .period {
	font-size: 0.9rem;
	font-weight: 400;
}

.price-card.featured .tier,
.price-card.featured .amount {
	color: #fff;
}

.price-note {
	font-size: 0.85rem;
	color: var(--text-muted);
}

/* ── STATS SCATTER ───────────────────────── */
.stats-scatter-section {
	background: var(--bg-light);
	position: relative;
	overflow: hidden;
}

.scatter-wrap {
	position: relative;
	height: 460px;
	margin: 3rem 0;
}

.scard {
	position: absolute;
	background: #fff;
	border: 1px solid var(--border-color);
	border-radius: 16px;
	padding: 1.4rem 1.8rem;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
	min-width: 170px;
	transition: box-shadow 0.3s ease, transform 0.3s ease;
	z-index: 2;
}

.scard:hover {
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.12);
	transform: scale(1.05) rotate(0deg) !important;
	z-index: 10;
}

.scard .s-icon {
	font-size: 1.1rem;
	color: #9AA5B4;
	margin-bottom: 0.4rem;
}

.scard .s-num {
	font-size: 1.8rem;
	font-weight: 900;
	color: var(--text-main);
}

.scard .s-label {
	font-size: 0.8rem;
	color: var(--text-muted);
}

/* Positioning & rotation */
.scard-1 {
	left: 2%;
	top: 15%;
	transform: rotate(-4deg);
}

.scard-2 {
	left: 28%;
	top: 5%;
	transform: rotate(2deg);
}

.scard-3 {
	right: 25%;
	top: 10%;
	transform: rotate(-2deg);
}

.scard-4 {
	right: 3%;
	top: 20%;
	transform: rotate(3deg);
}

.scard-5 {
	left: 15%;
	bottom: 10%;
	transform: rotate(2deg);
}

/* World-map concentric ring decoration */
.scatter-bg-rings {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	z-index: 1;
	pointer-events: none;
}

.scatter-bg-rings circle {
	fill: none;
	stroke: #C8CFDE;
	stroke-width: 1;
	stroke-dasharray: 4 8;
}

/* ── TESTIMONIALS ───────────────────────── */
.testi-card {
	background: #fff;
	border: 1px solid var(--border-color);
	border-radius: 16px;
	padding: 2rem;
}

.testi-card .quote {
	font-size: 1rem;
	line-height: 1.75;
	color: var(--text-main);
	margin-bottom: 1.5rem;
}

.testi-card .reviewer {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.testi-card .avatar {
	width: 42px;
	height: 42px;
	border-radius: 50%;
	background: var(--bg-light);
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	color: var(--green-primary);
	font-size: 1rem;
}

.testi-name {
	font-size: 0.9rem;
	font-weight: 700;
	display: block;
}

.testi-role {
	font-size: 0.8rem;
	color: var(--text-muted);
}

.clutch-card {
	background: #fff;
	border: 1px solid var(--border-color);
	border-radius: 16px;
	padding: 2.5rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	height: 100%;
}

.clutch-logo {
	font-size: 1.5rem;
	font-weight: 900;
	letter-spacing: -0.5px;
}

.clutch-ring {
	width: 110px;
	height: 110px;
	border-radius: 50%;
	border: 9px solid var(--green-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2.3rem;
	font-weight: 900;
}

.stars {
	color: #FF8C00;
	font-size: 1.2rem;
	letter-spacing: 2px;
}

.clutch-sub {
	font-size: 0.8rem;
	color: var(--text-muted);
}

/* ── FAQ ────────────────────────────────── */
.accordion-button:not(.collapsed) {
	background: #f7faf5;
	color: var(--green-primary);
}

.accordion-button:focus {
	box-shadow: none;
}

.accordion-item {
	border-radius: 10px !important;
	overflow: hidden;
	margin-bottom: 0.75rem;
	border: 1px solid var(--border-color) !important;
}

/* ── CTA BANNER ─────────────────────────── */
.cta-banner {
	background: var(--green-dark);
	border-radius: 24px;
}

.cta-banner h2 {
	font-size: clamp(2rem, 4vw, 3.5rem);
	letter-spacing: -1px;
}

/* ── FOOTER ─────────────────────────────── */
.footer-links a {
	color: #A3B3C2;
	text-decoration: none;
}

.footer-links a:hover {
	color: #fff;
}

/* ── SCROLL-TO-TOP ─────────────────────── */
.scroll-top-btn {
	position: fixed;
	bottom: 2rem;
	right: 2rem;
	width: 44px;
	height: 44px;
	background: var(--green-primary);
	color: #fff;
	border: none;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	z-index: 999;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.3s ease;
	box-shadow: 0 4px 16px rgba(96, 166, 48, 0.4);
}

.scroll-top-btn.visible {
	opacity: 1;
	pointer-events: auto;
}

/* Blue pill */
.blue-pill {
	position: fixed;
	bottom: 2rem;
	left: 2rem;
	width: 56px;
	height: 30px;
	background: #3B4EF8;
	border-radius: 999px;
	z-index: 900;
	opacity: 0.85;
}

/* Initial opacity for GSAP */
.gsap-init {
	opacity: 0;
}

/* --- New Style Definitions --- */

/* Font Family Additions */
h1,
h2,
h3,
h4,
.brand,
.layer-num,
.eyebrow {
	font-family: 'Red Hat Display', sans-serif;
	font-weight: 700;
}

h1 {
	font-weight: 900;
}

/* Global Accent Color (Matching provided visuals) */
:root {
	--vmx-green: #60A630;
	--text-dark: #1A1A1A;
}

/* Accent text */
.accent {
	color: var(--vmx-green);
}

/* Green Icons as requested */
.card-icon.green svg,
.green-icon {
	color: var(--vmx-green);
}

/* Section Head alignment utility */
.section-head.text-center {
	text-align: center;
}

.mx-auto {
	margin-left: auto;
	margin-right: auto;
}

/* 1. Stacked Visual (replacing previous) */
.stacked-card-visual {
	background: #fff;
	padding: 40px;
	border-radius: 12px;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05);
	text-align: center;
}

.stacked-card-visual p {
	margin-top: 20px;
	font-weight: 600;
	color: var(--text-dark);
}

/* 2. Architecture Layers Visual (replacing previous grid) */
.architecture-layers {
	display: flex;
	flex-direction: column;
	gap: 15px;
}

.layer-item {
	background: #F4F6F8;
	padding: 20px 25px;
	border-radius: 8px;
	display: flex;
	align-items: center;
	border: 1px solid #EAECEF;
}

.layer-item.highlight {
	background: #fff;
	border: 2px solid var(--vmx-green);
	box-shadow: 0 5px 15px rgba(96, 166, 48, 0.1);
}

.layer-num {
	font-size: 24px;
	color: var(--vmx-green);
	margin-right: 20px;
	width: 30px;
	text-align: center;
}

.layer-item h3 {
	margin: 0;
	font-size: 18px;
	color: var(--text-dark);
}

.layer-item p {
	margin: 0 0 0 auto;
	/* Push to right */
	font-size: 14px;
	color: #666;
}

/* CTA Banner Green Variant */
.cta-banner.green-bg {
	background-color: var(--vmx-green);
}

.btn-white {
	background: #fff;
	color: var(--vmx-green);
}

.btn-white:hover {
	background: #f0f0f0;
}

/* --- Animation Setup Classes --- */

/* Prevents elements from flashing before JS loads */
.gsap-text-animate,
.gsap-element-animate,
.staggered-grid>.card {
	opacity: 0;
	visibility: hidden;
}

/* Grayscale and opacity hover transitions for partner images */
.grayscale img {
	filter: grayscale(100%);
	opacity: 0.65;
	transition: filter 0.3s ease, opacity 0.3s ease;
}

.grayscale img:hover {
	filter: grayscale(0%);
	opacity: 1;
}

/* Logo Marquee / Slider Styles */
.logo-slider {
	overflow: hidden;
	width: 100%;
	position: relative;
	padding: 1.5rem 0;
	background: transparent;
}

/* Elegant edge fades using linear gradients */
.logo-slider::before,
.logo-slider::after {
	content: "";
	height: 100%;
	position: absolute;
	width: 150px;
	z-index: 2;
	pointer-events: none;
}

.logo-slider::before {
	left: 0;
	top: 0;
	background: linear-gradient(to right, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);
}

.logo-slider::after {
	right: 0;
	top: 0;
	background: linear-gradient(to left, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);
}

.logo-slider-track {
	display: flex;
	align-items: center;
	gap: 6rem;
	width: max-content;
	animation: scroll-marquee 25s linear infinite;
}

.logo-slider-track:hover {
	animation-play-state: paused;
}

.logo-slider img {
	height: 42px;
	width: auto;
	object-fit: contain;
	filter: grayscale(100%);
	opacity: 0.65;
	transition: filter 0.3s ease, opacity 0.3s ease, transform 0.3s ease;
}

.logo-slider img:hover {
	filter: grayscale(0%);
	opacity: 1;
	transform: scale(1.08);
}

@keyframes scroll-marquee {
	0% {
		transform: translate3d(0, 0, 0);
	}

	100% {
		transform: translate3d(-33.3333%, 0, 0);
	}
}