body {
	color: #1d1d1d;
	font-family: "Poppins", sans-serif;
}
a {
	color: #3b8aee;
	text-decoration: none;
}
.form-check-input:checked {
	background-color: #2f6ed5;
	border-color: #2f6ed5;
}
.form-select {
	border-radius: 10px;
}
.text-primary {
	color: #2f6ed5 !important;
}
.btn-mode {
	--bs-btn-bg: #3866ca;
	--bs-btn-color: var(--bs-tertiary-bg);
	border-radius: 25px;
}
.btn-outline-mode,
.btn-outline-secondary,
.btn-info,
.btn-outline-danger,
.btn-success {
	border-radius: 25px;
}
.btn-outline-primary {
	border: 1px solid #2f6ed5;
	color: #2f6ed5;
	border-radius: 25px;
}
.btn-outline-primary:hover,
.btn-outline-primary:active,
.btn-outline-primary:focus {
	border: 1px solid #2f6ed5;
	color: #ffffff;
	background-color: #2f6ed5 !important;
}
.btn-primary {
	background-color: #2f6ed5;
	border: 1px solid #2f6ed5;
	border-radius: 25px;
}
.btn-primary:hover,
.btn-primary:active,
.btn-primary:focus {
	background-color: #2c64bf !important;
	border: 1px solid #2c64bf !important;
}
.btn-secondary {
	border-radius: 25px;
}
.product-card-1 .product-price span {
	font-size: 28px;
	font-weight: 400;
}
.header-option-1 .header-top {
	padding: 5px 0px;
}
.toolbar-top {
	background-color: #f8f9fa;
	border-top: 1px solid #e6e6e6;
	border-bottom: 1px solid #e6e6e6;
}
.welcome-container {
	width: 100%;
	background: linear-gradient(135deg, #ffffff 0%, #f9f9f9 100%);
	border-radius: 20px;
	overflow: hidden;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08), 0 1px 3px rgba(0, 0, 0, 0.05), inset 0 1px 1px rgba(255, 255, 255, 0.7);
	display: flex;
	position: relative;
}

.welcome-content {
	padding: 40px;
	font-size: 15px;
	flex: 1;
	position: relative;
	z-index: 1;
}

.welcome-image {
	width: 350px;
	background-color: #f3f3f3;
	background-image: url("/assets/images/hp-group.jpg");
	background-size: cover;
	background-position: center;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
}

.welcome-badge {
	position: absolute;
	top: 20px;
	right: 20px;
	background: #fff;
	border-radius: 50px;
	padding: 8px 15px;
	font-size: 14px;
	font-weight: 600;
	color: #333;
	box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

.benefits {
	display: flex;
	gap: 20px;
	margin-bottom: 30px;
}

.benefit-item {
	display: flex;
	align-items: center;
	gap: 10px;
}

.benefit-icon {
	width: 32px;
	height: 32px;
	background-color: rgba(33, 37, 41, 0.1);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #212529;
	font-size: 16px;
}

.benefit-text {
	font-size: 14px;
	font-weight: 500;
	color: #495057;
}

.welcome-button {
	display: inline-block;
	background-color: #212529;
	color: white;
	border: none;
	padding: 12px 30px;
	border-radius: 50px;
	font-weight: 600;
	font-size: 16px;
	cursor: pointer;
	transition: all 0.3s ease;
	text-decoration: none;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

.welcome-button:hover {
	background-color: #000;
	transform: translateY(-2px);
	box-shadow: 0 6px 15px rgba(0, 0, 0, 0.15);
}

.discount-tag {
	position: absolute;
	bottom: 40px;
	left: 40px;
	background-color: #fff3cd;
	border-left: 4px solid #ffc107;
	padding: 12px 20px;
	border-radius: 8px;
	font-size: 15px;
	font-weight: 500;
	color: #664d03;
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
}

.discount-code {
	font-weight: 700;
	letter-spacing: 1px;
	margin-left: 5px;
}

.navbar-nav {
	--bs-nav-link-padding-x: 0;
	--bs-nav-link-padding-y: 0.5rem;
	--bs-nav-link-font-weight: ;
	--bs-nav-link-color: #000;
	--bs-nav-link-hover-color: var(--bs-navbar-hover-color);
	--bs-nav-link-disabled-color: var(--bs-navbar-disabled-color);
	display: flex;
	flex-direction: column;
	padding-left: 0;
	margin-bottom: 0;
	list-style: none;
	margin-left: 30px;
}

/* Parent clickable link */
.nav-toggle {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0.75rem 1rem;
	border-radius: 8px;
	font-weight: 500;
	color: #1a1a1a;
	transition: background 0.3s;
	text-decoration: none;
}
.shop-category-list .nav-link span {
	font-size: 15px;
	color: #2b2b2b;
}

.shop-category-list nav,
.nav .nav-link.active,
.shop-category-list .nav .nav .nav-link:hover {
	color: #1a73e8;
}

.nav-toggle:hover {
	background-color: #f7f7f7;
}

/* Collapse icon styling */
.collapse-icon {
	display: inline-block;
	position: relative;
	width: 12px;
	height: 12px;
	transition: all 0.3s ease;
}

.collapse-icon::before,
.collapse-icon::after {
	content: "";
	position: absolute;
	background-color: #1a73e8; /* modern blue */
	transition: all 0.3s ease;
}

.collapse-icon::before {
	width: 12px;
	height: 2px;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
}

.collapse-icon::after {
	width: 2px;
	height: 12px;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
}

/* Show minus on open */
.nav-toggle[aria-expanded="true"] .collapse-icon::after {
	transform: scaleY(0); /* hides vertical bar for minus */
}

/* Sub-items */
.sub-items {
	padding-left: 1.25rem;
	margin-top: 0.5rem;
}

.sub-items .nav-link {
	padding: 0.4rem 1rem;
	color: #333;
	text-decoration: none;
}

.sub-items .nav-link:hover {
	background-color: #f9f9f9;
	border-radius: 4px;
}
.nav-toggle[aria-expanded="true"] {
	background-color: #eef3fc;
	color: #1a73e8;
}
.shop-category-list .nav-link {
	padding: 10px;
	font-size: 20px;
}

/* Sidebar Category Active States */
.shop-category-list .nav-link {
	position: relative;
	padding: 0.75rem 1rem;
	color: #6c757d;
	text-decoration: none;
	border-radius: 0.375rem;
	transition: all 0.2s ease-in-out;
}

.shop-category-list .nav-link:hover {
	color: #495057;
	background-color: #f8f9fa;
}

/* Active parent category */
.shop-category-list .nav-link.active {
	color: #0d6efd;
	background-color: rgba(13, 110, 253, 0.1);
	font-weight: 600;
}

/* Active child category */
.shop-category-list .sub-items .nav-link.active {
	color: #0d6efd;
	background-color: rgba(13, 110, 253, 0.15);
	font-weight: 600;
	position: relative;
}

/* Add a small indicator for active child items */
.shop-category-list .sub-items .nav-link.active::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 3px;
	height: 20px;
	background-color: #0d6efd;
	border-radius: 0 2px 2px 0;
}

/* Collapse icon styles */
.collapse-icon {
	display: inline-block;
	transition: transform 0.2s ease-in-out;
}

/* Rotate icon animation (alternative to +/- if you prefer arrows) */
.nav-toggle[aria-expanded="true"] .collapse-icon {
	transform: rotate(180deg);
}

/* Sub-items styling */
.shop-category-list .sub-items {
	padding-left: 1rem;
	margin-top: 0.5rem;
	border-left: 2px solid #e9ecef;
}

.shop-category-list .sub-items .nav-link {
	padding: 0.5rem 1rem;
	font-size: 0.9em;
	position: relative;
}

.shop-category-list .sub-items .nav-link:hover {
	background-color: rgba(13, 110, 253, 0.05);
}

/* Breadcrumb-style active indicator */
/* .shop-category-list .nav-link.active::after {
	content: "";
	position: absolute;
	right: 1rem;
	top: 50%;
	transform: translateY(-50%);
	width: 0;
	height: 0;
	border-left: 6px solid #0d6efd;
	border-top: 4px solid transparent;
	border-bottom: 4px solid transparent;
} */

/* Remove the arrow for sub-items since they have the left border indicator */
.shop-category-list .sub-items .nav-link.active::after {
	display: none;
}

.radio-color .radio-color-label {
	border: 2px solid var(--bs-gray-300);
}

/* Smooth transitions for collapse */
.collapse {
	transition: height 0.3s ease;
}

/* Category count badges (optional - if you want to show product counts) */
.category-count {
	display: inline-block;
	padding: 0.25em 0.4em;
	font-size: 0.75em;
	font-weight: 700;
	line-height: 1;
	color: #6c757d;
	background-color: #e9ecef;
	border-radius: 0.375rem;
	margin-left: auto;
}

.nav-link.active .category-count {
	color: #0d6efd;
	background-color: rgba(13, 110, 253, 0.1);
}

.product-price {
	font-family: Arial, sans-serif;
	font-weight: bold;
}

.product-price .text-primary {
	color: #333 !important; /* Dark gray/black color */
	font-size: 2.5rem; /* Large font size */
	font-weight: 500;
	line-height: 1;
}

.product-price .text-primary small {
	font-size: 1.1rem; /* Smaller but still readable */
	vertical-align: top;
	font-weight: 500;
	margin-left: 2px;
	position: relative;
	top: 0.2rem;
}

/* For the main product page price */
.product-detail .product-price {
	margin-bottom: 1rem;
}

.product-detail .product-price .text-primary {
	font-size: 2rem; /* Even larger on product page */
}

.product-detail .product-price .text-primary small {
	font-size: 0.9rem;
}

/* Alternative compact version for product cards */
.product-card .product-price .text-primary {
	font-size: 1.8rem;
	color: #333 !important;
}

.product-card .product-price .text-primary small {
	font-size: 0.9rem;
}

/* Remove any default Bootstrap small styling */
.product-price small {
	font-weight: inherit;
}

/* Range pricing styling */
.product-price .price-range {
	font-size: 0.8rem;
	color: #666;
	font-weight: normal;
	margin-top: 0.25rem;
}

/* Mobile responsive adjustments */
@media (max-width: 991.98px) {
	.shop-category-list .nav-link {
		padding: 1rem;
		border-bottom: 1px solid #e9ecef;
		border-radius: 0;
	}

	.shop-category-list .sub-items {
		border-left: none;
		padding-left: 0;
		background-color: #f8f9fa;
	}

	.shop-category-list .sub-items .nav-link {
		padding-left: 2rem;
	}
}

/* Focus states for accessibility */
.shop-category-list .nav-link:focus {
	outline: 2px solid #0d6efd;
	outline-offset: 2px;
}

/* Loading state (optional) */
.shop-category-list.loading {
	opacity: 0.6;
	pointer-events: none;
}

/* Alternative style: Card-based categories */
.shop-sidebar-block.card-style .nav-item {
	margin-bottom: 0.5rem;
}

.shop-sidebar-block.card-style .nav-link {
	border: 1px solid #e9ecef;
	background-color: #fff;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.shop-sidebar-block.card-style .nav-link.active {
	border-color: #0d6efd;
	box-shadow: 0 2px 6px rgba(13, 110, 253, 0.2);
}

@media (max-width: 768px) {
	.welcome-container {
		flex-direction: column;
	}

	.welcome-image {
		width: 100%;
		height: 200px;
	}

	.benefits {
		flex-direction: column;
		gap: 15px;
	}
}
/* ACTUAL SOLUTION: Use img tag instead of background */
.welcome-container-fixed {
	background: white;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
	position: relative;
}

.welcome-image-wrapper {
	width: 100%;
	text-align: center;
	background-color: #f8f9fa;
	padding: 2rem 1rem;
	position: relative;
}

.welcome-image-actual {
	max-width: 100%;
	height: auto;
	border-radius: 8px;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

/* Alternative: Proper background positioning */
.welcome-container-bg-fixed {
	background: white;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
	position: relative;
}

.welcome-image-bg-proper {
	width: 100%;
	height: 300px;
	background-image: url("/assets/images/hp-group.jpg");
	background-size: auto 100%; /* This will show full height, may add letterboxing */
	background-repeat: no-repeat;
	background-position: center;
	background-color: #f8f9fa;
	position: relative;
}

/* Third option: Taller container to accommodate full image */
.welcome-container-tall {
	background: white;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
	position: relative;
}

.welcome-image-full-height {
	width: 100%;
	height: 500px; /* Much taller to accommodate full team */
	background-image: url("/assets/images/hp-group.jpg");
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center top; /* Focus on showing faces */
	position: relative;
}

.welcome-content-spacious {
	padding: 3rem;
}

.welcome-eyebrow {
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	color: #6b7280;
	margin-bottom: 1rem;
}

.welcome-title {
	font-size: 2.25rem;
	font-weight: 600;
	color: #1f2937;
	margin-bottom: 1rem;
	line-height: 1.2;
}

.welcome-description {
	font-size: 1rem;
	color: #6b7280;
	line-height: 1.6;
	margin-bottom: 2rem;
}

.welcome-features {
	display: flex;
	gap: 2rem;
	margin-bottom: 2rem;
	flex-wrap: wrap;
}

.feature-item {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.feature-icon {
	width: 16px;
	height: 16px;
	background-color: #10b981;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.feature-icon::after {
	content: "✓";
	color: white;
	font-size: 10px;
	font-weight: bold;
}

.feature-text {
	font-size: 0.875rem;
	color: #374151;
	font-weight: 500;
}

.welcome-cta {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	background-color: #1f2937;
	color: white;
	text-decoration: none;
	padding: 0.875rem 1.75rem;
	border-radius: 6px;
	font-weight: 500;
	font-size: 0.875rem;
	transition: all 0.2s ease;
	align-self: flex-start;
}

.welcome-cta:hover {
	background-color: #111827;
	color: white;
	transform: translateY(-1px);
}

.promo-badge {
	position: absolute;
	top: 1.5rem;
	right: 1.5rem;
	background: linear-gradient(135deg, #fbbf24, #f59e0b);
	color: #92400e;
	padding: 0.5rem 1rem;
	border-radius: 20px;
	font-size: 0.75rem;
	font-weight: 600;
	z-index: 3;
	box-shadow: 0 4px 12px rgba(251, 191, 36, 0.3);
}

/* Demo layout */
.demo-layout {
	display: flex;
	gap: 2rem;
	max-width: 1200px;
	margin: 0 auto;
}

.demo-sidebar {
	flex: 0 0 250px;
	background: white;
	border-radius: 12px;
	padding: 1.5rem;
	height: fit-content;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}

.demo-main {
	flex: 1;
}

.layout-option {
	margin-bottom: 3rem;
}

.layout-title {
	font-size: 1.125rem;
	font-weight: 600;
	color: #1f2937;
	margin-bottom: 1rem;
	background: #f3f4f6;
	padding: 0.5rem 1rem;
	border-radius: 6px;
}

.recommended {
	background: #ecfdf5;
	border: 2px solid #10b981;
}

/* Mobile responsive */
@media (max-width: 768px) {
	.welcome-image-full-height {
		height: 400px;
	}

	.welcome-features {
		flex-direction: column;
		gap: 1rem;
	}

	.welcome-content-spacious {
		padding: 2rem;
	}
}

/* --- Vexels-Inspired Clean Theme --- */

/* 1. Global Typography & Spacing */
.demo-main {
	display: flex;
	flex-direction: column;
	gap: 40px; /* Space between major sections */
}

h2.section-title {
	font-size: 2rem;
	font-weight: 800;
	text-align: center;
	margin-bottom: 30px;
	color: #1a1a1a;
	letter-spacing: -0.5px;
}

/* 2. The Clean Hero Section (Like the bottom "Fast Track" section) */
/* --- Clean Hero Section (White & Big Image) --- */
/* --- Vexels-Style Centered Hero --- */
.hero-section-centered {
	padding: 0px 0 20px 0; /* Top padding for breathing room */
	text-align: center;
	max-width: 100%;
}

/* 1. The Text Block */
.hero-text-block {
	max-width: 800px;
	margin: 0 auto 50px auto; /* Centers text and adds gap before image */
	padding: 0 20px;
}

.hero-eyebrow {
	display: block;
	font-size: 0.9rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 2px;
	color: #999;
	margin-bottom: 15px;
}

.hero-title-large {
	font-size: 3.5rem; /* Big, bold headline like Vexels */
	font-weight: 700;
	color: #1a1a1a;
	line-height: 1.2;
	margin-bottom: 20px;
}

.hero-description {
	font-size: 1.5rem;
	color: #323232;
	line-height: 1.6;
	margin-bottom: 35px;
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
}

/* 2. The "Vexels Style" Button */
.btn-black-pill {
	display: inline-block;
	background-color: #1a1a1a; /* Dark black/charcoal */
	color: #ffffff;
	padding: 18px 50px;
	border-radius: 50px;
	font-weight: 600;
	font-size: 1.1rem;
	text-decoration: none;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
	box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
}

.btn-black-pill:hover {
	transform: translateY(-3px);
	box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
	background-color: #000;
	color: #fff;
}

/* 3. The Full Width Image Container */
.hero-image-full {
	width: 100%;
	position: relative;
	border-radius: 20px;
	border: 1px solid #e2e8f0;
	box-shadow: 0 10px 30px -10px rgba(0, 0, 0, 0.08);
	overflow: hidden;
	margin-top: 40px;
	line-height: 0;
}
.hero-image-full img {
	width: 100%;
	height: auto;
	display: block;
	/* If your image is small, this limits it so it doesn't pixelate, 
       but "100%" width will stretch it to fill the container */
	max-width: 100%;
}

/* Mobile Adjustments */
@media (max-width: 768px) {
	.hero-title-large {
		font-size: 2.5rem;
	}
	.hero-text-block {
		margin-bottom: 30px;
	}
}

/* 3. The Feature Cards (Like top "Why Subscribe" section) */
.feature-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 20px;
}

.feature-card {
	background-color: #f8f9fa; /* Matches Vexels card color */
	padding: 40px 30px;
	border-radius: 16px;
	text-align: center;
	transition: transform 0.3s ease;
}

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

.feature-icon-wrapper {
	width: 50px;
	height: 50px;
	margin: 0 auto 20px auto;
	color: #1a1a1a;
}

.feature-card h3 {
	font-size: 1.1rem;
	font-weight: 700;
	margin-bottom: 12px;
	color: #000;
	line-height: 1.4;
}

.feature-card p {
	font-size: 0.9rem;
	color: #666;
	line-height: 1.5;
	margin: 0;
}

/* 4. The Dark CTA Strip (Like middle "Gain Exclusive Access" section) */
.dark-cta-strip {
	background-color: #1a1a1a;
	border-radius: 16px;
	padding: 40px 50px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 20px;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
}

.dark-cta-content {
	flex: 1;
	min-width: 300px;
}

.dark-cta-content h2 {
	color: #ffffff;
	font-size: 2rem;
	font-weight: 800;
	margin-bottom: 10px;
}

.dark-cta-content p {
	color: #cccccc;
	font-size: 1rem;
	margin: 0;
}

.btn-cta-blue {
	background-color: #3b8aee; /* Brand Blue */
	color: #ffffff;
	padding: 14px 35px;
	border-radius: 50px;
	font-weight: 600;
	font-size: 1rem;
	white-space: nowrap;
	transition: all 0.2s ease;
	border: none;
	box-shadow: 0 4px 15px rgba(59, 138, 238, 0.4);
}

.btn-cta-blue:hover {
	background-color: #2f6ed5;
	transform: scale(1.02);
	color: white;
}

/* Desktop override for Hero */
@media (min-width: 992px) {
	.clean-hero {
		flex-direction: row;
		align-items: center;
		min-height: 400px;
	}
	.clean-hero-image {
		height: 100%;
		min-height: 400px;
	}
}

/* --- Clean FAQ Section (Vexels Style) --- */

.clean-faq-section {
	padding: 20px 0;
	max-width: 100%;
}

.faq-header {
	text-align: center;
	margin-bottom: 50px;
}

.faq-header h2 {
	font-size: 2.2rem;
	font-weight: 800;
	color: #1a1a1a;
	margin-bottom: 10px;
}

.faq-header p {
	color: #666;
	font-size: 1.1rem;
}

/* The Grid Layout */
.faq-grid {
	display: block; /* Disables the rigid grid row structure */
	column-count: 2; /* Creates two independent flowing columns */
	column-gap: 20px;
}

/* Individual FAQ Item */
.faq-item {
	break-inside: avoid; /* Prevents a box from being split between columns */
	margin-bottom: 20px; /* Adds vertical spacing between items */
	/* Ensure the existing styles are maintained */
	background: #fff;
	border: 1px solid #e5e7eb;
	border-radius: 16px;
	overflow: hidden;
	transition: all 0.3s ease;
}

.faq-item:hover {
	border-color: #b0b0b0;
}

/* The Question Button */
.faq-question {
	width: 100%;
	background: none;
	border: none;
	padding: 20px 25px;
	text-align: left;
	display: flex;
	justify-content: space-between;
	align-items: center;
	cursor: pointer;
	font-family: "Poppins", sans-serif;
	font-size: 1rem;
	font-weight: 600;
	color: #1a1a1a;
}

/* The Plus Icon */
.faq-icon {
	font-size: 1.5rem;
	font-weight: 400;
	color: #1a1a1a;
	transition: transform 0.3s ease;
	line-height: 1;
}

/* The Answer (Hidden by default) */
.faq-answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.3s ease-out;
	padding: 0 25px;
	opacity: 0;
}

.faq-answer p {
	padding-bottom: 25px;
	color: #555;
	line-height: 1.6;
	margin: 0;
	font-size: 0.95rem;
}

/* Active State (When clicked) */
.faq-item.active {
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
	border-color: #3b8aee; /* Highlight color */
}

.faq-item.active .faq-icon {
	transform: rotate(45deg); /* Turns plus to X */
	color: #3b8aee;
}

.faq-item.active .faq-answer {
	opacity: 1;
	/* max-height is handled by JS */
}

/* Mobile: Stack to 1 column */
@media (max-width: 768px) {
	.faq-grid {
		column-count: 1;
	}
}
/* --- New "View All" Button Style --- */
.btn-faq-black {
	display: inline-block;
	background-color: #000000;
	color: #ffffff !important; /* Force white text */
	padding: 14px 35px;
	border-radius: 50px;
	font-weight: 600;
	font-size: 1rem;
	text-decoration: none;
	transition: all 0.2s ease;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

.btn-faq-black:hover {
	background-color: #333333;
	transform: translateY(-2px);
	box-shadow: 0 6px 15px rgba(0, 0, 0, 0.15);
}

/* Container */
.features-section-container {
	padding-bottom: 30px;
	max-width: 100%;
	position: relative;
}

.swiper.featuresSwiper {
	padding-bottom: 40px; /* Space for dots */
}

/* The "Split" Card Style */

/* =========================================
   2. CARD STYLING (Mobile First)
   ========================================= */
.feature-split-card {
	background: #ffffff;
	border-radius: 20px;
	overflow: hidden; /* Keeps image corners rounded */
	display: flex;
	flex-direction: column; /* Mobile: Stack Image on top of Text */
	border: 1px solid #f0f0f0;
	height: auto;

	margin: 0 auto;
	transition: transform 0.3s ease;
}

/* Hover Effect: Zoom Image */
.feature-split-card:hover .split-image img {
	transform: scale(1.05);
}

/* =========================================
   3. IMAGE SIDE
   ========================================= */
.split-image {
	width: 100%;
	height: 250px; /* Mobile height */
	overflow: hidden;
	position: relative;
}

.split-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s ease;
}

/* =========================================
   4. CONTENT SIDE (Text & Icon)
   ========================================= */
.split-content {
	background: #fff;
	padding: 30px 25px;
	width: 100%;

	/* Vertical Centering Logic */
	display: flex;
	flex-direction: column;
	justify-content: center; /* Vertically center content */
	align-items: flex-start; /* Horizontally left-align */
	height: 100%;
}

/* Clean Icon - No Background Box */
.split-icon-box {
	background: transparent;
	padding: 0;
	margin-bottom: 15px;
	color: #2f6ed5; /* Brand Blue */
	display: block;
	line-height: 1;
}

.split-icon-box svg {
	width: 36px;
	height: 36px;
	display: inline-flex;
	margin-bottom: 0; /* Remove the bottom margin since it's inline now */
}

/* Typography */
.split-content h3 {
	font-size: 1.5rem;
	font-weight: 700;
	margin-bottom: 12px;
	color: #1a1a1a;
	display: inline-flex;
	align-items: baseline; /* Changed from center */
	gap: 12px;
}

.split-content p {
	font-size: 1rem;
	color: #666;
	line-height: 1.6;
	margin-bottom: 0;
}

/* =========================================
   5. NAVIGATION ARROWS (The Fix)
   ========================================= */
.swiper-button-next,
.swiper-button-prev {
	width: 50px;
	height: 50px;
	background-color: #ffffff;
	border-radius: 50%;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
	color: #2f6ed5;
	border: 1px solid #e5e7eb;
	transition: all 0.3s ease;
	z-index: 20;
	display: flex;
	align-items: center;
	justify-content: center;

	/* Mobile: HIDE arrows (Swipe is better) */
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
}

.swiper-button-next:after,
.swiper-button-prev:after {
	font-size: 20px;
	font-weight: bold;
}

/* =========================================
   6. DESKTOP MEDIA QUERY (Min-width: 992px)
   ========================================= */
@media (min-width: 992px) {
	/* Create 'Gutters' for arrows */

	/* Switch Card to Row Layout */
	.feature-split-card {
		flex-direction: row;
		height: 380px; /* Fixed height for clean alignment */
	}

	.split-image {
		width: 50%;
		height: 100%;
	}

	.split-content {
		width: 50%;
		padding: 40px 50px; /* More breathing room */
	}

	/* Show and Position Arrows */
	.swiper-button-next,
	.swiper-button-prev {
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
		top: 50%;
		transform: translateY(-50%); /* Perfect vertical center */
	}

	.swiper-button-prev {
		left: 20px;
	}
	.swiper-button-next {
		right: 20px;
	}

	/* Arrow Hover */
	.swiper-button-next:hover,
	.swiper-button-prev:hover {
		background-color: #2f6ed5;
		color: #ffffff;
		transform: translateY(-50%) scale(1.1); /* Keep vertical center + grow */
		border-color: #2f6ed5;
	}
}
