@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Rajdhani:wght@500;600;700&display=swap');

:root {
	--navy: #061d3a;
	--navy2: #0d2e57;
	--red: #ef2c1d;
	--red2: #c91f15;
	--blue: #0d3f9f;
	--gold: #d9ad53;
	--ink: #101c2b;
	--muted: #677382;
	--paper: #fff;
	--soft: #f3f6f9;
	--line: #dfe5eb;
	--shadow: 0 24px 70px rgba(5, 29, 58, .14);
	--ease: cubic-bezier(.22, .8, .22, 1)
}

* {
	box-sizing: border-box
}

html {
	scroll-behavior: smooth
}

body {
	margin: 0;
	background: #fff;
	color: var(--ink);
	font-family: 'DM Sans', Arial, sans-serif;
	font-size: 16px;
	line-height: 1.68;
	overflow-x: hidden
}

body.menu-open {
	overflow: hidden
}

img {
	max-width: 100%;
	display: block
}

a {
	color: inherit;
	text-decoration: none
}

button,
input,
select,
textarea {
	font: inherit
}

button {
	cursor: pointer
}

.container {
	width: min(1220px, calc(100% - 40px));
	margin: auto
}

.section {
	padding: 70px 0
}

.section-soft {
	background: var(--soft)
}

.section-dark {
	background: var(--navy);
	color: #fff
}

.eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: var(--red);
	text-transform: uppercase;
	letter-spacing: .18em;
	font-weight: 700;
	font-size: 12px
}

.eyebrow:before {
	content: '';
	width: 28px;
	height: 2px;
	background: currentColor
}

.title {
	font: 700 clamp(38px, 5vw, 68px)/.98 'Rajdhani', sans-serif;
	text-transform: uppercase;
	letter-spacing: -.035em;
	margin: 15px 0 24px
}

.title-sm {
	font: 700 clamp(30px, 3.7vw, 52px)/1.02 'Rajdhani', sans-serif;
	text-transform: uppercase;
	letter-spacing: -.02em;
	margin: 12px 0 20px
}

.lead {
	font-size: 18px;
	color: var(--muted);
	max-width: 740px
}

.section-dark .lead,
.dark-card .lead {
	color: #becada
}

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	min-height: 54px;
	padding: 0 28px;
	border: 0;
	background: var(--red);
	color: #fff;
	text-transform: uppercase;
	letter-spacing: .13em;
	font-weight: 700;
	font-size: 12px;
	position: relative;
	overflow: hidden;
	transition: .35s var(--ease)
}

.btn:after {
	content: '↗';
	font-size: 18px
}

.btn:hover {
	background: var(--navy);
	transform: translateY(-3px);
	box-shadow: 0 15px 35px rgba(6, 29, 58, .22)
}

.btn-dark {
	background: var(--navy)
}

.btn-dark:hover {
	background: var(--red)
}

.btn-outline {
	background: transparent;
	border: 1px solid rgba(255, 255, 255, .45)
}

.btn-outline:hover {
	border-color: var(--red);
	background: var(--red)
}

.topbar {
	background: var(--navy);
	color: #e9f0f8;
	font-size: 12px
}

.topbar-inner {
	min-height: 44px;
	display: flex;
	align-items: center;
	justify-content: right;
	gap: 25px
}

.topbar-list {
	display: flex;
	gap: 24px;
	align-items: center
}

.topbar-list span {
	opacity: .92
}

.topbar-list a:hover {
	color: #ff766d
}

/* .lang {
	display: flex;
	align-items: center;
	gap: 7px
}

.lang b {
	font-weight: 600
} */

.header {
	position: sticky;
	top: 0;
	z-index: 1000;
	background: rgba(255, 255, 255, .96);
	backdrop-filter: blur(14px);
	border-bottom: 1px solid transparent;
	transition: .3s
}

.header.scrolled {
	box-shadow: 0 10px 35px rgba(3, 20, 42, .09);
	border-color: #edf1f5
}

.nav {
	height: 90px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 30px
}

.logo {
	width: 270px;
	max-width: 31vw
}

.nav-links {
	display: flex;
	align-items: center;
	gap: 34px;
	font: 600 15px 'DM Sans', sans-serif
}

.nav-links>a,
.nav-item>a {
	position: relative;
	padding: 34px 0
}

.nav-links>a:after,
.nav-item>a:after {
	content: '';
	position: absolute;
	left: 0;
	bottom: 26px;
	width: 0;
	height: 2px;
	background: var(--red);
	transition: .3s
}

.nav-links>a:hover:after,
.nav-item:hover>a:after,
.nav-links .active:after {
	width: 100%
}

.nav-item {
	position: relative
}

.dropdown {
	position: absolute;
	top: 78px;
	left: -24px;
	width: 250px;
	background: #fff;
	box-shadow: var(--shadow);
	padding: 16px 0;
	opacity: 0;
	visibility: hidden;
	transform: translateY(16px);
	transition: .3s var(--ease)
}

.dropdown a {
	display: block;
	padding: 10px 24px;
	color: #324257
}

.dropdown a:hover {
	background: var(--soft);
	color: var(--red);
	padding-left: 30px
}

.nav-item:hover .dropdown {
	opacity: 1;
	visibility: visible;
	transform: none
}

.nav-actions {
	display: flex;
	align-items: center;
	gap: 12px
}

.contact-btn {
	padding: 15px 20px;
	background: var(--red);
	color: #fff;
	text-transform: uppercase;
	letter-spacing: .13em;
	font-weight: 700;
	font-size: 11px
}

.menu-toggle {
	width: 48px;
	height: 48px;
	border: 0;
	background: var(--navy);
	display: none;
	place-items: center
}

.menu-toggle i,
.menu-toggle i:before,
.menu-toggle i:after {
	content: '';
	display: block;
	width: 21px;
	height: 2px;
	background: #fff;
	position: relative;
	transition: .3s
}

.menu-toggle i:before {
	position: absolute;
	top: -7px
}

.menu-toggle i:after {
	position: absolute;
	top: 7px
}

.mobile-panel {
	position: fixed;
	inset: 0 0 0 auto;
	width: min(420px, 90vw);
	z-index: 1500;
	background: #fff;
	transform: translateX(105%);
	transition: .45s var(--ease);
	padding: 95px 34px 40px;
	box-shadow: -15px 0 60px rgba(3, 20, 42, .2)
}

.mobile-panel.open {
	transform: none
}

.mobile-panel a {
	display: block;
	border-bottom: 1px solid var(--line);
	padding: 14px 0;
	font: 700 22px 'Rajdhani';
	text-transform: uppercase
}

.mobile-close {
	position: absolute;
	right: 25px;
	top: 25px;
	width: 46px;
	height: 46px;
	border: 0;
	background: var(--red);
	color: white;
	font-size: 23px
}

.hero {
	height: min(820px, calc(100vh - 134px));
	min-height: 650px;
	position: relative;
	background: var(--navy);
	overflow: hidden;
	color: #fff
}

.hero-track,
.hero-slide {
	position: absolute;
	inset: 0
}

.hero-slide {
	opacity: 0;
	transform: scale(1.04);
	transition: opacity 1s var(--ease), transform 7s linear;
	display: flex;
	align-items: center
}

.hero-slide.active {
	opacity: 1;
	transform: scale(1)
}

.hero-slide:before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, rgba(2, 15, 35, .96) 0%, rgba(2, 15, 35, .79) 43%, rgba(2, 15, 35, .25) 74%, rgba(2, 15, 35, .2) 100%), linear-gradient(180deg, transparent 65%, rgba(2, 15, 35, .8))
}

.hero-bg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: saturate(.9)
}

.hero-content {
	position: relative;
	z-index: 3;
	width: min(780px, 68vw);
	padding-left: max(20px, calc((100vw - 1220px)/2))
}

.hero-kicker {
    
	color: #ff675d;
	text-transform: uppercase;
	letter-spacing: .22em;
	font-weight: 700;
	font-size: 13px;
	animation: rise .8s both
}

.hero h1 {
	font: 700 clamp(56px, 7.2vw, 112px)/.84 'Rajdhani', sans-serif;
	text-transform: uppercase;
	letter-spacing: -.055em;
	margin: 20px 0 26px;
	max-width: 940px
}

.hero p {
	font-size: 18px;
	color: #d9e2ec;
	max-width: 690px;
	margin-bottom: 35px
}

.hero-actions {
	display: flex;
	gap: 14px;
	flex-wrap: wrap
}

.hero-art {
	position: absolute;
	right: 2vw;
	bottom: -10px;
	width: min(42vw, 620px);
	z-index: 2;
	filter: drop-shadow(0 30px 35px rgba(0, 0, 0, .35));
	animation: float 5s ease-in-out infinite
}

.hero-crane {
	position: absolute;
	right: -3%;
	top: -8%;
	width: 49vw;
	opacity: .64;
	z-index: 1
}

.hero-dots {
	position: absolute;
	left: max(20px, calc((100vw - 1220px)/2));
	bottom: 42px;
	z-index: 5;
	display: flex;
	gap: 10px
}

.hero-dot {
	width: 38px;
	height: 4px;
	border: 0;
	background: rgba(255, 255, 255, .28);
	padding: 0;
	transition: .4s
}

.hero-dot.active {
	background: var(--red);
	width: 65px
}

.scroll-cue {
	position: absolute;
	right: 40px;
	bottom: 45px;
	z-index: 5;
	writing-mode: vertical-rl;
	text-transform: uppercase;
	letter-spacing: .25em;
	font-size: 10px;
	display: flex;
	gap: 12px;
	align-items: center
}

.scroll-cue:after {
	content: '';
	height: 58px;
	width: 1px;
	background: #fff;
	opacity: .5
}

.intro-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 80px;
	align-items: center
}

.visual-stack {
	position: relative;
	min-height: 600px
}

.visual-stack .main-img {
	height: 550px;
	width: 83%;
	object-fit: contain;
}

.visual-stack .floating-img {
	position: absolute;
	right: 0;
	bottom: 0;
	width: 48%;
	height: 330px;
	object-fit: cover;
	border: 12px solid #fff;
	box-shadow: var(--shadow)
}

/*.year-badge {*/
/*	position: absolute;*/
/*	left: -25px;*/
/*	bottom: 45px;*/
/*	background: var(--red);*/
/*	color: #fff;*/
/*	width: 190px;*/
/*	height: 190px;*/
/*	display: grid;*/
/*	place-items: center;*/
/*	text-align: center;*/
/*	clip-path: polygon(50% 0, 93% 25%, 93% 75%, 50% 100%, 7% 75%, 7% 25%)*/
/*}*/

.year-badge {
	position: absolute;
	left: -41px;
	bottom: 6px;
	background: var(--red);
	color: #fff;
	width: 190px;
	height: 190px;
	display: grid;
	place-items: center;
	text-align: center;
	clip-path: polygon(50% 0, 93% 25%, 93% 75%, 50% 100%, 7% 75%, 7% 25%)
}

.year-badge strong {
	display: block;
	font: 700 58px/1 'Rajdhani'
}

.year-badge span {
	display: block;
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: .16em;
	max-width: 100px;
	margin: auto
}

.check-list {
	display: grid;
	gap: 13px;
	margin: 30px 0
}

.check-list span {
	display: flex;
	gap: 13px;
	align-items: flex-start;
	font-weight: 600
}

.check-list span:before {
	content: '✓';
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: #ffe8e6;
	color: var(--red);
	display: grid;
	place-items: center;
	flex: 0 0 auto;
	font-size: 12px
}

.mini-features {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 18px;
	margin: 28px 0
}

.mini-feature {
	border-left: 3px solid var(--red);
	padding-left: 16px
}

.mini-feature strong {
	display: block;
	font: 700 20px 'Rajdhani';
	text-transform: uppercase
}

.mini-feature small {
	color: var(--muted)
}

.choose {
	position: relative;
	overflow: hidden
}

.choose:after {
	content: '';
	position: absolute;
	right: -120px;
	bottom: -120px;
	width: 520px;
	height: 520px;
	background: url('../images/home4-im65.webp') center/contain no-repeat;
	opacity: .09
}

.choose-head {
	display: grid;
	grid-template-columns: .85fr 1.15fr;
	gap: 70px;
	align-items: end;
	margin-bottom: 55px
}

.feature-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1px;
	background: rgba(255, 255, 255, .15)
}

.feature-card {
	padding: 36px 28px;
	background: var(--navy);
	min-height: 275px;
	position: relative;
	transition: .35s;
	z-index: 2
}

.feature-card:hover {
	background: var(--red);
	transform: translateY(-7px)
}

.feature-no {
	font: 700 58px/1 'Rajdhani';
	color: rgba(255, 255, 255, .11)
}

.feature-card h3 {
	font: 700 23px/1.05 'Rajdhani';
	text-transform: uppercase;
	margin: 22px 0 14px
}

.feature-card p {
	color: #b9c5d4;
	font-size: 14px
}

.feature-card:hover p {
	color: #fff
}

.quote-strip {
	background: var(--red);
	color: #fff;
	padding: 48px 0
}

.quote-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 30px
}

.quote-inner h3 {
	font: 700 clamp(28px, 3vw, 44px)/1 'Rajdhani';
	text-transform: uppercase;
	margin: 0
}

.quote-strip .btn {
	background: #fff;
	color: var(--navy)
}

.who-grid {
	display: grid;
	grid-template-columns: 1.05fr .95fr;
	gap: 75px;
	align-items: center
}

.who-image {
	position: relative
}

.who-image img {
	height: 630px;
	width: 100%;
	/*object-fit: cover*/
}

.who-image:after {
	content: '';
	position: absolute;
	inset: 25px -25px -25px 25px;
	border: 8px solid var(--red);
	z-index: -1
}

.stats {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	margin-top: 65px;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line)
}

.stat {
	padding: 28px 15px;
	text-align: center;
	border-right: 1px solid var(--line)
}

.stat:last-child {
	border-right: 0
}

.stat b {
	font: 700 54px/1 'Rajdhani';
	color: var(--red)
}

.stat span {
	display: block;
	text-transform: uppercase;
	letter-spacing: .12em;
	font-size: 10px;
	margin-top: 8px
}

.expertise-head {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: 35px;
	margin-bottom: 50px
}

.expertise-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px
}

.expert-card {
	position: relative;
	height: 400px;
	overflow: hidden;
	background: #111
}

.expert-card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: .7s var(--ease)
}

.expert-card:after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 30%, rgba(2, 15, 35, .95))
}

.expert-card:hover img {
	transform: scale(1.08)
}

.expert-copy {
	position: absolute;
	z-index: 2;
	left: 28px;
	right: 28px;
	bottom: 25px;
	color: #fff
}

.expert-copy small {
	color: #ff5b50;
	font: 700 13px 'Rajdhani';
	letter-spacing: .12em
}

.expert-copy h3 {
	font: 700 24px/1.05 'Rajdhani';
	text-transform: uppercase;
	margin: 7px 0 10px
}

.expert-copy p {
	font-size: 13px;
	color: #d0dae7;
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	transition: .45s
}

.expert-card:hover p {
	max-height: 100px;
	opacity: 1
}

.process-wrap {
	display: grid;
	grid-template-columns: .8fr 1.2fr;
	gap: 70px
}

.process-tabs {
	display: grid;
	gap: 12px
}

.process-tab {
	border: 0;
	text-align: left;
	padding: 20px 22px;
	background: #fff;
	color: var(--navy);
	font: 700 17px 'Rajdhani';
	text-transform: uppercase;
	border-left: 4px solid transparent;
	transition: .3s
}

.process-tab.active,
.process-tab:hover {
	border-color: var(--red);
	background: var(--navy);
	color: #fff;
	transform: translateX(8px)
}

.process-panel {
	display: none;
	background: #fff;
	box-shadow: var(--shadow);
	padding: 45px
}

.process-panel.active {
	display: block;
	animation: fadeUp .55s var(--ease)
}

.process-panel .step {
	font: 700 82px/1 'Rajdhani';
	color: #e9edf2
}

.process-panel h3 {
	font: 700 35px/1 'Rajdhani';
	text-transform: uppercase;
	margin: -22px 0 20px;
	position: relative
}

.process-points {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 13px;
	margin-top: 25px
}

.process-points span:before {
	content: '◆';
	color: var(--red);
	margin-right: 9px;
	font-size: 9px
}

.projects {
	background: #071a33;
	color: #fff
}

.filter-row {
	display: flex;
	gap: 24px;
	flex-wrap: wrap;
	margin: 30px 0 40px
}

.filter-btn {
	border: 0;
	background: transparent;
	color: #aebdce;
	text-transform: uppercase;
	letter-spacing: .12em;
	font-weight: 700;
	font-size: 11px;
	padding: 0 0 7px;
	border-bottom: 2px solid transparent
}

.filter-btn.active,
.filter-btn:hover {
	color: #fff;
	border-color: var(--red)
}

.project-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 22px
}

.project-card {
	height: 390px;
	position: relative;
	overflow: hidden
}

.project-card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: .6s
}

.project-card:after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 43%, rgba(2, 13, 29, .95))
}

.project-card:hover img {
	transform: scale(1.07)
}

.project-copy {
	position: absolute;
	z-index: 2;
	left: 25px;
	right: 25px;
	bottom: 22px
}

.project-copy small {
	color: #ff6258;
	text-transform: uppercase;
	letter-spacing: .13em
}

.project-copy h3 {
	font: 600 20px/1.05 'Rajdhani';
	text-transform: uppercase;
	margin: 7px 0
}

.testimonials {
	overflow: hidden
}

.testimonial-track {
	display: flex;
	transition: .65s var(--ease)
}

.testimonial {
	min-width: 100%;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 65px;
	align-items: center
}

.testimonial-visual {
	height: 500px;
	position: relative;
	background: var(--navy);
	overflow: hidden
}

.testimonial-visual img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: .75
}

.testimonial-visual:after {
	content: '“';
	position: absolute;
	left: 28px;
	bottom: -55px;
	font: 700 210px Georgia;
	color: var(--red)
}

.testimonial blockquote {
	font: 600 clamp(24px, 3vw, 38px)/1.3 'Rajdhani';
	margin: 0 0 30px
}

.testimonial cite {
	font-style: normal;
	font-weight: 700
}

.testimonial cite span {
	display: block;
	color: var(--muted);
	font-size: 13px;
	font-weight: 400
}

.slider-arrows {
	display: flex;
	gap: 8px;
	margin-top: 30px
}

.slider-arrow {
	width: 50px;
	height: 50px;
	border: 1px solid var(--line);
	background: #fff;
	font-size: 18px
}

.slider-arrow:hover {
	background: var(--red);
	color: #fff;
	border-color: var(--red)
}

.partner-strip {
	padding: 45px 0;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line)
}

.partner-grid {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 40px;
	align-items: center
}

.partner-grid img {
	max-height: 45px;
	margin: auto;
	filter: grayscale(1);
	opacity: .55;
	transition: .3s
}

.partner-grid img:hover {
	filter: none;
	opacity: 1
}

.blog-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px
}

.blog-card {
	background: #fff;
	border: 1px solid var(--line);
	transition: .35s
}

.blog-card:hover {
	transform: translateY(-7px);
	box-shadow: var(--shadow)
}

.blog-card img {
	height: 205px;
	width: 100%;
	object-fit: cover
}

.blog-copy {
	padding: 24px
}

.blog-copy time {
	font-size: 11px;
	color: var(--red);
	text-transform: uppercase;
	letter-spacing: .14em;
	font-weight: 700
}

.blog-copy h3 {
	font: 700 23px/1.12 'Rajdhani';
	text-transform: uppercase;
	margin: 10px 0 15px
}

.text-link {
	color: var(--red);
	text-transform: uppercase;
	letter-spacing: .12em;
	font-size: 11px;
	font-weight: 700
}

.cta {
	position: relative;
	background: linear-gradient(90deg, rgba(5, 29, 58, .96), rgba(5, 29, 58, .72)), url('../images/Ind4-min.jpg') center/cover;
	color: #fff;
	padding: 90px 0
}

.cta-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 35px
}

.cta h2 {
	font: 700 clamp(40px, 5vw, 72px)/.9 'Rajdhani';
	text-transform: uppercase;
	margin: 0;
	max-width: 780px
}

.cta-actions {
	display: flex;
	gap: 12px;
	flex-wrap: wrap
}

.footer {
	background: #031225;
	color: #d0d9e4;
	padding-top: 80px
}

.footer-grid {
	display: grid;
	grid-template-columns: 1.4fr .7fr .8fr 1fr;
	gap: 55px;
	padding-bottom: 60px
}

.footer-logo {
	background: #fff;
	padding: 12px;
	width: 280px
}

.footer h4 {
	font: 700 20px 'Rajdhani';
	text-transform: uppercase;
	color: #fff;
	margin: 0 0 22px
}

.footer ul {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 10px
}

.footer a:hover {
	color: #ff6358
}

.footer-address {
	display: grid;
	gap: 11px;
	font-size: 14px
}

.newsletter {
	display: flex;
	border-bottom: 1px solid #5c6b7d;
	padding-bottom: 9px
}

.newsletter input {
	background: transparent;
	border: 0;
	outline: 0;
	color: #fff;
	min-width: 0;
	width: 100%
}

.newsletter button {
	border: 0;
	background: var(--red);
	color: #fff;
	width: 44px;
	height: 44px
}

.footer-bottom {
	border-top: 1px solid rgba(255, 255, 255, .12);
	padding: 24px 0;
	font-size: 12px
}

.footer-bottom-inner {
	display: flex;
	justify-content: space-between;
	gap: 20px;
	flex-wrap: wrap
}

.page-hero {
	height: 455px;
	background: linear-gradient(90deg, rgba(2, 15, 35, .94), rgba(2, 15, 35, .52)), url('../images/parts.jpg') center/cover;
	display: flex;
	align-items: center;
	color: #fff;
	position: relative;
	overflow: hidden
}

.page-hero:after {
	content: '';
	position: absolute;
	right: -40px;
	bottom: -80px;
	width: 350px;
	height: 350px;
	border: 65px solid rgba(255, 255, 255, .04);
	border-radius: 50%
}

.page-hero h1 {
	font: 700 clamp(55px, 7vw, 94px)/.9 'Rajdhani';
	text-transform: uppercase;
	margin: 0
}

.breadcrumbs {
	color: #d2dce8;
	text-transform: uppercase;
	letter-spacing: .13em;
	font-size: 11px;
	margin-top: 15px
}

.breadcrumbs a {
	color: #ff6056
}

.about-story {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 70px;
	align-items: start
}

.about-story .big-copy {
	font-size: 19px
}

.value-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 25px;
	margin-top: 50px
}

.value-card {
	padding: 34px;
	border: 1px solid var(--line);
	position: relative
}

.value-card:before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	width: 3px;
	height: 0;
	background: var(--red);
	transition: .4s
}

.value-card:hover:before {
	height: 100%
}

.value-card b {
	font: 700 24px 'Rajdhani';
	text-transform: uppercase;
	display: block;
	margin-bottom: 11px
}

.philosophy {
	display: grid;
	grid-template-columns: .9fr 1.1fr;
	gap: 70px;
	align-items: center
}

.philosophy img {
	height: 600px;
	width: 100%;
	object-fit: cover
}

.dark-card {
	background: var(--navy);
	color: #fff;
	padding: 60px;
	margin-left: -140px;
	position: relative
}

.leadership {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px
}

.leader-card {
	background: #fff;
	border: 1px solid var(--line)
}

.leader-image {
	height: 300px;
	background: linear-gradient(145deg, #0a2344, #163e6d);
	display: grid;
	place-items: center;
	overflow: hidden;
	position: relative
}

.leader-image img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	position: relative;
	z-index: 1;
	transition: transform .45s var(--ease);
	filter: drop-shadow(0 14px 20px rgba(0, 0, 0, .22))
}

.leader-card:hover .leader-image img {
	transform: scale(1.04)
}

.leader-copy {
	padding: 22px
}

.leader-copy h3 {
	font: 700 20px 'Rajdhani';
	text-transform: uppercase;
	margin: 0;
	white-space: nowrap;
	letter-spacing: -.2px
}

.leader-copy h3.research-title {
	font-size: 20px;
	white-space: nowrap;
	letter-spacing: -.2px
}

.leader-copy span {
	font-size: 13px;
	color: var(--muted)
}

.product-intro {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 70px;
	align-items: center
}

.product-showcase {
	height: 620px;
	background: linear-gradient(150deg, #f9fbfd, #e8edf3);
	display: grid;
	place-items: center;
	position: relative;
	overflow: hidden
}

.product-showcase:before {
	content: '';
	position: absolute;
	inset: 40px;
	border: 1px solid #dbe2e9
}

.product-showcase img {
	max-height: 540px;
	position: relative;
	z-index: 2;
	filter: drop-shadow(0 30px 25px rgba(6, 29, 58, .18))
}

.category-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 24px
}

.category-card {
	height: 430px;
	position: relative;
	overflow: hidden;
	background: #071a33;
	color: #fff
}

.category-card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: .72;
	transition: .7s
}

.category-card:after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 35%, rgba(2, 14, 30, .95))
}

.category-card:hover img {
	transform: scale(1.08);
	opacity: .58
}

.category-copy {
	position: absolute;
	z-index: 2;
	left: 34px;
	right: 34px;
	bottom: 28px
}

.category-copy h2 {
	font: 700 40px/1 'Rajdhani';
	text-transform: uppercase;
	margin: 0 0 14px
}

.category-copy a {
	color: #ff5c52;
	text-transform: uppercase;
	font-size: 11px;
	letter-spacing: .14em;
	font-weight: 700
}

.shop-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 30px;
	margin-bottom: 35px
}

.shop-head select {
	height: 52px;
	border: 1px solid var(--line);
	padding: 0 45px 0 16px;
	background: #fff
}

.product-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 28px
}

.product-card {
	border: 1px solid var(--line);
	background: #fff;
	transition: .35s;
	position: relative
}

.product-card:hover {
	transform: translateY(-7px);
	box-shadow: var(--shadow)
}

.product-image {
	height: 340px;
	background: #f5f7fa;
	display: grid;
	place-items: center;
	overflow: hidden;
	padding: 25px
}

.product-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: .55s
}

.product-card:hover .product-image img {
	transform: scale(1.07)
}

.product-badge {
    visibility :hidden;
	position: absolute;
	top: 15px;
	left: 15px;
	background: var(--red);
	color: #fff;
	padding: 6px 10px;
	text-transform: uppercase;
	letter-spacing: .1em;
	font-size: 9px;
	font-weight: 700
}

.wish {
	position: absolute;
	right: 15px;
	top: 15px;
	width: 38px;
	height: 38px;
	border: 0;
	background: #fff;
	border-radius: 50%;
	box-shadow: 0 5px 16px rgba(0, 0, 0, .12)
}

.product-copy {
	padding: 23px
}

.product-copy h3 {
	font: 700 24px/1.08 'Rajdhani';
	text-transform: uppercase;
	margin: 0 0 12px
}

.product-copy p {
	color: var(--muted);
	font-size: 13px;
	min-height: 66px
}

.product-meta {
	display: flex;
	justify-content: space-between;
	align-items: center;
	border-top: 1px solid var(--line);
	padding-top: 17px
}

.rating {
	color: #ef8f23;
	letter-spacing: 1px
}

.product-modal {
	position: fixed;
	inset: 0;
	background: rgba(1, 10, 25, .78);
	z-index: 2000;
	display: none;
	place-items: center;
	padding: 25px
}

.product-modal.open {
	display: grid
}

.modal-card {
	width: min(980px, 100%);
	max-height: 90vh;
	overflow: auto;
	background: #fff;
	display: grid;
	grid-template-columns: 1fr 1fr;
	position: relative
}

.modal-image {
	background: #f3f6f9;
	padding: 55px;
	display: grid;
	place-items: center
}

.modal-image img {
	max-height: 500px
}

.modal-copy {
	padding: 55px
}

.modal-copy h2 {
	font: 700 44px/1 'Rajdhani';
	text-transform: uppercase
}

.modal-close {
	position: absolute;
	right: 15px;
	top: 15px;
	border: 0;
	width: 42px;
	height: 42px;
	background: var(--navy);
	color: #fff;
	z-index: 3;
	font-size: 20px
}

.contact-grid {
	display: grid;
	grid-template-columns: .8fr 1.2fr;
	gap: 70px
}

.contact-info {
	background: var(--navy);
	color: #fff;
	padding: 50px
}

.contact-info h2 {
	font: 700 40px/1 'Rajdhani';
	text-transform: uppercase
}

.contact-item {
	padding: 22px 0;
	border-bottom: 1px solid rgba(255, 255, 255, .13)
}

.contact-item small {
	display: block;
	color: #ff5e54;
	text-transform: uppercase;
	letter-spacing: .14em;
	font-weight: 700
}

.contact-form {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 18px
}

.field {
	display: grid;
	gap: 8px
}

.field.full {
	grid-column: 1/-1
}

.field label {
	text-transform: uppercase;
	letter-spacing: .11em;
	font-size: 10px;
	font-weight: 700
}

.field input,
.field select,
.field textarea {
	width: 100%;
	border: 1px solid var(--line);
	padding: 15px 16px;
	outline: 0;
	background: #fff
}

.field input:focus,
.field select:focus,
.field textarea:focus {
	border-color: var(--red);
	box-shadow: 0 0 0 3px rgba(239, 44, 29, .08)
}

.field textarea {
	min-height: 150px;
	resize: vertical
}

/*.map {*/
/*	height: 440px;*/
/*	background: linear-gradient(rgba(5, 29, 58, .2), rgba(5, 29, 58, .2)), url('../images/Ind6-min.jpg') center/cover;*/
/*	display: grid;*/
/*	place-items: center*/
/*}*/

/*.map-card {*/
/*	background: #fff;*/
/*	padding: 35px;*/
/*	box-shadow: var(--shadow);*/
/*	max-width: 410px;*/
/*	text-align: center*/
/*}*/

/*.map-card h3 {*/
/*	font: 700 31px 'Rajdhani';*/
/*	text-transform: uppercase;*/
/*	margin: 0 0 12px*/
/*}*/

/*lcation new css */

.map {
    min-height: 500px;
    background:
        linear-gradient(rgba(5,29,58,.2), rgba(5,29,58,.2)),
        url('../images/Ind6-min.jpg') center/cover;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;
}

.map-wrapper {
    width: 100%;
    max-width: 1100px;
    display: flex;
    justify-content: space-between;
    gap: 40px;
}

.map-card {
    background: #fff;
    padding: 35px;
    box-shadow: var(--shadow);
    width: 100%;
    max-width: 450px;
    text-align: center;
}

.map-card h3 {
    font: 700 31px 'Rajdhani';
    text-transform: uppercase;
    margin: 0 0 12px;
}

/* Mobile */
@media (max-width: 768px) {
    .map-wrapper {
        flex-direction: column;
        align-items: center;
    }

    .map-card {
        max-width: 100%;
    }
}
/*end here */


.cookie {
	position: fixed;
	left: 20px;
	right: 20px;
	bottom: 20px;
	z-index: 1800;
	background: #fff;
	box-shadow: 0 20px 70px rgba(0, 0, 0, .23);
	padding: 18px 22px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 25px;
	font-size: 13px;
	transform: translateY(160%);
	transition: .5s var(--ease)
}

.cookie.show {
	transform: none
}

.cookie-actions {
	display: flex;
	gap: 8px
}

.cookie button {
	border: 0;
	padding: 10px 15px;
	text-transform: uppercase;
	letter-spacing: .1em;
	font-size: 9px;
	font-weight: 700
}

.cookie .accept {
	background: var(--red);
	color: #fff
}

.cookie .reject {
	background: var(--navy);
	color: #fff
}

[data-reveal] {
	opacity: 0;
	transform: translateY(38px);
	transition: opacity .8s var(--ease), transform .8s var(--ease)
}

[data-reveal].revealed {
	opacity: 1;
	transform: none
}

[data-reveal="left"] {
	transform: translateX(-38px)
}

[data-reveal="right"] {
	transform: translateX(38px)
}

[data-reveal="left"].revealed,
[data-reveal="right"].revealed {
	transform: none
}

@keyframes fadeUp {
	from {
		opacity: 0;
		transform: translateY(20px)
	}

	to {
		opacity: 1;
		transform: none
	}
}

@keyframes rise {
	from {
		opacity: 0;
		transform: translateY(25px)
	}

	to {
		opacity: 1;
		transform: none
	}
}

@keyframes float {
	50% {
		transform: translateY(-18px)
	}
}

@media(max-width:1050px) {
	.topbar-list span:last-child {
		display: none
	}

	.nav-links,
	.contact-btn {
		display: none
	}

	.menu-toggle {
		display: grid
	}

	.logo {
		max-width: 250px
	}

	.hero-content {
		width: 72vw
	}

	.hero-art {
		width: 48vw;
		right: -5vw
	}

	.intro-grid,
	.who-grid,
	.about-story,
	.product-intro,
	.contact-grid {
		gap: 45px
	}

	.feature-grid {
		grid-template-columns: 1fr 1fr
	}

	.expertise-grid,
	.project-grid,
	.product-grid {
		grid-template-columns: 1fr 1fr
	}

	.blog-grid {
		grid-template-columns: 1fr 1fr
	}

	.footer-grid {
		grid-template-columns: 1.2fr 1fr
	}

	.process-wrap {
		grid-template-columns: 1fr
	}

	.leadership {
		grid-template-columns: 1fr 1fr
	}

	.dark-card {
		margin-left: -80px
	}

	.partner-grid {
		grid-template-columns: repeat(3, 1fr)
	}

	.category-grid {
		grid-template-columns: 1fr 1fr
	}
}

@media(max-width:760px) {
	.container {
		width: min(100% - 28px, 1220px)
	}

	.topbar {
		display: none
	}

	.nav {
		height: 76px
	}

	.logo {
		width: 210px;
		max-width: 70vw
	}

	.section {
		padding: 75px 0
	}

	.hero {
		height: 720px;
		min-height: 0
	}

	.hero-content {
		width: auto;
		padding: 0 20px;
		align-self: flex-start;
		margin-top: 90px
	}

	.hero h1 {
		font-size: 55px
	}

	.hero p {
		font-size: 15px;
		max-width: 90%
	}

	.hero-art {
		width: 85vw;
		right: -20vw;
		bottom: -70px;
		opacity: .8
	}

	.hero-crane {
		width: 95vw;
		right: -35vw
	}

	.scroll-cue {
		display: none
	}

	.hero-dots {
		left: 20px;
		bottom: 22px
	}

	.intro-grid,
	.who-grid,
	.about-story,
	.philosophy,
	.product-intro,
	.contact-grid,
	.testimonial,
	.choose-head {
		grid-template-columns: 1fr
	}

	.visual-stack {
		min-height: 480px
	}

	.visual-stack .main-img {
		height: 430px;
		width: 90%
	}

	.visual-stack .floating-img {
		height: 250px;
		width: 55%
	}

	.year-badge {
		width: 145px;
		height: 145px;
		left: -8px;
		bottom: 20px
	}

	.year-badge strong {
		font-size: 44px
	}

	.feature-grid,
	.expertise-grid,
	.project-grid,
	.product-grid,
	.blog-grid,
	.value-grid,
	.category-grid {
		grid-template-columns: 1fr
	}

	.stats {
		grid-template-columns: 1fr 1fr
	}

	.stat:nth-child(2) {
		border-right: 0
	}

	.stat:nth-child(-n+2) {
		border-bottom: 1px solid var(--line)
	}

	.expert-card,
	.project-card {
		height: 370px
	}

	.quote-inner,
	.cta-inner,
	.expertise-head,
	.shop-head {
		align-items: flex-start;
		flex-direction: column
	}

	.quote-inner {
		display: flex
	}

	.process-panel {
		padding: 30px 23px
	}

	.process-points {
		grid-template-columns: 1fr
	}

	.testimonial-visual {
		height: 350px
	}

	.partner-grid {
		grid-template-columns: 1fr 1fr
	}

	.footer-grid {
		grid-template-columns: 1fr
	}

	.footer-logo {
		width: 240px
	}

	.page-hero {
		height: 340px
	}

	.dark-card {
		margin: -80px 18px 0;
		padding: 35px
	}

	.leadership {
		grid-template-columns: 1fr
	}

	.category-card {
		height: 370px
	}

	.product-image {
		height: 315px
	}

	.modal-card {
		grid-template-columns: 1fr
	}

	.modal-copy,
	.modal-image {
		padding: 35px
	}

	.contact-form {
		grid-template-columns: 1fr
	}

	.field.full {
		grid-column: auto
	}

	.cookie {
		display: block
	}

	.cookie-actions {
		margin-top: 12px
	}

	.mobile-panel {
		padding-top: 80px
	}

	.mini-features {
		grid-template-columns: 1fr
	}
}

/* new video css  */
.hero{
    position:relative;
    height:100vh;
    min-height:700px;
    overflow:hidden;
    display:flex;
    align-items:center;
}

.hero-video-wrapper{
    position:absolute;
    inset:0;
    z-index:1;
}

.hero-video{
    width:100%;
    height:100%;
    object-fit:cover;
}

.hero-overlay{
    position:absolute;
    inset:0;
    background:linear-gradient(
        90deg,
        rgba(0,0,0,0.75),
        rgba(0,0,0,0.35)
    );
}

.hero-content{
    margin-top: -115px;
    position:relative;
    z-index:2;
    max-width:700px;
    padding-left:94px;
    color:#fff;
}

.hero-kicker{
    
    font-size:10px;
    letter-spacing:3px;
    text-transform:uppercase;
    margin-bottom:20px;
}

.hero-content h1{
    font-size:50px;
    line-height:1.1;
    margin-bottom:20px;
    color:#fff;
}

.hero-content p{
    font-size:14px;
    line-height:1.8;
    max-width:600px;
    margin-bottom:30px;
}

@media(max-width:768px){

    .hero{
        min-height:650px;
    }

    .hero-content{
        padding:0 25px;
    }

    .hero-content h1{
        font-size:42px;
    }

    .hero-content p{
        font-size:16px;
    }
}

.product-image{
   cursor:pointer;
}


/* infra css  */

.infrastructure-hero {
	background: linear-gradient(90deg, rgba(2, 15, 35, .94), rgba(2, 15, 35, .48)), url('../images/infra banner.webp') center 46%/cover;
}

.infra-intro {
	display: grid;
	grid-template-columns: .95fr 1.05fr;
	gap: 80px;
	align-items: start;
}

.infra-intro-copy > p:not(.lead) {
	color: var(--muted);
	font-size: 17px;
}

.infra-pill-list {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 28px;
}

.infra-pill-list span {
	padding: 10px 15px;
	background: var(--soft);
	border: 1px solid var(--line);
	color: var(--navy);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
}

.infra-heading {
	display: grid;
	grid-template-columns: 1.2fr .8fr;
	gap: 70px;
	align-items: end;
	margin-bottom: 46px;
}

.infra-machine-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 26px;
}

.infra-machine-card {
	background: #fff;
	border: 1px solid var(--line);
	box-shadow: 0 14px 42px rgba(5, 29, 58, .07);
	overflow: hidden;
	transition: transform .4s var(--ease), box-shadow .4s var(--ease);
}

.infra-machine-card:hover {
	transform: translateY(-7px);
	box-shadow: var(--shadow);
}

.infra-machine-card-wide {
	grid-column: span 1;
}

.infra-machine-card-full {
	grid-column: 1 / -1;
}

.infra-machine-card-full .infra-machine-image {
	height: 500px;
}

.infra-machine-image {
	height: 390px;
	overflow: hidden;
	background: #e7ebef;
}

.infra-machine-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .65s var(--ease);
}

.infra-machine-card:hover .infra-machine-image img {
	transform: scale(1.035);
}

.infra-machine-copy {
	padding: 30px 32px 34px;
	position: relative;
}

.infra-machine-copy > span {
	display: inline-grid;
	place-items: center;
	width: 44px;
	height: 44px;
	background: var(--red);
	color: #fff;
	font: 700 17px 'Rajdhani', sans-serif;
	margin-bottom: 18px;
}

.infra-machine-copy h3 {
	font: 700 29px/1.05 'Rajdhani', sans-serif;
	text-transform: uppercase;
	margin: 0 0 12px;
}

.infra-machine-copy p {
	color: var(--muted);
	margin: 0;
}

.infra-process-head {
	max-width: 790px;
	margin-bottom: 52px;
}

.infra-process-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	border-top: 1px solid rgba(255, 255, 255, .17);
	border-bottom: 1px solid rgba(255, 255, 255, .17);
}

.infra-process-grid article {
	padding: 38px 28px;
	border-right: 1px solid rgba(255, 255, 255, .17);
}

.infra-process-grid article:last-child {
	border-right: 0;
}

.infra-process-grid b {
	color: var(--red);
	font: 700 18px 'Rajdhani', sans-serif;
	letter-spacing: .12em;
}

.infra-process-grid h3 {
	font: 700 27px 'Rajdhani', sans-serif;
	text-transform: uppercase;
	margin: 16px 0 10px;
}

.infra-process-grid p {
	color: #b9c6d7;
	font-size: 14px;
	margin: 0;
}

@media(max-width:1050px) {
	.infra-intro,
	.infra-heading {
		gap: 45px;
	}

	.infra-process-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.infra-process-grid article:nth-child(2) {
		border-right: 0;
	}

	.infra-process-grid article:nth-child(-n+2) {
		border-bottom: 1px solid rgba(255, 255, 255, .17);
	}
}

@media(max-width:760px) {
	.infrastructure-hero {
		background-position: 58% center;
	}

	.infra-intro,
	.infra-heading,
	.infra-machine-grid,
	.infra-process-grid {
		grid-template-columns: 1fr;
	}

	.infra-heading {
		gap: 15px;
		margin-bottom: 32px;
	}

	.infra-machine-image {
		height: 280px;
	}

	.infra-machine-card-full .infra-machine-image {
		height: 280px;
	}

	.infra-machine-copy {
		padding: 25px;
	}

	.infra-process-grid article {
		border-right: 0;
		border-bottom: 1px solid rgba(255, 255, 255, .17);
	}

	.infra-process-grid article:last-child {
		border-bottom: 0;
	}
}

/* end here  */

/* end here  */