:root {
	--fd-primary: #26699E;
	--fd-primary-dark: #1144A1;
	--fd-primary-darker: #002A86;
	--fd-primary-light: #21A0D7;
	--fd-text-body: 1.0rem;
	--fd-text-lead: 1.4rem;
	--fd-heading: 3rem;
	--bs-btn-hover-bg1: #184d77!important;
	--bs-btn-bg1: #26699e!important;
	--step-size: 120px;
	--glass-bg: rgba(255, 255, 255, 0.8);
	--primary-gradient: linear-gradient(135deg, #0d6efd 0%, #0a58ca 100%);
}

body {
	font-family: 'Poppins', sans-serif !important;
}

.rounded-pill {
	background-color: var( --bs-btn-bg1);
}

.rounded-pill:hover {
	background-color: var(--bs-btn-hover-bg1);
}

.rounded-pill-white {
	background-color: white;
	color: var( --bs-btn-bg1);
}

.rounded-pill-white:hover {
	background-color: white;
	color: var(--bs-btn-hover-bg1);
}

.fd-landing-home .lead, .fd-landing-home p.lead {
	font-size: var(--fd-text-lead);
	line-height: 1.6;
}

@media (min-width: 1600px) {
}

@media (max-width: 768px) {
	.fd-landing-home .lead {
		font-size: max(1.25rem, var(--fd-text-lead));
	}
}

.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;
}

.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;
}

@media (min-width: 1600px) {
	:root {
		--fd-heading: 4rem;
		--fd-text-body: 1.15rem;
		--fd-text-lead: 1.4rem;
	}

	.fd-landing-home h2 {
		font-size: 2.90rem;
	}

	.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.55rem, 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); }
}

@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.55rem, 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); }
}

@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;
}

.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: 80px !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%;
	text-transform: uppercase;
}

.fd-landing-home .hero-section h2 {
	text-wrap: balance;
    max-width: 100%;
	text-transform: uppercase;
}

.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;
}

.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%;
	}
}

.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;
	}
}

.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;
	}
}

#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) {
    .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; 
    }
}

.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),
.fd-landing-home .scroll-item a {
    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: 1.25rem !important;
    flex-grow: 0;
}

.fd-landing-home .scroll-item a {
    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;
	}
	
	.data-visual-container .smaller, .data-visual-container .text-primary, .data-visual-container .text-success {
        font-size: 1rem;
    }
}

@media (max-width: 375px) {
	.data-visual-container .smaller, .data-visual-container .text-primary, .data-visual-container .text-success {
        font-size: 0.85rem;
    }
}

@media (max-width: 320px) {
	.data-visual-container .smaller, .data-visual-container .text-primary, .data-visual-container .text-success {
        font-size: 0.65rem;
    }
}

.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;
    }

    .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-premium"]	{
        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);
    }
}

.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%;
	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%;
	}
}

@media (max-width: 991px) {
	.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;
    }
}

.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;
    }
}

.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;
	}
}

.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;
}

.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: 0px !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 .scroll-dots {
		display: flex !important;
	}
}

@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 .case-header {
		min-height: 180px; 
		display: flex;
		flex-direction: column;
		justify-content: center;
	}
}

@media (max-width: 768px) {
	.fd-landing-home .cases-container br, .fd-landing-home .footer-application br {
		display: none;
	}
}

.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;
}

.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);
}

.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);
}

@media (max-width: 768px) {
	.fd-landing-home .animate.fade-left,
	.fd-landing-home .animate.fade-right {
		transform: translateY(20px);
	}
}

#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; 
    }
}

.fd-landing-home .solutions-container {
	position: relative;
	max-width: 100% !important;
	padding: 0 !important;
}

.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;
}

.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;
}

.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;
}

@media (max-width: 1400px) {
	.fd-landing-home .solution-card {
		padding: 2rem 10%;
	}
}

@media (max-width: 991px) {
	.fd-landing-home .solution-card {
		padding: 2rem 5%;
	}
}

@media (max-width: 768px) {
	.fd-landing-home .solution-card {
		padding: 2rem 4%;
	}
	
	.fd-landing-home .solutions-row {
		scroll-snap-type: x proximity;
		-webkit-overflow-scrolling: touch;
	}
}

.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; 
}

#registration-section .revenue-icon, #gift-redemption-section .revenue-icon {
    max-width: 20px !important;
    height: auto !important;
	object-fit: contain !important;
	aspect-ratio: auto !important;
}

.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);
}

.solution-card .row.g-3 img {
    width: 100%;
    height: 250px;
    object-fit: cover;
    border-radius: 8px;
    display: block;
}

.video-preview, .portfolio-image {
    height: 250px;
    overflow: hidden;
    border-radius: 8px;
    background-color: #eee;
}

.absolute-middle-center {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 2;
}

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);
}

.popup-video-interactive {
    cursor: pointer;
}

.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);
}

.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;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-user-drag: none;
    user-drag: none;
    pointer-events: none;
}

@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;
    }
}

.fd-landing-home .solution-card video {
	max-width: 100%;
	height: auto;
}

.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);
}

#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;
}

.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; 
    }
}

#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;
}

.kiosk-gallery-swiper .swiper-slide, .digital-activation-swiper .swiper-slide {
    transition: all 0.5s ease;
    transform: scale(0.85);
    opacity: 0.4;
}

.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) {
	.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) {
	.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;
	}
}

.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;
	}
}

.fd-landing-home .bg-light-gray {
	background-color: #f5f5f5;
}

.fd-landing-home .bg-light-darker {
    background-color: #f2f2f2 !important;
}

.parallax {
	position: relative;
}

.last-paragraph-no-margin p:last-child {
	margin-bottom: 0;
}

.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;
}

.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;
	}
}

.field-hint {
    display: none;
    font-size: 0.85rem;
    margin-top: 4px;
}

.contact-input:focus + .field-hint {
    display: block;
}

.phone-input-group:focus-within + .field-hint {
    display: block;
}

.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-phone-input {
	flex: 1 !important;
	min-width: 0;
}

.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: #215b89 !important;
    border-color: #215b89 !important;
}

@media (max-width: 767px) {
    .btn-enquiry-submit {
        font-size: var(--fd-text-body) !important;
        padding-top: 7px !important;
        padding-bottom: 7px !important;
    }
}

@media (max-width: 380px) {
    #contact-form .cf-turnstile {
        transform: scale(0.85);
        transform-origin: center center;
        margin-left: auto;
        margin-right: auto;
        width: 100%;
        display: flex;
        justify-content: center;
    }
}

@media (max-width: 330px) {
     #contact-form .cf-turnstile {
        transform: scale(0.75);
    }
}

@media (min-width: 1200px) {
    .btn-enquiry-submit {
        min-width: 200px;
    }
}

.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);
}

.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.text-white {
	color:white !important;
}

.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;
	}
}

.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;
	}
}

.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 .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;
}

@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;
	}
}

.navbar-toggler {
	margin-left: auto;
}

.icon-padding {
	padding-left: 10px;
	height: 90%;
	width: 90%;
}

.mw-md-400 {
    max-width: 100%;
}

@media (min-width: 768px) {
    .mw-md-400 {
        max-width: 400px !important;
        width: 100%; 
        margin: 0 auto;
    }
}

.bg-primary-soft { background-color: rgba(13, 50, 94, 0.08); }
.bg-white-soft { background-color: rgba(255, 255, 255, 0.12); }
.bg-danger-soft { background-color: rgba(220, 53, 69, 0.08); }
.hover-lift { transition: all 0.3s ease; }
.hover-lift:hover { transform: translateY(-8px); box-shadow: 0 15px 35px rgba(0,0,0,0.1) !important; }
.filter-light { filter: brightness(0) invert(1); opacity: 0.9; }
.transition { transition: all 0.3s cubic-bezier(.25,.8,.25,1); }
.shadow-hover:hover { transform: translateY(-10px); box-shadow: 0 20px 40px rgba(0,0,0,0.08) !important; }
.overlay-badge { position: absolute; top: 1rem; left: 1rem; padding: 0.4rem 0.8rem; border-radius: 4px; color: white; font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; z-index: 10; }
.icon-circle { width: 45px; height: 45px; display: flex; align-items: center; justify-content: center; border-radius: 12px; font-size: 1.25rem; }
.card-img-top { height: 160px; object-fit: cover; transition: 0.5s; }
.card:hover .card-img-top { transform: scale(1.05); }
.card { border-radius: 15px !important; }

section {
    padding: 100px 0;
}

#contact-form {
    background-color: #0b4f8e;
}

.bg-smoky-black {
    background-color: #041c3c;
}

.bg-info {
    background-color: rgb(30 176 205) !important;
}

.navbar-toggler .navbar-toggler-line
{
    background: #0b4f8e!important;
}

.dropdown-menu li a {
    font-size: 0.9rem;
    padding: 10px 20px;
    color: white;
}

.header-button .btn-dark-gray {
    background-color: var(--fd-primary);
    border: none;
    border-radius: 50px !important;  
    padding: 8px 25px !important; 
    font-weight: 600 !important;
    color: #fff !important;
    text-transform: none;
}

.navbar .dropdown-menu {
    min-width: 220px !important;   
    padding-top: 10px !important;
    padding-bottom: 10px !important;
    border-radius: 12px !important;   
    margin-top: -5px !important;   
    border: 1px solid rgba(0,0,0,0.05) !important;
    box-shadow: 0 10px 25px rgba(0,0,0,0.1) !important;
}

.navbar .dropdown-menu li {
    margin-bottom: 0 !important;   
}
 
.navbar .dropdown-menu li a {
    padding: 0px !important;   
    font-size: 0.95rem !important;
    font-weight: 400 !important;
    color: #333 !important;
    display: block;
    transition: all 0.2s ease;
}

.navbar .dropdown-menu li a:hover,.dropdown-menu  li a:hover {
    padding-left: 5px !important;   
}

@media (min-width: 1200px) {
    .navbar .dropdown-menu {
        margin-top: 0 !important;   
        border-top: 3px solid var(--fd-primary);
        box-shadow: 0 10px 30px rgba(0,0,0,0.1);
    }
}
.mb-2r
{
	margin-bottom: 2rem;
}
.workflow-step { 
	position: relative; 
	padding: 0 15px;
}

.step-icon-wrap {
	width: var(--step-size);
	height: var(--step-size);
	border-radius: 50%;
	overflow: hidden;  
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 1.5rem;
	box-shadow: 0 10px 30px rgba(0,0,0,0.1);
	border: 4px solid #fff;  
	background: #fff; 
}

.step-icon-wrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;  
	object-position: center;
	transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.workflow-step:hover img {
	transform: scale(1.1);
}

@media (min-width: 992px) {
	.workflow-step:not(:last-child)::after {
		content: "";
		position: absolute;
		top: calc(var(--step-size) / 2);
		right: -20%;
		width: 40%;
		height: 2px;
		border-top: 2px dashed #cbd5e0;
		z-index: 0;
	}
} 
.transformation-box {
	background: var(--glass-bg);
	backdrop-filter: blur(10px);
	border: 1px solid rgba(13, 110, 253, 0.1);
	transition: all 0.4s ease;
}
.transformation-box:hover {
	border-color: #0d6efd;
	box-shadow: 0 20px 40px rgba(13, 110, 253, 0.05);
}

.feature-icon-circle {
	width: 60px;
	height: 60px;
	background: var(--primary-gradient);
	border-radius: 18px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1.5rem;
	box-shadow: 0 10px 20px rgba(13, 110, 253, 0.2);
}
.scroll-item {
	padding: 2rem;
	border-radius: 2rem;
	background: #fff;
	border: 1px solid #f1f1f1;
	transition: transform 0.3s ease;
}
.scroll-item:hover { transform: translateY(-5px); }

.scenario-card {
	background: #fff;
	border-radius: 1.5rem;
	padding: 2rem;
	border-left: 5px solid #26699e;
	box-shadow: 0 5px 15px rgba(0,0,0,0.02);
}
.data-visual-container {
	background: linear-gradient(20deg, #2d95e8, #9adafd, #41b6fa);
	border-radius: 2rem;
	padding: 3rem;
	box-shadow: 0 40px 80px rgba(0,0,0,0.07);
	position: relative;
	overflow: hidden;
}

.floating-badge {
	position: absolute;
	top: 20px;
	right: 20px;
    background: rgb(13 13 13 / 10%);
    color: #ffffff;
	padding: 8px 16px;
	border-radius: 50px;
	font-weight: bold;
	font-size: 0.85rem;
}

.transformation-card {
	border: 1px solid #eef2f7;
	background: #fff;
	transition: all 0.3s ease;
}

.transformation-card:hover {
	border-color:#26699E;
	transform: translateX(10px);
}
.text-dark {
    color: rgb(66 71 74) !important
}
.text-primary-2
{
	color:#1f7ac1;
}
.bg-soft
{
	background-color:#ecfaff;
}
.bento-grid {
	display: grid;
	grid-template-columns: repeat(12, 1fr);
	gap: 24px;
}

.bento-item {
	background: #ffffff;
	border: 1px solid rgba(38, 105, 158, 0.1); /* Subtle brand tint */
	border-radius: 24px;
	padding: 40px;
	height: 100%;
	transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
}

.bento-item:hover {
	transform: translateY(-8px);
	box-shadow: 0 20px 40px rgba(38, 105, 158, 0.12);
	border-color: var(--fd-primary);
}

.span-8 { grid-column: span 8; }
.span-4 { grid-column: span 4; }

.bento-item h3 {
	color: var(--fd-primary);
	font-size: 1.8rem;
	font-weight: 800;
	margin-bottom: 16px;
	line-height: 1.2;
	white-space: normal;
	word-break: keep-all; 
	overflow-wrap: break-word;
	hyphens: none;
}

.bento-item p {
	font-size: var(--fd-text-body);
	color: #555;
	line-height: 1.6;
}

.icon-box-large {
	width: 64px;
	height: 64px;
	/* background: rgba(38, 105, 158, 0.08);   */
	border-radius: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 24px;
	flex-shrink: 0;
}

.icon-box-large img {
	width: 32px;  
	height: 32px;
	object-fit: contain;
}

.bento-cta {
    background: #0871ba;
    color: white;
}
.bento-img-top {
	width: calc(100% + 80px); 
	margin: -40px -40px 30px -40px; 
	height: 200px;
	overflow: hidden;
}

.bento-img-top img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s ease;
}

.bento-item:hover .bento-img-top img {
	transform: scale(1.1);
}

.bento-flex-row {
	display: flex;
	flex-direction: row;
	gap: 30px;
	align-items: center;
}

@media (max-width: 768px) {
	.bento-flex-row { flex-direction: column; }
	.bento-img-top { width: calc(100% + 60px); margin: -30px -30px 20px -30px; }
}
@media (max-width: 992px) {
	.bento-grid { grid-template-columns: 1fr; }
	.span-8, .span-4 { grid-column: span 1; }
	.bento-item { padding: 30px; }
	.bento-item h3 { font-size: 1.5rem; }
}
 .faq-wrapper {
	max-width: 900px;
	margin: 0 auto;
}

.faq-card {
	border: 1px solid #edf2f7 !important;
	border-radius: 20px !important;
	margin-bottom: 16px;
	overflow: hidden;
	transition: all 0.3s ease;
	background: #fff;
}

.faq-card:hover {
	border-color: var(--fd-primary-light) !important;
	box-shadow: 0 10px 25px rgba(38, 105, 158, 0.05);
}

.faq-button {
	padding: 24px 30px !important;
	font-size: 1.15rem !important;
	font-weight: 700 !important;
	color: var(--fd-primary) !important;
	background-color: #fff !important;
	box-shadow: none !important;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.faq-button::after {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2326699E' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") !important;
	background-size: 1.25rem;
	transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.faq-button:not(.collapsed) {
	color: var(--fd-primary) !important;
	background-color: rgba(38, 105, 158, 0.02) !important;
}

.faq-body {
	padding: 0 30px 24px 30px !important;
	color: #555;
	line-height: 1.7;
	font-size: var(--fd-text-body);
}

.faq-card.active {
	border-color: var(--fd-primary) !important;
}
.cta-title {
	font-size: var(--fd-heading);
	letter-spacing: -1px;
}

.cta-subtitle {
	font-size: var(--fd-text-lead);
	max-width: 600px;
	margin: 0 auto 2.5rem;
} 

.bento-icon-img {
    width: 48px;
    height: 48px;
    object-fit: contain;
    margin-bottom: 20px;
}

.kiosk-gallery-item {
    transition: transform 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
    border-radius: 24px;
    overflow: hidden;
}

.kiosk-gallery-item:hover {
    transform: scale(1.02);
}

.feature-list-check {
    width: 24px;
    height: 24px;
    flex-shrink: 0;
    margin-top: 4px;
}

.cta-banner-bg {
    background: linear-gradient(rgba(38, 105, 158, 0.9), rgba(17, 68, 161, 0.9)), url("/images/kiosk/tech_enabler.jpg");
    background-size: cover;
    background-position: center;
    border-radius: 32px;
}

/* FAQ Customization to match Bento style */
.faq-section-wrapper {
    background-color: var(--bg-soft);
    border-radius: 32px;
    padding: 60px 0;
}

.experience-anchor {
	position: relative;
	padding: 40px;
	background: linear-gradient(145deg, #ffffff, #f0f7ff);
	border-radius: 40px;
	box-shadow: 0 30px 60px rgba(38, 105, 158, 0.08);
}

.overlap-feature {
	background: #fff;
	border-radius: 24px;
	padding: 25px;
	box-shadow: 0 15px 35px rgba(0,0,0,0.05);
	border: 1px solid rgba(38, 105, 158, 0.1);
	transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
	margin-bottom: 20px;
	display: flex;
	align-items: center;
	gap: 20px;
}

.overlap-feature:hover {
	transform: scale(1.03) translateX(10px);
	border-color: var(--fd-primary);
	box-shadow: 0 20px 45px rgba(38, 105, 158, 0.1);
}

.anchor-glow {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 120%;
	height: 120%;
	background: radial-gradient(circle, rgba(33, 160, 215, 0.1) 0%, rgba(255,255,255,0) 70%);
	transform: translate(-50%, -50%);
	z-index: 0;
}

.anchor-img {
	position: relative;
	z-index: 1;
	border-radius: 20px;
	filter: drop-shadow(0 20px 30px rgba(0,0,0,0.1));
}

.premium-check-list {
	border-top: 2px solid #f1f5f9;
	padding-top: 30px;
	margin-top: 30px;
}
.fd-badge-eyebrow {
	background-color: rgba(38, 105, 158, 0.08); /* 8% opacity of your primary blue */
	color: var(--fd-primary);
	font-size: 0.75rem; /* Small but readable */
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	padding: 6px 16px;
	border-radius: 50px; /* Perfect pill shape */
	display: inline-block;
	border: 1px solid rgba(38, 105, 158, 0.15); /* Subtle border for definition */
}
.split-rental-card .rental-img-side {
	flex: 0 0 35%; /* Reduced width from 50% to 35% for a slim look */
	min-height: 450px; /* Increased height */
	background-size: cover;
	background-position: center;
	border: 1px solid rgba(0,0,0,0.05);
}

.split-rental-card .col-md-6.p-5 {
	flex: 0 0 65%; /* Content takes more space */
}

/* Ensure dots are visible and themed */
.scroll-dots[data-dots-for="kiosk-rental-premium"] {
	display: flex !important;
	justify-content: center;
	margin-top: 30px;
	opacity: 1 !important;
	visibility: visible !important;
}

@media (max-width: 767px) {
	.split-rental-card .row {
		flex-direction: column;
	}
	.split-rental-card .rental-img-side {
		flex: 0 0 100%;
		min-height: 350px;
	}
}

/*Admin Portal*/
body.page-admin-login header .navbar-nav .nav-link { 
    color: #000000 !important; 
}

body.page-admin-login .navbar-toggler {
    pointer-events: none;
}

.admin-portal .bg-dark {
    background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%) !important;
}
	
@media (min-width: 992px) {
    .admin-portal .min-vh-lg-100 {
        min-height: 100vh !important;
    }
}

.admin-portal .field-hint {
    display: none;
    transition: opacity 0.3s ease;
}

.admin-portal .form-control:focus ~ .field-hint {
    display: block;
}

.admin-portal .position-relative:focus-within ~ .field-hint {
    display: block;
}

.admin-portal #togglePassword:focus {
    box-shadow: none !important;
}

@media (max-width: 991.98px) {
	.admin-portal .row.min-vh-lg-100 {
        min-height: auto !important;
    }

    .admin-portal .col-lg-6.bg-light {
        position: relative;
        overflow: hidden;
        padding: 1.5rem;
    }
	
	body .admin-portal {
        overscroll-behavior-y: contain;
    }

    body .admin-portal, html .admin-portal {
        background-color: #f8f9fa;
    }
	
	.admin-portal h2 {
		font-size: 2.5rem;
	}

    .admin-portal .login-card {
        box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075) !important;
        margin-top: 2rem;
        margin-bottom: 2rem;
		margin-left: auto;
        margin-right: auto;
		position: relative;
        z-index: 1;
    }
	
	.admin-portal .bg-light::before {
        content: "";
        position: absolute;
        top: -50px;
        right: -50px;
        width: 200px;
        height: 200px;
        background: rgba(13, 110, 253, 0.05);
        border-radius: 50%;
        z-index: 0;
    }
	
	.admin-portal .bg-light {
        background: radial-gradient(circle at top left, #f0f4f8 0%, #ffffff 100%) !important;
    }
}

@media (max-width: 576px) {
    .admin-portal .login-card {
        border-radius: 1.5rem !important;
        margin: 1rem;
        padding: 2rem !important;
    }
    
    .admin-portal .display-4 {
        font-size: 2.5rem;
    }
}