﻿:root {
	--bg-main: #f7f9fa;
	--bg-card: #ffffff;
	--bg-card-hover: #f2f5f4;
	--bg-muted: #edf0ef;
	--ink: #1a2420;
	--ink-soft: #546860;
	--accent: #0fa968;
	--accent-bright: #12c278;
	--accent-dim: rgba(15, 169, 104, 0.08);
	--accent-teal: #0d7377;
	--accent-teal-dim: rgba(13, 115, 119, 0.08);
	--accent-warm: #0d7377;
	--accent-warm-dim: rgba(13, 115, 119, 0.08);
	--secure-green: #0fa968;
	--secure-green-dim: rgba(15, 169, 104, 0.08);
	--line: rgba(0, 0, 0, 0.1);
	--line-soft: rgba(0, 0, 0, 0.06);
	--shadow-soft: 0 18px 45px rgba(0, 0, 0, 0.08);
	--shadow-glow: 0 0 60px rgba(15, 169, 104, 0.06);
	--radius-xl: 24px;
	--radius-lg: 18px;
	--radius-md: 14px;
	--ease: cubic-bezier(0.16, 1, 0.3, 1);
	--ease-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html {
	scroll-behavior: smooth;
	scrollbar-width: thin;
	scrollbar-color: rgba(0, 0, 0, 0.18) transparent;
}

::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-thumb { background: rgba(0, 0, 0, 0.18); border-radius: 999px; }
::-webkit-scrollbar-track { background: transparent; }

body {
	overflow-x: hidden;
	line-height: 1.6;
	color: var(--ink);
	background: var(--bg-main);
	font-family: 'Plus Jakarta Sans', sans-serif;
}

::selection { background: var(--accent); color: #fff; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   AMBIENT BACKGROUND EFFECTS (Light)
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.bg-noise {
	position: fixed;
	inset: 0;
	z-index: -2;
	opacity: 0.018;
	background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
	pointer-events: none;
}

.bg-gradient-orb {
	position: fixed;
	width: 800px;
	height: 800px;
	border-radius: 50%;
	filter: blur(160px);
	pointer-events: none;
	z-index: -1;
	animation: orbFloat 14s ease-in-out infinite alternate;
}

.bg-gradient-orb--top {
	top: -350px;
	right: -200px;
	background: radial-gradient(circle, rgba(15, 169, 104, 0.06) 0%, transparent 70%);
}

.bg-gradient-orb--bottom {
	bottom: -350px;
	left: -200px;
	background: radial-gradient(circle, rgba(15, 169, 104, 0.04) 0%, transparent 70%);
	animation-delay: -7s;
}

.bg-gradient-orb--mid {
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 600px;
	height: 600px;
	background: radial-gradient(circle, rgba(15, 169, 104, 0.025) 0%, transparent 60%);
	animation-delay: -3s;
}

@keyframes orbFloat {
	0% { transform: translate(0, 0) scale(1); }
	100% { transform: translate(30px, -40px) scale(1.1); }
}

.bg-grid {
	position: fixed;
	inset: 0;
	z-index: -1;
	background-image:
		linear-gradient(rgba(0,0,0,0.02) 1px, transparent 1px),
		linear-gradient(90deg, rgba(0,0,0,0.02) 1px, transparent 1px);
	background-size: 60px 60px;
	pointer-events: none;
	mask-image: radial-gradient(ellipse at center, black 30%, transparent 70%);
	-webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 70%);
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   NAVIGATION
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.top-nav {
	position: fixed;
	top: 0;
	z-index: 50;
	width: 100%;
	border-bottom: 1px solid rgba(0,0,0,0.06);
	background: rgba(248, 249, 251, 0.92);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	transition: box-shadow 0.3s var(--ease), border-color 0.3s var(--ease);
}

.nav-scrolled {
	box-shadow: 0 4px 30px rgba(0, 0, 0, 0.08);
	border-color: rgba(0, 0, 0, 0.1) !important;
}

.nav-inner {
	max-width: 1200px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0.9rem 1.25rem;
}

.nav-brand {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	text-decoration: none;
	color: var(--ink);
}

.nav-brand-name {
	font-family: 'Playfair Display', serif;
	font-size: 1.35rem;
	letter-spacing: 0.02em;
}

.nav-brand-tag {
	display: none;
	border-radius: 999px;
	border: 1px solid rgba(15, 169, 104, 0.25);
	background: var(--accent-dim);
	padding: 0.25rem 0.7rem;
	font-size: 0.6rem;
	font-weight: 800;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--accent);
}

@media (min-width: 768px) {
	.nav-brand-tag { display: inline-block; }
}

.nav-links {
	display: none;
	align-items: center;
	gap: 2rem;
}

@media (min-width: 768px) {
	.nav-links { display: flex; }
}

.nav-link {
	position: relative;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.13em;
	text-transform: uppercase;
	color: var(--ink-soft);
	text-decoration: none;
	transition: color 0.3s var(--ease);
}

.nav-link::after {
	content: "";
	position: absolute;
	left: 0; bottom: -5px;
	width: 0; height: 2px;
	background: var(--accent);
	transition: width 0.35s var(--ease);
	border-radius: 2px;
}

.nav-link:hover, .nav-link:focus-visible { color: var(--ink); }
.nav-link:hover::after, .nav-link:focus-visible::after { width: 100%; }

.menu-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	border: 1px solid rgba(0,0,0,0.12);
	background: transparent;
	color: var(--ink);
	font-size: 0.9rem;
	cursor: pointer;
}

@media (min-width: 768px) {
	.menu-btn { display: none; }
}

.mobile-menu {
	display: none;
	border-top: 1px solid rgba(0,0,0,0.08);
	background: rgba(248, 249, 251, 0.97);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	padding: 1.25rem;
}

.mobile-menu.is-open { display: flex; flex-direction: column; gap: 1rem; }

@media (min-width: 768px) {
	.mobile-menu { display: none !important; }
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   BUTTONS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.btn-main, .btn-ghost {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	border-radius: 999px;
	padding: 0.9rem 1.6rem;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	text-decoration: none;
	cursor: pointer;
	position: relative;
	overflow: hidden;
	border: none;
	font-family: 'Plus Jakarta Sans', sans-serif;
	transition: transform 0.35s var(--ease-bounce), box-shadow 0.35s var(--ease), background 0.3s var(--ease), color 0.3s var(--ease), border-color 0.3s var(--ease);
}

.btn-main::before, .btn-ghost::before {
	content: '';
	position: absolute;
	top: 0; left: -100%;
	width: 100%; height: 100%;
	background: linear-gradient(90deg, transparent, rgba(255,255,255,0.25), transparent);
	transition: left 0.6s var(--ease);
}

.btn-main:hover::before, .btn-ghost:hover::before {
	left: 100%;
}

/* Primary CTA - Call */
.btn-call-primary {
	background: linear-gradient(135deg, #0fa968 0%, #0d7377 100%);
	color: #fff;
	box-shadow: 0 8px 24px rgba(15, 169, 104, 0.25);
}

.btn-call-primary:hover, .btn-call-primary:focus-visible {
	transform: translateY(-3px) scale(1.02);
	box-shadow: 0 20px 40px rgba(15, 169, 104, 0.35), 0 0 20px rgba(15, 169, 104, 0.12);
	background: linear-gradient(135deg, #12c278 0%, #0fa968 100%);
}

/* Secondary CTA - Visit */
.btn-visit {
	background: transparent;
	border: 2px solid var(--accent);
	color: var(--accent);
}

.btn-visit:hover, .btn-visit:focus-visible {
	transform: translateY(-3px) scale(1.02);
	background: var(--accent);
	color: #fff;
	box-shadow: 0 20px 40px rgba(15, 169, 104, 0.25);
}

.btn-ghost {
	border: 1px solid var(--line);
	background: rgba(0, 0, 0, 0.03);
	color: var(--ink);
}

.btn-ghost:hover, .btn-ghost:focus-visible {
	transform: translateY(-3px) scale(1.02);
	border-color: rgba(0, 0, 0, 0.15);
	background: rgba(0, 0, 0, 0.06);
	box-shadow: 0 16px 35px rgba(0, 0, 0, 0.08);
}

/* Pulse ring on CTA */
.btn-pulse {
	animation: btnPulseRing 2.5s ease-out infinite;
}

@keyframes btnPulseRing {
	0% { box-shadow: 0 8px 24px rgba(15, 169, 104, 0.25), 0 0 0 0 rgba(15, 169, 104, 0.35); }
	70% { box-shadow: 0 8px 24px rgba(15, 169, 104, 0.25), 0 0 0 14px rgba(15, 169, 104, 0); }
	100% { box-shadow: 0 8px 24px rgba(15, 169, 104, 0.25), 0 0 0 0 rgba(15, 169, 104, 0); }
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   TRUST PILLS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.trust-pill {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	border-radius: 999px;
	border: 1px solid var(--line-soft);
	background: rgba(0, 0, 0, 0.03);
	padding: 0.45rem 0.85rem;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--ink-soft);
	transition: border-color 0.3s var(--ease), transform 0.3s var(--ease);
}

.trust-pill:hover {
	border-color: var(--line);
	transform: translateY(-1px);
}

.trust-pill-highlight {
	border-color: rgba(15, 169, 104, 0.2);
	background: var(--accent-dim);
	color: var(--accent);
	animation: pulseTag 2.8s ease-in-out infinite;
}

@keyframes pulseTag {
	0%, 100% { box-shadow: 0 0 0 rgba(15, 169, 104, 0); }
	50% { box-shadow: 0 4px 20px rgba(15, 169, 104, 0.1); }
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   SECTION HEADERS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.section-kicker {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	border-radius: 999px;
	border: 1px solid rgba(15, 169, 104, 0.15);
	background: var(--accent-dim);
	padding: 0.42rem 0.9rem;
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.11em;
	color: var(--accent);
}

.section-kicker-warm {
	background: var(--accent-warm-dim);
	color: var(--accent-warm);
	border-color: rgba(196, 125, 21, 0.15);
}

.section-kicker-green {
	background: var(--secure-green-dim);
	color: var(--secure-green);
	border-color: rgba(26, 138, 74, 0.15);
}

.section-title {
	margin-top: 0.85rem;
	max-width: 22ch;
	font-family: 'Playfair Display', serif;
	font-size: clamp(1.85rem, 3.5vw, 2.85rem);
	line-height: 1.1;
	color: var(--ink);
}

.section-subtitle {
	margin-top: 0.7rem;
	max-width: 560px;
	font-size: 1rem;
	color: var(--ink-soft);
	line-height: 1.65;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   HERO
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.hero {
	max-width: 1200px;
	margin: 0 auto;
	display: grid;
	gap: 2.5rem;
	padding: 1.25rem;
	padding-top: 7rem;
	padding-bottom: 3rem;
}

@media (min-width: 768px) {
	.hero {
		grid-template-columns: 1.15fr 0.85fr;
		padding-top: 9rem;
		padding-bottom: 4rem;
		gap: 3rem;
	}
}

.hero-title {
	max-width: 600px;
	font-family: 'Playfair Display', serif;
	font-size: clamp(2rem, 5vw, 3.2rem);
	line-height: 1.08;
	color: var(--ink);
}

.hero-title .highlight {
	position: relative;
	white-space: nowrap;
}

.hero-title .highlight::after {
	content: '';
	position: absolute;
	bottom: 2px;
	left: 0;
	width: 100%;
	height: 0.18em;
	background: rgba(15, 169, 104, 0.18);
	border-radius: 2px;
}

.hero-subtitle {
	margin-top: 1.25rem;
	max-width: 520px;
	font-size: 1rem;
	line-height: 1.7;
	color: var(--ink-soft);
}

@media (min-width: 768px) {
	.hero-subtitle { font-size: 1.08rem; }
}

.hero-pills {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: 1.5rem;
}

.hero-ctas {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin-top: 2rem;
}

@media (min-width: 480px) {
	.hero-ctas { flex-direction: row; }
}

.hero-microcopy {
	margin-top: 0.6rem;
	font-size: 0.72rem;
	color: var(--ink-soft);
	display: flex;
	align-items: center;
	gap: 0.4rem;
}

.hero-microcopy i {
	color: var(--secure-green);
	font-size: 0.6rem;
}

/* Hero Image Card */
.hero-image-card {
	border-radius: var(--radius-xl);
	overflow: hidden;
	position: relative;
	border: 1px solid var(--line);
	box-shadow: var(--shadow-soft);
}

.hero-image-card img {
	width: 100%;
	height: 340px;
	object-fit: cover;
	display: block;
}

@media (min-width: 768px) {
	.hero-image-card img { height: 100%; min-height: 440px; }
}

.hero-image-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(26, 31, 46, 0.5) 0%, transparent 50%);
	pointer-events: none;
}

.hero-image-badge {
	position: absolute;
	left: 1rem;
	bottom: 1rem;
	display: flex;
	align-items: center;
	gap: 0.5rem;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.3);
	background: rgba(0, 0, 0, 0.55);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	padding: 0.55rem 1rem;
	font-size: 0.68rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: #fff;
}

.hero-image-badge i {
	color: #12c278;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   METRIC CARDS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.metrics-row {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0.75rem;
	margin-top: 2rem;
	max-width: 520px;
}

@media (min-width: 480px) {
	.metrics-row { grid-template-columns: repeat(4, 1fr); }
}

.metric-card {
	border-radius: var(--radius-md);
	border: 1px solid var(--line-soft);
	background: var(--bg-card);
	padding: 0.9rem;
	box-shadow: 0 2px 8px rgba(0,0,0,0.04);
	transition: border-color 0.3s var(--ease), box-shadow 0.3s var(--ease), transform 0.3s var(--ease-bounce);
}

.metric-card:hover {
	border-color: rgba(15, 169, 104, 0.18);
	box-shadow: 0 8px 24px rgba(0,0,0,0.08);
	transform: translateY(-2px);
}

.metric-value {
	font-family: 'Playfair Display', serif;
	font-size: 1.4rem;
	line-height: 1;
	margin-bottom: 0.25rem;
	color: var(--accent);
}

.metric-label {
	font-size: 0.62rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--ink-soft);
	line-height: 1.3;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   CARDS â€” Shared
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.card {
	border-radius: var(--radius-lg);
	border: 1px solid var(--line-soft);
	background: var(--bg-card);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.05);
	transition: transform 0.4s var(--ease-bounce), box-shadow 0.4s var(--ease), border-color 0.4s var(--ease);
}

.card:hover {
	transform: translateY(-6px);
	box-shadow: 0 20px 48px rgba(0, 0, 0, 0.1);
	border-color: rgba(15, 169, 104, 0.15);
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   PROBLEM CARDS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.problem-card {
	padding: 1.4rem;
	position: relative;
	overflow: hidden;
}

.problem-card::after {
	content: '';
	position: absolute;
	bottom: -30px; right: -30px;
	width: 100px; height: 100px;
	border-radius: 50%;
	background: rgba(220, 60, 40, 0.04);
	transition: transform 0.5s var(--ease), opacity 0.5s var(--ease);
	opacity: 0;
}

.problem-card:hover::after {
	transform: scale(2.5);
	opacity: 1;
}

.problem-icon {
	width: 48px; height: 48px;
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(220, 60, 40, 0.08);
	color: #c0392b;
	font-size: 1.1rem;
	margin-bottom: 1rem;
	transition: transform 0.35s var(--ease-bounce);
}

.problem-card:hover .problem-icon {
	transform: scale(1.1) rotate(-5deg);
}

.problem-card h3 {
	font-size: 1.04rem;
	font-weight: 700;
	margin-bottom: 0.55rem;
	color: var(--ink);
}

.problem-card p {
	font-size: 0.92rem;
	color: var(--ink-soft);
	line-height: 1.6;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   SOLUTION / BENEFIT CARDS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.benefit-card {
	padding: 1.4rem;
	position: relative;
	overflow: hidden;
}

.benefit-card::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 2px;
	background: linear-gradient(90deg, transparent, var(--accent), transparent);
	opacity: 0;
	transition: opacity 0.4s var(--ease);
}

.benefit-card:hover::before { opacity: 1; }

.benefit-card::after {
	content: '';
	position: absolute;
	top: -50%; left: -50%;
	width: 200%; height: 200%;
	background: radial-gradient(circle at var(--mouse-x, 50%) var(--mouse-y, 50%), rgba(15, 169, 104, 0.04) 0%, transparent 50%);
	pointer-events: none;
	opacity: 0;
	transition: opacity 0.4s var(--ease);
}

.benefit-card:hover::after { opacity: 1; }

.benefit-icon {
	width: 48px; height: 48px;
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--accent-dim);
	color: var(--accent);
	font-size: 1.1rem;
	margin-bottom: 1rem;
	transition: background 0.35s var(--ease), color 0.35s var(--ease), transform 0.35s var(--ease-bounce), box-shadow 0.35s var(--ease);
}

.benefit-card:hover .benefit-icon {
	background: var(--accent);
	color: #fff;
	transform: scale(1.12) rotate(-5deg);
	box-shadow: 0 8px 20px rgba(15, 169, 104, 0.2);
}

.benefit-card h3 {
	font-family: 'Playfair Display', serif;
	font-size: 1.15rem;
	line-height: 1.2;
	margin-bottom: 0.6rem;
	color: var(--ink);
}

.benefit-card p {
	font-size: 0.92rem;
	color: var(--ink-soft);
	line-height: 1.6;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   DIFFERENTIATOR CARDS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.diff-card {
	padding: 1.4rem;
	position: relative;
	overflow: hidden;
	text-align: center;
}

.diff-icon {
	width: 56px; height: 56px;
	border-radius: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--accent-warm-dim);
	color: var(--accent-warm);
	font-size: 1.3rem;
	margin: 0 auto 1rem;
	transition: transform 0.35s var(--ease-bounce), box-shadow 0.35s var(--ease);
}

.diff-card:hover .diff-icon {
	transform: scale(1.12) rotate(-5deg);
	box-shadow: 0 8px 20px rgba(196, 125, 21, 0.15);
}

.diff-card h3 {
	font-family: 'Playfair Display', serif;
	font-size: 1.12rem;
	margin-bottom: 0.55rem;
	color: var(--ink);
}

.diff-card p {
	font-size: 0.9rem;
	color: var(--ink-soft);
	line-height: 1.55;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   PROCESS TIMELINE
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.process-grid {
	display: grid;
	gap: 1.25rem;
}

@media (min-width: 768px) {
	.process-grid { grid-template-columns: repeat(4, 1fr); }
}

.process-step {
	padding: 1.5rem;
	position: relative;
	overflow: hidden;
	text-align: center;
}

.process-step::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 3px;
	background: linear-gradient(90deg, transparent, var(--secure-green), transparent);
	opacity: 0;
	transition: opacity 0.4s var(--ease);
}

.process-step:hover::before { opacity: 1; }

.process-number {
	width: 48px; height: 48px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--secure-green-dim);
	border: 2px solid rgba(26, 138, 74, 0.2);
	color: var(--secure-green);
	font-family: 'Playfair Display', serif;
	font-size: 1.2rem;
	font-weight: 700;
	margin: 0 auto 1rem;
	transition: transform 0.35s var(--ease-bounce), background 0.35s var(--ease), color 0.35s var(--ease);
}

.process-step:hover .process-number {
	transform: scale(1.15);
	background: var(--secure-green);
	color: #fff;
}

.process-step h3 {
	font-weight: 700;
	font-size: 1rem;
	margin-bottom: 0.5rem;
	color: var(--ink);
}

.process-step p {
	font-size: 0.88rem;
	color: var(--ink-soft);
	line-height: 1.55;
}

@media (min-width: 768px) {
	.process-step:not(:last-child)::after {
		content: 'â†’';
		position: absolute;
		right: -0.85rem;
		top: 1.65rem;
		font-size: 1.2rem;
		color: var(--secure-green);
		opacity: 0.5;
	}
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   TESTIMONIAL CARDS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.review-card {
	padding: 1.4rem;
	position: relative;
}

.review-card::before {
	content: '"';
	position: absolute;
	top: 0.4rem; right: 1rem;
	font-family: 'Playfair Display', serif;
	font-size: 5rem;
	line-height: 1;
	color: rgba(15, 169, 104, 0.06);
	pointer-events: none;
}

.review-stars {
	color: var(--accent-warm);
	font-size: 0.75rem;
	margin-bottom: 0.8rem;
	letter-spacing: 2px;
}

.review-card p { font-size: 0.94rem; line-height: 1.65; color: var(--ink-soft); }

.review-card cite {
	display: inline-block;
	margin-top: 1rem;
	font-size: 0.76rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	font-style: normal;
	color: var(--ink);
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   FAQ
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.faq-item {
	border-radius: 14px;
	border: 1px solid var(--line-soft);
	background: var(--bg-card);
	padding: 1rem 1.2rem;
	transition: border-color 0.3s var(--ease), box-shadow 0.3s var(--ease);
}

.faq-item:hover {
	border-color: var(--line);
	box-shadow: 0 8px 20px rgba(0, 0, 0, 0.06);
}

.faq-item summary {
	cursor: pointer;
	font-weight: 700;
	list-style: none;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	font-size: 0.95rem;
	color: var(--ink);
}

.faq-item summary::-webkit-details-marker { display: none; }

.faq-item summary::after {
	content: '+';
	font-size: 1.3rem;
	font-weight: 400;
	color: var(--accent);
	transition: transform 0.4s var(--ease-bounce);
	flex-shrink: 0;
}

.faq-item[open] summary::after { transform: rotate(135deg); }
.faq-item[open] summary { margin-bottom: 0.6rem; }
.faq-item p { color: var(--ink-soft); font-size: 0.93rem; line-height: 1.6; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   GUARANTEE BADGES
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.guarantee-card {
	padding: 1.5rem;
	text-align: center;
	position: relative;
	overflow: hidden;
}

.guarantee-icon {
	width: 52px; height: 52px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--secure-green-dim);
	border: 2px solid rgba(26, 138, 74, 0.15);
	color: var(--secure-green);
	font-size: 1.2rem;
	margin: 0 auto 0.85rem;
	transition: transform 0.35s var(--ease-bounce);
}

.guarantee-card:hover .guarantee-icon {
	transform: scale(1.15) rotate(-5deg);
}

.guarantee-card h3 {
	font-weight: 700;
	font-size: 0.95rem;
	margin-bottom: 0.4rem;
	color: var(--ink);
}

.guarantee-card p {
	font-size: 0.88rem;
	color: var(--ink-soft);
	line-height: 1.55;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   CTA BANNER
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.cta-banner {
	position: relative;
	overflow: hidden;
	border-radius: var(--radius-xl);
	border: 1px solid var(--line-soft);
	background: linear-gradient(135deg, #ffffff 0%, #f0f4f8 100%);
	padding: 3rem 2rem;
	text-align: center;
	box-shadow: 0 8px 32px rgba(0,0,0,0.06);
}

.cta-banner::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(ellipse at center, rgba(15, 169, 104, 0.04) 0%, transparent 65%);
	pointer-events: none;
}

.cta-banner::after {
	content: '';
	position: absolute;
	inset: -1px;
	border-radius: var(--radius-xl);
	padding: 1px;
	background: linear-gradient(135deg, rgba(15, 169, 104, 0.2), transparent 40%, transparent 60%, rgba(15, 169, 104, 0.08));
	-webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
	mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
	-webkit-mask-composite: xor;
	mask-composite: exclude;
	pointer-events: none;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   IMAGE SECTION
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.image-section {
	border-radius: var(--radius-xl);
	overflow: hidden;
	position: relative;
	border: 1px solid var(--line);
	box-shadow: var(--shadow-soft);
}

.image-section img {
	width: 100%;
	height: 300px;
	object-fit: cover;
	display: block;
	transition: transform 0.6s var(--ease);
}

@media (min-width: 768px) {
	.image-section img { height: 400px; }
}

.image-section:hover img {
	transform: scale(1.03);
}

.image-section-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(26, 31, 46, 0.35) 0%, transparent 50%);
	pointer-events: none;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   CONTACT SECTION
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.contact-panel {
	border-radius: var(--radius-lg);
	border: 1px solid var(--line-soft);
	background: var(--bg-card);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.05);
	padding: 1.5rem;
}

.contact-cta-card {
	border-radius: var(--radius-xl);
	border: 1px solid var(--line);
	background: linear-gradient(135deg, #1a2538 0%, #243348 100%);
	padding: 2rem;
	box-shadow: var(--shadow-soft);
	position: relative;
	overflow: hidden;
	text-align: center;
	color: #eef2f7;
}

.contact-cta-card .accent-text { color: #12c278; }
.contact-cta-card .soft-text { color: #8899aa; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   MARQUEE
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.marquee-wrapper {
	overflow: hidden;
	border-top: 1px solid var(--line-soft);
	border-bottom: 1px solid var(--line-soft);
	background: rgba(0, 0, 0, 0.02);
	padding: 1.1rem 0;
}

.marquee-track {
	display: flex;
	gap: 3rem;
	animation: marqueeScroll 30s linear infinite;
	width: max-content;
}

.marquee-track span {
	white-space: nowrap;
	font-size: 0.78rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--ink-soft);
}

.marquee-track .accent-dot {
	display: inline-block;
	width: 5px; height: 5px;
	border-radius: 50%;
	background: var(--accent);
	margin: 0 1.5rem;
	vertical-align: middle;
}

@keyframes marqueeScroll {
	0% { transform: translateX(0); }
	100% { transform: translateX(-50%); }
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   GLOWING DIVIDER (Light)
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.glow-divider {
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--accent), transparent);
	opacity: 0.15;
	margin: 0 auto;
	max-width: 50%;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   REVEAL ANIMATIONS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
[data-reveal] {
	opacity: 0;
	transform: translateY(35px) scale(0.97);
	transition: opacity 0.8s var(--ease), transform 0.8s var(--ease);
}

[data-reveal].is-visible {
	opacity: 1;
	transform: translateY(0) scale(1);
}

[data-reveal-delay="1"] { transition-delay: 0.12s; }
[data-reveal-delay="2"] { transition-delay: 0.24s; }
[data-reveal-delay="3"] { transition-delay: 0.36s; }

[data-reveal-dir="left"] { transform: translateX(-40px) scale(0.97); }
[data-reveal-dir="left"].is-visible { transform: translateX(0) scale(1); }

[data-reveal-dir="right"] { transform: translateX(40px) scale(0.97); }
[data-reveal-dir="right"].is-visible { transform: translateX(0) scale(1); }

[data-reveal-dir="scale"] { transform: scale(0.85); }
[data-reveal-dir="scale"].is-visible { transform: scale(1); }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   FLOATING PARTICLES (Light â€” subtle)
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.particles {
	position: fixed;
	inset: 0;
	z-index: -1;
	pointer-events: none;
	overflow: hidden;
}

.particle {
	position: absolute;
	width: 3px; height: 3px;
	border-radius: 50%;
	background: rgba(15, 169, 104, 0.12);
	animation: particleFloat linear infinite;
}

@keyframes particleFloat {
	0% { transform: translateY(100vh) rotate(0deg); opacity: 0; }
	10% { opacity: 1; }
	90% { opacity: 1; }
	100% { transform: translateY(-10vh) rotate(720deg); opacity: 0; }
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   FIXED CTA (Mobile)
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.fixed-cta {
	position: fixed;
	right: 1rem; bottom: 1rem;
	z-index: 40;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	border-radius: 999px;
	border: none;
	background: linear-gradient(135deg, #0fa968, #0d7377);
	padding: 0.85rem 1.3rem;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.11em;
	text-transform: uppercase;
	text-decoration: none;
	color: #fff;
	box-shadow: 0 14px 28px rgba(15, 169, 104, 0.3);
	transition: transform 0.3s var(--ease-bounce), box-shadow 0.3s var(--ease);
	animation: btnPulseRing 2.5s ease-out infinite;
}

.fixed-cta:hover, .fixed-cta:focus-visible {
	transform: translateY(-3px) scale(1.05);
	box-shadow: 0 22px 40px rgba(15, 169, 104, 0.4);
}

@media (min-width: 1024px) {
	.fixed-cta { display: none; }
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   TILT EFFECT (3D cards)
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.tilt-card {
	transform-style: preserve-3d;
	perspective: 800px;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   FOOTER
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.footer {
	border-top: 1px solid rgba(0,0,0,0.08);
	background: #1a2538;
	color: #c8d4e0;
}

.footer-inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 2.5rem 1.25rem;
}

.footer-top {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

@media (min-width: 768px) {
	.footer-top {
		flex-direction: row;
		align-items: flex-start;
		justify-content: space-between;
	}
}

.footer-brand a {
	font-family: 'Playfair Display', serif;
	font-size: 1.3rem;
	letter-spacing: 0.02em;
	text-decoration: none;
	color: #eef2f7;
}

.footer-brand a span { color: #12c278; }

.footer-brand p {
	margin-top: 0.5rem;
	font-size: 0.85rem;
	color: #8899aa;
	max-width: 280px;
}

.footer .nav-link { color: #8899aa; }
.footer .nav-link:hover { color: #eef2f7; }
.footer .nav-link::after { background: #12c278; }

.footer-links {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.footer-bottom {
	margin-top: 2rem;
	padding-top: 1.5rem;
	border-top: 1px solid rgba(255,255,255,0.08);
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	align-items: center;
	font-size: 0.72rem;
	color: #8899aa;
}

@media (min-width: 768px) {
	.footer-bottom {
		flex-direction: row;
		justify-content: space-between;
	}
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   SECTION CONTAINERS
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.section {
	max-width: 1200px;
	margin: 0 auto;
	padding: 3rem 1.25rem;
}

@media (min-width: 768px) {
	.section { padding: 4.5rem 1.25rem; }
}

.section-sm {
	max-width: 1200px;
	margin: 0 auto;
	padding: 2rem 1.25rem;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   RESPONSIVE
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
@media (max-width: 767px) {
	.section-title { max-width: 100%; }
}

@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
	*, *::before, *::after {
		animation: none !important;
		transition: none !important;
	}
}

