:root {
	--font-heading: "Manrope", sans-serif;
	--font-body: "Roboto", sans-serif;

	--bg: #090909;
	--bg-soft: #101214;
	--surface: #14171a;
	--surface-2: #1b1f24;
	--text: #f4f5f7;
	--muted: #a0a6ad;

	--accent: #ff5a1f;
	--accent-2: #d8420f;
	--accent-glow: rgba(255, 90, 31, 0.35);

	--radius-lg: 22px;
	--radius-md: 16px;
	--radius-sm: 12px;

	--space-section: clamp(4rem, 7vw, 7rem);
	--space-section-sm: clamp(2.5rem, 5vw, 4rem);
	--container-max: 1260px;

	--shadow-soft: 0 10px 30px rgba(0, 0, 0, 0.35);
	--shadow-accent: 0 10px 35px rgba(216, 66, 15, 0.32);

	--transition: 0.35s ease;
}

* {
	box-sizing: border-box;
}

html,
body {
	margin: 0;
	padding: 0;
	background: radial-gradient(circle at 80% -20%, rgba(255, 90, 31, 0.12), transparent 40%), var(--bg);
	color: var(--text);
	font-family: var(--font-body);
	scroll-behavior: smooth;
}

body {
	overflow-x: hidden;
}

.container {
	max-width: var(--container-max);
}

h1,
h2,
h3,
h4 {
	font-family: var(--font-heading);
	margin: 0;
}

p {
	margin: 0;
}

a {
	color: inherit;
	text-decoration: none;
}

.section-space {
	padding: var(--space-section) 0;
}

.section-space-sm {
	padding: var(--space-section-sm) 0;
}

.eyebrow {
	display: inline-block;
	margin-bottom: 0.65rem;
	color: var(--accent);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	font-size: 0.8rem;
	font-weight: 700;
}

.section-title {
	font-size: clamp(1.8rem, 3vw, 2.8rem);
	line-height: 1.16;
}

.section-text {
	margin-top: 1rem;
	max-width: 67ch;
	color: var(--muted);
	font-size: 1.04rem;
	line-height: 1.75;
}

.site-header {
	position: absolute;
	z-index: 20;
	width: 100%;
}

.navbar {
	background: transparent;
}

.logo-dot {
	width: 0.9rem;
	height: 0.9rem;
	border-radius: 50%;
	background: radial-gradient(circle at 35% 35%, #ffc9b2, var(--accent));
	box-shadow: 0 0 22px var(--accent-glow);
}

.logo-text {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 0.98rem;
}

.nav-link {
	color: rgba(255, 255, 255, 0.9);
	font-weight: 500;
	position: relative;
	transition: color var(--transition);
}

.nav-link::after {
	content: "";
	position: absolute;
	left: 0.4rem;
	right: 0.4rem;
	bottom: 0.2rem;
	height: 2px;
	transform: scaleX(0);
	transform-origin: center;
	background: linear-gradient(90deg, var(--accent), transparent);
	transition: transform var(--transition);
}

.nav-link:hover,
.nav-link:focus {
	color: #fff;
}

.nav-link:hover::after,
.nav-link:focus::after {
	transform: scaleX(1);
}

.hero-section {
	position: relative;
	min-height: min(100vh, 880px);
	/* display: grid;
	place-items: center; */
}

.hero-video,
.hero-overlay,
.hero-grid {
	position: absolute;
	inset: 0;
}

.hero-video {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.hero-overlay {
	background:
		linear-gradient(180deg, rgba(9, 9, 9, 0.55) 0%, rgba(9, 9, 9, 0.85) 55%, rgba(9, 9, 9, 0.95) 100%),
		radial-gradient(circle at 20% 20%, rgba(216, 66, 15, 0.23), transparent 45%);
}

.hero-grid {
	opacity: 0.18;
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.08) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.08) 1px, transparent 1px);
	background-size: 44px 44px;
	mask-image: radial-gradient(circle at center, black 30%, transparent 95%);
}

.hero-content {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	/* z-index: 2; */
	text-align: center;
}

.hero-title {
	margin-inline: auto;
	max-width: 17ch;
	font-size: clamp(2.1rem, 5vw, 4.8rem);
	line-height: 1.07;
	letter-spacing: -0.02em;
	text-wrap: balance;
	text-shadow: 0 10px 35px rgba(0, 0, 0, 0.65);
}

.about-section {
	background: linear-gradient(180deg, rgba(12, 12, 12, 1), rgba(10, 12, 14, 0));
}

.top-glow {
	position: relative;
	background:
		radial-gradient(circle at 20% -6%, rgba(255, 90, 31, 0.28), transparent 36%),
		radial-gradient(circle at 82% 4%, rgba(255, 90, 31, 0.18), transparent 30%),
		var(--bg);
}

.top-glow::before,
.top-glow::after {
	content: "";
	position: fixed;
	z-index: 0;
	pointer-events: none;
	filter: blur(48px);
	opacity: 0.9;
}

.top-glow::before {
	width: 300px;
	height: 180px;
	left: -70px;
	top: 58px;
	background: rgba(255, 90, 31, 0.35);
}

.top-glow::after {
	width: 280px;
	height: 180px;
	right: -80px;
	top: 52px;
	background: rgba(255, 90, 31, 0.27);
}

.top-glow .site-header,
.top-glow main,
.top-glow .site-footer {
	position: relative;
	z-index: 1;
}

.about-page {
	position: relative;
}

.about-main {
	padding-top: clamp(6.8rem, 9vw, 8.5rem);
}

.about-page-title {
	max-width: 18ch;
}

.about-card {
	height: 100%;
	padding: clamp(1.25rem, 2.6vw, 1.85rem);
	border-radius: var(--radius-lg);
	background:
		linear-gradient(160deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.01)),
		rgba(16, 18, 21, 0.9);
	border: 1px solid rgba(255, 255, 255, 0.1);
	box-shadow: var(--shadow-soft);
}

.about-card h2 {
	font-size: clamp(1.25rem, 2.1vw, 1.75rem);
	margin-bottom: 0.7rem;
	line-height: 1.2;
}

.about-card p:last-child {
	color: var(--muted);
	line-height: 1.75;
}

.services-page {
	position: relative;
}

.services-main {
	padding-top: clamp(6.8rem, 9vw, 8.5rem);
}

.services-page-title {
	max-width: 16ch;
}

.services-lead {
	max-width: 72ch;
}

.services-grid {
	margin-top: clamp(1.2rem, 2vw, 1.8rem);
}

.services-grid-card {
	height: 100%;
	border-radius: var(--radius-md);
	padding: 1.25rem;
	background: linear-gradient(160deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.01));
	border: 1px solid rgba(255, 255, 255, 0.09);
	transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
}

.services-grid-card:hover {
	transform: translateY(-4px);
	border-color: rgba(255, 90, 31, 0.42);
	box-shadow: 0 14px 28px rgba(0, 0, 0, 0.34), 0 0 24px rgba(255, 90, 31, 0.17);
}

.services-grid-card i {
	font-size: 1.6rem;
	color: var(--accent);
}

.services-grid-card h2 {
	margin-top: 0.7rem;
	font-size: 1.12rem;
}

.services-grid-card p {
	margin-top: 0.5rem;
	color: var(--muted);
	line-height: 1.65;
}

.contact-page {
	position: relative;
}

.contact-main {
	padding-top: clamp(6.8rem, 9vw, 8.5rem);
}

.contact-page-title {
	max-width: 16ch;
}

.contact-lead {
	max-width: 66ch;
}

.contact-form {
	border-radius: var(--radius-lg);
	padding: clamp(1.1rem, 2.3vw, 1.7rem);
	background:
		linear-gradient(160deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.02)),
		rgba(16, 18, 21, 0.9);
	border: 1px solid rgba(255, 255, 255, 0.1);
	box-shadow: var(--shadow-soft);
}

.form-label {
	font-family: var(--font-heading);
	font-size: 0.9rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.88);
}

.form-control {
	background: rgba(8, 9, 11, 0.9);
	border: 1px solid rgba(255, 255, 255, 0.16);
	color: #fff;
	padding: 0.75rem 0.9rem;
	border-radius: 12px;
}

.form-control:focus {
	background: rgba(8, 9, 11, 1);
	color: #fff;
	border-color: rgba(255, 90, 31, 0.7);
	box-shadow: 0 0 0 0.22rem rgba(255, 90, 31, 0.2);
}

.form-control::placeholder {
	color: rgba(255, 255, 255, 0.46);
}

.contact-info-card {
	height: 100%;
	border-radius: var(--radius-lg);
	padding: clamp(1.1rem, 2.3vw, 1.7rem);
	background: linear-gradient(155deg, rgba(255, 90, 31, 0.18), rgba(255, 90, 31, 0.04));
	border: 1px solid rgba(255, 255, 255, 0.14);
	box-shadow: var(--shadow-soft);
}

.contact-info-card h2 {
	font-size: clamp(1.3rem, 2vw, 1.7rem);
	margin-bottom: 0.8rem;
}

.contact-info-card p {
	color: rgba(255, 255, 255, 0.88);
	line-height: 1.7;
	margin-top: 0.55rem;
}

.contact-info-card i {
	color: var(--accent);
	margin-right: 0.4rem;
}

.about-media-wrap {
	border-radius: var(--radius-lg);
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.09);
	box-shadow: var(--shadow-soft);
}

.about-media {
	width: 100%;
	min-height: 340px;
	object-fit: cover;
	filter: contrast(1.08) saturate(1.06);
}

.stats-section {
	/* background: linear-gradient(180deg, #0f1114 0%, #0a0d10 100%); */
}

.stat-card {
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: var(--radius-md);
	padding: 1.4rem 1rem;
	text-align: center;
	background: linear-gradient(160deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0));
	height: 100%;
}

.stat-number {
	font-family: var(--font-heading);
	font-size: clamp(1.6rem, 2.4vw, 2.5rem);
	font-weight: 800;
	color: #fff;
}

.stat-label {
	margin-top: 0.45rem;
	color: var(--muted);
	font-size: 0.95rem;
}

.process-card {
	border-radius: var(--radius-lg);
	padding: clamp(1.3rem, 3vw, 2.4rem);
	background: linear-gradient(145deg, var(--accent) -10%, var(--accent-2) 30%, #20120c 100%);
	box-shadow: var(--shadow-accent);
	border: 1px solid rgba(255, 255, 255, 0.12);
}

.process-intro {
	max-width: 72ch;
	opacity: 0.95;
}

.process-heading {
	margin-bottom: 1.35rem;
}

.process-item {
	height: 100%;
	border-radius: var(--radius-sm);
	padding: 1rem;
	background: rgba(9, 9, 9, 0.28);
	border: 1px solid rgba(255, 255, 255, 0.16);
	backdrop-filter: blur(1px);
}

.process-item h3 {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 1.05rem;
	color: #fff;
}

.process-item h3 i {
	color: #ffd7c8;
}

.process-item p {
	margin-top: 0.65rem;
	font-size: 0.95rem;
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.88);
}

.services-section {
	/* background: linear-gradient(180deg, #090909 0%, #0f1114 100%); */
}

.services-head {
	margin-bottom: 1.2rem;
}

.services-swiper {
	padding: 1.2rem 0 2.8rem;
}

.service-card {
	height: 100%;
	border-radius: var(--radius-md);
	padding: 1.45rem;
	background: linear-gradient(160deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.01));
	border: 1px solid rgba(255, 255, 255, 0.09);
	transition: transform var(--transition), border-color var(--transition), box-shadow var(--transition);
}

.service-card i {
	font-size: 1.7rem;
	color: var(--accent);
}

.service-card h3 {
	margin-top: 0.75rem;
	font-size: 1.15rem;
}

.service-card p {
	margin-top: 0.5rem;
	color: var(--muted);
	line-height: 1.62;
}

.swiper-slide-active .service-card {
	transform: translateY(-8px);
	border-color: rgba(255, 90, 31, 0.45);
	box-shadow: 0 18px 35px rgba(0, 0, 0, 0.38), 0 0 30px rgba(255, 90, 31, 0.18);
}

.swiper-pagination-bullet {
	width: 8px;
	height: 8px;
	background: #fff;
	opacity: 0.33;
}

.swiper-pagination-bullet-active {
	background: var(--accent);
	opacity: 1;
}

.cta-card {
	border-radius: var(--radius-lg);
	padding: clamp(1.4rem, 3vw, 2.3rem);
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 1rem;
	border: 1px solid rgba(255, 255, 255, 0.1);
	background:
		linear-gradient(160deg, rgba(216, 66, 15, 0.21), rgba(216, 66, 15, 0.06)),
		rgba(18, 20, 23, 0.85);
}

.cta-card h2 {
	font-size: clamp(1.5rem, 3vw, 2.4rem);
}

.btn-accent {
	background: linear-gradient(130deg, var(--accent), var(--accent-2));
	color: #fff;
	font-weight: 700;
	border-radius: 999px;
	padding: 0.72rem 1.45rem;
	border: none;
	box-shadow: 0 10px 25px rgba(216, 66, 15, 0.35);
	transition: transform var(--transition), box-shadow var(--transition);
}

.btn-accent:hover,
.btn-accent:focus {
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 14px 28px rgba(216, 66, 15, 0.42);
}

.site-footer {
	position: relative;
	padding: 3.8rem 0 1.2rem;
	background:
		linear-gradient(0deg, rgba(216, 66, 15, 0.48), rgba(9, 9, 9, 1) 80%),
		#090909;
	overflow: hidden;
}

.footer-fx {
	position: absolute;
	inset: -20% -10% auto;
	height: 280px;
	background:
		radial-gradient(circle at 0% 250%, rgba(255, 120, 77, 0.2), transparent 35%),
		radial-gradient(circle at 100% 250%, rgba(255, 90, 31, 0.18), transparent 36%);
	filter: blur(18px);
	pointer-events: none;
}

.footer-content {
	position: relative;
	z-index: 1;
}

.footer-brand h3 {
	margin-top: 1rem;
	font-size: 1.45rem;
}

.footer-info h4,
.footer-links h4 {
	margin-bottom: 0.55rem;
	font-size: 1.05rem;
}

.footer-info p {
	color: rgba(255, 255, 255, 0.88);
	line-height: 1.72;
}

.footer-links {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.footer-links a {
	width: fit-content;
	color: rgba(255, 255, 255, 0.9);
	transition: color var(--transition), transform var(--transition);
}

.footer-links a:hover,
.footer-links a:focus {
	color: #fff;
	transform: translateX(3px);
}

.footer-bottom {
	margin-top: 2.3rem;
	padding-top: 1.15rem;
	border-top: 1px solid rgba(255, 255, 255, 0.15);
	text-align: center;
}

.footer-bottom p {
	color: rgba(255, 255, 255, 0.74);
	font-size: 0.92rem;
}

.reveal-up {
	opacity: 0;
	transform: translateY(16px);
	transition: opacity 0.7s ease, transform 0.7s ease;
}

.reveal-up.in-view {
	opacity: 1;
	transform: translateY(0);
}

.delay-1 {
	transition-delay: 0.12s;
}

.delay-2 {
	transition-delay: 0.24s;
}

.delay-3 {
	transition-delay: 0.36s;
}

@media (max-width: 991.98px) {
	.navbar-collapse {
		margin-top: 0.8rem;
		padding: 0.7rem;
		border-radius: 12px;
		background: rgba(9, 9, 9, 0.72);
		backdrop-filter: blur(8px);
	}
}

@media (max-width: 767.98px) {
	.hero-section {
		min-height: 86vh;
	}
	.hero-content {
		top: 60%;
	}

	.hero-title {
		font-size: 2.4rem !important;
		/* max-width: 13ch; */
	}

	.about-media {
		min-height: 260px;
	}
	.footer-brand {
		text-align: center;
	}
	.footer-brand a {
		width: fit-content;
		margin: 0 auto;
		text-align: center;
	}
	footer .logo-img {
		width: 200px;
		height: auto;
	}
	.footer-info {
		margin-top: 1.8rem;
		padding-inline-start: 20px;
	}
	.footer-links {
		padding-inline-start: 20px;
	}
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation: none !important;
		transition: none !important;
		scroll-behavior: auto !important;
	}
}
.accent-text {
	color: var(--accent);
}
.logo-img {
	height: 80px;
}
footer .logo-img {
	width: 200px;
	height: auto;
}