/* ---------------------------------------------- */
/* TYPOGRAPHY - FIXED FOR CROSS-PLATFORM CONSISTENCY
/* ---------------------------------------------- */

@font-face {
	font-family: "Gilroy";
	src: url("../webfonts/Gilroy-Light.eot");
	src: url("../webfonts/Gilroy-Light%EF%B9%96.eot#iefix")
			format("embedded-opentype"),
		url("../webfonts/Gilroy-Light.woff2") format("woff2"),
		url("../webfonts/Gilroy-Light.woff") format("woff"),
		url("../webfonts/Gilroy-Light.ttf") format("truetype"),
		url("../webfonts/Gilroy-Light.svg#Gilroy-Light") format("svg");
	font-weight: 300;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Gilroy";
	src: url("../webfonts/Gilroy-Medium.eot");
	src: url("../webfonts/Gilroy-Medium%EF%B9%96.eot#iefix")
			format("embedded-opentype"),
		url("../webfonts/Gilroy-Medium.woff2") format("woff2"),
		url("../webfonts/Gilroy-Medium.woff") format("woff"),
		url("../webfonts/Gilroy-Medium.ttf") format("truetype"),
		url("../webfonts/Gilroy-Medium.svg#Gilroy-Medium") format("svg");
	font-weight: 500;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Gilroy";
	src: url("../webfonts/Gilroy-Bold.eot");
	src: url("../webfonts/Gilroy-Bold%EF%B9%96.eot#iefix")
			format("embedded-opentype"),
		url("../webfonts/Gilroy-Bold.woff2") format("woff2"),
		url("../webfonts/Gilroy-Bold.woff") format("woff"),
		url("../webfonts/Gilroy-Bold.ttf") format("truetype"),
		url("../webfonts/Gilroy-Bold.svg#Gilroy-Bold") format("svg");
	font-weight: 700;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Gilroy";
	src: url("../webfonts/Gilroy-ExtraBold.eot");
	src: url("../webfonts/Gilroy-ExtraBold%EF%B9%96.eot#iefix")
			format("embedded-opentype"),
		url("../webfonts/Gilroy-ExtraBold.woff2") format("woff2"),
		url("../webfonts/Gilroy-ExtraBold.woff") format("woff"),
		url("../webfonts/Gilroy-ExtraBold.ttf") format("truetype"),
		url("../webfonts/Gilroy-ExtraBold.svg#Gilroy-ExtraBold") format("svg");
	font-weight: 800;
	font-style: normal;
	font-display: swap;
}

/* CSS Variables */
:root {
	/* Colors */
	--primary: #1d75a8;
	--primary-hover: #0d4667;
	--black: #000000;
	--white: #ffffff;
	--dark-grey: #1d1d1b;
	--light-grey: #c0c0c0;
	--error-color: #dc3545;
	--star-color: #ffd700;

	/* Typography - Fixed for cross-platform consistency */
	--font-family: "Gilroy", -apple-system, BlinkMacSystemFont, "Segoe UI", Arial,
		sans-serif;
	--font-weight-light: 300;
	--font-weight-medium: 500;
	--font-weight-bold: 700;
	--font-weight-extrabold: 800;

	/* Font Sizes */
	--font-sm: 16px;
	--font-base: 18px;
	--font-lg: 24px;
	--font-xl: 30px;
	--font-xxl: 60px;

	/* Spacing */
	--space-sm: 10px;
	--space-md: 20px;
	--space-lg: 40px;
	--space-xl: 80px;

	/* Layout */
	--radius: 8px;
	--radius-circle: 50%;
	--container-sm: 680px;
	--container-md: 800px;
	--container-lg: 1280px;

	/* Transitions */
	--transition: 0.3s ease;
	--transition-smooth: 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	--transition-bounce: 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
	--transition-exit: 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);

	/* Modal specific */
	--modal-overlay-bg: rgba(0, 0, 0, 0.6);
	--modal-bg-overlay: rgba(0, 0, 0, 0.6);
	--modal-text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.8);
	--modal-backdrop-filter: blur(2px);

	/* Font rendering improvements */
	--font-smoothing: antialiased;
	--moz-font-smoothing: grayscale;

	--swiper-theme-color: var(--primary);
	--swiper-navigation-size: 44px;
}

/* Prevent horizontal scroll and content shifting on mobile */
html,
body {
	overflow-x: hidden;
	width: 100%;
	box-sizing: border-box;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

img,
.container,
.intro,
.modal,
.swiper,
.swiper-slide {
	max-width: 100%;
	box-sizing: border-box;
}

/* ==========================================================================
   FONT RENDERING IMPROVEMENTS
   ========================================================================== */

* {
	-webkit-font-smoothing: var(--font-smoothing);
	-moz-osx-font-smoothing: var(--moz-font-smoothing);
	text-rendering: optimizeLegibility;
}

/* Specific improvements for Windows Chrome */
@media screen and (-webkit-min-device-pixel-ratio: 0) {
	body {
		-webkit-text-stroke: 0.01em transparent;
	}
}

/* ==========================================================================
   BASE STYLES
   ========================================================================== */

body {
	background-color: var(--black);
	margin: 0;
	padding: 0;
	font-family: var(--font-family);
	font-weight: var(--font-weight-extrabold);
	text-align: -webkit-center;
}

h1,
h2,
h3,
h4,
p {
	color: var(--white);
	line-height: 1.3;
	margin: 0;
}

h1 {
	font-family: var(--font-family);
	font-weight: var(--font-weight-extrabold);
	font-size: var(--font-xxl);
	max-width: var(--container-md);
	text-align: center;
	margin-bottom: var(--space-xl);
}

h2 {
	font-family: var(--font-family);
	font-weight: var(--font-weight-extrabold);
	font-size: var(--font-xl);
	text-align: center;
}

h3 {
	font-size: var(--font-lg);
	margin-bottom: var(--space-sm);
}

p {
	font-family: var(--font-family);
	font-weight: var(--font-weight-extrabold);
	font-size: var(--font-base);
	max-width: var(--container-md);
	text-align: center;
}

.container {
	max-width: var(--container-lg);
	place-self: center;
}

.info-text {
	max-width: var(--container-lg);
	place-self: center;
	padding: var(--space-lg) 0;
}

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

.highlighted {
	color: var(--primary);
}

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

.line-gap {
	margin-bottom: var(--space-sm);
}

.line-biggap {
	margin-bottom: var(--space-lg);
}

.mobile-hide {
	display: block;
}

.emphasis {
	font-family: var(--font-family);
	font-weight: var(--font-weight-extrabold);
	font-size: var(--font-xxl);
	max-width: var(--container-lg);
	text-align: center;
}

.email {
	font-size: var(--font-lg);
	font-family: var(--font-family);
	font-weight: var(--font-weight-light);
	padding: var(--space-md);
}

a.mainlink {
	color: var(--white);
	font-family: var(--font-family);
	font-weight: var(--font-weight-extrabold);
	text-decoration: none;
	transition: var(--transition);
}

a.mainlink:hover {
	color: var(--primary);
}

section {
	text-align: -webkit-center;
}

.section-spacing {
	margin: var(--space-lg) 0;
}

/* ==========================================================================
   ANIMATIONS
   ========================================================================== */

.fade-in {
	opacity: 0;
	transform: translateY(10px);
	transition: opacity 1s ease, transform 1s ease;
}

.fade-in.visible {
	opacity: 1;
	transform: translateY(0);
}

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

/* ==========================================================================
   HEADER SECTION
   ========================================================================== */

.header,
.info-bar {
	max-width: var(--container-lg);
	justify-self: center;
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	width: 100%;
}

.header {
	padding: var(--space-lg) 0 100px 0;
}

.info-bar {
	padding: var(--space-lg) 0px;
}

.header div,
.info-bar div {
	display: flex;
	flex-direction: row;
	color: var(--white);
	font-size: var(--font-xl);
	font-family: var(--font-family);
	font-weight: var(--font-weight-light);
	align-items: center;
}

.info-bar div {
	gap: 10px;
}

.header img {
	width: 140px;
	margin-right: var(--space-md);
}
/* ==========================================================================
   INTRO SECTION
   ========================================================================== */

.intro {
	background-image: linear-gradient(to top, var(--black) 0%, transparent 15%),
		url(../images/USC-HCLP-BG.jpg);
	background-position: top right;
	background-size: cover;
	background-repeat: no-repeat;
	padding-bottom: var(--space-xl);
	margin-bottom: calc(var(--space-xl) * -1);
}

.intro .container {
	padding: var(--space-sm) var(--space-xl);
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.arc-top {
	max-width: 1600px;
	width: 100%;
}

/* ==========================================================================
   FORM STYLES
   ========================================================================== */

.multi-step-form-container {
	max-width: var(--container-sm);
	width: 100%;
}

/* Form Step Visibility Controls */
.form-step {
	display: none;
	opacity: 0;
	transform: translateY(20px);
	transition: opacity var(--transition), transform var(--transition);
	gap: 15px;
	flex-direction: row;
}

.form-step.active {
	display: flex;
	opacity: 1;
	transform: translateY(0);
	height: auto;
}

.form-step.completed {
	display: none;
}

/* Input Styles */
.form-step .input-container {
	position: relative;
	width: 100%;
}

.form-step .input-container input {
	background-color: var(--dark-grey);
	border: 2px solid var(--primary);
	border-radius: var(--radius);
	color: var(--white);
	padding: 26px 26px var(--space-sm) 26px;
	width: 100%;
	font-size: var(--font-base);
	font-family: var(--font-family);
	font-weight: var(--font-weight-medium);
	transition: var(--transition);
}

.form-step .input-container input:focus,
.form-step .input-container input:not(:placeholder-shown) {
	outline: 2px solid var(--white);
}

.form-step .input-container input.error {
	border-color: var(--error-color);
	outline-color: var(--error-color);
}

/* Label Styles */
.form-step .input-container label {
	position: absolute;
	left: var(--space-sm);
	top: 15px;
	font-family: var(--font-family);
	font-weight: var(--font-weight-extrabold);
	font-size: var(--font-lg);
	color: var(--light-grey);
	white-space: nowrap;
	transition: var(--transition);
	background-color: var(--dark-grey);
	padding: 0 var(--space-sm);
	pointer-events: none;
}

.form-step .input-container label .light {
	font-family: var(--font-family);
	font-weight: var(--font-weight-light);
}

.form-step .input-container input:focus + label,
.form-step .input-container input:not(:placeholder-shown) + label {
	top: 7px;
	left: 17px;
	font-size: var(--font-sm);
	color: var(--primary);
}

.form-step .input-container input.error + label {
	color: var(--error-color);
}

/* Error Messages */
.error-message {
	color: var(--error-color);
	font-size: var(--font-sm);
	font-family: var(--font-family);
	font-weight: var(--font-weight-extrabold);
	margin-top: var(--space-sm);
	opacity: 0;
	transform: translateY(-10px);
	transition: var(--transition);
	text-align: left;
	margin-left: 20px;
	position: absolute;
}

.error-message.show {
	opacity: 1;
	transform: translateY(0);
}

/* Button Styles */
.form-step button {
	border: none;
	border-radius: var(--radius);
	background-color: var(--primary);
	color: var(--white);
	transition: var(--transition);
	text-transform: capitalize;
	height: 61px;
	font-size: var(--font-lg);
	font-family: var(--font-family);
	font-weight: var(--font-weight-extrabold);
	min-width: 220px;
	z-index: 10;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-sm);
}

.form-step button:hover {
	background-color: var(--primary-hover);
}

.form-step button .fas {
	font-size: 22px;
}

/* Thank You Message */
.thank-you-message {
	display: none;
	opacity: 0;
	text-align: center;
	padding: var(--space-sm) var(--space-lg);
	color: var(--white);
	transition: var(--transition);
	background-color: var(--primary);
	border-radius: var(--radius);
	margin: var(--space-sm);
	font-size: var(--font-lg);
	font-family: var(--font-family);
	font-weight: var(--font-weight-medium);
}

.thank-you-message.active {
	display: block;
	opacity: 1;
}

/* ==========================================================================
   SOCIAL ICONS
   ========================================================================== */

.social {
	display: flex;
	flex-direction: row;
	justify-content: center;
	gap: var(--space-lg);
	margin-top: var(--space-lg);
	margin-bottom: var(--space-xl);
}

.social i {
	font-size: 45px;
	background-color: var(--primary);
	padding: 16px;
	border-radius: var(--radius-circle);
}

.icons {
	display: flex;
	flex-direction: column;
	text-align: center;
	font-size: var(--font-sm);
	font-family: var(--font-family);
	font-weight: var(--font-weight-medium);
	color: var(--white);
	gap: var(--space-sm);
	text-decoration: none;
}

.icons:hover {
	transform: scale(1.1);
}

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

.faq-section {
	counter-reset: accordion-counter;
	padding: var(--space-lg) 0 0 0;
}

.faq-section .container {
	width: 100%;
}

.faq-title {
	text-align: center;
	margin-bottom: var(--space-lg);
	color: var(--white);
}

.accordion {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
	max-width: var(--container-lg);
	margin: 0 auto;
}

.accordion details {
	background-color: var(--dark-grey);
	border-radius: var(--radius);
	overflow: hidden;
	transition: var(--transition);
	border: 2px solid transparent;
}

.accordion details[open],
.accordion details:hover {
	border: 2px solid var(--primary);
}

.accordion summary {
	color: var(--white);
	font-size: var(--font-lg);
	font-family: var(--font-family);
	font-weight: var(--font-weight-light);
	padding: var(--space-sm) var(--space-lg);
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	list-style: none;
	position: relative;
	transition: var(--transition);
}

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

.accordion summary::after {
	content: "\f054";
	font-family: "Font Awesome 6 Free";
	font-weight: 700;
	color: var(--primary);
	font-size: var(--font-xl);
	margin-left: auto;
	transition: var(--transition);
}

.accordion details[open] summary::after {
	transform: rotate(90deg);
}

details.opening summary {
	color: var(--primary);
}

details .content {
	display: block !important;
	max-height: 0;
	overflow: hidden;
	transition: max-height var(--transition-smooth), opacity 0.4s ease-out;
	opacity: 0;
	text-align: left;
	padding: var(--space-sm) var(--space-lg) var(--space-md) var(--space-lg);
	transition: max-height var(--transition-smooth), opacity 0.4s ease-out;
}

details.opening .content {
	max-height: fit-content;
	opacity: 1;
}

.accordion .content p {
	font-family: var(--font-family);
	font-weight: var(--font-weight-light);
	color: var(--white);
	font-size: var(--font-base);
	line-height: 1.6;
	text-align: left;
	max-width: none;
}

.accordion .content b {
	color: var(--primary);
}

/* ==========================================================================
   MODAL STYLES - SIMPLIFIED (NO CONFLICTING ANIMATIONS)
   ========================================================================== */

.modal-overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0);
	display: flex;
	justify-content: center;
	align-items: center;
	opacity: 0;
	visibility: hidden;
	transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	z-index: 1000;
	backdrop-filter: blur(0px);
}

.modal-overlay.active {
	opacity: 1;
	visibility: visible;
	background: var(--modal-overlay-bg);
	backdrop-filter: blur(8px);
}

.modal {
	background-image: none !important;
	display: flex;
	flex-direction: column;
	background-size: contain !important;
	background-position: center;
	background-repeat: no-repeat !important;
	position: relative;
	background: var(--dark-grey);
	border-radius: var(--radius);
	max-width: 700px;
	width: 100%;
	padding: var(--space-lg);
	height: auto;
	overflow-y: auto;
	transform: scale(0.7) translateY(50px);
	transition: all var(--transition-bounce);
	box-shadow: 0 0 0 rgba(0, 0, 0, 0);
	border: 2px solid var(--primary);
	opacity: 0;
	will-change: transform, opacity;
}

/* Modal background overlay for text readability */
.modal::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	backdrop-filter: var(--modal-backdrop-filter);
	z-index: -1;
	background: linear-gradient(
		135deg,
		var(--modal-bg-overlay) 0%,
		rgba(0, 0, 0, 0.4) 50%,
		var(--modal-bg-overlay) 100%
	);
	opacity: 0;
	transition: opacity 0.3s ease-in-out 0.2s;
}

.modal-overlay.active .modal {
	transform: scale(1) translateY(0);
	opacity: 1;
	box-shadow: 0 25px 50px rgba(0, 0, 0, 0.5);
}

.modal-overlay.active .modal::before {
	opacity: 1;
}

/* Modal Content - Let fade-in handle animations */

.modal-close {
	position: absolute;
	top: 20px;
	right: 20px;
	background: rgba(29, 29, 27, 0.9);
	border: 2px solid var(--primary);
	color: var(--primary);
	width: 45px;
	height: 45px;
	border-radius: var(--radius);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 35px;
	font-family: var(--font-family);
	font-weight: var(--font-weight-light);
	transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	opacity: 0;
	z-index: 10;
}

.modal-overlay.active .modal-close {
	opacity: 1;
}

.modal-close:hover {
	color: var(--white);
	background: var(--primary);
	transform: scale(1.1);
	box-shadow: 0 8px 25px rgba(194, 178, 110, 0.4);
}

.modal-content,
.modal-footer {
	position: relative;
	z-index: 2;
	background-color: transparent;
}

.modal-title {
	font-size: var(--font-xxl);
	margin-bottom: var(--space-lg);
	color: var(--white);
	line-height: 1;
	font-family: var(--font-family);
	font-weight: var(--font-weight-extrabold);
	text-align: left;
	max-width: 100%;
}

.modal-description {
	color: var(--white);
	line-height: 1.2;
	margin-bottom: var(--space-lg);
	font-size: var(--font-lg);
	text-align: left;
	font-family: var(--font-family);
	font-weight: var(--font-weight-extrabold);
	max-width: 100%;
}

.modal-link {
	position: absolute;
	bottom: var(--space-sm);
	right: var(--space-sm);
	background: var(--primary);
	color: var(--black);
	padding: var(--space-sm) var(--space-lg);
	border-radius: var(--radius);
	text-decoration: none;
	transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	font-family: var(--font-family);
	font-weight: var(--font-weight-extrabold);
	font-size: var(--font-base);
	display: inline-block;
}

.modal-link:hover {
	transform: translateY(-2px);
	box-shadow: 0 var(--space-sm) var(--space-sm) rgba(194, 178, 110, 0.4);
}

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

.modal-footer p {
	text-align: left;
	font-size: var(--font-sm);
}

/* Exit animation enhancement */
.modal-overlay:not(.active) .modal {
	transform: scale(0.8) translateY(-50px);
	transition: all var(--transition-exit);
}

.modal-overlay:not(.active) .modal-close {
	transform: scale(0.6);
	transition: all 0.2s ease-in;
}

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

.footer .container {
	padding: 0 0 var(--space-lg) 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-sm);
	position: relative;
}

.footer-container {
	place-self: center;
	max-width: var(--container-lg);
	padding: var(--space-lg) 0;
	display: flex;
	gap: var(--space-md);
	flex-direction: row;
	justify-content: space-between;
	position: relative;
	align-items: start;
}

.footer-container .footer-details {
	display: flex;
	gap: var(--space-sm);
	flex-direction: column;
	color: var(--white);
	font-size: var(--font-base);
	font-family: var(--font-family);
	font-weight: var(--font-weight-medium);
	line-height: 1.5;
	text-align: left;
}

.footer a:not(.mainlink) {
	color: var(--primary);
	font-family: var(--font-family);
	font-weight: var(--font-weight-extrabold);
	text-decoration: none;
	transition: var(--transition);
}

.footer .email a {
	color: var(--white);
}

.footer .email a:hover {
	color: var(--primary);
}

.footer a:hover {
	color: var(--white);
}

/* More Text Toggle */
.more-text {
	margin-top: var(--space-md);
	max-height: 0;
	transform: scaleY(0);
	transform-origin: top;
	overflow: hidden;
	transition: max-height var(--transition), transform var(--transition),
		opacity var(--transition);
	opacity: 0;
}

.more-text.show {
	max-height: 200px;
	transform: scaleY(1);
	opacity: 1;
}

/* ==========================================================================
   POLICIES
   ========================================================================== */

.policies .header {
	padding-bottom: 40px;
}

.policies p,
.policies h1,
.policies h2 {
	text-align: left;
	max-width: 100%;
}

.policies h1 {
	margin-bottom: 0px;
}

.policies .info-text {
	padding: var(--space-md) 0;
	width: 100%;
}

/* ==========================================================================
   SWIPER ADDITIONS
   ========================================================================== */

.swiper {
	width: 100%;
	padding: 0;
	overflow: hidden;
	position: relative;
	max-width: var(--container-lg);
	margin: 0 auto;
	border-radius: 9px;
}

.swiper-wrapper {
	display: flex;
	align-items: stretch;

	transition: transform var(--transition-smooth);
	will-change: transform;
}

.swiper-slide {
	height: 270px;
	position: relative;
	cursor: pointer;
	border-radius: var(--radius);
	overflow: hidden;
	transition: var(--transition);
	border: 2px solid var(--primary);
	padding: var(--space-sm);
	margin-right: var(--space-md);
}

.slider2-swiper .swiper-slide {
	height: 340px;
}

.swiper-slide:last-child {
	margin-right: 0;
	visibility: hidden;
}

.swiper-slide:hover {
	border-color: var(--primary);
}

/* Slide content structure for Swiper */
.swiper-slide .slide-content {
	position: relative;
	width: 100%;
	height: 100%;
	border-radius: var(--radius);
	overflow: hidden;
}

.swiper-slide .slide-content img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	transition: var(--transition);
	padding: 20px;
	transform: translateY(-25px);
}

.swiper-slide:hover .slide-content img {
	transform: translateY(-25px) scale(1.05);
}

.swiper-slide .slide-overlay {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	/* background: linear-gradient(transparent 0%, rgba(0, 0, 0, 0.9) 40%); */
	padding: var(--space-md);
	color: var(--white);
}

.swiper-slide .slide-title {
	font-size: var(--font-sm);
	font-family: var(--font-bold);
	color: var(--white);
	margin: 0;
	text-align: center;
	justify-self: center;
}

.swiper-button-next,
.swiper-button-prev {
	background-color: var(--dark-grey);
	border: none;
	color: var(--primary);
	padding: 0 var(--space-md);
	border-radius: var(--radius);
	cursor: pointer;
	transition: var(--transition);
	font-family: var(--font-bold);
	width: auto;
	height: 100%;
	margin-top: 0;
	top: 50%;
	transform: translateY(-50%);
}

.swiper-button-next:after,
.swiper-button-prev:after {
	content: "";
	display: none;
}

.swiper-button-next i,
.swiper-button-prev i {
	font-size: var(--font-xl);
}

.swiper-button-next:hover,
.swiper-button-prev:hover {
	color: var(--white);
	background-color: var(--primary);
}

.swiper-button-disabled {
	opacity: 0;
	pointer-events: none;
	cursor: not-allowed;
	background-color: var(--dark-grey);
}

.swiper-button-next.swiper-button-disabled,
.swiper-button-prev.swiper-button-disabled {
	opacity: 0 !important;
	cursor: auto;
	pointer-events: none;
}

.swiper-button-disabled:hover {
	transform: translateY(-50%);
}

/* Position navigation buttons */
.swiper-button-prev {
	left: 0;
}

.swiper-button-next {
	right: 0;
}

/* Add FontAwesome icons to Swiper buttons */
.swiper-button-prev::before {
	content: "\f053";
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
	font-size: var(--font-xl);
}

.swiper-button-next::before {
	content: "\f054";
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
	font-size: var(--font-xl);
}

.swiper-pagination {
	position: static;
	margin-top: var(--space-md);
	text-align: center;
}

.swiper-pagination-bullet {
	background: rgba(194, 178, 110, 0.3);
	opacity: 1;
	transition: var(--transition);
	border: 1px solid var(--primary);
}

.swiper-pagination-bullet-active {
	background: var(--primary);
}

/* Hide original slider elements when using Swiper */
.swiper .slider-wrapper,
.swiper .slider-track,
.swiper .slider-nav {
	display: none;
}

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

.testimonial-card {
	height: 100%;
	padding: var(--space-md);
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.testimonial-stars {
	display: flex;
	gap: 0.25rem;
	margin-bottom: var(--space-md);
	align-self: center;
}

.testimonial-stars .star {
	color: var(--star-color);
	font-size: 1.5rem;
	line-height: 1;
}

.testimonial-content {
	color: var(--white);
	line-height: 1.6;
	flex-grow: 1;
	text-align: left;
	font-weight: var(--font-weight-medium);
	margin-bottom: var(--space-md);
}

.testimonial-author {
	color: var(--white);
	text-align: left;
	font-weight: var(--font-weight-extrabold);
	margin-top: auto;
}

.testimonial-author hr {
	border: 1px solid var(--primary);
	margin-bottom: var(--space-md);
}

/* ==========================================================================
   RESPONSIVE DESIGN
   ========================================================================== */

@media only screen and (max-width: 1280px) {
	.info-text,
	.header,
	.info-bar,
	.slider-container {
		max-width: 90%;
	}

	.faq-section,
	.slider .container,
	.footer-container {
		padding: var(--space-md) var(--space-lg);
	}
}

@media only screen and (max-width: 1200px) {
	/* CSS Variables */
	:root {
		/* Font Sizes */
		--font-sm: 15px;
		--font-base: 16px;
		--font-lg: 18px;
		--font-xl: 22px;
		--font-xxl: 32px;

		/* Spacing */
		--space-lg: 30px;
		--space-xl: 40px;

		/* Layout */
		--container-sm: 100%;
		--container-md: 100%;
		--container-lg: 100%;
	}

	.header {
		padding-bottom: 120px;
	}

	.footer-container {
		flex-direction: column;
		align-items: center;
	}

	.footer-details {
		text-align: center;
	}
}

@media only screen and (max-width: 768px) {
	.accordion summary {
		padding: var(--space-sm) var(--space-md);
	}
	details .content {
		padding: var(--space-sm) var(--space-md) var(--space-md) var(--space-md);
	}
	.footer-container .footer-details {
		text-align: center;
	}
	.mobile-hide {
		display: none;
	}

	.form-step {
		gap: 0px;
		flex-direction: column;
	}

	.form-step .input-container label {
		top: 20px;
		font-size: var(--font-sm);
	}

	.form-step .input-container input:focus + label,
	.form-step .input-container input:not(:placeholder-shown) + label {
		font-size: 13px;
	}

	.input-container {
		width: 100%;
	}

	.text-slide {
		padding: var(--space-md) var(--space-sm);
		width: 100%;
	}

	.modal-footer {
		padding: 2%;
	}

	.modal-category {
		margin-bottom: var(--space-sm);
	}

	.faq-section,
	.footer .container {
		padding: var(--space-lg);
		justify-self: center;
	}

	.faq-section {
		padding-bottom: 0px;
	}

	.faq-section .container {
		padding: 0;
	}

	.header {
		padding-bottom: 70px;
	}

	.logo {
		width: 100%;
	}
	.logo img {
		filter: drop-shadow(2px 4px 6px rgba(0, 0, 0, 1));
	}

	.footer-container > div {
		width: 100%;
	}

	.slide {
		min-width: 195px;
		width: 195px;
		height: 195px;
	}

	.modal {
		width: 95%;
		margin: var(--space-md);
	}

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

	.intro .container {
		padding: var(--space-sm) var(--space-lg);
	}

	.swiper-slide {
		min-width: 195px;
		width: 195px;
		height: 195px;
		margin-right: var(--space-sm);
	}

	.swiper-slide:last-child {
		margin-right: 0px;
		display: none;
	}

	.swiper-button-next,
	.swiper-button-prev {
		padding: var(--space-sm);
	}

	.swiper-button-next::before,
	.swiper-button-prev::before {
		font-size: var(--font-lg);
	}
}
