@charset "utf-8";

/* ===================================
   CSS RESET & BASE STYLES
   =================================== */

/* Core Variables */
:root {
	/* Brand Colors */
	--primary-blue: #65b5da;
	--secondary-blue: #4962bf;
	--accent-coral: #ff6b6b;
	--accent-warm: #ffa726;
	--neutral-light: #f8fafc;
	--neutral-medium: #e2e8f0;
	--neutral-dark: #334155;
	
	/* Text Colors */
	--text-dark: #1e293b;
	--text-medium: #475569;
	--text-light: #64748b;
	--text-white: #ffffff;
	
	/* Shadows */
	--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
	--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
	--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
	--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
	
	/* Gradients */
	--gradient-primary: linear-gradient(135deg, var(--primary-blue) 0%, var(--secondary-blue) 100%);
	--gradient-accent: linear-gradient(135deg, var(--accent-coral) 0%, var(--accent-warm) 100%);
	--gradient-overlay: linear-gradient(135deg, rgba(101, 181, 218, 0.9) 0%, rgba(73, 98, 191, 0.9) 100%);
	
	/* Fonts */
	--font-primary: 'Roboto', system-ui, -apple-system, sans-serif;
	--font-secondary: 'Roboto', system-ui, -apple-system, sans-serif;
	
	/* Spacing */
	--space-xs: 0.5rem;
	--space-sm: 1rem;
	--space-md: 1.5rem;
	--space-lg: 2rem;
	--space-xl: 3rem;
	--space-2xl: 4rem;
	--space-3xl: 6rem;
	
	/* Border Radius */
	--radius-sm: 0.375rem;
	--radius-md: 0.5rem;
	--radius-lg: 0.75rem;
	--radius-xl: 1rem;
	--radius-2xl: 1.5rem;
	
	/* Transitions */
	--transition-fast: 0.15s ease;
	--transition-normal: 0.3s ease;
	--transition-slow: 0.5s ease;
}

/* CSS Reset */
*, *::before, *::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	line-height: 1.15;
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

body {
	font-family: var(--font-primary);
	font-size: 1rem;
	line-height: 1.6;
	color: var(--text-dark);
	background-color: #ffffff;
	overflow-x: hidden;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* Remove default styling */
ul, ol {
	list-style: none;
}

a {
	text-decoration: none;
	color: inherit;
}

img, picture, video, canvas, svg {
	display: block;
	max-width: 100%;
	height: auto;
}

input, button, textarea, select {
	font: inherit;
	color: inherit;
}

button {
	background: none;
	border: none;
	cursor: pointer;
}

/* Focus states for accessibility */
*:focus {
	outline: 2px solid var(--primary-blue);
	outline-offset: 2px;
}

/* ===================================
   TYPOGRAPHY
   =================================== */

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-primary);
	font-weight: 700;
	line-height: 1.2;
	color: var(--text-dark);
	margin-bottom: var(--space-md);
}

h1 {
	font-size: clamp(2.5rem, 5vw, 4rem);
	font-weight: 800;
	line-height: 1.1;
}

h2 {
	font-size: clamp(2rem, 4vw, 3rem);
	font-weight: 700;
}

h3 {
	font-size: clamp(1.5rem, 3vw, 2rem);
	font-weight: 600;
}

h4 {
	font-size: clamp(1.25rem, 2.5vw, 1.5rem);
	font-weight: 600;
}

h5 {
	font-size: 1.125rem;
	font-weight: 600;
}

h6 {
	font-size: 1rem;
	font-weight: 600;
}

p {
	margin-bottom: var(--space-sm);
	color: var(--text-medium);
	line-height: 1.7;
}

/* Text utilities */
.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }

.text-primary { color: var(--primary-blue); }
.text-secondary { color: var(--secondary-blue); }
.text-accent { color: var(--accent-coral); }
.text-white { color: var(--text-white); }

/* ===================================
   BUTTONS & INTERACTIVE ELEMENTS
   =================================== */

.btn {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	padding: 0.875rem 1.75rem;
	border-radius: var(--radius-lg);
	font-family: var(--font-primary);
	font-weight: 600;
	font-size: 1rem;
	text-decoration: none;
	transition: all var(--transition-normal);
	cursor: pointer;
	border: 2px solid transparent;
	position: relative;
	overflow: hidden;
}

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

.btn:hover::before {
	left: 100%;
}

.btn-primary {
	background: var(--gradient-primary);
	color: var(--text-white);
	box-shadow: var(--shadow-md);
}

.btn-primary:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg);
}

.btn-secondary {
	background: var(--gradient-accent);
	color: var(--text-white);
	box-shadow: var(--shadow-md);
}

.btn-secondary:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg);
}

.btn-large {
	padding: 1.125rem 2.25rem;
	font-size: 1.125rem;
}

/* ===================================
   LAYOUT & CONTAINERS
   =================================== */

.container {
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 var(--space-lg);
}

/* Section spacing */
section {
	padding: var(--space-3xl) 0;
	position: relative;
}

.section-header {
	text-align: center;
	max-width: 800px;
	margin: 0 auto var(--space-2xl);
	padding: 0 var(--space-lg);
}

.section-subtitle {
	display: inline-block;
	color: var(--accent-coral);
	font-family: var(--font-primary);
	font-weight: 600;
	font-size: 0.875rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin-bottom: var(--space-sm);
	padding: 0.5rem 1rem;
	background: rgba(255, 107, 107, 0.1);
	border-radius: var(--radius-2xl);
}

.section-description {
	font-size: 1.25rem;
	color: var(--text-medium);
	margin-top: var(--space-md);
	line-height: 1.6;
}

/* ===================================
   NAVIGATION
   =================================== */

.nav {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	background: var(--secondary-blue);
	z-index: 1000;
	transition: all var(--transition-normal);
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.nav.scrolled {
	box-shadow: var(--shadow-md);
	border-bottom-color: rgba(255, 255, 255, 0.2);
}

.nav-container {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0.625rem var(--space-lg);
	max-width: 1400px;
	margin: 0 auto;
}

.nav-logo {
	font-family: var(--font-secondary);
	font-size: 1.5rem;
	font-weight: 700;
	color: white;
	text-decoration: none;
	display: flex;
	align-items: center;
	gap: var(--space-xs);
	transition: color var(--transition-fast);
	padding: 0.25rem 0;
}

.nav-logo:hover {
	color: var(--accent-coral);
}

.nav-logo img {
	height: 58px;
	width: auto;
}

.nav-menu {
	display: flex;
	align-items: center;
	gap: var(--space-lg);
}

.nav-link {
	color: white;
	text-decoration: none;
	font-weight: 500;
	position: relative;
	padding: var(--space-xs) 0;
	transition: color var(--transition-fast);
}

.nav-link::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 0;
	height: 2px;
	background: var(--accent-coral);
	transition: width var(--transition-normal);
}

.nav-link:hover {
	color: var(--accent-coral);
}

.nav-link:hover::after,
.nav-link.active::after {
	width: 100%;
}

.nav-cta {
	background: var(--gradient-accent);
	color: white;
	padding: 0.75rem 1.5rem;
	border-radius: var(--radius-lg);
	font-weight: 600;
	transition: all var(--transition-normal);
	box-shadow: var(--shadow-sm);
	border: 2px solid transparent;
}

.nav-cta:hover {
	transform: translateY(-1px);
	box-shadow: var(--shadow-md);
	border-color: rgba(255, 255, 255, 0.2);
}

.nav-toggle {
	display: none;
	background: none;
	border: none;
	cursor: pointer;
	padding: var(--space-xs);
	color: white;
}

/* Mobile Navigation */
@media (max-width: 1200px) {
	.nav-toggle {
		display: block;
	}

	.nav-menu {
		display: none;
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background: var(--secondary-blue);
		padding: var(--space-lg);
		flex-direction: column;
		align-items: stretch;
		gap: var(--space-sm);
		box-shadow: var(--shadow-lg);
		border-top: 1px solid rgba(255, 255, 255, 0.1);
	}

	.nav-menu.active {
		display: flex;
	}

	.nav-link {
		display: block;
		text-align: center;
		padding: var(--space-sm);
		border-radius: var(--radius-md);
		background: rgba(255, 255, 255, 0.1);
		transition: all var(--transition-fast);
		color: white;
	}

	.nav-link:hover {
		background: var(--accent-coral);
		color: white;
	}

	.nav-link::after {
		display: none;
	}

	.nav-cta {
		width: 100%;
		text-align: center;
		margin-top: var(--space-sm);
	}
}

@media (max-width: 768px) {
	.nav-container {
		padding: 0.5rem var(--space-sm);
	}

	.nav-logo {
		padding: 0.125rem 0;
	}

	.nav-logo img {
		height: 52px;
	}
}

/* ===================================
   HERO SECTION
   =================================== */

.hero {
	position: relative;
	min-height: 100vh;
	display: flex;
	align-items: center;
	padding: 8rem 0 4rem;
	overflow: hidden;
	background: var(--secondary-blue);
}

.hero-media {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
}

.hero-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.hero-overlay {
	position: absolute;
	inset: 0;
	z-index: 2;
	background: var(--gradient-overlay);
	mix-blend-mode: multiply;
}

.hero-content {
	position: relative;
	z-index: 3;
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 var(--space-lg);
	color: var(--text-white);
}

.hero-copy-background {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: clamp(600px, 80vw, 1100px);
	height: clamp(400px, 60vw, 600px);
	background: radial-gradient(
		ellipse at center,
		rgba(73, 98, 191, 0.7) 0%,
		rgba(73, 98, 191, 0.65) 30%,
		rgba(73, 98, 191, 0.55) 45%,
		rgba(73, 98, 191, 0.35) 55%,
		rgba(73, 98, 191, 0.15) 60%,
		rgba(73, 98, 191, 0.05) 70%,
		transparent 90%,
		transparent 100%
	);
	border-radius: 50%;
	z-index: -1;
	pointer-events: none;
}

.hero-title {
	font-family: var(--font-primary);
	font-size: clamp(3rem, 8vw, 5.5rem);
	font-weight: 800;
	line-height: 1.1;
	margin-bottom: var(--space-md);
	color: var(--text-white);
	text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
	opacity: 0;
	transform: translateY(30px);
	animation: fadeInUp 0.8s ease forwards 0.3s;
	position: relative;
	z-index: 1;
}

.hero-subtitle {
	font-size: clamp(1.25rem, 4vw, 1.625rem);
	max-width: 650px;
	margin-bottom: var(--space-xl);
	color: rgba(255, 255, 255, 0.95);
	line-height: 1.6;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
	opacity: 0;
	transform: translateY(30px);
	animation: fadeInUp 0.8s ease forwards 0.5s;
	position: relative;
	z-index: 1;
}

.hero-cta-group {
	display: flex;
	gap: var(--space-sm);
	flex-wrap: wrap;
	opacity: 0;
	transform: translateY(30px);
	animation: fadeInUp 0.8s ease forwards 0.7s;
	position: relative;
	z-index: 1;
}

.hero-cta-group .btn {
	font-size: 1.125rem;
	padding: 1rem 2rem;
	box-shadow: var(--shadow-lg);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.hero-cta-group .btn-primary {
	background: var(--gradient-accent);
	border: 2px solid rgba(255, 255, 255, 0.2);
}

.hero-cta-group .btn-primary:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow-xl);
	border-color: rgba(255, 255, 255, 0.3);
}

.hero-cta-group .btn-secondary {
	background: rgba(255, 255, 255, 0.15);
	color: var(--text-white);
	border: 2px solid rgba(255, 255, 255, 0.3);
}

.hero-cta-group .btn-secondary:hover {
	background: rgba(255, 255, 255, 0.25);
	transform: translateY(-3px);
	box-shadow: var(--shadow-xl);
	border-color: rgba(255, 255, 255, 0.5);
}

.hero-scroll {
	position: absolute;
	bottom: 2rem;
	left: 50%;
	transform: translateX(-50%);
	z-index: 3;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-xs);
	color: var(--text-white);
	text-decoration: none;
	opacity: 0;
	animation: fadeIn 0.8s ease forwards 1s;
	transition: all var(--transition-normal);
}

.hero-scroll:hover {
	transform: translateX(-50%) translateY(-5px);
}

.hero-scroll-text {
	font-size: 0.875rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.hero-scroll-icon {
	width: 24px;
	height: 24px;
	animation: bounce 2s infinite;
	filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.3));
}

/* Sharp Triangle Divider */
.shape-divider {
	position: absolute;
	bottom: -1px;
	left: 0;
	width: 100%;
	overflow: hidden;
	line-height: 0;
	z-index: 2;
}

.shape-divider svg {
	position: relative;
	display: block;
	width: calc(100% + 1.3px);
	height: 120px;
}

.shape-divider .shape-fill {
	fill: var(--neutral-light);
}

/* Hero Animations */
@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(30px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes fadeIn {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}

@keyframes bounce {
	0%, 20%, 50%, 80%, 100% {
		transform: translateY(0);
	}
	40% {
		transform: translateY(-10px);
	}
	60% {
		transform: translateY(-5px);
	}
}

/* Hero Responsive Design */
@media (max-width: 768px) {
	.hero {
		text-align: center;
		padding: 6rem 0 3rem;
	}

	.hero-copy-background {
		width: clamp(400px, 90vw, 600px);
		height: clamp(300px, 70vw, 450px);
	}

	.hero-cta-group {
		justify-content: center;
		gap: var(--space-sm);
	}

	.hero-cta-group .btn {
		flex: 1;
		min-width: 200px;
		justify-content: center;
	}

	.hero-scroll {
		display: none;
	}

	.shape-divider svg {
		height: 80px;
	}
}

@media (max-width: 480px) {
	.hero-title {
		font-size: clamp(2.25rem, 6vw, 3.5rem);
		margin-bottom: var(--space-sm);
	}
	
	.hero-subtitle {
		font-size: clamp(1rem, 3vw, 1.25rem);
		margin-bottom: var(--space-lg);
	}
	
	.hero-cta-group .btn {
		padding: 0.875rem 1.5rem;
		font-size: 1rem;
		min-width: 180px;
	}

	.hero-cta-group {
		flex-direction: column;
		align-items: center;
	}

	.hero-copy-background {
		width: clamp(320px, 95vw, 500px);
		height: clamp(250px, 80vw, 400px);
	}
}

/* ===================================
   WHY CHOOSE US SECTION
   =================================== */

.why-choose-us {
	background: var(--neutral-light);
	padding: var(--space-3xl) 0;
	position: relative;
	overflow: hidden;
}

.why-choose-us::before {
	content: '';
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: 
		radial-gradient(circle at 0% 60%, rgba(101, 181, 218, 0.08) 0%, transparent 40%),
		radial-gradient(circle at 100% 100%, rgba(255, 107, 107, 0.08) 0%, transparent 50%);
	pointer-events: none;
}

.benefits-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-xl);
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 var(--space-lg);
}

.benefit-card {
	background: white;
	border-radius: var(--radius-2xl);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	transition: all var(--transition-normal);
	position: relative;
	border: 1px solid rgba(101, 181, 218, 0.1);
	display: flex;
	flex-direction: column;
}

.benefit-card::before {
	content: '';
	position: absolute;
	top: 150px; /* Moved down 50px from original 100px */
	left: 0;
	width: 100%;
	height: 4px;
	background: var(--gradient-primary);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform var(--transition-slow);
	z-index: 1;
}

.benefit-card:hover {
	transform: translateY(-8px);
	box-shadow: var(--shadow-xl);
	border-color: rgba(101, 181, 218, 0.2);
}

.benefit-card:hover::before {
	transform: scaleX(1);
}

.benefit-header-image {
	width: 100%;
	height: 150px; /* Made 50px taller from original 100px */
	overflow: hidden;
	position: relative;
}

.benefit-header-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	transition: transform var(--transition-normal);
}

.benefit-card:hover .benefit-header-image img {
	transform: scale(1.05);
}

.benefit-icon {
	position: absolute;
	top: 100px; /* Moved down 50px from original 50px */
	left: var(--space-lg);
	width: 70px;
	height: 70px;
	border-radius: var(--radius-xl);
	background: var(--gradient-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: var(--shadow-lg);
	transition: all var(--transition-normal);
	z-index: 10;
	border: 4px solid white;
}

.benefit-icon::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 0;
	height: 0;
	background: rgba(255, 255, 255, 0.2);
	border-radius: 50%;
	transform: translate(-50%, -50%);
	transition: all var(--transition-slow);
}

.benefit-card:hover .benefit-icon {
	transform: scale(1.1) rotate(5deg);
	box-shadow: var(--shadow-xl);
}

.benefit-card:hover .benefit-icon::before {
	width: 100%;
	height: 100%;
}

.benefit-icon svg {
	width: 32px;
	height: 32px;
	color: white;
	z-index: 1;
	position: relative;
	transition: transform var(--transition-normal);
}

.benefit-card:hover .benefit-icon svg {
	transform: scale(1.1);
}

.benefit-content {
	padding: var(--space-xl);
	padding-top: calc(var(--space-lg) + 35px);
	flex-grow: 1;
}

.benefit-title {
	font-family: var(--font-primary);
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--text-dark);
	margin-bottom: var(--space-md);
	line-height: 1.3;
	transition: color var(--transition-fast);
	padding-right: var(--space-sm);
}

.benefit-card:hover .benefit-title {
	color: var(--secondary-blue);
}

.benefit-description {
	color: var(--text-medium);
	line-height: 1.6;
	font-size: 1.0625rem;
	margin-bottom: 0;
}

/* Specific animations for each card */
.benefit-card:nth-child(1) {
	animation: slideInLeft 0.6s ease forwards;
	opacity: 0;
	transform: translateX(-30px);
}

.benefit-card:nth-child(2) {
	animation: slideInRight 0.6s ease forwards 0.1s;
	opacity: 0;
	transform: translateX(30px);
}

.benefit-card:nth-child(3) {
	animation: slideInLeft 0.6s ease forwards 0.2s;
	opacity: 0;
	transform: translateX(-30px);
}

.benefit-card:nth-child(4) {
	animation: slideInRight 0.6s ease forwards 0.3s;
	opacity: 0;
	transform: translateX(30px);
}

@keyframes slideInLeft {
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

@keyframes slideInRight {
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

/* Responsive Design */
@media (max-width: 768px) {
	.why-choose-us {
		padding: var(--space-2xl) 0;
	}

	.benefits-grid {
		grid-template-columns: 1fr;
		gap: var(--space-md);
		padding: 0 var(--space-sm);
	}

	.benefit-icon {
		top: 90px; /* Moved down 50px from original 40px */
		left: 50%;
		transform: translateX(-50%);
		width: 60px;
		height: 60px;
	}

	.benefit-card:hover .benefit-icon {
		transform: translateX(-50%) scale(1.1) rotate(5deg);
	}

	.benefit-content {
		padding: var(--space-lg);
		padding-top: calc(var(--space-lg) + 30px);
		text-align: center;
	}

	.benefit-icon svg {
		width: 28px;
		height: 28px;
	}

	.benefit-title {
		font-size: 1.375rem;
		padding-right: 0;
	}

	.benefit-description {
		font-size: 1rem;
	}

	.benefit-header-image {
		height: 150px; /* Keep the same height increase on mobile */
	}

	.benefit-card::before {
		top: 150px; /* Keep the same position adjustment on mobile */
	}

	/* Reset animations on mobile for better performance */
	.benefit-card:nth-child(n) {
		animation: none;
		opacity: 1;
		transform: none;
	}
}

/* ===================================
   SOLUTIONS SECTION
   =================================== */

.solutions {
	background: white;
	padding: var(--space-3xl) 0;
	position: relative;
	overflow: hidden;
}

.solutions::before {
	content: '';
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: 
		radial-gradient(circle at 100% 0%, rgba(73, 98, 191, 0.06) 0%, transparent 50%),
		radial-gradient(circle at 0% 100%, rgba(255, 167, 38, 0.06) 0%, transparent 50%);
	pointer-events: none;
}

.solutions-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(380px, 1fr));
	gap: var(--space-xl);
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 var(--space-lg);
}

.solution-card {
	background: white;
	border-radius: var(--radius-2xl);
	overflow: hidden;
	box-shadow: var(--shadow-md);
	transition: all var(--transition-normal);
	position: relative;
	border: 2px solid transparent;
	display: flex;
	flex-direction: column;
}

.solution-card:hover {
	transform: translateY(-12px);
	box-shadow: var(--shadow-xl);
	border-color: var(--primary-blue);
}

.solution-image {
	position: relative;
	aspect-ratio: 16/10;
	overflow: hidden;
	background: var(--neutral-medium);
}

.solution-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-slow);
}

.solution-card:hover .solution-image img {
	transform: scale(1.08);
}

.solution-image::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to bottom, 
		transparent 0%, 
		rgba(0,0,0,0.1) 60%,
		rgba(0,0,0,0.3) 100%
	);
	opacity: 0;
	transition: opacity var(--transition-normal);
}

.solution-card:hover .solution-image::after {
	opacity: 1;
}

.solution-badge {
	position: absolute;
	top: var(--space-sm);
	right: var(--space-sm);
	padding: 0.5rem 1rem;
	border-radius: var(--radius-2xl);
	font-weight: 600;
	font-size: 0.875rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	z-index: 2;
	box-shadow: var(--shadow-md);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	transition: all var(--transition-normal);
}

.solution-badge:nth-of-type(1) {
	background: var(--gradient-primary);
	color: white;
}

.solution-card:hover .solution-badge {
	transform: scale(1.05) translateY(-2px);
	box-shadow: var(--shadow-lg);
}

.solution-content {
	padding: var(--space-xl);
	flex-grow: 1;
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.solution-title {
	font-family: var(--font-primary);
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--text-dark);
	margin-bottom: var(--space-sm);
	line-height: 1.3;
	transition: color var(--transition-fast);
}

.solution-card:hover .solution-title {
	color: var(--secondary-blue);
}

.solution-description {
	color: var(--text-medium);
	line-height: 1.6;
	margin-bottom: var(--space-md);
	flex-grow: 1;
}

.solution-features {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: var(--space-md);
}

.feature-tag {
	background: var(--neutral-light);
	color: var(--secondary-blue);
	padding: 0.375rem 0.875rem;
	border-radius: var(--radius-2xl);
	font-size: 0.875rem;
	font-weight: 500;
	border: 1px solid rgba(73, 98, 191, 0.1);
	transition: all var(--transition-fast);
}

.solution-card:hover .feature-tag {
	background: rgba(73, 98, 191, 0.1);
	border-color: rgba(73, 98, 191, 0.2);
	transform: translateY(-1px);
}

.solution-stats {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-sm);
	padding-top: var(--space-sm);
	border-top: 1px solid var(--neutral-medium);
	margin-top: auto;
}

.stat {
	text-align: center;
	padding: var(--space-sm);
	border-radius: var(--radius-md);
	background: var(--neutral-light);
	transition: all var(--transition-fast);
}

.solution-card:hover .stat {
	background: rgba(101, 181, 218, 0.1);
}

.stat-number {
	display: block;
	font-family: var(--font-primary);
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--secondary-blue);
	line-height: 1.2;
	margin-bottom: 0.25rem;
}

.stat-label {
	font-size: 0.8125rem;
	color: var(--text-light);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

/* Badge color variations */
.solution-card:nth-child(1) .solution-badge {
	background: var(--gradient-primary);
	color: white;
}

.solution-card:nth-child(2) .solution-badge {
	background: var(--gradient-accent);
	color: white;
}

.solution-card:nth-child(3) .solution-badge {
	background: linear-gradient(135deg, #8b5cf6 0%, #a855f7 100%);
	color: white;
}

.solution-card:nth-child(4) .solution-badge {
	background: linear-gradient(135deg, #10b981 0%, #059669 100%);
	color: white;
}

.solution-card:nth-child(5) .solution-badge {
	background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
	color: white;
}

.solution-card:nth-child(6) .solution-badge {
	background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
	color: white;
}

/* Entrance animations */
.solution-card:nth-child(odd) {
	animation: slideInFromLeft 0.8s ease forwards;
	opacity: 0;
	transform: translateX(-40px);
}

.solution-card:nth-child(even) {
	animation: slideInFromRight 0.8s ease forwards;
	opacity: 0;
	transform: translateX(40px);
}

.solution-card:nth-child(1) { animation-delay: 0.1s; }
.solution-card:nth-child(2) { animation-delay: 0.2s; }
.solution-card:nth-child(3) { animation-delay: 0.3s; }
.solution-card:nth-child(4) { animation-delay: 0.4s; }
.solution-card:nth-child(5) { animation-delay: 0.5s; }
.solution-card:nth-child(6) { animation-delay: 0.6s; }

@keyframes slideInFromLeft {
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

@keyframes slideInFromRight {
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

/* Responsive Design */
@media (max-width: 1200px) {
	.solutions-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--space-lg);
	}
}

@media (max-width: 768px) {
	.solutions {
		padding: var(--space-2xl) 0;
	}

	.solutions-grid {
		grid-template-columns: 1fr;
		gap: var(--space-lg);
		padding: 0 var(--space-sm);
	}

	.solution-content {
		padding: var(--space-lg);
	}

	.solution-stats {
		grid-template-columns: 1fr;
		gap: var(--space-xs);
	}

	.stat {
		padding: var(--space-xs);
	}

	.stat-number {
		font-size: 0.875rem;
	}

	/* Disable animations on mobile for performance */
	.solution-card:nth-child(n) {
		animation: none;
		opacity: 1;
		transform: none;
	}
}

@media (max-width: 480px) {
	.solution-image {
		aspect-ratio: 16/9;
	}

	.solution-features {
		gap: 0.375rem;
	}

	.feature-tag {
		font-size: 0.8125rem;
		padding: 0.25rem 0.75rem;
	}
}


/* ===================================
   PROCESS SECTION
   =================================== */

.process {
	background: linear-gradient(35deg, var(--primary-blue) 0%, var(--secondary-blue) 100%);
	padding: var(--space-3xl) 0;
	color: white;
	position: relative;
	overflow: hidden;
}

.process::before {
	content: '';
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: 
		radial-gradient(circle at 20% 20%, rgba(101, 181, 218, 0.3) 0%, transparent 40%),
		radial-gradient(circle at 80% 80%, rgba(255, 107, 107, 0.2) 0%, transparent 40%);
	pointer-events: none;
}

.process-steps {
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 var(--space-lg);
	display: flex;
	flex-direction: column;
	gap: var(--space-3xl);
	position: relative;
}

.step-card {
	display: grid;
	grid-template-columns: 1fr 290px;
	gap: 0;
	align-items: stretch;
	background: white;
	border-radius: var(--radius-2xl);
	box-shadow: var(--shadow-md);
	transition: all var(--transition-normal);
	position: relative;
	border: 2px solid transparent;
	overflow: hidden;
	min-height: 320px;
	width: 60%; /* 20% less wide: 75% * 0.8 = 60% */
}

/* Stagger the cards - modules 1 and 3 have same offset */
.step-card:nth-child(1) {
	margin-left: 120px;
	animation: slideInFromLeft 0.8s ease forwards;
	opacity: 0;
	transform: translateX(-50px);
}

.step-card:nth-child(2) {
	margin-left: auto;
	margin-right: 150px;
	animation: slideInFromRight 0.8s ease forwards 0.3s;
	opacity: 0;
	transform: translateX(50px);
}

.step-card:nth-child(3) {
	margin-left: 120px;
	animation: slideInFromLeft 0.8s ease forwards 0.6s;
	opacity: 0;
	transform: translateX(-50px);
}

.step-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(90deg, transparent, rgba(101, 181, 218, 0.1), transparent);
	transition: left var(--transition-slow);
}

.step-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--shadow-xl);
	border-color: var(--primary-blue);
}

.step-card:hover::before {
	left: 100%;
}

.step-card.reverse {
	grid-template-columns: 290px 1fr;
}

.step-card.reverse .step-visual {
	order: 1;
}

.step-card.reverse .step-content {
	order: 2;
}

.step-number {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 60px;
	height: 60px;
	border-radius: 50%;
	background: var(--gradient-primary);
	font-family: var(--font-primary);
	font-size: 1.5rem;
	font-weight: 800;
	color: white;
	box-shadow: var(--shadow-lg);
	transition: all var(--transition-normal);
	border: 3px solid white;
	margin-right: var(--space-md);
	flex-shrink: 0;
	vertical-align: middle;
}

.step-card:hover .step-number {
	transform: translateY(-20%) scale(1.1) rotate(0deg);
	box-shadow: var(--shadow-xl);
}

.step-content {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
	padding: var(--space-lg) var(--space-xl);
	justify-content: center;
}

.step-title {
	font-family: var(--font-primary);
	font-size: 1.625rem;
	font-weight: 700;
	color: var(--text-dark);
	margin-bottom: var(--space-sm);
	transition: color var(--transition-fast);
	line-height: 1.2;
}

.step-card:hover .step-title {
	color: var(--secondary-blue);
}

.step-description {
	color: var(--text-medium);
	line-height: 1.55;
	font-size: 1rem;
	margin-bottom: var(--space-sm);
}

.step-features {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-sm) 0;
	display: flex;
	flex-direction: column;
	gap: 0.375rem;
}

.step-feature {
	color: var(--text-medium);
	font-size: 0.875rem;
	display: flex;
	align-items: center;
	gap: var(--space-xs);
	transition: all var(--transition-fast);
	position: relative;
	padding-left: var(--space-sm);
	line-height: 1.4;
}

.step-feature::before {
	content: '';
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--primary-blue);
	flex-shrink: 0;
	transition: all var(--transition-fast);
	position: absolute;
	left: 0;
}

.step-card:hover .step-feature {
	color: var(--text-dark);
	transform: translateX(4px);
}

.step-card:hover .step-feature::before {
	background: var(--accent-coral);
	transform: scale(1.3);
}

.step-timeline {
	display: flex;
	align-items: center;
	gap: var(--space-xs);
	padding: 0.5rem var(--space-sm);
	background: rgba(101, 181, 218, 0.1);
	border-radius: var(--radius-2xl);
	color: var(--secondary-blue);
	font-weight: 600;
	font-size: 0.8125rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	align-self: flex-start;
	transition: all var(--transition-fast);
}

.step-card:hover .step-timeline {
	background: rgba(101, 181, 218, 0.2);
	transform: scale(1.05);
}

.step-timeline svg {
	width: 14px;
	height: 14px;
	color: var(--primary-blue);
}

.step-visual {
	position: relative;
	overflow: hidden;
	background: var(--neutral-medium);
	height: 100%;
	display: flex;
	align-items: stretch;
	border-radius: 0 var(--radius-2xl) var(--radius-2xl) 0;
}

.step-card.reverse .step-visual {
	border-radius: var(--radius-2xl) 0 0 var(--radius-2xl);
}

.step-visual::before {
	content: '';
	position: absolute;
	inset: 0;
	background: var(--gradient-overlay);
	opacity: 0;
	transition: opacity var(--transition-normal);
	z-index: 1;
}

.step-card:hover .step-visual::before {
	opacity: 0.1;
}

.step-visual img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	transition: transform var(--transition-slow);
}

.step-card:hover .step-visual img {
	transform: scale(1.08);
}

.process-cta {
	background: rgba(255, 255, 255, 0.15);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	border-radius: var(--radius-2xl);
	padding: var(--space-xl);
	text-align: center;
	color: white;
	margin-top: var(--space-2xl);
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
	box-shadow: var(--shadow-lg);
	transition: all var(--transition-normal);
	border: 2px solid rgba(255, 255, 255, 0.2);
}

.process-cta:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-xl);
	background: rgba(255, 255, 255, 0.2);
	border-color: rgba(255, 255, 255, 0.3);
}

.cta-title {
	font-family: var(--font-primary);
	font-size: 1.5rem;
	font-weight: 700;
	color: white;
	margin-bottom: var(--space-sm);
}

.cta-description {
	color: rgba(255, 255, 255, 0.9);
	margin-bottom: var(--space-md);
	font-size: 1.125rem;
}

.process-cta .btn {
	background: rgba(255, 255, 255, 0.2);
	color: white;
	border: 2px solid rgba(255, 255, 255, 0.3);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.process-cta .btn:hover {
	background: rgba(255, 255, 255, 0.3);
	border-color: rgba(255, 255, 255, 0.5);
	transform: translateY(-2px);
}

@keyframes slideInFromLeft {
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

@keyframes slideInFromRight {
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

/* Responsive Design */
@media (max-width: 1024px) {
	.step-card {
		grid-template-columns: 1fr 240px;
		min-height: 280px;
		width: 64%; /* Proportionally adjusted: 80% * 0.8 = 64% */
	}

	.step-card.reverse {
		grid-template-columns: 240px 1fr;
	}

	.step-content {
		padding: var(--space-md) var(--space-lg);
	}

	.step-title {
		font-size: 1.5rem;
	}

	.step-description {
		font-size: 0.95rem;
	}

	.step-feature {
		font-size: 0.8125rem;
	}

	.step-card:nth-child(1) {
		margin-left: 60px;
	}

	.step-card:nth-child(2) {
		margin-right: 80px;
	}

	.step-card:nth-child(3) {
		margin-left: 60px;
	}
}

@media (max-width: 768px) {
	.process {
		padding: var(--space-2xl) 0;
	}

	.process-steps {
		padding: 0 var(--space-sm);
		gap: var(--space-lg);
	}

	.step-card {
		grid-template-columns: 1fr;
		text-align: center;
		min-height: auto;
		width: 100%;
		margin-left: 0 !important;
		margin-right: 0 !important;
	}

	.step-card.reverse {
		grid-template-columns: 1fr;
	}

	.step-card.reverse .step-visual,
	.step-card.reverse .step-content {
		order: unset;
	}

	.step-number {
		position: relative;
		top: auto;
		left: auto;
		right: auto;
		transform: none;
		margin: var(--space-lg) auto;
		width: 80px;
		height: 80px;
		font-size: 2rem;
	}

	.step-card:hover .step-number {
		transform: scale(1.1) rotate(10deg);
	}

	.step-visual {
		height: 200px;
		order: 1;
	}

	.step-content {
		order: 2;
		padding: var(--space-lg);
	}

	.step-title {
		font-size: 1.5rem;
	}

	.step-description {
		font-size: 1rem;
	}

	.step-feature {
		font-size: 0.875rem;
	}

	.step-features {
		align-items: center;
	}

	.step-timeline {
		align-self: center;
	}

	.process-cta {
		margin-top: var(--space-lg);
		padding: var(--space-lg);
	}

	/* Disable animations on mobile */
	.step-card:nth-child(n) {
		animation: none;
		opacity: 1;
		transform: none;
	}
}

/* ===================================
   SUCCESS STORIES SECTION
   =================================== */

.success-stories {
	background: white;
	padding: var(--space-3xl) 0;
	position: relative;
	overflow: hidden;
}

.success-stories::before {
	content: '';
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: 
		radial-gradient(circle at 0% 0%, rgba(73, 98, 191, 0.05) 0%, transparent 50%),
		radial-gradient(circle at 100% 100%, rgba(255, 167, 38, 0.05) 0%, transparent 50%);
	pointer-events: none;
}

.stories-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-xl);
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 var(--space-lg);
}

.story-card {
	background: white;
	border-radius: var(--radius-2xl);
	overflow: hidden;
	box-shadow: var(--shadow-md);
	transition: all var(--transition-normal);
	position: relative;
	border: 2px solid transparent;
	display: flex;
	flex-direction: column;
}

.story-card.featured {
	grid-column: span 2;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	background: var(--gradient-primary);
	color: white;
	min-height: 400px;
}

.story-card:hover {
	transform: translateY(-8px);
	box-shadow: var(--shadow-xl);
	border-color: var(--primary-blue);
}

.story-card.featured:hover {
	border-color: rgba(255, 255, 255, 0.3);
}

.story-image {
	position: relative;
	aspect-ratio: 16/10;
	overflow: hidden;
	background: var(--neutral-medium);
}

.story-card.featured .story-image {
	aspect-ratio: unset;
	height: 100%;
}

.story-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-slow);
}

.story-card:hover .story-image img {
	transform: scale(1.08);
}

.story-overlay {
	position: absolute;
	top: var(--space-sm);
	left: var(--space-sm);
	background: rgba(0, 0, 0, 0.7);
	color: white;
	padding: 0.5rem 1rem;
	border-radius: var(--radius-2xl);
	font-size: 0.875rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	transition: all var(--transition-normal);
}

.story-card:hover .story-overlay {
	background: rgba(0, 0, 0, 0.8);
	transform: scale(1.05);
}

.story-content {
	padding: var(--space-xl);
	flex-grow: 1;
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.story-card.featured .story-content {
	padding: var(--space-2xl);
	justify-content: center;
}

.story-title {
	font-family: var(--font-secondary);
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--text-dark);
	margin-bottom: var(--space-sm);
	line-height: 1.3;
	transition: color var(--transition-fast);
}

.story-card.featured .story-title {
	color: white;
	font-size: 1.75rem;
}

.story-card:hover .story-title {
	color: var(--secondary-blue);
}

.story-card.featured:hover .story-title {
	color: rgba(255, 255, 255, 0.95);
}

.story-description {
	color: var(--text-medium);
	line-height: 1.6;
	font-size: 1.125rem;
	margin-bottom: var(--space-md);
	flex-grow: 1;
	font-style: italic;
	position: relative;
}

.story-card.featured .story-description {
	color: rgba(255, 255, 255, 0.9);
	font-size: 1.25rem;
}

.story-description::before {
	content: '"';
	font-size: 3rem;
	color: var(--primary-blue);
	position: absolute;
	top: -1rem;
	left: -0.5rem;
	font-family: var(--font-secondary);
	opacity: 0.3;
}

.story-card.featured .story-description::before {
	color: rgba(255, 255, 255, 0.4);
}

.story-quote {
	margin-bottom: var(--space-md);
}

.quote-author {
	font-weight: 600;
	color: var(--text-light);
	font-size: 0.95rem;
}

.story-card.featured .quote-author {
	color: rgba(255, 255, 255, 0.8);
}

.story-stats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-sm);
	margin-bottom: var(--space-md);
}

.story-card.featured .story-stats {
	grid-template-columns: repeat(3, 1fr);
}

.stat {
	text-align: center;
	padding: var(--space-sm);
	border-radius: var(--radius-md);
	background: var(--neutral-light);
	transition: all var(--transition-fast);
}

.story-card.featured .stat {
	background: rgba(255, 255, 255, 0.15);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.story-card:hover .stat {
	background: rgba(101, 181, 218, 0.1);
	transform: translateY(-2px);
}

.story-card.featured:hover .stat {
	background: rgba(255, 255, 255, 0.2);
}

.stat-number {
	display: block;
	font-family: var(--font-secondary);
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--secondary-blue);
	line-height: 1.2;
}

.story-card.featured .stat-number {
	color: white;
	font-size: 1.375rem;
}

.stat-label {
	font-size: 0.8125rem;
	color: var(--text-light);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.story-card.featured .stat-label {
	color: rgba(255, 255, 255, 0.8);
}

.story-details {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: auto;
}

.detail-tag {
	background: var(--neutral-light);
	color: var(--secondary-blue);
	padding: 0.375rem 0.875rem;
	border-radius: var(--radius-2xl);
	font-size: 0.875rem;
	font-weight: 500;
	border: 1px solid rgba(73, 98, 191, 0.1);
	transition: all var(--transition-fast);
}

.story-card.featured .detail-tag {
	background: rgba(255, 255, 255, 0.15);
	color: white;
	border-color: rgba(255, 255, 255, 0.2);
}

.story-card:hover .detail-tag {
	background: rgba(73, 98, 191, 0.1);
	border-color: rgba(73, 98, 191, 0.2);
	transform: translateY(-1px);
}

.story-card.featured:hover .detail-tag {
	background: rgba(255, 255, 255, 0.25);
	border-color: rgba(255, 255, 255, 0.3);
}

.stories-cta {
	background: var(--gradient-primary);
	border-radius: var(--radius-2xl);
	padding: var(--space-xl);
	text-align: center;
	color: white;
	margin-top: var(--space-2xl);
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
	box-shadow: var(--shadow-lg);
	transition: all var(--transition-normal);
}

.stories-cta:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-xl);
}

.stories-cta .cta-title {
	font-family: var(--font-secondary);
	font-size: 1.5rem;
	font-weight: 700;
	color: white;
	margin-bottom: var(--space-sm);
}

.stories-cta .cta-description {
	color: rgba(255, 255, 255, 0.9);
	margin-bottom: var(--space-md);
	font-size: 1.125rem;
}

.stories-cta .btn {
	background: rgba(255, 255, 255, 0.2);
	color: white;
	border: 2px solid rgba(255, 255, 255, 0.3);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.stories-cta .btn:hover {
	background: rgba(255, 255, 255, 0.3);
	border-color: rgba(255, 255, 255, 0.5);
	transform: translateY(-2px);
}

/* Entrance animations */
.story-card:nth-child(1) {
	animation: slideInFromBottom 0.8s ease forwards;
	opacity: 0;
	transform: translateY(40px);
}

.story-card:nth-child(2) {
	animation: slideInFromBottom 0.8s ease forwards 0.2s;
	opacity: 0;
	transform: translateY(40px);
}

.story-card:nth-child(3) {
	animation: slideInFromBottom 0.8s ease forwards 0.4s;
	opacity: 0;
	transform: translateY(40px);
}

.story-card:nth-child(4) {
	animation: slideInFromBottom 0.8s ease forwards 0.6s;
	opacity: 0;
	transform: translateY(40px);
}

@keyframes slideInFromBottom {
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Responsive Design */
@media (max-width: 1024px) {
	.story-card.featured {
		grid-template-columns: 1fr;
		grid-column: span 2;
	}

	.story-card.featured .story-image {
		aspect-ratio: 16/8;
		height: auto;
	}

	.story-stats {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 768px) {
	.success-stories {
		padding: var(--space-2xl) 0;
	}

	.stories-grid {
		grid-template-columns: 1fr;
		gap: var(--space-lg);
		padding: 0 var(--space-sm);
	}

	.story-card.featured {
		grid-column: span 1;
	}

	.story-content {
		padding: var(--space-lg);
	}

	.story-card.featured .story-content {
		padding: var(--space-xl);
	}

	.story-stats {
		grid-template-columns: 1fr 1fr;
		gap: var(--space-xs);
	}

	.story-card.featured .story-stats {
		grid-template-columns: repeat(3, 1fr);
	}

	.stat {
		padding: var(--space-xs);
	}

	.stories-cta {
		margin-top: var(--space-lg);
		padding: var(--space-lg);
	}

	/* Disable animations on mobile */
	.story-card:nth-child(n) {
		animation: none;
		opacity: 1;
		transform: none;
	}
}

@media (max-width: 480px) {
	.story-stats {
		grid-template-columns: 1fr;
	}

	.story-card.featured .story-stats {
		grid-template-columns: 1fr 1fr;
	}

	.story-details {
		gap: 0.375rem;
	}

	.detail-tag {
		font-size: 0.8125rem;
		padding: 0.25rem 0.75rem;
	}
}

/* ===================================
   TESTIMONIALS SECTION
   =================================== */

.testimonials {
	background: var(--secondary-blue);
	padding: var(--space-3xl) 0;
	color: white;
	position: relative;
	overflow: hidden;
}

.testimonials::before {
	content: '';
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: 
		radial-gradient(circle at 20% 20%, rgba(101, 181, 218, 0.3) 0%, transparent 40%),
		radial-gradient(circle at 80% 80%, rgba(255, 107, 107, 0.2) 0%, transparent 40%);
	pointer-events: none;
}

.testimonials-header {
	text-align: center;
	max-width: 800px;
	margin: 0 auto var(--space-2xl);
	padding: 0 var(--space-lg);
	position: relative;
}

.testimonials-subtitle {
	display: inline-block;
	color: var(--accent-coral);
	font-family: var(--font-primary);
	font-weight: 600;
	font-size: 0.875rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin-bottom: var(--space-sm);
	padding: 0.5rem 1rem;
	background: rgba(255, 107, 107, 0.2);
	border-radius: var(--radius-2xl);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.testimonials-title {
	color: white;
	margin-bottom: var(--space-md);
	text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

.testimonials-description {
	color: rgba(255, 255, 255, 0.9);
	font-size: 1.25rem;
	line-height: 1.6;
}

.testimonials-slider {
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 var(--space-lg);
	position: relative;
	overflow: hidden;
}

.testimonial-track {
	display: flex;
	gap: var(--space-lg);
	transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
	will-change: transform;
}

.testimonial-card {
	min-width: calc(33.333% - var(--space-md));
	flex: 0 0 calc(33.333% - var(--space-md));
	background: rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	border-radius: var(--radius-2xl);
	padding: var(--space-xl);
	border: 1px solid rgba(255, 255, 255, 0.2);
	transition: all var(--transition-normal);
	position: relative;
	overflow: hidden;
}

.testimonial-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
	transition: left var(--transition-slow);
}

.testimonial-card:hover {
	transform: translateY(-6px);
	background: rgba(255, 255, 255, 0.15);
	border-color: rgba(255, 255, 255, 0.3);
	box-shadow: 0 20px 40px rgba(0, 0, 0, 0.2);
}

.testimonial-card:hover::before {
	left: 100%;
}

.testimonial-content {
	margin-bottom: var(--space-lg);
	font-size: 1.125rem;
	line-height: 1.7;
	color: rgba(255, 255, 255, 0.95);
	font-style: italic;
	position: relative;
	padding-top: var(--space-md);
}

.testimonial-content::before {
	content: '"';
	position: absolute;
	top: -0.5rem;
	left: -0.5rem;
	font-size: 4rem;
	color: rgba(255, 255, 255, 0.2);
	font-family: var(--font-secondary);
	line-height: 1;
}

.testimonial-content::after {
	content: '"';
	position: absolute;
	bottom: -1rem;
	right: 0;
	font-size: 4rem;
	color: rgba(255, 255, 255, 0.2);
	font-family: var(--font-secondary);
	line-height: 1;
}

.testimonial-footer {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
}

.testimonial-image {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	overflow: hidden;
	border: 3px solid rgba(255, 255, 255, 0.3);
	flex-shrink: 0;
	transition: all var(--transition-normal);
	background: var(--neutral-medium);
}

.testimonial-card:hover .testimonial-image {
	border-color: rgba(255, 255, 255, 0.5);
	transform: scale(1.05);
}

.testimonial-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-normal);
}

.testimonial-card:hover .testimonial-image img {
	transform: scale(1.1);
}

.testimonial-author {
	flex-grow: 1;
	min-width: 0;
}

.author-name {
	font-weight: 600;
	color: white;
	margin-bottom: 0.25rem;
	font-size: 1rem;
}

.author-title {
	font-size: 0.875rem;
	color: rgba(255, 255, 255, 0.8);
	font-weight: 500;
	line-height: 1.3;
}

.author-location {
	font-size: 0.8125rem;
	color: var(--accent-coral);
	font-weight: 500;
	margin-top: 0.125rem;
}

.slider-controls {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: var(--space-lg);
	margin-top: var(--space-2xl);
}

.slider-arrow {
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.15);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border: 2px solid rgba(255, 255, 255, 0.2);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	color: white;
	transition: all var(--transition-normal);
	position: relative;
	overflow: hidden;
}

.slider-arrow::before {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.1);
	transform: scale(0);
	transition: transform var(--transition-normal);
}

.slider-arrow:hover {
	background: rgba(255, 255, 255, 0.25);
	border-color: rgba(255, 255, 255, 0.4);
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(0, 0, 0, 0.3);
}

.slider-arrow:hover::before {
	transform: scale(1);
}

.slider-arrow:disabled {
	opacity: 0.5;
	cursor: not-allowed;
	transform: none;
}

.slider-arrow:disabled:hover {
	background: rgba(255, 255, 255, 0.15);
	border-color: rgba(255, 255, 255, 0.2);
	box-shadow: none;
}

.slider-dots {
	display: flex;
	gap: var(--space-xs);
	align-items: center;
}

.slider-dot {
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.3);
	transition: all var(--transition-normal);
	cursor: pointer;
	border: 2px solid transparent;
}

.slider-dot.active {
	background: var(--accent-coral);
	transform: scale(1.2);
	border-color: rgba(255, 255, 255, 0.3);
	box-shadow: 0 0 0 4px rgba(255, 107, 107, 0.3);
}

.slider-dot:hover:not(.active) {
	background: rgba(255, 255, 255, 0.5);
	transform: scale(1.1);
}

/* Responsive Design */
@media (max-width: 1200px) {
	.testimonial-card {
		min-width: calc(50% - var(--space-sm));
		flex: 0 0 calc(50% - var(--space-sm));
	}
}

@media (max-width: 768px) {
	.testimonials {
		padding: var(--space-2xl) 0;
	}

	.testimonials-slider {
		padding: 0 var(--space-sm);
	}

	.testimonial-track {
		gap: var(--space-sm);
	}

	.testimonial-card {
		min-width: 100%;
		flex: 0 0 100%;
		padding: var(--space-lg);
	}

	.testimonial-content {
		font-size: 1rem;
		margin-bottom: var(--space-md);
	}

	.testimonial-content::before,
	.testimonial-content::after {
		font-size: 3rem;
	}

	.testimonial-image {
		width: 56px;
		height: 56px;
	}

	.slider-controls {
		gap: var(--space-md);
		margin-top: var(--space-lg);
	}

	.slider-arrow {
		width: 48px;
		height: 48px;
	}

	.slider-dot {
		width: 10px;
		height: 10px;
	}
}

@media (max-width: 480px) {
	.testimonial-card {
		padding: var(--space-md);
	}

	.testimonial-content {
		padding-top: var(--space-sm);
	}

	.testimonial-footer {
		gap: var(--space-xs);
	}

	.testimonial-image {
		width: 48px;
		height: 48px;
	}

	.author-name {
		font-size: 0.9375rem;
	}

	.author-title {
		font-size: 0.8125rem;
	}

	.author-location {
		font-size: 0.75rem;
	}
}

/* ===================================
   FAQ SECTION
   =================================== */

.faq {
	background: white;
	padding: var(--space-3xl) 0;
	position: relative;
	overflow: hidden;
}

.faq::before {
	content: '';
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: 
		radial-gradient(circle at 0% 0%, rgba(101, 181, 218, 0.06) 0%, transparent 50%),
		radial-gradient(circle at 100% 100%, rgba(255, 107, 107, 0.06) 0%, transparent 50%);
	pointer-events: none;
}

.faq-header {
	text-align: center;
	max-width: 800px;
	margin: 0 auto var(--space-2xl);
	padding: 0 var(--space-lg);
}

.faq-subtitle {
	display: inline-block;
	color: var(--accent-coral);
	font-family: var(--font-primary);
	font-weight: 600;
	font-size: 0.875rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin-bottom: var(--space-sm);
	padding: 0.5rem 1rem;
	background: rgba(255, 107, 107, 0.1);
	border-radius: var(--radius-2xl);
}

.faq-description {
	color: var(--text-medium);
	font-size: 1.25rem;
	margin-top: var(--space-md);
	line-height: 1.6;
}

.faq-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-xl);
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 var(--space-lg);
}

.faq-column {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.faq-item {
	background: var(--gradient-primary);
	border-radius: var(--radius-xl);
	overflow: hidden;
	box-shadow: var(--shadow-md);
	transition: all var(--transition-normal);
	position: relative;
	color: white;
}

.faq-item::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 0;
	height: 4px;
	background: var(--accent-coral);
	transition: width var(--transition-normal);
}

.faq-item:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
}

.faq-item:hover::before {
	width: 100%;
}

.faq-item.active {
	box-shadow: var(--shadow-lg);
}

.faq-item.active::before {
	width: 100%;
}

.faq-question {
	padding: var(--space-lg);
	display: flex;
	justify-content: space-between;
	align-items: center;
	cursor: pointer;
	background: none;
	border: none;
	width: 100%;
	text-align: left;
	color: white;
	font-weight: 600;
	font-size: 1.125rem;
	line-height: 1.4;
	transition: all var(--transition-fast);
	position: relative;
}

.faq-question:hover {
	color: rgba(255, 255, 255, 0.9);
}

.faq-item.active .faq-question {
	color: white;
}

.faq-icon {
	width: 24px;
	height: 24px;
	color: rgba(255, 255, 255, 0.8);
	transition: all var(--transition-normal);
	flex-shrink: 0;
	margin-left: var(--space-sm);
}

.faq-item.active .faq-icon {
	transform: rotate(45deg);
	color: var(--accent-coral);
}

.faq-answer {
	max-height: 0;
	overflow: hidden;
	transition: all var(--transition-normal);
	padding: 0 var(--space-lg);
	color: rgba(255, 255, 255, 0.9);
	line-height: 1.6;
	font-size: 1rem;
	opacity: 0;
}

.faq-item.active .faq-answer {
	max-height: 300px;
	padding: var(--space-md) var(--space-lg) var(--space-xl);
	opacity: 1;
}

.faq-contact {
	background: var(--gradient-primary);
	border-radius: var(--radius-2xl);
	padding: var(--space-2xl);
	text-align: center;
	margin-top: var(--space-2xl);
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
	box-shadow: var(--shadow-lg);
	transition: all var(--transition-normal);
	color: white;
	position: relative;
	overflow: hidden;
}

.faq-contact:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-xl);
}

.faq-contact-title {
	font-family: var(--font-secondary);
	font-size: 1.5rem;
	font-weight: 700;
	color: white;
	margin-bottom: var(--space-sm);
}

.faq-contact-description {
	color: rgba(255, 255, 255, 0.9);
	margin-bottom: var(--space-md);
	font-size: 1.125rem;
}

.faq-contact .btn {
	background: var(--gradient-accent);
	color: white;
	border: 2px solid rgba(255, 255, 255, 0.3);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}

.faq-contact .btn:hover {
	background: var(--gradient-accent);
	border-color: rgba(255, 255, 255, 0.5);
	transform: translateY(-2px);
}

/* Entrance animations for FAQ items */
.faq-item:nth-child(1) {
	animation: slideInFromLeft 0.6s ease forwards;
	opacity: 0;
	transform: translateX(-30px);
}

.faq-item:nth-child(2) {
	animation: slideInFromLeft 0.6s ease forwards 0.1s;
	opacity: 0;
	transform: translateX(-30px);
}

.faq-item:nth-child(3) {
	animation: slideInFromLeft 0.6s ease forwards 0.2s;
	opacity: 0;
	transform: translateX(-30px);
}

.faq-item:nth-child(4) {
	animation: slideInFromRight 0.6s ease forwards 0.1s;
	opacity: 0;
	transform: translateX(30px);
}

.faq-item:nth-child(5) {
	animation: slideInFromRight 0.6s ease forwards 0.2s;
	opacity: 0;
	transform: translateX(30px);
}

.faq-item:nth-child(6) {
	animation: slideInFromRight 0.6s ease forwards 0.3s;
	opacity: 0;
	transform: translateX(30px);
}

.faq-item:nth-child(7) {
	animation: slideInFromLeft 0.6s ease forwards 0.4s;
	opacity: 0;
	transform: translateX(-30px);
}

.faq-item:nth-child(8) {
	animation: slideInFromLeft 0.6s ease forwards 0.5s;
	opacity: 0;
	transform: translateX(-30px);
}

.faq-item:nth-child(9) {
	animation: slideInFromLeft 0.6s ease forwards 0.6s;
	opacity: 0;
	transform: translateX(-30px);
}

.faq-item:nth-child(10) {
	animation: slideInFromRight 0.6s ease forwards 0.4s;
	opacity: 0;
	transform: translateX(30px);
}

.faq-item:nth-child(11) {
	animation: slideInFromRight 0.6s ease forwards 0.5s;
	opacity: 0;
	transform: translateX(30px);
}

.faq-item:nth-child(12) {
	animation: slideInFromRight 0.6s ease forwards 0.6s;
	opacity: 0;
	transform: translateX(30px);
}

@keyframes slideInFromLeft {
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

@keyframes slideInFromRight {
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

/* Custom scrollbar for FAQ answers if needed */
.faq-answer::-webkit-scrollbar {
	width: 4px;
}

.faq-answer::-webkit-scrollbar-track {
	background: rgba(255, 255, 255, 0.1);
	border-radius: 2px;
}

.faq-answer::-webkit-scrollbar-thumb {
	background: rgba(255, 255, 255, 0.3);
	border-radius: 2px;
}

.faq-answer::-webkit-scrollbar-thumb:hover {
	background: rgba(255, 255, 255, 0.5);
}

/* Responsive Design */
@media (max-width: 1024px) {
	.faq-grid {
		gap: var(--space-lg);
	}

	.faq-question {
		font-size: 1.0625rem;
		padding: var(--space-md) var(--space-lg);
	}

	.faq-answer {
		padding: 0 var(--space-lg);
	}

	.faq-item.active .faq-answer {
		padding: var(--space-md) var(--space-lg) var(--space-xl);
	}
}

@media (max-width: 768px) {
	.faq {
		padding: var(--space-2xl) 0;
	}

	.faq-grid {
		grid-template-columns: 1fr;
		gap: var(--space-md);
		padding: 0 var(--space-sm);
	}

	.faq-question {
		font-size: 1rem;
		padding: var(--space-md);
	}

	.faq-answer {
		padding: 0 var(--space-md);
		font-size: 0.9375rem;
	}

	.faq-item.active .faq-answer {
		padding: var(--space-md) var(--space-md) var(--space-xl);
	}

	.faq-contact {
		padding: var(--space-lg);
		margin-top: var(--space-lg);
	}

	.faq-contact-title {
		font-size: 1.5rem;
	}

	/* Reset animations on mobile for better performance */
	.faq-item:nth-child(n) {
		animation: none;
		opacity: 1;
		transform: none;
	}
}

@media (max-width: 480px) {
	.faq-question {
		padding: var(--space-sm) var(--space-md);
		font-size: 0.9375rem;
	}

	.faq-answer {
		padding: 0 var(--space-md);
		font-size: 0.875rem;
	}

	.faq-item.active .faq-answer {
		padding: var(--space-md) var(--space-md) var(--space-xl);
	}

	.faq-icon {
		width: 20px;
		height: 20px;
	}

	.faq-contact {
		padding: var(--space-md);
	}

	.faq-contact-title {
		font-size: 1.375rem;
	}

	.faq-contact-description {
		font-size: 1rem;
	}
}

/* ===================================
   CONTACT SECTION
   =================================== */

.contact {
	background: var(--neutral-light);
	padding: var(--space-3xl) 0;
	position: relative;
	overflow: hidden;
}

.contact::before {
	content: '';
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: 
		radial-gradient(circle at 20% 0%, rgba(73, 98, 191, 0.08) 0%, transparent 50%),
		radial-gradient(circle at 80% 100%, rgba(255, 107, 107, 0.08) 0%, transparent 50%);
	pointer-events: none;
}

.contact-header {
	text-align: center;
	max-width: 700px;
	margin: 0 auto var(--space-2xl);
	padding: 0 var(--space-lg);
}

.contact-subtitle {
	display: inline-block;
	color: var(--accent-coral);
	font-family: var(--font-primary);
	font-weight: 600;
	font-size: 0.875rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin-bottom: var(--space-sm);
	padding: 0.5rem 1rem;
	background: rgba(255, 107, 107, 0.1);
	border-radius: var(--radius-2xl);
}

.contact-description {
	color: var(--text-medium);
	font-size: 1.25rem;
	margin-top: var(--space-md);
	line-height: 1.6;
}

.contact-content {
	display: grid;
	grid-template-columns: 1fr 350px;
	gap: var(--space-2xl);
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 var(--space-lg);
	align-items: start;
}

.contact-form-section {
	background: white;
	border-radius: var(--radius-2xl);
	padding: var(--space-2xl);
	box-shadow: var(--shadow-lg);
	transition: all var(--transition-normal);
	position: relative;
	overflow: hidden;
}

.contact-form-section::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 4px;
	background: var(--gradient-primary);
}

.contact-form-section:hover {
	box-shadow: var(--shadow-xl);
}

.form-header {
	margin-bottom: var(--space-lg);
	text-align: center;
}

.form-header h3 {
	font-family: var(--font-primary);
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--text-dark);
	margin-bottom: var(--space-xs);
}

.form-header p {
	color: var(--text-medium);
	font-size: 1rem;
	line-height: 1.5;
	margin: 0;
}

.contact-form {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.form-group {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.form-group label {
	font-weight: 600;
	color: var(--text-dark);
	font-size: 0.9375rem;
	margin-bottom: 0.25rem;
}

.form-group input,
.form-group select,
.form-group textarea {
	padding: 0.875rem 1rem;
	border: 2px solid var(--neutral-medium);
	border-radius: var(--radius-md);
	font-size: 1rem;
	transition: all var(--transition-fast);
	background: white;
	color: var(--text-dark);
	font-family: inherit;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
	outline: none;
	border-color: var(--primary-blue);
	box-shadow: 0 0 0 3px rgba(101, 181, 218, 0.1);
	transform: translateY(-1px);
}

.form-group input:hover,
.form-group select:hover,
.form-group textarea:hover {
	border-color: var(--primary-blue);
}

.form-group textarea {
	resize: vertical;
	min-height: 80px;
}

.form-group input::placeholder,
.form-group textarea::placeholder {
	color: var(--text-light);
}

.checkbox-group {
	display: flex;
	align-items: flex-start;
	gap: var(--space-xs);
	margin-top: var(--space-sm);
}

.checkbox-group input[type="checkbox"] {
	width: 18px;
	height: 18px;
	margin: 0;
	flex-shrink: 0;
	margin-top: 2px;
	accent-color: var(--primary-blue);
}

.checkbox-group label {
	font-size: 0.9375rem;
	line-height: 1.4;
	cursor: pointer;
	font-weight: 500;
}

.btn-accent {
	background: var(--gradient-accent);
	color: white;
}

.btn-accent:hover {
	background: var(--gradient-accent);
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg);
}

.btn-large {
	padding: 1.125rem 2rem;
	font-size: 1.125rem;
	font-weight: 700;
	margin-top: var(--space-sm);
	justify-content: center;
	min-height: 56px;
	width: 100%;
}

.form-disclaimer {
	font-size: 0.875rem;
	color: var(--text-light);
	text-align: center;
	margin-top: var(--space-sm);
	line-height: 1.4;
	margin-bottom: 0;
}

.contact-info-section {
	display: flex;
	flex-direction: column;
	gap: var(--space-lg);
}

.assessment-benefits {
	background: rgba(101, 181, 218, 0.05);
	border-radius: var(--radius-xl);
	padding: var(--space-lg);
	border: 1px solid rgba(101, 181, 218, 0.1);
}

.assessment-benefits h4 {
	font-family: var(--font-primary);
	font-size: 1.125rem;
	font-weight: 700;
	color: var(--text-dark);
	margin-bottom: var(--space-md);
	text-align: center;
}

.benefits-list {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.benefits-list li {
	display: flex;
	align-items: flex-start;
	gap: var(--space-sm);
	color: var(--text-medium);
	font-size: 0.875rem;
	line-height: 1.4;
}

.benefits-list li svg {
	color: var(--primary-blue);
	flex-shrink: 0;
	margin-top: 2px;
}

.benefits-list li span {
	flex: 1;
}

.social-proof-compact {
	background: var(--gradient-primary);
	color: white;
	border-radius: var(--radius-xl);
	padding: var(--space-lg);
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-md);
	text-align: center;
	position: relative;
	overflow: hidden;
}

.social-proof-compact::before {
	content: '';
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.1), transparent);
	animation: shimmer 3s ease-in-out infinite;
}

@keyframes shimmer {
	0% { left: -100%; }
	50% { left: 100%; }
	100% { left: 100%; }
}

.proof-stat {
	position: relative;
	z-index: 1;
}

.proof-stat strong {
	display: block;
	font-family: var(--font-primary);
	font-size: 1.125rem;
	font-weight: 700;
	color: white;
	margin-bottom: 0.125rem;
}

.proof-stat span {
	font-size: 0.8125rem;
	color: rgba(255, 255, 255, 0.9);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	font-weight: 500;
}

/* Form validation states - FIXED */
.form-group input:valid:not(:placeholder-shown),
.form-group textarea:valid:not(:placeholder-shown) {
	border-color: #10b981;
}

.form-group select:valid {
	border-color: #10b981;
}

/* Only show invalid styles when explicitly marked with error class */
.form-group input.error,
.form-group select.error,
.form-group textarea.error {
	border-color: #ef4444 !important;
	box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1) !important;
	animation: shake 0.3s ease-in-out;
}

/* Loading state for form submission */
.contact-form.loading .btn {
	position: relative;
	color: transparent;
}

.contact-form.loading .btn::after {
	content: '';
	position: absolute;
	width: 20px;
	height: 20px;
	top: 50%;
	left: 50%;
	margin-left: -10px;
	margin-top: -10px;
	border: 2px solid transparent;
	border-top-color: currentColor;
	border-radius: 50%;
	animation: spin 1s linear infinite;
}

@keyframes spin {
	to {
		transform: rotate(360deg);
	}
}

@keyframes slideIn {
	from {
		opacity: 0;
		transform: translateY(-10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes successSlideIn {
	from {
		opacity: 0;
		transform: translateY(20px) scale(0.95);
	}
	to {
		opacity: 1;
		transform: translateY(0) scale(1);
	}
}

@keyframes shake {
	0%, 100% { transform: translateX(0); }
	25% { transform: translateX(-5px); }
	75% { transform: translateX(5px); }
}

/* Responsive Design */
@media (max-width: 1024px) {
	.contact-content {
		grid-template-columns: 1fr 320px;
		gap: var(--space-lg);
	}

	.contact-form-section {
		padding: var(--space-lg);
	}

	.assessment-benefits {
		padding: var(--space-md);
	}

	.social-proof-compact {
		padding: var(--space-md);
	}
}

@media (max-width: 768px) {
	.contact {
		padding: var(--space-2xl) 0;
	}

	.contact-content {
		grid-template-columns: 1fr;
		gap: var(--space-lg);
		padding: 0 var(--space-sm);
	}

	.contact-form-section {
		padding: var(--space-lg);
	}

	.form-header h3 {
		font-size: 1.5rem;
	}

	.assessment-benefits {
		padding: var(--space-md);
	}

	.social-proof-compact {
		padding: var(--space-md);
		gap: var(--space-sm);
	}

	.benefits-list {
		gap: var(--space-sm);
	}
}

@media (max-width: 480px) {
	.contact-form-section {
		padding: var(--space-md);
	}

	.form-header {
		margin-bottom: var(--space-md);
	}

	.form-header h3 {
		font-size: 1.375rem;
	}

	.form-group input,
	.form-group select,
	.form-group textarea {
		padding: 0.75rem;
		font-size: 0.9375rem;
	}

	.btn-large {
		padding: 1rem 1.5rem;
		font-size: 1.0625rem;
	}

	.assessment-benefits h4 {
		font-size: 1rem;
	}

	.benefits-list li {
		font-size: 0.8125rem;
	}

	.benefits-list {
		gap: var(--space-xs);
	}
}

/* ===================================
   FOOTER SECTION
   =================================== */

.footer {
	background: var(--secondary-blue);
	color: white;
	position: relative;
	overflow: hidden;
}

.footer::before {
	content: '';
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: 
		radial-gradient(circle at 10% 0%, rgba(101, 181, 218, 0.3) 0%, transparent 50%),
		radial-gradient(circle at 90% 100%, rgba(255, 107, 107, 0.2) 0%, transparent 50%);
	pointer-events: none;
}

.footer-top {
	position: relative;
	padding: var(--space-2xl) var(--space-lg) var(--space-lg);
}

.footer-grid {
	display: grid;
	grid-template-columns: 400px 200px 300px;
	justify-content: space-between;
	max-width: 1200px;
	margin: 0 auto;
	align-items: start;
}

.footer-brand {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.footer-logo {
	width: 160px;
	height: auto;
	margin-bottom: var(--space-xs);
	transition: all var(--transition-normal);
}

.footer-logo:hover {
	transform: scale(1.05);
}

.footer-description {
	color: rgba(255, 255, 255, 0.85);
	font-size: 0.9375rem;
	line-height: 1.5;
	margin-bottom: var(--space-sm);
}

.footer-credentials {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
	margin-bottom: var(--space-md);
}

.credential-item {
	display: flex;
	align-items: center;
	gap: var(--space-xs);
	color: rgba(255, 255, 255, 0.9);
	font-size: 0.875rem;
	font-weight: 500;
}

.credential-icon {
	width: 16px;
	height: 16px;
	color: var(--accent-coral);
	flex-shrink: 0;
}

.footer-social {
	display: flex;
	gap: var(--space-sm);
}

.social-link {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all var(--transition-normal);
	border: 2px solid rgba(255, 255, 255, 0.2);
	position: relative;
	overflow: hidden;
}

.social-link::before {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: 50%;
	background: var(--gradient-accent);
	transform: scale(0);
	transition: transform var(--transition-normal);
}

.social-link:hover {
	transform: translateY(-2px);
	border-color: rgba(255, 255, 255, 0.4);
	box-shadow: 0 6px 15px rgba(0, 0, 0, 0.3);
}

.social-link:hover::before {
	transform: scale(1);
}

.social-icon {
	width: 18px;
	height: 18px;
	color: white;
	z-index: 1;
	position: relative;
	transition: transform var(--transition-normal);
}

.social-link:hover .social-icon {
	transform: scale(1.1);
}

.footer-column {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.footer-column h4 {
	color: white;
	font-family: var(--font-primary);
	font-size: 1.125rem;
	font-weight: 700;
	margin-bottom: var(--space-sm);
	position: relative;
}

.footer-column h4::after {
	content: '';
	position: absolute;
	bottom: -6px;
	left: 0;
	width: 30px;
	height: 2px;
	background: var(--gradient-accent);
	border-radius: 2px;
}

.footer-links {
	list-style: none;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}

.footer-link {
	color: rgba(255, 255, 255, 0.8);
	text-decoration: none;
	font-weight: 500;
	font-size: 0.875rem;
	position: relative;
	padding: 0.25rem 0;
	transition: all var(--transition-fast);
	display: inline-block;
}

.footer-link::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 0;
	height: 2px;
	background: var(--accent-coral);
	transition: width var(--transition-normal);
}

.footer-link:hover {
	color: white;
}

.footer-link:hover::after,
.footer-link.active::after {
	width: 100%;
}

.footer-contact {
	color: rgba(255, 255, 255, 0.85);
}

.contact-item {
	display: flex;
	align-items: flex-start;
	gap: var(--space-sm);
	margin-bottom: var(--space-sm);
	padding: var(--space-xs);
	border-radius: var(--radius-md);
	transition: all var(--transition-fast);
}

.contact-item:last-child {
	margin-bottom: 0;
}

.contact-item:hover {
	background: rgba(255, 255, 255, 0.05);
	transform: translateX(2px);
}

.contact-icon {
	width: 18px;
	height: 18px;
	color: var(--accent-coral);
	flex-shrink: 0;
	margin-top: 2px;
}

.contact-item div {
	flex-grow: 1;
}

.contact-item strong {
	display: block;
	color: white;
	font-weight: 600;
	margin-bottom: 0.125rem;
	font-size: 0.9375rem;
}

.contact-item small {
	color: rgba(255, 255, 255, 0.7);
	font-size: 0.8125rem;
}

.footer-bottom {
	position: relative;
	padding: var(--space-md) var(--space-lg);
	border-top: 1px solid rgba(255, 255, 255, 0.2);
	background: rgba(0, 0, 0, 0.1);
}

.footer-copyright {
	max-width: 1200px;
	margin: 0 auto;
	text-align: center;
}

.footer-copyright p {
	color: rgba(255, 255, 255, 0.7);
	font-size: 0.875rem;
	margin: 0;
}

.footer-legal {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	color: rgba(255, 255, 255, 0.7);
	font-size: 0.875rem;
}

.footer-legal span:not(:last-child) {
	cursor: pointer;
	transition: color var(--transition-fast);
}

.footer-legal span:not(:last-child):hover {
	color: var(--accent-coral);
}

/* Entrance animations */
.footer-brand {
	animation: slideInFromBottom 0.8s ease forwards;
	opacity: 0;
	transform: translateY(30px);
}

.footer-column:nth-child(2) {
	animation: slideInFromBottom 0.8s ease forwards 0.2s;
	opacity: 0;
	transform: translateY(30px);
}

.footer-column:nth-child(3) {
	animation: slideInFromBottom 0.8s ease forwards 0.4s;
	opacity: 0;
	transform: translateY(30px);
}

@keyframes slideInFromBottom {
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Responsive Design */
@media (max-width: 1024px) {
	.footer-grid {
		grid-template-columns: 300px 180px 250px;
		justify-content: space-between;
	}

	.footer-logo {
		width: 140px;
	}

	.footer-description {
		font-size: 0.875rem;
	}
}

@media (max-width: 768px) {
	.footer-top {
		padding: var(--space-xl) var(--space-sm) var(--space-lg);
	}

	.footer-grid {
		grid-template-columns: 1fr;
		gap: var(--space-lg);
		text-align: center;
	}

	.footer-brand {
		align-items: center;
		text-align: center;
	}

	.footer-logo {
		width: 120px;
	}

	.footer-social {
		justify-content: center;
	}

	.footer-column h4::after {
		left: 50%;
		transform: translateX(-50%);
	}

	.footer-links {
		align-items: center;
	}

	.footer-contact {
		max-width: 350px;
		margin: 0 auto;
	}

	.footer-copyright {
		flex-direction: column;
		text-align: center;
		gap: var(--space-xs);
	}

	/* Reset animations on mobile for better performance */
	.footer-brand,
	.footer-column:nth-child(n) {
		animation: none;
		opacity: 1;
		transform: none;
	}
}

@media (max-width: 480px) {
	.footer-top {
		padding: var(--space-lg) var(--space-sm);
	}

	.footer-logo {
		width: 100px;
	}

	.footer-description {
		font-size: 0.8125rem;
	}

	.footer-column h4 {
		font-size: 1rem;
	}

	.social-link {
		width: 36px;
		height: 36px;
	}

	.social-icon {
		width: 16px;
		height: 16px;
	}

	.footer-legal {
		flex-direction: column;
		gap: var(--space-xs);
	}

	.credential-item {
		font-size: 0.8125rem;
	}

	.contact-item strong {
		font-size: 0.875rem;
	}

	.contact-item small {
		font-size: 0.75rem;
	}
}

/* ===================================
   ENHANCED UTILITY CLASSES
   =================================== */

/* Existing utilities are good, adding these enhancements: */

/* Additional Spacing Utilities */
.p-1 { padding: var(--space-xs); }
.p-2 { padding: var(--space-sm); }
.p-3 { padding: var(--space-md); }
.p-4 { padding: var(--space-lg); }
.p-5 { padding: var(--space-xl); }
.p-6 { padding: var(--space-2xl); }

.px-1 { padding-left: var(--space-xs); padding-right: var(--space-xs); }
.px-2 { padding-left: var(--space-sm); padding-right: var(--space-sm); }
.px-3 { padding-left: var(--space-md); padding-right: var(--space-md); }
.px-4 { padding-left: var(--space-lg); padding-right: var(--space-lg); }
.px-5 { padding-left: var(--space-xl); padding-right: var(--space-xl); }
.px-6 { padding-left: var(--space-2xl); padding-right: var(--space-2xl); }

.mx-1 { margin-left: var(--space-xs); margin-right: var(--space-xs); }
.mx-2 { margin-left: var(--space-sm); margin-right: var(--space-sm); }
.mx-3 { margin-left: var(--space-md); margin-right: var(--space-md); }
.mx-4 { margin-left: var(--space-lg); margin-right: var(--space-lg); }
.mx-5 { margin-left: var(--space-xl); margin-right: var(--space-xl); }
.mx-6 { margin-left: var(--space-2xl); margin-right: var(--space-2xl); }

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

/* Gap Utilities for Flexbox/Grid */
.gap-1 { gap: var(--space-xs); }
.gap-2 { gap: var(--space-sm); }
.gap-3 { gap: var(--space-md); }
.gap-4 { gap: var(--space-lg); }
.gap-5 { gap: var(--space-xl); }
.gap-6 { gap: var(--space-2xl); }

/* Width and Height Utilities */
.w-full { width: 100%; }
.w-auto { width: auto; }
.w-fit { width: fit-content; }
.w-screen { width: 100vw; }

.h-full { height: 100%; }
.h-auto { height: auto; }
.h-fit { height: fit-content; }
.h-screen { height: 100vh; }

.max-w-xs { max-width: 20rem; }
.max-w-sm { max-width: 24rem; }
.max-w-md { max-width: 28rem; }
.max-w-lg { max-width: 32rem; }
.max-w-xl { max-width: 36rem; }
.max-w-2xl { max-width: 42rem; }
.max-w-3xl { max-width: 48rem; }
.max-w-4xl { max-width: 56rem; }
.max-w-5xl { max-width: 64rem; }
.max-w-6xl { max-width: 72rem; }
.max-w-7xl { max-width: 80rem; }
.max-w-full { max-width: 100%; }

/* Position Utilities */
.relative { position: relative; }
.absolute { position: absolute; }
.fixed { position: fixed; }
.sticky { position: sticky; }
.static { position: static; }

/* Z-Index Utilities */
.z-0 { z-index: 0; }
.z-10 { z-index: 10; }
.z-20 { z-index: 20; }
.z-30 { z-index: 30; }
.z-40 { z-index: 40; }
.z-50 { z-index: 50; }

/* Flexbox Direction and Wrap */
.flex-row { flex-direction: row; }
.flex-col { flex-direction: column; }
.flex-row-reverse { flex-direction: row-reverse; }
.flex-col-reverse { flex-direction: column-reverse; }

.flex-wrap { flex-wrap: wrap; }
.flex-nowrap { flex-wrap: nowrap; }
.flex-wrap-reverse { flex-wrap: wrap-reverse; }

.flex-1 { flex: 1 1 0%; }
.flex-auto { flex: 1 1 auto; }
.flex-initial { flex: 0 1 auto; }
.flex-none { flex: none; }

.flex-grow { flex-grow: 1; }
.flex-shrink { flex-shrink: 1; }
.flex-shrink-0 { flex-shrink: 0; }

/* Grid Utilities */
.grid-cols-1 { grid-template-columns: repeat(1, minmax(0, 1fr)); }
.grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid-cols-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.grid-cols-6 { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.grid-cols-12 { grid-template-columns: repeat(12, minmax(0, 1fr)); }

.col-span-1 { grid-column: span 1 / span 1; }
.col-span-2 { grid-column: span 2 / span 2; }
.col-span-3 { grid-column: span 3 / span 3; }
.col-span-4 { grid-column: span 4 / span 4; }
.col-span-full { grid-column: 1 / -1; }

/* Border Radius Utilities */
.rounded-none { border-radius: 0; }
.rounded-sm { border-radius: var(--radius-sm); }
.rounded { border-radius: var(--radius-md); }
.rounded-md { border-radius: var(--radius-md); }
.rounded-lg { border-radius: var(--radius-lg); }
.rounded-xl { border-radius: var(--radius-xl); }
.rounded-2xl { border-radius: var(--radius-2xl); }
.rounded-full { border-radius: 9999px; }

/* Shadow Utilities */
.shadow-none { box-shadow: none; }
.shadow-sm { box-shadow: var(--shadow-sm); }
.shadow { box-shadow: var(--shadow-md); }
.shadow-md { box-shadow: var(--shadow-md); }
.shadow-lg { box-shadow: var(--shadow-lg); }
.shadow-xl { box-shadow: var(--shadow-xl); }

/* Background Utilities */
.bg-transparent { background-color: transparent; }
.bg-white { background-color: white; }
.bg-primary { background-color: var(--primary-blue); }
.bg-secondary { background-color: var(--secondary-blue); }
.bg-accent { background-color: var(--accent-coral); }
.bg-neutral-light { background-color: var(--neutral-light); }
.bg-neutral-medium { background-color: var(--neutral-medium); }

.bg-gradient-primary { background: var(--gradient-primary); }
.bg-gradient-accent { background: var(--gradient-accent); }

/* Overflow Utilities */
.overflow-hidden { overflow: hidden; }
.overflow-visible { overflow: visible; }
.overflow-scroll { overflow: scroll; }
.overflow-auto { overflow: auto; }
.overflow-x-hidden { overflow-x: hidden; }
.overflow-y-hidden { overflow-y: hidden; }
.overflow-x-scroll { overflow-x: scroll; }
.overflow-y-scroll { overflow-y: scroll; }

/* Cursor Utilities */
.cursor-pointer { cursor: pointer; }
.cursor-default { cursor: default; }
.cursor-not-allowed { cursor: not-allowed; }
.cursor-wait { cursor: wait; }
.cursor-text { cursor: text; }
.cursor-move { cursor: move; }

/* User Select Utilities */
.select-none { user-select: none; }
.select-text { user-select: text; }
.select-all { user-select: all; }
.select-auto { user-select: auto; }

/* Pointer Events */
.pointer-events-none { pointer-events: none; }
.pointer-events-auto { pointer-events: auto; }

/* Opacity Utilities */
.opacity-0 { opacity: 0; }
.opacity-25 { opacity: 0.25; }
.opacity-50 { opacity: 0.5; }
.opacity-75 { opacity: 0.75; }
.opacity-100 { opacity: 1; }

/* Transform Utilities */
.transform { transform: translateZ(0); }
.scale-0 { transform: scale(0); }
.scale-50 { transform: scale(0.5); }
.scale-75 { transform: scale(0.75); }
.scale-90 { transform: scale(0.9); }
.scale-95 { transform: scale(0.95); }
.scale-100 { transform: scale(1); }
.scale-105 { transform: scale(1.05); }
.scale-110 { transform: scale(1.1); }
.scale-125 { transform: scale(1.25); }
.scale-150 { transform: scale(1.5); }

.rotate-0 { transform: rotate(0deg); }
.rotate-1 { transform: rotate(1deg); }
.rotate-2 { transform: rotate(2deg); }
.rotate-3 { transform: rotate(3deg); }
.rotate-6 { transform: rotate(6deg); }
.rotate-12 { transform: rotate(12deg); }
.rotate-45 { transform: rotate(45deg); }
.rotate-90 { transform: rotate(90deg); }
.rotate-180 { transform: rotate(180deg); }

/* Transition Utilities */
.transition-none { transition: none; }
.transition-all { transition: all var(--transition-normal); }
.transition-fast { transition: all var(--transition-fast); }
.transition-slow { transition: all var(--transition-slow); }
.transition-colors { transition: color var(--transition-normal), background-color var(--transition-normal), border-color var(--transition-normal); }
.transition-opacity { transition: opacity var(--transition-normal); }
.transition-transform { transition: transform var(--transition-normal); }

/* Animation Utilities */
.animate-pulse {
	animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

.animate-bounce {
	animation: bounce 1s infinite;
}

.animate-spin {
	animation: spin 1s linear infinite;
}

@keyframes pulse {
	0%, 100% { opacity: 1; }
	50% { opacity: 0.5; }
}

/* Screen Reader Only */
.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* Focus Utilities */
.focus\:outline-none:focus { outline: none; }
.focus\:ring:focus { 
	outline: none;
	box-shadow: 0 0 0 3px rgba(101, 181, 218, 0.3);
}

.nav a:focus,
.footer-links a:focus {
    outline: none;
}

/* Hover Utilities */
.hover\:scale-105:hover { transform: scale(1.05); }
.hover\:scale-110:hover { transform: scale(1.1); }
.hover\:-translate-y-1:hover { transform: translateY(-0.25rem); }
.hover\:-translate-y-2:hover { transform: translateY(-0.5rem); }

/* Group Hover (for parent hover effects) */
.group:hover .group-hover\:scale-105 { transform: scale(1.05); }
.group:hover .group-hover\:opacity-100 { opacity: 1; }
.group:hover .group-hover\:opacity-0 { opacity: 0; }

/* Responsive Prefixes - Add these to any utility as needed */
@media (min-width: 640px) {
	.sm\:block { display: block; }
	.sm\:hidden { display: none; }
	.sm\:flex { display: flex; }
	.sm\:grid { display: grid; }
	.sm\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.sm\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (min-width: 768px) {
	.md\:block { display: block; }
	.md\:hidden { display: none; }
	.md\:flex { display: flex; }
	.md\:grid { display: grid; }
	.md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.md\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
	.md\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

@media (min-width: 1024px) {
	.lg\:block { display: block; }
	.lg\:hidden { display: none; }
	.lg\:flex { display: flex; }
	.lg\:grid { display: grid; }
	.lg\:grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
	.lg\:grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
	.lg\:grid-cols-5 { grid-template-columns: repeat(5, minmax(0, 1fr)); }
}