:root {
	--electric-purple: #9810fa;
	--deep-void-purple: #542985;
	--deep-void-purple: #59168b;
	--royal-electric: #6e3e99;
	--ethereal-violet: #966eb7;
	--neon-violet: #966eb7;
	--glitch-lavender: #b38ec9;
	--crimson-violet: #861043;
	--cyber-pink: #ec4899;
	--black: #000000;
	--white: #ffffff;
	--oxford-blue: #101828;
	--inky-navy: #06080f;
	--deep-steel: #1e2939;
	--cool-gray: #99a1af;
	--alert-red: #fb2c36;
	--caution-gold: #f0b100;
	--emerald-green: #00c950;
	--deep-forest-green: #006327;
	--azure-glow: #2b7fff;
	--cyber-cyan: #00b8db;
	--urbanist: "Urbanist", sans-serif;
	--border-color: rgba(255, 255, 255, 0.2);
	--fs: 18px;
	--fs-small: 16px;
	--fs-large: 20px;
	--line-height-base: 1.5;
	--border-radius: 16px;
	--box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

/* T Y P O G R A P H Y */
html {
	scroll-behavior: smooth;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

body {
	background-color: #050505 !important;
	font-size: var(--fs) !important;
	color: var(--white) !important;
	font-family: var(--urbanist) !important;
	line-height: 30px !important;

	@media (max-width: 1024px) {
		font-size: 18px;
	}

	@media (max-width: 767px) {
		font-size: var(--fs-small);
	}
}

a {
	color: var(--white) !important;
	transition: 0.3s all;

	&:hover {
		color: var(--gold) !important;
	}

	@media (max-width: 767px) {
		font-size: var(--fs-small);
	}
}

.text-large {
	font-size: var(--fs-large);
}

.text-small {
	font-size: var(--fs-small);
}

p:only-of-type,
p:last-child {
	margin-bottom: 0;
}

ul,
ol {
	padding-left: 18px !important;

	li {
		&::marker {
			color: var(--gold) !important;
		}
	}
}

.text-gray {
	color: var(--cool-gray) !important;
}

.text-gold {
	color: var(--caution-gold) !important;
}

.text-violet {
	color: var(--ethereal-violet) !important;
}

.text-purple {
	color: var(--electric-purple) !important;
}

.current_page_item {
	a {
		color: var(--gold) !important;
	}
}

.line-clamp-2 {
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.line-clamp-3 {
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.line-clamp-4 {
	display: -webkit-box;
	-webkit-line-clamp: 4;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.aspect-ratio-inherit {
	aspect-ratio: inherit !important;
}

.highlight {
	background: linear-gradient(
		90deg,
		var(--Electric-Purple, #9810fa) 50%,
		var(--Crimson-Violet, #861043) 100%
	);
	background-clip: text;
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	font-weight: 700;
}

h1,
.heading-1 {
	color: var(--white);
	font-size: 64px;
	font-weight: 400;
	line-height: 80px;

	@media (max-width: 1024px) {
		font-size: 34px;
		line-height: 43px;
	}

	@media (max-width: 767px) {
		font-size: 28px;
		line-height: 38px;
	}
}

h2,
.heading-2 {
	color: var(--white);
	font-size: 40px;
	font-weight: 400;
	line-height: 35px;

	@media (max-width: 1024px) {
		font-size: 32px;
	}

	@media (max-width: 767px) {
		font-size: 24px;
	}
}

h3,
.heading-3 {
	color: var(--white);
	font-size: 30px;
	font-weight: 700;
	line-height: 1.4;

	@media (max-width: 1024px) {
		font-size: 22px;
	}

	@media (max-width: 767px) {
		font-size: 20px;
	}
}

/* C O N T A I N E R*/
section {
	position: relative;
	> .container {
		width: 100%;
		max-width: 1340px !important;
		padding: 60px 20px !important;

		@media (max-width: 1024px) {
			margin: 0 !important;
			padding: 50px 30px !important;
		}

		@media (max-width: 767px) {
			padding: 40px 20px !important;
		}
	}
}

/* H E A D E R */
header {
	position: relative;
	background: rgba(0, 0, 0, 0.6);
	backdrop-filter: blur(25px);
	width: 100%;
	z-index: 9999;

	> .container {
		width: 100%;
		max-width: 1340px !important;

		@media (max-width: 1024px) {
			margin: 0 !important;
		}

		@media (max-width: 767px) {
		}
	}

	.desktop-header {
		display: block;
		padding-top: 10px;
		padding-bottom: 10px;

		@media (max-width: 1024px) {
			display: none;
		}

		img {
			width: 180px;
			height: auto;
		}
	}

	.mobile-header {
		display: none;

		@media (max-width: 1024px) {
			display: block;
		}

		.row {
			padding: 10px;
			.col {
				.mobile-logo {
					width: 170px;
					height: auto;
					object-fit: contain;
				}

				.icon-link {
					font-size: 24px;
				}

				.menu-wrapper {
					width: 30px;
					height: 30px;
					margin-top: 4px;
					cursor: pointer;

					.hamburger-menu {
						width: 30px;
						height: 4px;
						position: relative;
						transform: translateY(25px);
						background: rgba(255, 255, 255, 1);
						transition: all 0ms 300ms;

						&.animate {
							background: rgba(255, 255, 255, 0);

							&:after {
								top: 0;
								transform: rotate(45deg);
								transition:
									top 300ms cubic-bezier(0.23, 1, 0.32, 1),
									transform 300ms 300ms
										cubic-bezier(0.23, 1, 0.32, 1);
							}

							&:before {
								bottom: 0;
								transform: rotate(-45deg);
								transition:
									bottom 300ms cubic-bezier(0.23, 1, 0.32, 1),
									transform 300ms 300ms
										cubic-bezier(0.23, 1, 0.32, 1);
							}
						}

						&:after {
							width: 30px;
							height: 4px;
							content: "";
							position: absolute;
							left: 0;
							top: 10px;
							background: rgba(255, 255, 255, 1);
							transition:
								top 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1),
								transform 300ms cubic-bezier(0.23, 1, 0.32, 1);
						}

						&:before {
							width: 30px;
							height: 4px;
							content: "";
							position: absolute;
							left: 0;
							bottom: 10px;
							background: rgba(255, 255, 255, 1);
							transition:
								bottom 300ms 300ms
									cubic-bezier(0.23, 1, 0.32, 1),
								transform 300ms cubic-bezier(0.23, 1, 0.32, 1);
						}
					}
				}
			}
		}
	}
}

/* F O O T E R */
footer {
	background: rgba(0, 0, 0, 0.6);
	backdrop-filter: blur(25px);
	border-top: 0.5px solid var(--deep-steel, #1e2939);

	.container {
		width: 100%;
		max-width: 900px !important;

		@media (max-width: 1024px) {
			margin: 0 !important;
		}

		@media (max-width: 767px) {
		}

		.row {
			@media (max-width: 1024px) {
				flex-direction: column;
			}

			.nav-wrapper {
				@media (max-width: 1024px) {
					margin-top: 10px;
				}
			}

			.col {
				width: max-content;

				a {
					font-size: 14px;
					color: var(--cool-gray) !important;
					font-weight: 600;
					transition: 0.3s all;
					text-decoration: none;

					&:hover {
						color: var(--ethereal-violet) !important;
					}

					img {
						width: 180px;
						height: auto;
						margin-top: -10px;
						margin-left: -10px;
					}
				}

				p {
					font-size: 14px !important;
					color: var(--cool-gray) !important;
				}

				i {
					margin-right: 10px;

					&:hover {
						&:before {
							color: var(--electric-purple);
							transition: 0.3s all;
						}
					}

					&:before {
						font-size: 30px;
						color: var(--royal-electric);
					}
				}

				ul {
					padding-left: 0 !important;
				}
			}
		}

		.copyright-wrapper {
			.copyright {
				font-size: 14px;
				color: var(--cool-gray);
			}
		}
	}
}

#mobileMenuModal {
	overflow: hidden;
	top: 80px !important;

	.modal-dialog {
		.modal-content {
			background: var(--black);

			.modal-body {
				display: flex;
				flex-direction: column;
				flex-wrap: nowrap;
				align-items: flex-start;
			}
		}
	}

	.background-gradient {
		position: absolute;
		top: 0;
		right: 0;
		background: var(--deep-void-purple);
		filter: blur(400px);
		width: 50%;
		height: 1000px;
		z-index: 1;
	}
}

/* N A V */
.nav {
	.menu-item {
		a {
			color: var(--cool-gray) !important;
			display: block;
			font-size: 14px;
			font-weight: 600;
			text-decoration: none;
		}

		&:hover {
			a {
				color: var(--ethereal-violet) !important;
			}
		}

		&.current-menu-item {
			a {
				color: var(--ethereal-violet) !important;
			}
		}
	}
}

/* B U T T O N S */
.btn {
	padding: 10px 12px !important;
	border-radius: 10px !important;
	transition: opacity 0.3s ease;

	.button-wrapper {
		.button-text {
			font-size: 14px;
			font-weight: 600;
			line-height: 20px;
		}
	}

	&.btn-primary {
		position: relative;
		display: flex;
		justify-content: center;
		align-items: center;
		border: none;
		overflow: hidden;
		background: linear-gradient(
			92deg,
			var(--electric-purple, #9810fa) 0%,
			var(--cyber-pink, #ec4899) 100%
		);

		.button-wrapper {
			display: flex;
			flex-direction: row;
			align-items: center;
			gap: 10px;
			position: relative;
			z-index: 2;
		}

		&::before {
			content: "";
			position: absolute;
			inset: 0;
			background: var(--royal-electric);
			opacity: 0;
			z-index: 1;
			transition: 0.3s all;
		}

		&:hover::before {
			opacity: 1;
		}
	}

	&.btn-secondary {
		position: relative;
		display: flex;
		justify-content: center;
		align-items: center;
		border: none;
		overflow: hidden;
		background: var(--white);

		&:hover {
			background-color: var(--royal-electric);

			.button-wrapper {
				.button-text {
					color: var(--white);
				}
			}
		}

		.button-wrapper {
			position: relative;
			z-index: 2;

			.button-text {
				color: var(--deep-void-purple);
			}
		}
	}

	&.btn-download {
		position: relative;
		display: flex;
		justify-content: center;
		align-items: center;
		border: none;
		overflow: hidden;
		background: var(--deep-void-purple, #542985);
		box-shadow: 0 0 5px 0 var(--ethereal-violet, #966eb7);

		&:hover {
			background: var(--royal-electric, #6e3e99);
			box-shadow: 0 0 15px 0 var(--ethereal-violet, #966eb7);
		}

		.button-wrapper {
			position: relative;
			z-index: 2;

			.button-text {
				color: var(--white) !important;
			}
		}
	}

	&.btn-large {
		width: 100%;
		max-width: 380px;
	}

	&.bg-gradient-purple {
		position: relative;
		background: linear-gradient(
			94deg,
			var(--electric-purple, #9810fa) 0%,
			var(--cyber-pink, #ec4899) 100%
		);
		border: none;
		color: var(--white);
		overflow: hidden;

		&:hover {
			color: var(--white) !important;
		}

		&::before {
			content: "";
			position: absolute;
			inset: 0;
			background: var(--royal-electric, #6e3e99);
			opacity: 0;
			transition: opacity 0.3s ease;
			z-index: 0;
		}

		&:hover::before {
			opacity: 1;
		}

		> * {
			position: relative;
			z-index: 1;
		}
	}

	&.btn-get {
		min-width: 170px;
		display: flex;
		justify-content: flex-start;
		align-items: flex-start;
		padding: 12px 20px !important;
		border-radius: 15px;
		border: 0.5px solid var(--deep-void-purple, #542985);
		background: linear-gradient(
			101deg,
			var(--oxford-blue, #101828) 0%,
			var(--black, #000) 50%,
			var(--oxford-blue, #101828) 100%
		);
		box-shadow: 0 0 10px 0 var(--deep-void-purple, #542985);

		&:hover {
			box-shadow: 0 0 10px 0 var(--glitch-lavender, #b38ec9);
		}

		.button-wrapper {
			display: flex;
			flex-direction: row;
			justify-content: center;
			align-items: center;
			gap: 22px;

			i {
				&:before {
					font-size: 25px;
					color: var(--royal-electric);
				}
			}

			.button-text {
				display: flex;
				flex-direction: column;
				align-items: flex-start;
				color: var(--white) !important;
				font-size: 14px;
				font-weight: 600;

				span {
					font-size: 12px;
					color: var(--royal-electric);
				}
			}
		}
	}

	&.btn-small {
		padding: 10px;
		background: rgba(6, 8, 15, 0.5);
		border: 1px solid var(--deep-steel, #1e2939);
		border-radius: 10px;

		.button-wrapper {
			display: flex;
			flex-direction: row;
			flex-wrap: wrap;
			justify-content: center;
			align-items: center;
			gap: 10px;

			i {
				&:before {
					transition: 0.3s all;
				}
			}

			.button-text {
				transition: 0.3s all;
			}
		}

		&:hover {
			box-shadow: 0 0 5px 0 var(--glitch-lavender, #b38ec9);

			.button-wrapper {
				i {
					&:before {
						color: var(--glitch-lavender);
					}
				}
				.button-text {
					color: var(--glitch-lavender);
				}
			}
		}
	}
}

/* C A R D S */
.card-wrapper {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	gap: 50px;

	@media (max-width: 1024px) {
		gap: 20px;
	}

	@media (max-width: 767px) {
		flex-direction: column !important;
	}

	.card {
		width: calc(calc(100% / 3) - 34px);
		display: flex;
		align-items: center;
		padding: 30px;
		border: 1px solid var(--deep-steel);
		border-radius: 20px;
		overflow: hidden;

		@media (max-width: 1024px) {
			width: calc(calc(100% / 3) - 14px);
		}

		@media (max-width: 767px) {
			width: 100%;
			overflow: inherit;
		}

		&.bg-dark {
			position: relative;
			background: rgba(6, 8, 15, 0.5) !important;
			border: 0.5px solid transparent;
			border: 1px solid var(--deep-steel, #1e2939);
			transition:
				border 0.3s ease,
				box-shadow 0.3s ease;

			&::before {
				content: "";
				position: absolute;
				inset: 0;
				background: linear-gradient(
					133deg,
					var(--deep-void-purple, rgba(84, 41, 133, 0.3)) 0%,
					var(--crimson-violet, rgba(134, 16, 67, 0.3)) 100%
				);
				opacity: 0;
				border-radius: 20px;
				transition: opacity 0.3s ease;
				z-index: 0;
			}

			&:hover {
				border: 0.5px solid #c27aff;
				box-shadow: 0 0 10px 0 var(--neon-violet, #c27aff);

				&::before {
					/* opacity: 1; */
				}
			}

			> * {
				position: relative;
				z-index: 1;
			}
		}
	}
}

/* F O R M */
.forminator-ui {
	padding: 35px !important;
	background: var(--inky-navy, #06080f) !important;
	box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25) !important;
	border-radius: 20px !important;

	.forminator-row {
		&:not(:last-child) {
			@media (max-width: 1024px) {
				margin-bottom: 40px !important;
			}
		}

		.forminator-field-name {
			.forminator-field {
				position: relative;

				&:before {
					content: "";
					width: 30px;
					height: 30px;
					position: absolute;
					left: 20px;
					bottom: 6px;
					background-image: url(../../assets/images/icon-name.svg);
					background-size: contain;
					background-repeat: no-repeat;
					background-position: center;
				}
			}
		}

		.forminator-field-email {
			.forminator-field {
				position: relative;

				&:before {
					content: "";
					width: 30px;
					height: 30px;
					position: absolute;
					left: 20px;
					bottom: 6px;
					background-image: url(../../assets/images/icon-envelope.svg);
					background-size: contain;
					background-repeat: no-repeat;
					background-position: center;
				}
			}
		}

		.forminator-field-textarea {
			.forminator-field {
				position: relative;

				&:before {
					content: "";
					width: 30px;
					height: 30px;
					position: absolute;
					left: 20px;
					top: 42px;
					background-image: url(../../assets/images/icon-message.svg);
					background-size: contain;
					background-repeat: no-repeat;
					background-position: center;
				}
			}
		}

		&.forminator-row-last {
			margin-bottom: 0 !important;

			.forminator-field {
				overflow: hidden;
				position: relative;
				width: 100% !important;
				background: linear-gradient(
					94deg,
					var(--Electric-Purple, #9810fa) 0%,
					var(--Cyber-Pink, #ec4899) 100%
				) !important;
				border-radius: 10px !important;
				z-index: 1;

				&::before {
					content: "";
					position: absolute;
					inset: 0;
					background: var(--royal-electric, #6e3e99);
					opacity: 0;
					transition: opacity 0.3s ease;
					z-index: -1;
				}

				&:hover {
					cursor: pointer;

					&::before {
						opacity: 1;
					}
				}

				.forminator-button {
					width: 100%;
					padding: 10px 20px !important;
					color: var(--white) !important;
					background: transparent !important;
					margin-bottom: 0 !important;
				}
			}
		}

		.forminator-field {
			.forminator-label {
				color: var(--electric-purple) !important;
				font-size: 18px !important;
				line-height: 30px !important;
				margin-bottom: 5px !important;

				.forminator-required {
					color: var(--electric-purple) !important;
				}
			}

			.forminator-input,
			.forminator-textarea {
				color: var(--white) !important;
				padding: 10px 20px 10px 60px !important;
				border-radius: 10px !important;
				border: 1px solid var(--deep-steel, #1e2939) !important;
				background: transparent !important;

				&::placeholder {
					color: rgba(153, 161, 175, 0.5) !important;
					font-size: 16px !important;
					line-height: 25px !important;
				}

				&:focus-visible,
				&:focus,
				&:active {
					box-shadow: 0 0 10px 0 var(--electric-purple, #9810fa) !important;
					outline: none !important;
				}
			}

			.forminator-error-message {
				position: absolute;
			}
		}
	}
}

#videoModal {
	.modal-dialog {
		width: fit-content;
		margin: auto;

		.modal-content {
			.btn-close {
				z-index: 2;
			}
			.modal-body {
				#modalVideo {
					height: 100vh;
					max-height: 700px;
				}
			}
		}
	}
}
