/* ===== ROOT VARIABLES ===== */
:root {
	--fd-primary: #26699E;
	--fd-primary-dark: #1144A1;
	--fd-primary-darker: #002A86;
	--fd-primary-light: #21A0D7;

	--fd-text-body: 1.125rem;
	--fd-text-lead: 1.4rem;
	--fd-heading: 3rem;
}

/* ===== BASE STYLES ===== */
.fd-landing-home {
	font-family: 'Poppins', sans-serif;
}

.fd-landing-home .lead, .fd-landing-home p.lead {
	font-size: var(--fd-text-lead);
	line-height: 1.6;
	/* color: #686868 !important; */
}

.fd-landing-home .container {
	width: 100%;
	max-width: 1400px !important;
	padding-left: 30px !important;
	padding-right: 30px !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

@media (min-width: 1600px) {
	.fd-landing-home .container {
		max-width: 1500px !important;
	}
}

@media (max-width: 768px) {
	.fd-landing-home .lead {
		font-size: max(1.25rem, var(--fd-text-lead));
	}

	.fd-landing-home .container {
		padding-left: 15px !important;
		padding-right: 15px !important;
	}
}

.fd-landing-home .text-primary {
	color: var(--fd-primary) !important;
}

.fd-landing-home p:not(.footer-application p), .fd-landing-home .locally-section, .fd-landing-home strong {
	color: #525253;
}

.fd-landing-home .text-white,
.fd-landing-home .hero-section p,
.fd-landing-home .hardware-section p,
.fd-landing-home .cta-section p {
	color: #ffffff !important;
}

/* ===== Equal Spacing between Sections ===== */
.fd-landing-home section:not(.chatbot-section, .hero-section), .fd-landing-home .py-5 {
	padding-top: clamp(2.5rem, 5vh, 5rem) !important;
	padding-bottom: clamp(2.5rem, 5vh, 5rem) !important;
}

.fd-landing-home .extra-section-padding {
	padding-top: clamp(2.5rem, 5vh, 5rem);
	padding-bottom: clamp(2.5rem, 5vh, 5rem);
}

.fd-landing-home .extra-bottom-padding {
	padding-bottom: clamp(2.5rem, 5vh, 5rem);
}

/* ===== TYPOGRAPHY - PROPER HIERARCHY ===== */
.fd-landing-home h1 {
	font-size: var(--fd-heading);
	line-height: 1.2;
}

.fd-landing-home h2 {
	font-size: 2.5rem;
	line-height: 1.25;
}

.fd-landing-home h3 {
	font-size: 2rem;
	line-height: 1.3;
}

.fd-landing-home h4 {
	font-size: 1.75rem;
	line-height: 1.35;
}

.fd-landing-home h5 {
	font-size: 1.55rem;
	line-height: 1.4;
}

.fd-landing-home h6 {
	font-size: 1.45rem;
	line-height: 1.45;
}

.fd-landing-home p {
	font-size: var(--fd-text-body);
	line-height: 1.7;
}

.fd-landing-home .lead {
	font-size: var(--fd-text-lead);
	line-height: 1.7;
}

/* ===== RESPONSIVE FONT SCALING - MAINTAINING HIERARCHY ===== */
@media (min-width: 1600px) {
	:root {
		--fd-heading: 4rem;
		--fd-text-body: 1.15rem;
		--fd-text-lead: 1.4rem;
	}

	.fd-landing-home h2 {
		font-size: 3.5rem;
	}

	.fd-landing-home h3 {
		font-size: 2.75rem;
	}

	.fd-landing-home h4 {
		font-size: 2.25rem;
	}

	.fd-landing-home h5 {
		font-size: 1.8rem;
	}

	.fd-landing-home h6 {
		font-size: 1.6rem;
	}
}

@media (max-width: 1599px) and (min-width: 1400px) {
	:root {
		--fd-heading: 3.2rem;
		--fd-text-body: 1.125rem;
		--fd-text-lead: 1.35rem;
	}

	.fd-landing-home h2 {
		font-size: 2.8rem;
	}

	.fd-landing-home h3 {
		font-size: 2.5rem;
	}

	.fd-landing-home h4 {
		font-size: 2rem;
	}

	.fd-landing-home h5 {
		font-size: 1.7rem;
	}

	.fd-landing-home h6 {
		font-size: 1.5rem;
	}
}

@media (max-width: 1399px) and (min-width: 1200px) {
	:root {
		--fd-heading: 2.8rem;
		--fd-text-body: 1.125rem;
		--fd-text-lead: 1.3rem;
	}

	.fd-landing-home h2 {
		font-size: 2.4rem;
	}

	.fd-landing-home h3 {
		font-size: 2.25rem;
	}

	.fd-landing-home h4 {
		font-size: 1.85rem;
	}

	.fd-landing-home h5 {
		font-size: 1.62rem;
	}

	.fd-landing-home h6 {
		font-size: 1.45rem;
	}
}

@media (max-width: 1199px) and (min-width: 992px) {
	:root {
		--fd-heading: 3rem;
		--fd-text-body: 1.1rem;
		--fd-text-lead: 1.28rem;
	}

	.fd-landing-home h2 {
		font-size: 2.5rem;
	}

	.fd-landing-home h3 {
		font-size: 2rem;
	}

	.fd-landing-home h4 {
		font-size: 1.75rem;
	}

	.fd-landing-home h5 {
		font-size: 1.55rem;
	}

	.fd-landing-home h6 {
		font-size: 1.4rem;
	}

	.fd-landing-home p {
		line-height: 1.75;
	}
}

@media (max-width: 991px) {
	:root {
		--fd-text-body: clamp(1.25rem, 3.2vw, 1.4rem);   
		--fd-text-lead: clamp(1.5rem, 3.5vw, 1.6rem);    
		--fd-heading: clamp(2.4rem, 8vw, 2.6rem);
	}

	.fd-landing-home p {
		font-size: var(--fd-text-body);
		line-height: 1.7;
	}

	.fd-landing-home .lead {
		font-size: var(--fd-text-lead);
		line-height: 1.6;
	}

	.fd-landing-home h6 { font-size: clamp(1.65rem, 4vw, 1.75rem); }
	.fd-landing-home h5 { font-size: clamp(1.8rem, 4.5vw, 1.9rem); }
	.fd-landing-home h4 { font-size: clamp(1.95rem, 5vw, 2.05rem); }
	.fd-landing-home h3 { font-size: clamp(2.1rem, 6vw, 2.2rem); }
	.fd-landing-home h2 { font-size: clamp(2.25rem, 7vw, 2.35rem); }
	.fd-landing-home h1 { font-size: var(--fd-heading); }
}

/* Mobile 768px and below */
@media (max-width: 768px) {
	:root {
		--fd-text-body: clamp(1.25rem, 3.2vw, 1.4rem);   
		--fd-text-lead: clamp(1.5rem, 3.5vw, 1.6rem);    
		--fd-heading: clamp(2.4rem, 8vw, 2.6rem);
	}

	.fd-landing-home p {
		font-size: var(--fd-text-body);
		line-height: 1.7;
	}

	.fd-landing-home .lead {
		font-size: var(--fd-text-lead);
		line-height: 1.6;
	}

	.fd-landing-home h6 { font-size: clamp(1.65rem, 4vw, 1.75rem); }
	.fd-landing-home h5 { font-size: clamp(1.8rem, 4.5vw, 1.9rem); }
	.fd-landing-home h4 { font-size: clamp(1.95rem, 5vw, 2.05rem); }
	.fd-landing-home h3 { font-size: clamp(2.1rem, 6vw, 2.2rem); }
	.fd-landing-home h2 { font-size: clamp(2.25rem, 7vw, 2.35rem); }
	.fd-landing-home h1 { font-size: var(--fd-heading); }
}

/* ===== BUTTON ANIMATIONS ===== */
@keyframes waveText {
	0%   { transform: translateY(0); }
	25%  { transform: translateY(-3px); }
	50%  { transform: translateY(2px); }
	75%  { transform: translateY(-1px); }
	100% { transform: translateY(0); }
}

.fd-landing-home .btn:hover .btn-text {
	animation: waveText 0.6s ease-in-out;
	display: inline-block;
}

/* ===== HERO SECTION ===== */
.fd-landing-home .hero-section {
	background-image: url("/images/landing/background/blue-background_web.jpeg");
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	color: #fff;
	overflow: hidden;
	padding-top: 160px !important;
	padding-bottom: 0 !important;
	position: relative;
}

.fd-landing-home .hero-section .row {
    margin-left: 0;
    margin-right: 0;
	display: flex;
    align-items: stretch;
}

.fd-landing-home .hero-section .hero-content {
	padding: 80px 0;
	align-items: flex-start;
}

.fd-landing-home .hero-section .hero-image-col {
	display: flex;
	align-items: flex-end;
	padding-bottom: 0 !important;
	margin-bottom: 0 !important;
	justify-content: center;
	height: 100%;
}

.fd-landing-home .hero-section .hero-image {
	display: block;
	width: 100%;
	height: auto;
	margin-top: auto;
	margin-bottom: -1px;
	object-fit: contain;
}

.fd-landing-home .hero-content {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

.fd-landing-home .hero-section h1,
.fd-landing-home .hero-section .hero-heading {
	font-size: var(--fd-heading);
	line-height: 1.2;
}

.fd-landing-home .hero-section h1 {
	text-wrap: balance;
    max-width: 100%;
}

.fd-landing-home .hero-section h3 {
    text-wrap: balance;
    max-width: 100%;
}

.fd-landing-home .hero-section .hero-heading {
    max-width: 100%;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    line-height: 1.2;
    display: block;
}

/* Hero Button Colors */
.fd-landing-home .hero-section .btn-primary {
	background-color: #ffffff;
	color: var(--fd-primary);
	border-color: #ffffff;
}

.fd-landing-home .hero-section .btn-primary:hover {
	background-color: var(--fd-primary);
	color: #ffffff;
	border-color: var(--fd-primary);
}

@media (max-width: 1239px) and (min-width: 992px) {
    .fd-landing-home .hero-section .hero-content {
        padding: 40px 0;
    }
    .fd-landing-home .hero-section {
        padding-top: 120px !important;
    }
}

@media (min-width: 992px) {
    .fd-landing-home .hero-heading {
        max-width: 550px; 
    }
}

@media (max-width: 991px) {
	.fd-landing-home .hero-section {
		padding-top: 4rem !important;
	}

	.fd-landing-home .hero-section .hero-content {
		padding: 40px 0 0;
		text-align: center;
		align-items: center;
	}

	.fd-landing-home .hero-heading {
		margin-left: auto;
		margin-right: auto;
	}

	.fd-landing-home .hero-section .hero-image {
		max-width: 400px !important; 
		width: 80%;
		margin: 0 auto -5px;
	}
}

@media (max-width: 768px) {
	.fd-landing-home .hero-section {
		background-image: url("/images/landing/background/blue-background_mobile.jpeg");
		padding-top: 0 !important;
	}

	.fd-landing-home .hero-section .container {
		max-width: 100% !important;
		padding-left: 5vw !important;
		padding-right: 5vw !important;
	}

	.fd-landing-home .hero-section .hero-content {
		padding: 40px 0 0;
		text-align: center;
	}

	.fd-landing-home .hero-section .hero-image {
		max-width: 75%;
		margin: 0 auto -5px;
	}
}

@media (max-width: 576px) {
	.fd-landing-home .hero-section .hero-image {
		max-width: 75%;
	}
}

/* ABOUT SECTION */
.fd-landing-home .about-us .row {
	align-items: center;
}

@media (max-width: 991px) {
	.fd-landing-home .about-us .row {
		flex-direction: column;
		text-align: center;
		gap: 2rem !important;
		margin-top: 0 !important;
	}

	.fd-landing-home .about-us .row img {
		max-width: 80%;
		margin-top: 0 !important;
		margin-bottom: 0 !important;
	}

	.fd-landing-home .about-us .row > div {
		margin-top: 0 !important;
		margin-bottom: 0 !important;
	}

	.fd-landing-home .about-us h2,
	.fd-landing-home .about-us p {
		margin-top: 0 !important;
	}
}

/* ===== LOCALLY ROOTED SECTION ===== */
.fd-landing-home .locally-section {
	background-image: url("/images/landing/frontpage/ms_background.png");
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

@media (max-width: 768px) {
	.fd-landing-home .locally-section {
		background-image: url("/images/landing/frontpage/ms_background-mobile.png");
	}

	.fd-landing-home .locally-section p {
		padding: 0 5vw;
	}

	.fd-landing-home .locally-section br {
		display: none;
	}
}

/* ===== ELEVATE EVENT SECTION ===== */
#section-products .position-relative {
    width: 100%;
    margin: 0 auto;
}

.elevate-event-swiper {
    width: 100%;
    overflow: visible !important;
}

.elevate-event-swiper .swiper-wrapper {
    display: flex;
    align-items: stretch;
}

.elevate-event-swiper .swiper-slide {
	opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
	justify-content: center;
}

.elevate-event-swiper .swiper-slide-active,
.elevate-event-swiper .swiper-slide-next,
.elevate-event-swiper .swiper-slide-prev {
    opacity: 1;
    visibility: visible;
}

@media (max-width: 1199px) {
    /* Strictly hide the "half" cards on mobile */
    .elevate-event-swiper .swiper-slide-next,
    .elevate-event-swiper .swiper-slide-prev {
        opacity: 0; 
        visibility: hidden;
    }
    
    .elevate-event-swiper .swiper-slide-active {
        opacity: 1;
        visibility: visible;
    }
	
	.elevate-event-swiper .scroll-item {
        margin: 0 auto;
        text-align: center;
        max-width: 400px; /* Prevents it from becoming too wide on tablets */
    }
}

/* ===== HORIZONTAL SCROLL SECTIONS ===== */
.fd-landing-home .scroll-item {
	padding: 1rem;
    text-align: center;
    display: flex;
    flex-direction: column;
	align-items: center;
    height: 100%;
}

.fd-landing-home .scroll-item p.lead,
.fd-landing-home .scroll-item h5,
.fd-landing-home .scroll-item p:not(.lead) {
    line-height: 1.5;
    margin-top: 0 !important;
}

.fd-landing-home .scroll-item img {
	max-width: 15vw;
	height: auto;
	margin-bottom: 0.75rem !important;
	pointer-events: none;
}

.fd-landing-home .scroll-item p.lead.mb-2 {
    margin-bottom: 1.25rem !important;
    font-weight: 600;
}

.fd-landing-home .scroll-item h5 {
    margin-bottom: 1.25rem !important;
    font-weight: 700;
}

.fd-landing-home .scroll-item p:not(.lead) {
    margin-bottom: 0 !important;
    flex-grow: 0;
}

@media (max-width: 768px) {
	.fd-landing-home #section-products br {
		display: none;
	}

	.fd-landing-home .scroll-item p.lead.mb-2,
    .fd-landing-home .scroll-item h5 {
        margin-bottom: 1rem !important;
    }

	.fd-landing-home .scroll-item img {
		max-width: 46vw;
	}
}

@media (max-width: 576px) {
	.fd-landing-home .scroll-item {
		flex: 0 0 92vw;
		max-width: 92vw;
	}
}

/* Scroll Dots */
.fd-landing-home .scroll-dots {
	display: none;
	justify-content: center;
	align-items: center;
	gap: 0.75rem;
	margin-top: 1.5rem;
	padding: 1rem 0;
}

.fd-landing-home .scroll-dots.active {
	display: flex;
}

.fd-landing-home .scroll-dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background-color: #d0d0d0;
	cursor: pointer;
	transition: all 0.3s ease;
}

.fd-landing-home .scroll-dot.active {
	background-color: var(--fd-primary);
	transform: scale(1.2);
}

@media (min-width: 769px) {
    .scroll-dots {
        display: none !important;
    }

    /* EXCEPTION: Force display for Interactive Solutions sections even on Desktop */
    .scroll-dots[data-dots-for="elevate"],
	.scroll-dots[data-dots-for="interactive-experiences"],
    .scroll-dots[data-dots-for="walls"],
    .scroll-dots[data-dots-for="games"],
    .scroll-dots[data-dots-for="engagement"],
    .scroll-dots[data-dots-for="utility"],
    .scroll-dots[data-dots-for="integration-capabilities"],
	.scroll-dots[data-dots-for="kiosk-gallery"],
	.scroll-dots[data-dots-for="elevate-benefits"],
	.scroll-dots[data-dots-for="digital-activation"],
	.scroll-dots[data-dots-for="kiosk-rental"]	{
        display: flex !important;
        justify-content: center;
        gap: 10px;
        margin-top: 1.5rem;
    }
}

@media (max-width: 768px) {
	.fd-landing-home .scroll-dots {
        display: flex !important;
        justify-content: center;
        margin-top: 1.5rem;
        gap: 8px;
    }
    
    .fd-landing-home .scroll-dot {
        display: inline-block !important;
        width: 10px;
        height: 10px;
        background-color: #ccc;
        border-radius: 50%;
    }
	
	.fd-landing-home .scroll-dot.active {
        background: var(--fd-primary);
    }
}

/* ===== HARDWARE SECTION ===== */
.fd-landing-home .hardware-section {
	background-color: #0a4f8f;
	position: relative;
	overflow: visible;
}

.fd-landing-home .hardware-section .row {
	align-items: center;
}

.fd-landing-home .hardware-section .hardware-image {
	max-width: 80%;
	margin-top: clamp(-200px, -15vw, -100px);
	display: block;
	transition: transform 0.3s ease;
}

.fd-landing-home .hardware-section .feature-icon {
	width: 26px;
	height: 26px;
	margin-right: 1rem;
	margin-top: 4px;
	flex-shrink: 0;
}

.fd-landing-home .hardware-section p {
	color: #ffffff !important;
	opacity: 1;
}

.fd-landing-home .hardware-section .btn-primary {
	background-color: #ffffff;
	color: var(--fd-primary);
	border-color: #ffffff;
	white-space: normal !important; 
    text-wrap: balance;
}

.hardware-btn-grid {
    display: grid;
    gap: 1rem;
    justify-content: center; 
}

.fd-landing-home .hardware-section .btn-text {
    white-space: normal !important;
    display: block;
}

@media (max-width: 1199px) {
	.fd-landing-home .hardware-section .hardware-image {
		max-width: 70%;
		margin-top: -100px;
	}
}

@media (max-width: 991px) {
	.fd-landing-home .hardware-section {
		overflow: hidden;
		padding-top: 0;
	}

	.fd-landing-home .hardware-section .hardware-image {
		max-width: 350px !important; 
		width: 80%;
		margin: 1rem auto 0 !important;
		display: block;
	}
}

@media (min-width: 768px) {
    .hardware-btn-grid {
        justify-content: start; 
        grid-auto-flow: column;
        grid-auto-columns: 1fr; 
    }
}

.hardware-action-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
    width: 100%;
}

@media (max-width: 767px) {
    .hardware-btn-grid {
        grid-template-columns: 1fr;
        max-width: 350px;
        margin-left: auto;
        margin-right: auto;
    }
}

/* ===== OPERATIONS CARDS ===== */
.fd-landing-home .ops-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    height: 100%;
}

.fd-landing-home .ops-container h2 {
	text-wrap: balance;
}

.fd-landing-home .ops-card h5,
.fd-landing-home .ops-card p {
    line-height: 1.4; 
    margin-top: 0 !important;
}

.fd-landing-home .ops-card img {
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: 0.75rem;
    margin-bottom: 1.5rem !important; 
}

.fd-landing-home .ops-card h5 {
    font-weight: 700;
    margin-bottom: 1.25rem !important;
    min-height: 3rem; 
    display: flex;
    align-items: center;
    justify-content: center;
}

.fd-landing-home .ops-card p {
    margin-bottom: 0 !important;
    flex-grow: 0;
}

@media (max-width: 768px) {
    .fd-landing-home .ops-card {
        margin-bottom: 3rem;
    }

    .fd-landing-home .ops-card h5 {
        min-height: auto;
        margin-bottom: 1rem !important;
    }
}

/* ===== REVENUE SECTION ===== */
.fd-landing-home .revenue-section .revenue-image {
	max-width: 75%;
}

.fd-landing-home .revenue-section .revenue-icon {
	width: 76px;
	min-width: 76px;
	height: 76px;
	margin-right: 1rem;
	flex-shrink: 0;
}

@media (max-width: 768px) {
	.fd-landing-home .revenue-section .revenue-icon {
		width: 60px;
		min-width: 60px;
		height: 60px;
	}

	.fd-landing-home .revenue-section .revenue-image {
		max-width: 75%;
		display: block;
		margin-left: auto;
		margin-right: auto;
	}
}

/* ===== CASE STUDIES SECTION ===== */
.fd-landing-home .cases-container h2 {
	text-wrap: balance;
}

.fd-landing-home .case-card {
	background: #fff;
	border-radius: 0.75rem;
	box-shadow: 0 6px 20px rgba(0,0,0,.08);
	height: 100%;
	user-select: none;
	display: flex;
	flex-direction: column;
	overflow: hidden;
}

.fd-landing-home .case-header {
	padding: 1.5rem;
	text-align: center;
	border-radius: 0.75rem 0.75rem 0 0;
	flex-shrink: 0;
	color: #fff;
}

.fd-landing-home .case-header h5 {
	margin-bottom: 0.5rem;
	overflow: hidden;
	line-height: 1.3;
	min-height: 3.5rem;
}

.fd-landing-home .case-body {
	padding: 1.5rem;
	flex: 1;
	display: flex;
	flex-direction: column;
}

.fd-landing-home .case-body strong {
	display: block;
	margin-top: 0.75rem;
}

.fd-landing-home .case-body strong:first-of-type {
	margin-top: 0;
}

.fd-landing-home .case-body p {
	color: #525253;
	margin-bottom: 0;
}

.fd-landing-home .case-header h5,
.fd-landing-home .case-header p {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    margin-bottom: 0;
}

/* Case header color variants */
.fd-landing-home .case-header-blue-1 {
	background: #26699E;
}

.fd-landing-home .case-header-blue-2 {
	background: #1144A1;
}

.fd-landing-home .case-header-blue-3 {
	background: #002A86;
}

.fd-landing-home .case-header-blue-4 {
	background: #21A0D7;
}

.case-studies-swiper {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
    margin-top: -40px !important;
    overflow: visible !important; 
}

.swiper-wrapper {
    overflow: visible !important;
}

.case-studies-swiper .swiper-slide {
	transition: all 0.5s ease;
	transform: scale(1);
	opacity: 1;
	height: auto;
}

.case-studies-swiper .swiper-slide-active {
	transform: scale(1);
	opacity: 1;
}

@media (min-width: 1222px) {
	.case-studies-swiper {
		overflow: visible !important;
	}
	
	.case-studies-swiper .swiper-wrapper {
		display: grid !important;
		grid-template-columns: repeat(4, 1fr) !important;
		gap: 24px !important;
		transform: none !important;
		width: auto !important;
	}
	
	.case-studies-swiper .swiper-slide {
		width: auto !important;
		transform: none !important;
		opacity: 1 !important;
	}
	
	.fd-landing-home .cases-container .scroll-dots {
		display: none !important;
	}
}

@media (max-width: 1221px) {
    .case-studies-swiper .swiper-slide-active {
		opacity: 1;
        visibility: visible;
	}
	
    .case-studies-swiper .swiper-slide-next,
    .case-studies-swiper .swiper-slide-prev {
        opacity: 0; 
        visibility: hidden;
    }
	
	.fd-landing-home .cases-container {
		max-width: 60% !important;
		padding: 0 !important;
	}
	
	.fd-landing-home .cases-container .scroll-dots {
		display: flex !important;
	}
}

/* Ensure consistent heights on desktop */
@media (min-width: 992px) {
	.fd-landing-home .case-header {
		min-height: clamp(200px, 14vw, 230px);
		display: flex;
		flex-direction: column;
		justify-content: center;
	}
}

@media (max-width: 991px) and (min-width: 769px) {
	.fd-landing-home .cases-container {
		max-width: 70% !important;
		padding: 0 !important;
	}

	/* Ensure the Desktop-style header height is maintained */
	.fd-landing-home .case-header {
		min-height: 180px; 
		display: flex;
		flex-direction: column;
		justify-content: center;
	}
}

@media (max-width: 768px) {
	.fd-landing-home .cases-container {
		margin-left: 0;
		margin-right: 0;
		max-width: 80% !important;
	}

	.fd-landing-home .cases-container br, .fd-landing-home .footer-application br {
		display: none;
	}
}

/* ===== CTA SECTION ===== */
.fd-landing-home .cta-section {
	background-image: linear-gradient(rgba(0,0,0,.55), rgba(0,0,0,.55)), url("/images/landing/frontpage/level_up_business.png");
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	color: #fff;
}

/* CTA Button Colors */
.fd-landing-home .cta-section .btn-primary {
	background-color: #ffffff;
	color: var(--fd-primary);
	border-color: #ffffff;
}

.fd-landing-home .cta-section .btn-primary:hover {
	background-color: var(--fd-primary);
	color: #ffffff;
	border-color: var(--fd-primary);
}

/* ===== SCROLL ANIMATIONS ===== */
.fd-landing-home .animate {
	opacity: 0;
	transform: translateZ(0);
	will-change: opacity, transform;
	transition: opacity 0.6s ease, transform 0.6s ease;
}

.fd-landing-home .animate.fade-up {
	transform: translateY(40px);
}

.fd-landing-home .animate.fade-left {
	transform: translateX(-40px);
}

.fd-landing-home .animate.fade-right {
	transform: translateX(40px);
}

.fd-landing-home .animate.scale-in {
	transform: scale(0.85);
}

.fd-landing-home .animate.show {
	opacity: 1;
	transform: translate(0, 0) scale(1);
}

/* Reduce motion for mobile */
@media (max-width: 768px) {
	.fd-landing-home .animate.fade-left,
	.fd-landing-home .animate.fade-right {
		transform: translateY(20px);
	}
}

/* ===== INTERACTIVE SOLUTIONS ===== */
/* Interactive Experience */
#why-icons .position-relative {
    width: 100%;
    margin: 0 auto;
}

.interactive-experiences-swiper {
    width: 100%;
    overflow: visible !important;
}

.interactive-experiences-swiper .swiper-wrapper {
    display: flex;
    align-items: stretch;
}

.interactive-experiences-swiper .swiper-slide {
	opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
	justify-content: center;
}

.interactive-experiences-swiper .swiper-slide-active,
.interactive-experiences-swiper .swiper-slide-next,
.interactive-experiences-swiper .swiper-slide-prev {
    opacity: 1;
    visibility: visible;
}

@media (max-width: 1199px) {
    .interactive-experiences-swiper .swiper-slide-next,
    .interactive-experiences-swiper .swiper-slide-prev {
        opacity: 0; 
        visibility: hidden;
    }
    
    .interactive-experiences-swiper .swiper-slide-active {
        opacity: 1;
        visibility: visible;
    }
	
	.interactive-experiences-swiper .scroll-item {
        margin: 0 auto;
        text-align: center;
        max-width: 400px; /* Prevents it from becoming too wide on tablets */
    }
}

/* Solutions Container */
.fd-landing-home .solutions-container {
	position: relative;
	max-width: 100% !important;
	padding: 0 !important;
}

/* Solutions Row - Full Width Card Display */
.fd-landing-home .solutions-row {
	display: flex;
	overflow-x: auto;
	overflow-y: hidden;
	scroll-behavior: auto;
	-webkit-overflow-scrolling: touch;
	padding: 0;
	margin: 0;
	gap: 0;
	cursor: grab;
	user-select: none;
	scroll-snap-type: none;
}

.fd-landing-home .solutions-row.is-interacting {
	cursor: grabbing;
	scroll-snap-type: none;
}

.fd-landing-home .solutions-row::-webkit-scrollbar {
	display: none;
}

/* Solution Card - Full Width on ALL screens */
.fd-landing-home .solution-card {
	flex: 0 0 100%;
	min-width: 100%;
	max-width: 100%;
	scroll-snap-align: start;
	scroll-snap-stop: always;
	padding: 2rem 15%;
	box-sizing: border-box;
}

.fd-landing-home .scroll-dots[data-dots-for] .scroll-dot {
    display: inline-block !important;
}

.walls-solutions-swiper .swiper-slide,
.games-solutions-swiper .swiper-slide,
.engagement-solutions-swiper .swiper-slide,
.utility-solutions-swiper .swiper-slide {
	transition: transform 0.5s ease;
	opacity: 1 !important;
	transform: scale(1) !important;
}

/* Keep active slides at normal scale */
.walls-solutions-swiper .swiper-slide-active,
.games-solutions-swiper .swiper-slide-active,
.engagement-solutions-swiper .swiper-slide-active,
.utility-solutions-swiper .swiper-slide-active {
	transform: scale(1) !important;
	opacity: 1 !important;
}

/* Desktop padding adjustments */
@media (max-width: 1400px) {
	.fd-landing-home .solution-card {
		padding: 2rem 10%;
	}
}

@media (max-width: 991px) {
	.fd-landing-home .solution-card {
		padding: 2rem 5%;
	}
}

/* Mobile */
@media (max-width: 768px) {
	.fd-landing-home .solution-card {
		padding: 2rem 4%;
	}
	
	/* Ensure snap is enabled on mobile */
	.fd-landing-home .solutions-row {
		scroll-snap-type: x proximity;
		-webkit-overflow-scrolling: touch;
	}
}

/* ===== SCROLL DOTS - Always visible on ALL screens ===== */
.fd-landing-home .solutions-container .scroll-dots {
	display: flex !important;
	justify-content: center;
	align-items: center;
	gap: 0.75rem;
	margin-top: 2rem;
	padding: 1rem 0;
	visibility: visible !important;
    opacity: 1 !important;
}

.fd-landing-home .scroll-dot.active {
	background-color: var(--fd-primary);
	transform: scale(1.2);
}

#why-icons .scroll-item img {
    width: auto !important;
    max-height: 80px !important;
    margin-bottom: 1.75rem !important;
	pointer-events: none;
}

#registration-section .list-unstyled li, #gift-redemption-section .list-unstyled li {
    display: flex;
    align-items: center !important; /* This centers the icon with the text row */
}

#registration-section .revenue-icon, #gift-redemption-section .revenue-icon {
    max-width: 20px !important;
    height: auto !important;
	object-fit: contain !important;
	aspect-ratio: auto !important;
}

/* Video Preview Styling */
.fd-landing-home .video-preview {
	cursor: pointer;
	transition: transform 0.3s ease;
}

.fd-landing-home .video-preview:hover {
	transform: scale(1.05);
}

.fd-landing-home .video-preview i {
	opacity: 0.9;
	transition: opacity 0.3s ease, transform 0.3s ease;
}

.fd-landing-home .video-preview:hover i {
	opacity: 1;
	transform: scale(1.1);
}

/* Target the small gallery/video thumbnails */
.solution-card .row.g-3 img {
    width: 100%;
    height: 250px;
    object-fit: cover;
    border-radius: 8px;
    display: block;
}

/* Ensure the video preview container matches the image height */
.video-preview, .portfolio-image {
    height: 250px;
    overflow: hidden;
    border-radius: 8px;
    background-color: #eee;
}

/* Fix for Magnific Popup zoom icon/play icon centering */
.absolute-middle-center {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 2;
}

/* Prevent background interaction on mobile while video is open */
body.mfp-zoom-out-cur {
    overflow: hidden !important;
    touch-action: none;
    -webkit-overflow-scrolling: none;
}

.mfp-iframe-scaler {
    overflow: visible !important;
    -webkit-transform: translateZ(0);
}

/* Ensure the custom class looks like a pointer */
.popup-video-interactive {
    cursor: pointer;
}

/* Lightbox Gallery Items */
.fd-landing-home .lightbox-group-gallery-item {
	display: block;
	position: relative;
	overflow: hidden;
	border-radius: 0.5rem;
	transition: transform 0.3s ease;
}

.fd-landing-home .lightbox-group-gallery-item:hover {
	transform: scale(1.05);
}

/* Solution Card Content */
.fd-landing-home .solution-card img.img-fluid.rounded-3 {
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

.fd-landing-home .solution-card .col-lg-6 {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.solution-card img, .solution-card video, .no-hijack {
    -webkit-user-select: none;  /* Chrome, Safari, Opera */
    -moz-user-select: none;     /* Firefox */
    -ms-user-select: none;      /* IE/Edge */
    user-select: none;          /* Standard */
    
    -webkit-user-drag: none;    /* Prevents dragging image to desktop */
    user-drag: none;
    
    pointer-events: none;       /* EXTREME: This disables all clicks. 
                                   ONLY use this on background videos/images, 
                                   not on links or popup triggers! */
}

/* Mobile optimization */
@media (max-width: 991px) {
	.fd-landing-home .solution-card .row {
		text-align: center;
	}

	.fd-landing-home .solution-card .order-lg-1,
	.fd-landing-home .solution-card .order-lg-2 {
		order: 0 !important;
	}

	.fd-landing-home .solution-card img.img-fluid.rounded-3 {
		max-width: 80%;
		margin: 0 auto 2rem;
	}
}

@media (max-width: 767px) {
    .solution-card .row.g-3 img, .video-preview, .portfolio-image {
        height: 140px;
    }
}

/* Ensure video elements in solution cards are responsive */
.fd-landing-home .solution-card video {
	max-width: 100%;
	height: auto;
}

/* Image thumbnails in solution cards */
.fd-landing-home .solution-card .row.g-3 img {
	cursor: pointer;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.fd-landing-home .solution-card .row.g-3 img:hover {
	transform: translateY(-5px);
	box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
}

/* Solution Cards - Ensure content is centered and readable */
.fd-landing-home .solution-card .col-lg-6 {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

/* Mobile optimization for solution cards */
@media (max-width: 991px) {
	.fd-landing-home .solution-card .row {
		text-align: center;
	}

	.fd-landing-home .solution-card .order-lg-1,
	.fd-landing-home .solution-card .order-lg-2 {
		order: 0 !important;
	}

	.fd-landing-home .solution-card img.img-fluid.rounded-3 {
		max-width: 80%;
		margin: 0 auto 2rem;
	}
}

/* ===== KIOSK PAGE SPECIFIC STYLES ===== */
/* INTEGRATION CAPABILITIES SECTION */
#integration-capabilities .position-relative {
    width: 100%;
    margin: 0 auto;
}

.integration-capabilities-swiper {
    width: 100%;
    overflow: visible !important;
}

.integration-capabilities-swiper .swiper-wrapper {
    display: flex;
    align-items: stretch;
}

.integration-capabilities-swiper .swiper-slide {
	opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
	justify-content: center;
}

/* Center the active slide with scale effect */
.integration-capabilities-swiper .swiper-slide-active,
.integration-capabilities-swiper .swiper-slide-next,
.integration-capabilities-swiper .swiper-slide-prev {
    opacity: 1;
    visibility: visible;
}

@media (max-width: 1199px) {
    .integration-capabilities-swiper .swiper-slide-next,
    .integration-capabilities-swiper .swiper-slide-prev {
        opacity: 0;
        visibility: hidden;
    }
    
    .integration-capabilities-swiper .swiper-slide-active {
        opacity: 1;
        visibility: visible;
    }
	
	.integration-capabilities-swiper .scroll-item {
        margin: 0 auto;
        text-align: center;
        max-width: 400px; /* Prevents it from becoming too wide on tablets */
    }
}

/* Kiosk Gallery Swiper (Original Design) */
#gallery-section .row.justify-content-center.mb-5, #activation-section .row.justify-content-center.mb-5, #device-section .row.justify-content-center.mb-5 {
    margin-bottom: 2rem !important;
}

#activation-section h4, #device-section h4 {
    margin-bottom: 1.25rem !important;
    line-height: 1.2;
    display: block;
}

#gallery-section h2, #activation-section h2, #device-section h2 {
    margin-bottom: 1.5rem !important;
    line-height: 1.2;
}

#gallery-section p, #activation-section p, #device-section .p {
    margin-bottom: 0 !important;
    line-height: 1.6;
}

@media (max-width: 991px) {
    #gallery-section .row.justify-content-center.mb-5, #activation-section .row.justify-content-center.mb-5, #device-section .row.justify-content-center.mb-5 {
        margin-bottom: 1.25rem !important;
    }
    
    #gallery-section h2, #activation-section h2, #activation-section h4, #device-section h2, #device-section h4  {
        margin-bottom: 1rem !important;
    }
}

.slider-blog-banner .swiper-slide {
	width: 55% !important;
}

.integration-capabilities-swiper .scroll-item img {
	width: auto !important;
    max-height: 200px !important;
    margin-bottom: 1rem !important;
	pointer-events: none;
}

.fd-landing-home .kiosk-container h2, .kiosk-container h4 {
	text-wrap: balance;
}

.fd-landing-home .kiosk-container .scroll-dots {
	display: flex !important;
	justify-content: center;
	align-items: center;
	gap: 0.75rem;
	margin-top: 1rem;
	padding: 1rem 0;
	visibility: visible !important;
    opacity: 1 !important;
}

.fd-landing-home .border-radius-4px {
    overflow: hidden;
}

/* Make the inactive slides smaller and transparent */
.kiosk-gallery-swiper .swiper-slide, .digital-activation-swiper .swiper-slide {
    transition: all 0.5s ease;
    transform: scale(0.85);
    opacity: 0.4;
}

/* Highlight the active slide (The one in the middle) */
.kiosk-gallery-swiper .swiper-slide-active, .digital-activation-swiper .swiper-slide-active {
    transform: scale(1);
    opacity: 1;
}

.fd-landing-home .kiosk-container .feature-icon {
	width: 26px;
	height: 26px;
	margin-right: 1rem;
	margin-top: 4px;
	flex-shrink: 0;
}

.kiosk-rental-swiper .swiper-wrapper {
    display: flex;
    align-items: stretch;
}

.kiosk-rental-swiper .swiper-slide {
    height: auto;
    display: flex;
}

.kiosk-rental-swiper .swiper-slide > div {
    width: 100%;
    display: flex;
    flex-direction: column;
}

.kiosk-rental-swiper .swiper-slide .row.g-0 {
    flex: 1;
}

.kiosk-rental-swiper .padding-4-rem-all {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.kiosk-rental-swiper h5 {
    margin-bottom: 1.25rem !important;
    line-height: 1.3;
}

.kiosk-rental-swiper p {
	margin-bottom: 1.25rem !important;
    line-height: 1.6;
}

.kiosk-rental-swiper p:last-child,
.kiosk-rental-swiper .mb-0 {
    margin-bottom: 0 !important;
}

.kiosk-rental-swiper .col {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

@media (min-width: 992px) {
	/* Desktop: Left slider, Right text */
	.fd-landing-home .kiosk-rental-section .order-lg-1 {
		padding-right: 2rem;
	}
	
	.fd-landing-home .kiosk-rental-section .order-lg-2 {
		padding-left: 2rem;
	}
}

@media (max-width: 991px) {
	/* Mobile/Tablet: Top text, Bottom slider */
	.fd-landing-home .kiosk-rental-section .order-1 {
		margin-bottom: 0;
	}
	
	.fd-landing-home .kiosk-rental-section .order-2 {
		margin-top: 0;
	}
}

.fd-landing-home .kiosk-small-card img {
	max-width: 300px;
	object-fit: cover;
	width: 100%;
}

@media (max-width: 768px) {
	.integration-capabilities-swiper .scroll-item {
		padding: 0.75rem !important;
	}
	
	.integration-capabilities-swiper .scroll-item img {
		margin-bottom: 0.5rem !important;
	}
}

/* Digitalization Section */
.fd-landing-home .digtal-banner-section {
	background-image: url("/images/kiosk/tech_enabler.jpg");
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	background-color: rgba(0, 0, 0, 0.5);
	background-blend-mode: darken;
}

.fd-landing-home .digtal-banner-section h3,
.fd-landing-home .digtal-banner-section p {
	color: #ffffff !important;
}

@media (max-width: 768px) {
	.fd-landing-home .digtal-banner-section p {
		padding: 0 5vw;
	}

	.fd-landing-home .digtal-banner-section br {
		display: none;
	}
}

@media (max-width: 991px) {
	.md-margin-4-half-rem-bottom {
		margin-bottom: 4.5rem;
	}
	
	.md-padding-6-rem-bottom {
		padding-bottom: 6rem;
	}
	
	.md-w-100 {
		width: 100%;
	}
	
	.md-margin-30px-bottom {
		margin-bottom: 30px;
	}
}

/* Background helper */
.fd-landing-home .bg-light-gray {
	background-color: #f5f5f5;
}

.fd-landing-home .bg-light-darker {
    background-color: #f2f2f2 !important;
}

/* Parallax section */
.parallax {
	position: relative;
}

/* Text utilities */
.last-paragraph-no-margin p:last-child {
	margin-bottom: 0;
}

/* ===== CONTACT PAGE ===== */
/* ===== CONTACT FORM STYLES (Contact Page Only) ===== */
.fd-landing-home .contact-form-card {
	background: #ffffff;
	border-radius: 1rem;
	padding: 3rem;
	box-shadow: 0 8px 30px rgba(0, 0, 0, 0.1);
	transition: all 0.3s ease;
}

.fd-landing-home .contact-form-card:hover {
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.15);
}

.fd-landing-home .contact-input {
	border: 2px solid #e0e0e0;
	border-radius: 0.5rem;
	padding: 1rem 1.25rem;
	font-size: var(--fd-text-body);
	transition: all 0.3s ease;
	background-color: #ffffff;
}

.fd-landing-home .contact-input:focus {
	border-color: var(--fd-primary);
	box-shadow: 0 0 0 0.2rem rgba(38, 105, 158, 0.15);
	outline: none;
}

.fd-landing-home .contact-input::placeholder {
	color: #999;
}

.fd-landing-home textarea.contact-input {
	resize: vertical;
	min-height: 150px;
}

/* Phone Input Group with Country Code */
.fd-landing-home .phone-input-group {
	display: flex;
	gap: 0.75rem;
}

.fd-landing-home .contact-country-select {
	flex: 0 0 130px;
	border: 2px solid #e0e0e0;
	border-radius: 0.5rem;
	padding: 1rem 0.75rem;
	font-size: var(--fd-text-body);
	transition: all 0.3s ease;
	background-color: #ffffff;
	cursor: pointer;
}

.fd-landing-home .contact-country-select:focus {
	border-color: var(--fd-primary);
	box-shadow: 0 0 0 0.2rem rgba(38, 105, 158, 0.15);
	outline: none;
}

.fd-landing-home .contact-phone-input {
	flex: 1;
}

.fd-landing-home #contact-form .lead {
	color: #525253;
}

.fd-landing-home #contact-form .btn {
	background-color: var(--fd-primary);
}

@media (max-width: 768px) {
	.fd-landing-home .contact-form-card {
		padding: 2rem 1.5rem;
	}
}

/* ===== CONTACT FORM STYLES (Contact Page Only) ===== */
.fd-landing-home .contact-form-card {
	background: #ffffff;
	border-radius: 1rem;
	padding: 3rem;
	box-shadow: 0 8px 30px rgba(0, 0, 0, 0.1);
	transition: all 0.3s ease;
}

.fd-landing-home .contact-form-card:hover {
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.15);
}

.fd-landing-home .contact-input {
	border: 2px solid #e0e0e0;
	border-radius: 0.5rem;
	padding: 1rem 1.25rem;
	font-size: var(--fd-text-body);
	transition: all 0.3s ease;
	background-color: #ffffff;
}

.fd-landing-home .contact-input:focus {
	border-color: var(--fd-primary);
	box-shadow: 0 0 0 0.2rem rgba(38, 105, 158, 0.15);
	outline: none;
}

.fd-landing-home .contact-input::placeholder {
	color: #999;
}

.fd-landing-home textarea.contact-input {
	resize: vertical;
	min-height: 150px;
}

.field-hint {
    display: none;
    font-size: 0.85rem;
    margin-top: 4px;
}

.contact-input:focus + .field-hint {
    display: block;
}

/* Hint for mobile field */
.phone-input-group:focus-within + .field-hint {
    display: block;
}

/* Phone Input Group with Country Code */
.fd-landing-home .phone-input-group {
	display: flex;
	gap: 0.75rem;
}

.fd-landing-home .contact-country-select {
	flex: 0 0 100px;
	min-width: 100px;
	border: 2px solid #e0e0e0;
	border-radius: 0.5rem;
	padding: 1rem 0.75rem;
	font-size: var(--fd-text-body);
	transition: all 0.3s ease;
	background-color: #ffffff;
	cursor: pointer;
}

.fd-landing-home .contact-country-select:focus {
	border-color: var(--fd-primary);
	box-shadow: 0 0 0 0.2rem rgba(38, 105, 158, 0.15);
	outline: none;
}

.fd-landing-home .contact-phone-input {
	flex: 1 !important;
	min-width: 0;
}

@media (max-width: 768px) {
	.fd-landing-home .contact-form-card {
		padding: 2rem 1.5rem;
	}
}

/* Form submit button */
.btn-enquiry-submit {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
    font-size: var(--fd-text-body) !important;
    transition: all 0.3s ease-in-out;
}

.btn-enquiry-submit:hover {
    transform: translateY(-3px);
    background-color: #0b5ed7 !important;
}

@media (max-width: 767px) {
    .btn-enquiry-submit {
        font-size: var(--fd-text-body) !important;
        padding-top: 7px !important;
        padding-bottom: 7px !important;
    }
}

@media (min-width: 1200px) {
    .btn-enquiry-submit {
        min-width: 200px;
    }
}

/* Form Validation and Hints */
.fd-landing-home .input-hint {
	font-size: 0.9rem;
	font-style: italic;
	color: #666;
	margin-top: 0.5rem;
	display: block;
	opacity: 0;
	transition: opacity 0.3s ease;
}

.fd-landing-home .input-hint.show {
	opacity: 1;
}

.fd-landing-home .form-error-message {
	background-color: #fee;
	border: 1px solid #fcc;
	border-radius: 0.5rem;
	padding: 1rem 1.25rem;
	color: #c33;
	font-size: var(--fd-text-body);
	margin-bottom: 1rem;
	display: none;
}

.fd-landing-home .form-error-message.show {
	display: block;
}

.fd-landing-home .contact-input.is-invalid {
	border-color: #dc3545;
}

.fd-landing-home .contact-input.is-invalid:focus {
	border-color: #dc3545;
	box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25);
}

body.modal-open {
	overflow: auto !important;
	padding-right: 0 !important;
}

.fd-landing-home .modal {
	z-index: 9999;
}

.fd-landing-home .modal-dialog {
	pointer-events: all;
}

.fd-landing-home .modal-content {
	border-radius: 1rem;
	border: none;
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.3);
}

/* ===== CONTACT OPTIONS LIST (Contact Page Only) ===== */
.fd-landing-home .contact-options-list {
	display: flex;
	flex-direction: column;
	gap: 2rem;
}

.fd-landing-home .contact-option-item {
	background: #ffffff;
	border-radius: 0.75rem;
	padding: 2rem;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
	display: flex;
	align-items: center;
	gap: 1.5rem;
	transition: all 0.3s ease;
}

.fd-landing-home .contact-option-item:hover {
	transform: translateY(-5px);
	box-shadow: 0 8px 25px rgba(0, 0, 0, 0.12);
}

.fd-landing-home .contact-option-icon {
	flex-shrink: 0;
	width: 70px;
	height: 70px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.fd-landing-home .contact-option-icon img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
}

.fd-landing-home .contact-option-content {
	flex: 1;
}

.fd-landing-home .link-arrow {
	color: var(--fd-primary) !important;
	font-weight: 600;
	text-decoration: none;
	transition: transform 0.3s ease;
	display: inline-block;
	margin-top: auto;
}

.fd-landing-home .link-arrow:hover {
	transform: translateX(4px);
}

@media (max-width: 991px) {
	.fd-landing-home .contact-options-list {
		margin-top: 3rem;
	}
}

@media (max-width: 768px) {
	.fd-landing-home .contact-option-item {
		flex-direction: column;
		text-align: center;
		align-items: center;
	}

	.fd-landing-home .contact-option-icon {
		width: 60px;
		height: 60px;
	}
}

/* ===== SOCIAL MEDIA SECTION (Contact Page Only) ===== */
.fd-landing-home .social-section-heading {
	color: #525253 !important;
}

.fd-landing-home .social-divider {
	width: 100%;
	height: 2px;
	background-color: #333;
}

.fd-landing-home .social-icons {
	display: flex;
	gap: 1.5rem;
	justify-content: center;
}

.fd-landing-home .social-icon {
	width: 50px;
	height: 50px;
	border-radius: 50%;
	background-color: #ffffff;
	border: 2px solid var(--fd-primary);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--fd-primary);
	font-size: 1.5rem;
	transition: all 0.3s ease;
	text-decoration: none;
}

.fd-landing-home .social-icon:hover {
	background-color: var(--fd-primary);
	color: #ffffff;
	transform: translateY(-3px);
	box-shadow: 0 6px 15px rgba(38, 105, 158, 0.3);
}

@media (max-width: 768px) {
	.fd-landing-home .social-divider {
		display: none;
	}
}

/* ===== MAP & ADDRESS SECTION (Contact Page Only) ===== */
.fd-landing-home .contact-map-container {
	border-radius: 0.75rem;
	overflow: hidden;
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.1);
	height: 100%;
	min-height: 500px;
}

.fd-landing-home .contact-map {
	width: 100%;
	height: 100%;
	min-height: 500px;
	border: 0;
}

.fd-landing-home .address-header {
	display: flex;
    align-items: center;
    gap: 2;
}

.fd-landing-home .office-addresses {
	display: flex;
	flex-direction: column;
	gap: 2rem;
	height: 100%;
}

.fd-landing-home .office-address-card {
	background: #ffffff;
	border-radius: 0.75rem;
	padding: 2.5rem;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
	transition: all 0.3s ease;
	flex: 1;
	text-align: left;
}

.fd-landing-home .office-address-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 8px 25px rgba(0, 0, 0, 0.12);
}

.fd-landing-home .office-divider {
	width: 100%;
	height: 2px;
	background-color: #e0e0e0;
	margin-bottom: 1.5rem !important;
}

/* Card Contact List Alignment */
.card-contact-list .contact-row {
    display: flex;
    width: 100%;
}

.card-contact-list .icon-col {
    flex: 0 0 45px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.card-contact-list .text-col {
    flex: 1;
    padding-left: 5px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.contact-row.align-items-start .icon-col {
    align-items: flex-start;
    padding-top: 5px;
}

.card-contact-list i {
    width: 25px;
    text-align: center;
    font-size: 1.5rem;
}

.card-contact-list span, 
.card-contact-list a {
    font-size: var(--fd-text-body);
    line-height: 1.5;
    transition: color 0.3s ease;
	color: #525253;
}

.card-contact-list a:hover {
    color: var(--bs-primary) !important;
    text-decoration: underline !important;
}

.align-items-start i {
    margin-top: 4px;
}

.fd-landing-home .office-address-card {
    padding: 2rem !important;
    height: auto !important;
}

.office-addresses .border-top {
    border-color: rgba(0, 0, 0, 0.1) !important;
}

/* Tablet: Side-by-side addresses with centered text */
@media (min-width: 768px) and (max-width: 991px) {
	.fd-landing-home .office-addresses {
		flex-direction: row;
		gap: 1.5rem;
	}

	.fd-landing-home .office-address-card {
		padding: 2rem 1.5rem;
	}
}

@media (max-width: 991px) {
	.fd-landing-home .contact-map-container {
		min-height: 400px;
	}

	.fd-landing-home .contact-map {
		min-height: 400px;
	}

	.fd-landing-home .office-addresses {
		margin-top: 2rem;
	}
}

@media (max-width: 767px) {
	.fd-landing-home .contact-map-container {
		min-height: 350px;
	}

	.fd-landing-home .contact-map {
		min-height: 350px;
	}

	.fd-landing-home .office-address-card {
		padding: 2rem;
		text-align: left;
	}
}