/*=======================

        General

=======================*/
:root {
	--font-size-body: clamp(14px, 0.0111111111* calc(100* var(--vw, 1vw)), 16px);
	--font-size-body-tiny: clamp(10px, 0.0069444444* calc(100* var(--vw, 1vw)), 10px);
	--font-size-body-small: clamp(12px, 0.0083333333* calc(100* var(--vw, 1vw)), 12px);
	--font-size-body-medium: clamp(21px, 0.0145833333* calc(100* var(--vw, 1vw)), 21px);
	--font-size-body-large: clamp(26px, 0.01875* calc(100* var(--vw, 1vw)), 27px);
	--font-size-huge: clamp(56px, 0.0972222222* calc(100* var(--vw, 1vw)), 140px);
	--font-size-h1: clamp(34px, 0.0555555556* calc(100* var(--vw, 1vw)), 80px);
	--font-size-h2: clamp(33px, 0.0423611111* calc(100* var(--vw, 1vw)), 60px);
	--font-size-h3: clamp(28px, 0.0326388889* calc(100* var(--vw, 1vw)), 40px);
	--font-size-h4: clamp(22px, 0.025* calc(100* var(--vw, 1vw)), 30px);
	--font-size-h5: clamp(20px, 0.0208333333* calc(100* var(--vw, 1vw)), 28px);
	--font-size-h6: clamp(22px, 0.0194444444* calc(100* var(--vw, 1vw)), 24px);
}

@media (min-width: 1400px) {
    
	main#primary .entry-content {
        max-width: 1320px;
    }
}

@media (min-width: 1600px) {
    main#primary .entry-content {
        max-width: 1440px;
    }
}

h1.page-title{
	margin-bottom: 50px;
}

main#primary .entry-content{
    margin: 0 auto;
    padding: 100px 18px;
}



html,

body {

	font-family: 'Onsite Std' !important;

	font-weight: 400;

	margin: 0 !important;

	padding: 0;

	font-size: 18px;

	/* background-color: #171717; */

	background: linear-gradient(180deg, #1C1C1E 0%, #1A1A1A 78.54%, #171717 100%);
	overflow-x: hidden;
}

p {
	font-size: var(--font-size-body);
	margin: 0px;

	color: #FFFFFF;

	font-weight: 300;

}

h1, h2, h3, h4, h5, h6 {

	color: #FFFFFF;
	margin: 0;
	font-weight: 300;

}

h1, .h1 {
	font-size: var(--font-size-h1);
	line-height: 1.2;
}

h2, .h2 {
	font-size: var(--font-size-h2);
	line-height: 1.2;
}

h3, .h3 {
	font-size: var(--font-size-h3);
	line-height: 1.2;
}

h4, .h4 {
	font-size: var(--font-size-h4);
	line-height: 1.3;
}

h5, .h5 {
	font-size: var(--font-size-h5);
	line-height: 1.3;
}

h6, .h6 {
	font-size: var(--font-size-h6);
	line-height: 1.3;
}

.has-subtile small {
	font-family: 'GT America Mono';
	font-size: 13.33px;
	line-height: 16.07px;
	width: 162.67px;
	border-top: 1px solid #FFFFFF;
	padding-top: 5px;
	display: inline-block;
	margin-right: 12px;
	text-align: left;
}

h1 span, h2 span, h3 span, h4 span, h5 span, h6 span {
	color: #FF0024;
}

.first-line-wrapper {
	color: #fff !important;
}

a:hover {

	text-decoration: none;

}

a {



	text-decoration: none;

}

:focus {

	outline: none !important;

}

:focus-visible {
	outline: none !important;
}

img {

	max-width: 100%;

}

ul {

	padding: 0;

	margin: 0;

}

ul li {

	list-style: none;

	margin: 0px;

}

.overflow-hidden {
	overflow: hidden !important;
}

.container {
	width: 100%;
	padding-right: 15px;
	padding-left: 15px;
	margin-right: auto;
	margin-left: auto;
}

.row {
	display: flex;
	flex-wrap: wrap;
	margin-right: -15px;
	margin-left: -15px;
}

.col {
	flex-basis: 0;
	flex-grow: 1;
	max-width: 100%;
	padding-right: 15px;
	padding-left: 15px;
}

.col-12 {
	flex: 0 0 100%;
	max-width: 100%;
}



@media (min-width: 768px) {


	.col-md-6 {
		flex: 0 0 50%;
		max-width: 50%;
	}

	.col-md-9 {
		flex: 0 0 70%;
		max-width: 70%;
	}
}

.d-flex {
	display: flex;
}

.justify-content-start {
	justify-content: flex-start;
}

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

.justify-content-end {
	justify-content: flex-end;
}

.align-items-start {
	align-items: flex-start;
}

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

.align-items-end {
	align-items: flex-end;
}

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

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

.flex-column {
	flex-direction: column;
}

.flex-row {
	flex-direction: row;
}

/*=======================

       Page Layout

=======================*/

/* Base container */
.container {
	width: 100%;
	padding-right: var(--bs-gutter-x, 1rem);
	padding-left: var(--bs-gutter-x, 1rem);
	margin-right: auto;
	margin-left: auto;
}

/* Fluid container (full width at all sizes) */
.container-fluid {
	width: 100%;
	padding-right: var(--bs-gutter-x, 2rem);
	padding-left: var(--bs-gutter-x, 2rem);
	margin-right: auto;
	margin-left: auto;
}

/* Container with fixed width at small breakpoint (≥576px) */
@media (min-width: 576px) {
	.container-sm {
		max-width: 540px;
	}
}

/* Container with fixed width at medium breakpoint (≥768px) */
@media (min-width: 768px) {
	.container-md {
		max-width: 98%;
	}
}

/* Container with fixed width at large breakpoint (≥992px) */
@media (min-width: 1200px) {
	.container-lg {
		max-width: 1140px;
	}
}

/* Container with fixed width at extra-large breakpoint (≥1200px) */
@media (min-width: 1400px) {
	.container-xl {
		max-width: 1320px;
	}
}

/* Container with fixed width at extra-extra-large breakpoint (≥1400px) */
@media (min-width: 1600px) {
	.container-xxl {
		max-width: 1440px;
	}
}

.split-parent {
	overflow: hidden;
}

.line {
	overflow: hidden;
}

.word {
	overflow: hidden;
}

.split-child {
	display: inline-block;
	line-height: 1.2;
}

.title-animation div {
	transition: clip-path .9s cubic-bezier(0.215, 0.61, 0.355, 1), transform .9s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition-delay: 0s;
	transform: translate3d(0, 100%, 0);
	clip-path: polygon(-10% -100%, 110% -100%, 110% 0%, -10% 0%);
}

.title-animation.is-inview div {
	display: inline-block !important;
	transform: translate3d(0, 0, 0);
	clip-path: polygon(-10% 0%, 110% 0%, 110% 110%, -10% 110%);
}




.overflow-hidden {
	overflow: hidden;
}

.stagger-by-row,
.stagger-animation,
.fade-right,
.fade-left {
	visibility: hidden;
}

.title-animation {
	opacity: 0;
}

.is-inview.title-animation {
	opacity: 1;
}

@media screen and (min-width: 769px) {
	.fade-animation {
		visibility: hidden;
	}
}


.orbit-main-wrapper {
	width: 45vw;
	/* Use viewport width for consistent scaling */
	height: 45vw;
	/* Set height equal to width for proportional scaling */
	position: absolute;
	right: -10vw;
	top: -10vw;
	opacity: 0;
	transform: scale(0.8);
	/* Keep scale at 1, scale via GSAP animations if needed */
}

.orbit-container {
	position: relative;
	width: 100%;
	height: 100%;
}

/* Central logo styling */
.central-logo {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	display: flex;
	align-items: center;
	justify-content: center;
}

.central-logo svg {
	width: clamp(32%, 8vw, 80%);
	/* Dynamically adjust between 60% and 80%, based on viewport width */
	height: auto;
	/* Maintain aspect ratio */
}

/* Orbit layers */
.orbit {
	position: absolute;
	top: 50%;
	left: 50%;
	border-radius: 50%;
	transform: translate(-50%, -50%);
	/* Use relative sizes for the orbits */
}

.orbit-1 {
	width: 40%;
	/* Set as a percentage of the .orbit-main-wrapper */
	height: 40%;
	/* Keep height and width equal for proportional scaling */
	border: 1.27px solid #fff;
	opacity: 0.2;
}

.orbit-2 {
	width: 60%;
	/* Adjust percentages for different orbits */
	height: 60%;
	border: 1.27px solid #fff;
}

.orbit-3 {
	width: 80%;
	height: 80%;
	border: 1.27px dashed #FF2D2D;
}

.orbit-4 {
	width: 100%;
	height: 100%;
	border: 1.27px solid #fff;
}

/* Icon wrapper */
.icon-wrapper {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 100%;
	height: 100%;
	transform-origin: center;
	transform: translate(-50%, -50%);
}

/* Icons */
.icon {
	position: absolute;
	width: clamp(32px, 5vw, 60px);
	/* Icon size adjusts based on viewport but stays between 40px and 50px */
	height: clamp(32px, 5vw, 60px);
	/* Icon height matches the width */
	background-color: #171717;
	border-radius: 50%;
	border: 1px solid white;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: clamp(8px, 1vw, 10px);
}

.icon svg {
	height: 100%;
	width: 100%;
}

/* Specific icon positions */
/* Icon positioning for different orbits */

/* Orbit 2 Icons */
.icon2-1 {
	top: 0;
	/* Position towards the top */
	left: 50%;
	/* Center horizontally */
	transform: translate(-50%, -50%);
	/* Center within orbit */
}

.icon2-2 {
	bottom: 0;
	/* Positioned towards the bottom */
	left: 50%;
	/* Center horizontally */
	transform: translate(-50%, -50%);
}

.icon2-3 {
	top: 50%;
	/* Midway through the orbit vertically */
	right: 0;
	/* Positioned towards the right */
	transform: translate(50%, -50%);
}

.icon2-4 {
	top: 50%;
	/* Midway through the orbit vertically */
	left: 0;
	/* Positioned towards the right */
	transform: translate(50%, -50%);
}

/* Orbit 4 Icons */
.icon4-1 {
	top: 0;
	left: 50%;
}

.icon4-2 {
	top: 20%;
	left: 10%;
	/* Move to the left side */
	transform: translate(-50%, -50%);
}

.icon4-3 {
	top: 50%;
	/* Middle of the orbit vertically */
	left: 0;
	/* All the way to the left */
	transform: translate(-50%, -50%);
}

.icon4-4 {
	bottom: 20%;
	left: 10%;
	/* Towards the left */
	transform: translate(-50%, 50%);
}

.icon4-5 {
	bottom: 0;
	left: 50%;
	/* Positioned towards the right */
	transform: translate(-50%, 50%);
}

.icon4-6 {
	bottom: 15%;
	right: 5%;
	/* Positioned far right */
	transform: translate(50%, -50%);
}

.icon4-7 {
	top: 20%;
	/* Slightly higher up */
	right: 10%;
	/* Towards the right */
	transform: translate(50%, -50%);
}

.icon4-8 {
	top: 50%;
	/* Slightly higher up */
	right: 0;
	/* Towards the right */
	transform: translate(50%, -50%);
}


.loading-screen {
	z-index: 99999;
	background-color: #171717;
	opacity: 1;
	pointer-events: auto;
	justify-content: center;
	align-items: center;
	display: flex;
	position: fixed;
	inset: 0;
}

.loading-screen__icon {
	height: 100px;
	width: 100px;
	position: relative;
	padding: 10px;
}

.loading-screen__icon>svg {
	height: 100%;
	width: 100%;
}

.loading-screen__icon-dark {
	background-color: #171717;
	opacity: 0.9;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	/* Initially start out of view (at the bottom) */
	left: 0;
	transform: translateY(0%);
	/* Start from the bottom */
}

.transition-screen__loading {
	right: 15px;
	bottom: 15px;
	width: 3em;
	position: absolute;
	z-index: 9;
}

.has-parallax-effect {
	height: 130%;
}


.img-cover {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	position: absolute;
	top: 0;
}


.desc-text-s2 span {
	position: relative;
	z-index: 1;
	/* Ensure the text stays above the glow */
}

.position-relative {
	position: relative !important;
}

.has-glow-animation {
	position: relative;
}

.has-glow {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(255, 54, 54, 0.5);
	filter: blur(50px);
	opacity: 0;
	/* Initially hidden */

	/* Behind the text */
	transition: opacity 0.3s ease;
	/* Smooth transition for show/hide */
}



.moving-glow {
	position: absolute;
	top: 40%;
	left: 50%;
	width: 60%;
	/* You can adjust the size as needed */
	height: 60%;
	border-radius: 100vw;
	/* Huge radius to make it a smooth circle */
	background: rgba(255, 54, 54, 0.2);
	/* Soft red glow */
	filter: blur(222.55px);
	/* Blur effect to create a glow */
	pointer-events: none;
	/* Disable interaction */

	/* Ensure it stays behind the content */
	transform: translate(-50%, -50%);
	/* Center it at start */
}

.mfp-close-btn-in .mfp-close {
	font-size: 54px;
	font-weight: 300;
	padding: 2px;
	right: 15px;
	top: 16px;
	color: #fff;
	font-family: 'Onsite Std';
}

@media screen and (min-width: 1600px) {
	.orbit-main-wrapper {
		width: 800px;
		height: 800px;
	}

	.main-home-page .hero-section #scroll_animation {
		bottom: -200px !important;
	}

	.main-home-page .hero-section {
		padding: 180px 0 180px 0 !important;
	}
}

/* Fade-in transition */
.mfp-wrap.mfp-fade-in.mfp-ready {
	opacity: 1;
	transition: all 0.3s ease-in-out;
	/* Adjust duration and easing as needed */
}

.mfp-fade-in.mfp-removing {
	opacity: 0;
	transition: all 0.3s ease-in-out;
}

/* Example for a zoom-in effect */
.mfp-fade-in.mfp-ready .mfp-content {
	transform: scale(1);
	opacity: 1;
}

.mfp-fade-in.mfp-removing .mfp-content {
	transform: scale(0.9);
	/* Scale down when closing */
	opacity: 0;
}

.img-cover {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	position: absolute;
	top: 0;
}

.has-parallax-effect {
	height: 150%;
}

.zoom-in {
	opacity: 0;
	/* Start invisible */
	transform: scale(1.2);
	/* Start slightly zoomed in */
	transition: none;

}

@media (max-width: 767px){
	main#primary .entry-content{
		padding: 70px 18px;
	}
}