/* Quantum Techs — style.css (clean consolidated) */

@import url('global.css');
@import url('header.css');
@import url('footer.css');
@import url('animate.css');
@import url('swiper.min.css');
@import url('font-awesome.css');
@import url('custom-animate.css');
@import url('odometer-theme-default.css');

/* ─────────────────────────────────────────
   BANNER
───────────────────────────────────────── */
.banner-one {
	position: relative;
	width: 100%;
	min-height: 100vh;
	overflow: hidden;
	padding: 0;
	display: block;
	background-size: cover;
	background-position: center;
}

.banner-one:before {
	position: absolute;
	content: '';
	inset: 0;
	background: linear-gradient(135deg, #9dd8d8 0%, #c5edec 40%, #e0f9f9 100%);
	opacity: 1;
	z-index: 0;
}

.banner-inner-grid {
	position: relative;
	z-index: 2;
	display: grid;
	grid-template-columns: 1fr 1fr;
	min-height: 100vh;
	width: 100%;
}

.banner-text-col {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 160px 50px 80px 80px;
	position: relative;
	z-index: 2;
}

.banner-one_heading {
	font-size: 90px !important;
	font-weight: 800 !important;
	line-height: 0.95em !important;
	letter-spacing: -3px !important;
	color: #0d2b2b !important;
	text-transform: uppercase !important;
	margin-bottom: 30px !important;
}

.banner-one_content { position: relative; }
.banner-one_content-inner { position: relative; }

.banner-one_text {
	font-size: 18px;
	line-height: 30px;
	color: #1a4040;
	padding-top: 20px;
	margin-bottom: 10px;
	border-top: 2px solid rgba(42,143,143,0.5);
}

.banner-one_text-two {
	font-size: 16px;
	line-height: 26px;
	color: #2a5555;
	padding-bottom: 25px;
	margin-bottom: 30px;
	border-bottom: 1px solid rgba(42,143,143,0.30);
}

.banner-cta {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 16px 32px;
	font-size: 14px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	color: #ffffff;
	background: var(--color-two);
	width: fit-content;
	transition: all 0.3s ease;
}
.banner-cta:hover { background: var(--main-color); color: #ffffff; transform: translateX(5px); }

.banner-text-col .down-box {
	position: absolute;
	bottom: 30px;
	left: 80px;
	width: 50px;
	height: 50px;
	cursor: pointer;
	animation: icon-bounce 1.2s ease-out infinite;
	z-index: 5;
}

.banner-robot-col {
	position: relative;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	overflow: visible;
	z-index: 2;
}

#robot-container {
	position: absolute;
	bottom: -20px;
	left: 0; right: 0; top: 0;
	transform-style: preserve-3d;
	will-change: transform;
}

#robot-container spline-viewer {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 110%;
	display: block;
}

.banner-one .robot {
	position: absolute !important;
	inset: 0 !important;
	width: 100% !important;
	height: 110% !important;
	mix-blend-mode: normal !important;
}

/* ─────────────────────────────────────────
   SERVICES
───────────────────────────────────────── */
.services-one {
	position: relative;
	padding: 100px 0 70px;
	background: #ffffff;
}

.service-block_one { position: relative; margin-bottom: 30px; }

.service-block_one-inner {
	position: relative;
	padding: 35px 40px;
	border: 1px solid rgba(42,143,143,0.20);
	background: #ffffff;
	transition: all 400ms ease;
	overflow: hidden;
}

.service-block_one-inner:before {
	position: absolute;
	content: '';
	inset: -1px;
	opacity: 0;
	transform: scale(1, 0.2);
	transition: all 500ms ease;
	background: linear-gradient(135deg, var(--main-color) 0%, var(--color-two) 100%);
	z-index: 0;
}

.service-block_one-inner:hover::before { opacity: 1; transform: scale(1,1); }

.service-block_one-heading {
	position: relative;
	font-size: 26px !important;
	font-weight: 600 !important;
	line-height: 1.3em !important;
	color: #141414;
	z-index: 1;
	transition: color 0.3s ease;
}

.service-block_one-inner:hover .service-block_one-heading { color: #ffffff; }
.service-block_one-icon { position: relative; z-index: 1; }

.services-cta { text-align: center; margin-top: 40px; padding-top: 20px; border-top: 1px solid rgba(42,143,143,0.15); }

.theme-btn-link {
	display: inline-block;
	padding: 14px 36px;
	font-size: 15px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: var(--main-color);
	border: 2px solid var(--main-color);
	transition: all 0.3s ease;
}
.theme-btn-link:hover { background: var(--main-color); color: #ffffff; }
.theme-btn-link i { margin-left: 8px; transition: transform 0.3s ease; }
.theme-btn-link:hover i { transform: translateX(4px); }

/* ─────────────────────────────────────────
   GALLERY / OUR WORK
───────────────────────────────────────── */
.gallery-one {
	position: relative;
	padding: 100px 0 70px;
	background-color: #f7fdfd;
}

.gallery-block_one { position: relative; margin-bottom: 30px; }
.gallery-block_one-inner { position: relative; }

.gallery-block_one-content {
	position: relative;
	padding: 25px;
	border: 1px solid rgba(42,143,143,0.15);
	background: #ffffff;
	overflow: hidden;
}

.gallery-block_one-content:before {
	position: absolute;
	content: '';
	inset: -1px;
	opacity: 0;
	transform: scale(0.2, 1);
	transition: all 500ms ease;
	background: linear-gradient(135deg, var(--main-color) 0%, var(--color-two) 100%);
	z-index: 0;
}

.gallery-block_one-inner:hover .gallery-block_one-content:before { opacity: 1; transform: scale(1,1); }

.gallery-block_one-image {
	position: relative;
	overflow: hidden;
	margin-bottom: 25px;
	z-index: 1;
}

.gallery-block_one-image img { width: 100%; display: block; transition: transform 0.5s ease; }
.gallery-block_one-inner:hover .gallery-block_one-image img { transform: scale(1.04); }

.gallery-block_one-title {
	position: relative;
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: 1px;
	font-weight: 600;
	color: var(--main-color);
	z-index: 1;
	transition: color 0.3s ease;
}
.gallery-block_one-inner:hover .gallery-block_one-title { color: rgba(255,255,255,0.75); }

.gallery-block_one-heading {
	position: relative;
	font-size: 20px !important;
	font-weight: 600;
	margin-top: 8px;
	text-transform: uppercase;
	z-index: 1;
}
.gallery-block_one-heading a { color: #141414; }
.gallery-block_one-inner:hover .gallery-block_one-heading a { color: #ffffff; }

.service-block_one-more {
	position: relative;
	margin-left: 25px;
	z-index: 1;
	opacity: 0;
	transform: translateY(-10px);
	transition: opacity 0.4s ease, transform 0.4s ease;
}
.gallery-block_one-inner:hover .service-block_one-more { opacity: 1; transform: translateY(0); }

.service-block_one-more .view-more {
	font-size: 14px;
	font-weight: 600;
	display: inline-block;
	padding: 8px 38px 8px 14px;
	color: var(--main-color);
	text-transform: uppercase;
	background-color: #ffffff;
}
.service-block_one-more .view-more i {
	position: absolute;
	right: 1px; top: 1px; bottom: 1px;
	width: 30px;
	font-size: 16px;
	line-height: 31px;
	color: #ffffff;
	background-color: var(--main-color);
	text-align: center;
}

/* ─────────────────────────────────────────
   JOURNAL SECTIONS
───────────────────────────────────────── */
.journal-one {
	position: relative;
	padding: 100px 0 70px;
	background-attachment: fixed;
	background-size: cover;
}
.journal-one:before {
	position: absolute;
	content: '';
	inset: 0;
	opacity: 0.94;
	background-color: #0d1a1a;
}
.journal-one .journal-block_one { width: 20%; float: left; padding: 0 15px; }

.journal-two {
	position: relative;
	padding: 30px 0 70px;
	background: #ffffff;
}
.journal-two .journal-block_one { width: 20%; float: left; padding: 0 15px; }

.journal-block_one { position: relative; margin-bottom: 30px; }

.journal-block_one-inner {
	position: relative;
	padding: 25px;
	background-color: rgba(255,255,255,0.05);
	border: 1px solid rgba(255,255,255,0.10);
}
.journal-block_one-inner:before {
	position: absolute;
	content: '';
	inset: -1px;
	opacity: 0;
	transform: scale(0.2, 1);
	transition: all 500ms ease;
	background: linear-gradient(135deg, var(--main-color) 0%, var(--color-two) 100%);
}
.journal-block_one-inner:hover::before { opacity: 1; transform: scale(1,1); }

.journal-block_one-title {
	position: relative;
	font-size: 12px !important;
	padding: 4px 12px;
	text-transform: capitalize;
	color: var(--main-color);
	display: inline-block;
	border: 1px solid rgba(42,143,143,0.40);
	background: rgba(42,143,143,0.08);
	transition: all 0.3s ease;
	letter-spacing: 0.5px;
}
.journal-block_one-inner:hover .journal-block_one-title { color: #ffffff; border-color: transparent; background: transparent; }

.journal-block_one-heading {
	position: relative;
	font-size: 16px !important;
	font-weight: 500 !important;
	line-height: 24px !important;
	margin-top: 18px;
	max-width: 220px;
	margin-bottom: 80px;
}
.journal-block_one-heading a { color: #ffffff; }
.journal-block_one-heading a:hover { color: rgba(255,255,255,0.75); }

.journal-block_one-arrow {
	position: absolute;
	right: 10px; bottom: 15px;
	font-size: 28px;
	color: rgba(255,255,255,0.50);
	transform: rotate(45deg);
	transition: color 0.3s ease;
}

/* journal-two overrides (white bg) */
.journal-two .journal-block_one-inner {
	background: #ffffff;
	border: 1px solid rgba(42,143,143,0.15);
	border-left: 3px solid var(--main-color);
}
.journal-two .journal-block_one-inner::before { display: none; }
.journal-two .journal-block_one-inner:hover { background: #f7fdfd; transform: translateX(4px); }
.journal-two .journal-block_one-title { color: var(--main-color); border: none; background: none; padding: 0; }
.journal-two .journal-block_one-heading a { color: #141414; }
.journal-two .journal-block_one-heading a:hover { color: var(--main-color); }
.journal-two .journal-block_one-arrow { color: var(--main-color); }

/* ─────────────────────────────────────────
   TESTIMONIALS
───────────────────────────────────────── */
.testimonial-one {
	position: relative;
	padding: 100px 0 70px;
	background-color: #f7fdfd;
}
.testimonial-one.style-two { padding-top: 0; background: none; }
.testimonial-block_one { position: relative; margin-bottom: 30px; }
.testimonial-block_one-inner { position: relative; }

.testimonial-block_one-content {
	position: relative;
	padding: 25px;
	border: 1px solid rgba(42,143,143,0.15);
	background: #ffffff;
	transition: all 400ms ease;
	overflow: hidden;
}
.testimonial-block_one-content:before {
	position: absolute;
	content: '';
	inset: 0;
	opacity: 0;
	background: linear-gradient(135deg, var(--main-color) 0%, var(--color-two) 100%);
	transition: all 0.5s ease;
	transform: perspective(400px) rotateX(-90deg);
	transform-origin: top;
}
.testimonial-block_one-inner:hover .testimonial-block_one-content:before { opacity: 1; transform: perspective(400px) rotateX(0deg); }

.testimonial-block_one-author { position: relative; width: 70px; height: 70px; display: inline-block; border-radius: 50%; overflow: hidden; }
.testimonial-block_one-author img { width: 100%; }

.testimonial-block_one-name { position: relative; font-size: 18px !important; font-weight: 600 !important; margin-top: 15px; color: #141414; transition: color 0.3s ease; }
.testimonial-block_one-inner:hover .testimonial-block_one-name { color: #ffffff; }

.testimonial-block_one-designation { position: relative; font-size: 13px !important; margin-top: 4px; color: var(--main-color); transition: color 0.3s ease; opacity: 1 !important; }
.testimonial-block_one-inner:hover .testimonial-block_one-designation { color: rgba(255,255,255,0.80); }

.testimonial-block_one-number { position: relative; font-size: 40px; font-weight: 700; margin-top: 20px; opacity: 0.08; text-align: right; color: var(--main-color); transition: all 0.3s ease; }
.testimonial-block_one-inner:hover .testimonial-block_one-number { opacity: 0.25; color: #ffffff; }

.testimonial-block_one-lower { position: relative; margin-left: 20px; margin-top: 20px; font-size: 15px !important; line-height: 25px !important; padding-left: 60px; color: #5a6464; transition: color 0.3s ease; }
.testimonial-block_one-inner:hover .testimonial-block_one-lower { color: rgba(255,255,255,0.85); }
.testimonial-block_one-lower .quote_icon { position: absolute; left: 0; top: 4px; }

/* ─────────────────────────────────────────
   STATS
───────────────────────────────────────── */
.stats-one {
	position: relative;
	padding: 100px 0;
	background-attachment: fixed;
	background-size: cover;
}
.stats-one:before { position: absolute; content: ''; inset: 0; opacity: 0.93; background-color: #0d1a1a; }
.stats-one.style-two::before { display: none; }
.stats-one.style-two { background: #f7fdfd; padding: 80px 0; }

.stats-one .inner-container { position: relative; overflow: hidden; border: 1px solid rgba(42,143,143,0.35); border-bottom: 0; }
.stats-one .counter-block_one { float: left; padding: 0; }
.counter-block_one { position: relative; }
.counter-block_one-inner {
	position: relative;
	padding: 35px 40px;
	border-right: 1px solid rgba(42,143,143,0.25);
	border-bottom: 1px solid rgba(42,143,143,0.25);
	background: rgba(255,255,255,0.03);
	transition: background 0.3s ease;
}
.counter-block_one-inner:before { position: absolute; content: ''; right: 16px; top: 16px; width: 12px; height: 12px; border-radius: 50%; background: var(--main-color); opacity: 0.6; }
.counter-block_one-inner:hover { background: rgba(42,143,143,0.08); }
.counter-block_one-counter { position: relative; font-size: 60px !important; font-weight: 700 !important; line-height: 1em; color: var(--main-color) !important; }
.counter-block_one-text { position: relative; font-size: 16px !important; font-weight: 500 !important; margin-top: 5px; color: rgba(255,255,255,0.65); text-transform: capitalize; }
.stats-one.style-two .counter-block_one-text { color: #5a6464; }

.stats-one_contact-column { padding: 0; float: left; }
.stats-one_contact-inner { position: relative; padding: 35px; background: linear-gradient(135deg, var(--main-color) 0%, var(--color-two) 100%); height: 100%; }
.stats-one_contact-content { position: relative; padding: 20px 20px 20px 70px; background-color: rgba(0,0,0,0.20); }
.stats-one_contact-icon { position: absolute; left: 20px; top: 50%; transform: translateY(-50%); font-size: 30px; color: #ffffff; }
.stats-one_contact-content h3 { font-size: 26px; font-weight: 600; color: #ffffff; text-transform: uppercase; }
.stats-one_contact-content .text { font-size: 16px; color: rgba(255,255,255,0.80); }

/* ─────────────────────────────────────────
   AWARDS / WHY US
───────────────────────────────────────── */
.awards-one { position: relative; padding: 100px 0; background-color: #ffffff; }
.awards-one.style-two { padding-top: 0; background: none; }
.awards-block_one { position: relative; margin-bottom: 10px; }
.awards-block_one-inner {
	position: relative;
	padding: 10px;
	min-height: 110px;
	border: 1px solid rgba(42,143,143,0.15);
	transition: all 400ms ease;
	overflow: hidden;
}
.awards-block_one-inner:before {
	position: absolute;
	content: '';
	inset: -1px;
	opacity: 0;
	transform: scale(1, 0.2);
	transition: all 500ms ease;
	background: linear-gradient(135deg, var(--main-color) 0%, var(--color-two) 100%);
}
.awards-block_one-inner:hover::before { opacity: 1; transform: scale(1,1); }

.awards-block_one-content { position: relative; padding-top: 22px; padding-left: 115px; z-index: 1; }
.awards-block_one-number {
	position: absolute;
	left: 0; top: 0;
	width: 90px; height: 90px;
	font-size: 36px;
	line-height: 90px;
	text-align: center;
	font-weight: 700;
	color: var(--main-color);
	background-color: rgba(42,143,143,0.07);
	border: 1px solid rgba(42,143,143,0.15);
	transition: all 0.3s ease;
}
.awards-block_one-inner:hover .awards-block_one-number { color: #ffffff; background: transparent; border-color: rgba(255,255,255,0.25); }

.awards-block_one-title { position: relative; font-size: 22px !important; font-weight: 600 !important; color: #141414; text-transform: uppercase; transition: color 0.3s ease; }
.awards-block_one-inner:hover .awards-block_one-title { color: #ffffff; }
.awards-block_one-title span { position: relative; font-size: 14px !important; font-weight: 400 !important; display: block; color: #5a6464; opacity: 1 !important; margin-left: 0; top: 0; }
.awards-block_one-inner:hover .awards-block_one-title span { color: rgba(255,255,255,0.75); }

.awards-block_one-arrow { position: absolute; right: 20px; top: 50%; transform: translateY(-50%); z-index: 1; font-size: 36px; color: rgba(42,143,143,0.30); transition: color 0.3s ease; }
.awards-block_one-inner:hover .awards-block_one-arrow { color: rgba(255,255,255,0.60); }
.awards-block_one-link { position: absolute; inset: 0; z-index: 10; display: block; }

/* ─────────────────────────────────────────
   PAGE TITLE
───────────────────────────────────────── */
.page-title {
	position: relative;
	text-align: center;
	padding: 150px 0 90px;
	background: linear-gradient(135deg, #f0fafa 0%, #e8f8f8 100%);
	border-bottom: 2px solid rgba(42,143,143,0.15);
}
.page-title_heading { position: relative; font-size: 90px; line-height: 1em; color: #141414; text-transform: uppercase; }
.page-title_text { position: relative; font-size: 17px; margin-top: 12px; color: var(--main-color); font-weight: 500; letter-spacing: 0.5px; }

/* ─────────────────────────────────────────
   TEAM
───────────────────────────────────────── */
.team-one { position: relative; padding: 60px 0 0; background: #ffffff; }
.team-one .title-box { position: relative; margin-bottom: 50px; }
.team-one .title-box h2 { font-size: 32px !important; font-weight: 400; line-height: 46px !important; max-width: 800px; color: #5a6464 !important; }

.team-block_one { position: relative; margin-bottom: 40px; transition: transform 0.4s ease; }
.team-block_one:hover { transform: translateY(-8px); }
.team-block_one-inner { position: relative; padding-left: 25px; padding-bottom: 40px; min-height: 280px; overflow: hidden; border: 1px solid rgba(42,143,143,0.15); border-top: 3px solid var(--main-color); }
.team-block_one-image { position: absolute !important; right: 10px; bottom: 0; max-width: 160px; }
.team-block_one-image img { max-height: 240px; width: auto; display: block; }

.team-block_one-socials { position: relative; width: 172px; margin-top: 40px; display: inline-block; padding: 10px 9px 4px; background-color: #f7fdfd; border: 1px solid rgba(42,143,143,0.15); }
.team-block_one-socials a { position: relative; width: 70px; height: 40px; margin: 0 2px 5px; line-height: 38px; text-align: center; display: inline-block; border: 1px solid rgba(42,143,143,0.15); opacity: 0; transform: translateY(10px); transition: all 0.4s ease; }
.team-block_one:hover .team-block_one-socials a { opacity: 1; transform: translateY(0); }
.team-block_one-socials a img { width: 22px; position: relative; top: -1px; }

.team-block_one-heading { position: relative; font-weight: 600; margin-top: 25px; }
.team-block_one-heading a { color: #141414; }
.team-block_one-heading a:hover { color: var(--main-color); }
.team-block_one-designation { position: relative; font-size: 15px; margin-top: 3px; color: var(--main-color); font-weight: 500; }

/* ─────────────────────────────────────────
   CONTACT
───────────────────────────────────────── */
.contact-one { position: relative; padding: 60px 0 80px; background: #ffffff; }
.contact-one_info-column { position: relative; margin-bottom: 30px; }
.contact-one_heading { font-size: 32px !important; font-weight: 500; color: #141414; line-height: 1.35em; }
.contact-one_list { position: relative; margin-top: 25px; padding: 20px 0; border-top: 1px solid rgba(42,143,143,0.20); border-bottom: 1px solid rgba(42,143,143,0.20); }
.contact-one_list li { position: relative; font-size: 18px; line-height: 28px; margin-bottom: 16px; color: #5a6464; }
.contact-one_list li:last-child { margin-bottom: 0; }
.contact-one_list li a { color: var(--main-color); font-weight: 500; }
.contact-one_list li a:hover { color: var(--color-two); }
.contact-one_socials { position: relative; margin-top: 25px; display: flex; flex-wrap: wrap; gap: 10px; }
.contact-one_socials li a { font-size: 15px; font-weight: 500; color: #5a6464; padding: 6px 14px; border: 1px solid rgba(42,143,143,0.20); transition: all 0.3s ease; }
.contact-one_socials li a:hover { color: #ffffff; background: var(--main-color); border-color: var(--main-color); }

.contact-one_form-outer { position: relative; padding: 40px; border: 1px solid rgba(42,143,143,0.15); background: #f7fdfd; border-top: 3px solid var(--main-color); }
.contact-one_form-outer h3 { font-weight: 600; margin-bottom: 25px; color: #141414; font-size: 26px; }

.contact-form .form-group { position: relative; margin-bottom: 20px; }
.contact-form .form-group input[type="text"],
.contact-form .form-group input[type="email"],
.contact-form .form-group input[type="tel"] {
	display: block; width: 100%; line-height: 28px; padding: 10px 18px; height: 54px;
	font-size: 16px; color: #141414; background: #ffffff;
	border: 1px solid rgba(42,143,143,0.20); transition: all 300ms ease;
}
.contact-form .form-group input:focus, .contact-form .form-group textarea:focus {
	border-color: var(--main-color); box-shadow: 0 0 0 3px rgba(42,143,143,0.10); outline: none;
}
.contact-form .form-group input::placeholder, .contact-form .form-group textarea::placeholder { color: #aaa; }
.contact-form .form-group textarea { display: block; width: 100%; font-size: 16px; padding: 14px 18px; color: #141414; height: 160px; resize: none; background: #ffffff; border: 1px solid rgba(42,143,143,0.20); transition: all 300ms ease; }
.contact-form .form-group button { padding: 16px 40px; font-weight: 600; font-size: 16px; color: #ffffff; text-transform: uppercase; letter-spacing: 1px; background: linear-gradient(135deg, var(--main-color) 0%, var(--color-two) 100%); transition: all 0.4s ease; cursor: pointer; }
.contact-form .form-group button:hover { background: linear-gradient(135deg, var(--color-two) 0%, var(--main-color) 100%); }
.contact-form input.error, .contact-form textarea.error { border-color: #ff4444 !important; }
.contact-form label.error { display: block; padding: 5px 0 0; font-size: 12px; color: #ff4444; font-weight: 600; }

/* ─────────────────────────────────────────
   JOURNAL & SINGLE WORK DETAIL PAGES
───────────────────────────────────────── */
.journal-detail { position: relative; padding: 180px 0 60px; background: #ffffff; }
.journal-detail .column { position: relative; margin-bottom: 30px; }
.journal-detail_image { position: relative; padding-right: 20px; margin-bottom: 25px; }
.journal-detail_image img { width: 100%; display: block; }
.journal-detail_title { position: relative; font-size: 40px !important; font-weight: 500; line-height: 50px !important; margin-bottom: 20px; color: #141414; }
.journal-detail p { font-size: 17px; line-height: 28px; margin-bottom: 16px; color: #5a6464; }

.single-work { position: relative; padding: 180px 0 60px; background: #ffffff; }
.single-work .column { position: relative; margin-bottom: 30px; }
.single-work_image { position: relative; padding-right: 20px; margin-bottom: 25px; }
.single-work_image img { width: 100%; display: block; }
.single-work_title { font-size: 48px !important; font-weight: 700; line-height: 1.1em; margin-bottom: 18px; color: #141414; text-transform: uppercase; letter-spacing: -1px; }
.single-work p { font-size: 17px; line-height: 28px; margin-bottom: 15px; color: #5a6464; }
.single-work_list { position: relative; margin-top: 30px; border: 1px solid rgba(42,143,143,0.20); border-bottom: 0; }
.single-work_list li { position: relative; padding: 18px 20px; font-size: 18px; font-weight: 600; color: #141414; text-transform: uppercase; border-bottom: 1px solid rgba(42,143,143,0.15); background: #ffffff; transition: background 0.3s ease; }
.single-work_list li:hover { background: #f7fdfd; }
.single-work_list li span { display: block; font-size: 16px; font-weight: 400; margin-top: 5px; text-transform: capitalize; color: var(--main-color); }
.single-work_list a { color: var(--main-color); }

.work-one { position: relative; padding: 40px 0 100px; background: #f7fdfd; }

/* ─────────────────────────────────────────
   MISC
───────────────────────────────────────── */
a.backtop { display: inline-flex; align-items: center; justify-content: center; background: transparent; width: 44px; height: 44px; border: 1px solid var(--main-color); font-size: 20px; color: var(--main-color); transition: all 0.4s ease; }
a.backtop:hover { background: var(--main-color); color: #ffffff; }

::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: #f0fafa; }
::-webkit-scrollbar-thumb { background: var(--main-color); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: var(--color-two); }
::selection { background: var(--main-color); color: #ffffff; }
html { scroll-behavior: smooth; }

/* ─────────────────────────────────────────
   RESPONSIVE
───────────────────────────────────────── */
@media only screen and (max-width: 1200px) {
	.banner-one_heading { font-size: 72px !important; }
	.banner-text-col { padding: 150px 30px 80px 40px !important; }
}
@media only screen and (max-width: 991px) {
	.banner-inner-grid { grid-template-columns: 1fr !important; grid-template-rows: auto 400px; }
	.banner-text-col { padding: 130px 30px 40px 30px !important; order: 1; }
	.banner-robot-col { order: 2; min-height: 400px; }
	#robot-container { position: relative !important; height: 400px; bottom: auto !important; }
	.banner-one_heading { font-size: 60px !important; letter-spacing: -2px !important; }
	.banner-text-col .down-box { left: 30px !important; }
	.page-title_heading { font-size: 70px; }
	.journal-one .journal-block_one, .journal-two .journal-block_one { width: 50%; }
}
@media only screen and (max-width: 767px) {
	.banner-one_heading { font-size: 46px !important; letter-spacing: -1px !important; }
	.page-title_heading { font-size: 52px; }
	.awards-block_one-title { font-size: 18px !important; }
	.single-work_title { font-size: 32px !important; }
	.journal-detail_title { font-size: 28px !important; line-height: 38px !important; }
}
@media only screen and (max-width: 479px) {
	.banner-one_heading { font-size: 36px !important; }
	.banner-text-col { padding: 110px 20px 40px 20px !important; }
	.page-title_heading { font-size: 38px; }
}

/* ─────────────────────────────────────────
   STATS — fix text visibility (white text)
───────────────────────────────────────── */
.stats-one .sec-title_heading { color: #ffffff !important; }
.counter-block_one-counter { color: var(--main-color) !important; }
.counter-block_one-text { color: rgba(255,255,255,0.85) !important; }

/* ─────────────────────────────────────────
   PROCESS SECTION
───────────────────────────────────────── */
.process-section .sec-title_heading { color: #ffffff !important; }

.process-block { margin-bottom: 40px; }

.process-block-inner {
	position: relative;
	padding: 35px 30px;
	border: 1px solid rgba(42,143,143,0.30);
	border-top: 3px solid var(--main-color);
	background: rgba(255,255,255,0.04);
	transition: all 0.3s ease;
	height: 100%;
}

.process-block-inner:hover {
	background: rgba(42,143,143,0.10);
	transform: translateY(-5px);
}

.process-number {
	font-size: 56px;
	font-weight: 800;
	color: var(--main-color);
	line-height: 1em;
	margin-bottom: 16px;
	opacity: 0.85;
}

.process-title {
	font-size: 20px !important;
	font-weight: 600 !important;
	color: #ffffff !important;
	margin-bottom: 14px;
	line-height: 1.3em !important;
}

.process-text {
	font-size: 15px !important;
	line-height: 25px !important;
	color: rgba(255,255,255,0.65) !important;
}

/* ─────────────────────────────────────────
   SERVICES DETAIL PAGE CARDS
───────────────────────────────────────── */
.service-detail-card {
	padding: 40px 35px;
	border: 1px solid rgba(42,143,143,0.18);
	border-top: 3px solid var(--main-color);
	background: #ffffff;
	height: 100%;
	transition: all 0.3s ease;
}

.service-detail-card:hover {
	box-shadow: 0 10px 40px rgba(42,143,143,0.12);
	transform: translateY(-4px);
}

.service-detail-icon {
	margin-bottom: 20px;
}

.service-detail-icon img {
	width: 56px;
	height: 56px;
	object-fit: contain;
}

.service-detail-card h3 {
	font-size: 24px !important;
	font-weight: 700 !important;
	color: #141414 !important;
	margin-bottom: 14px;
	line-height: 1.3em !important;
}

.service-detail-card p {
	font-size: 15px !important;
	line-height: 26px !important;
	color: #5a6464 !important;
	margin-bottom: 20px;
}

.service-detail-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.service-detail-list li {
	position: relative;
	font-size: 14px;
	font-weight: 500;
	color: #3a5050;
	padding: 7px 0 7px 26px;
	border-bottom: 1px solid rgba(42,143,143,0.08);
}

.service-detail-list li:last-child { border-bottom: none; }

.service-detail-list li i {
	position: absolute;
	left: 0;
	top: 10px;
	color: var(--main-color);
	font-size: 13px;
}

/* Why Choose Us on white bg tweak */
.awards-one[style*="background:#f7fdfd"] .awards-block_one-number {
	background-color: rgba(42,143,143,0.08);
}

/* ─────────────────────────────────────────
   SERVICE BLOCKS WITH IMAGE BACKGROUNDS (home page)
───────────────────────────────────────── */
.service-block_one-inner.service-img-bg {
	position: relative;
	min-height: 220px;
	background-size: cover !important;
	background-position: center !important;
	display: flex !important;
	flex-direction: column !important;
	justify-content: flex-end !important;
	padding: 30px 35px !important;
	border: none !important;
	overflow: hidden;
}

.service-block_one-inner.service-img-bg:before { display: none !important; }

.service-img-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(5,25,25,0.88) 0%, rgba(5,25,25,0.30) 60%, rgba(5,25,25,0.10) 100%);
	transition: background 0.4s ease;
	z-index: 0;
}

.service-block_one-inner.service-img-bg:hover .service-img-overlay {
	background: linear-gradient(to top, rgba(26,100,100,0.92) 0%, rgba(26,100,100,0.50) 100%);
}

.service-block_one-inner.service-img-bg .service-block_one-heading {
	position: relative;
	z-index: 1;
	color: #ffffff !important;
	font-size: 28px !important;
	font-weight: 700 !important;
	text-shadow: 0 2px 8px rgba(0,0,0,0.4);
	margin-bottom: 12px;
}

.service-block_one-link {
	position: relative;
	z-index: 1;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	font-weight: 600;
	color: rgba(255,255,255,0.75);
	text-transform: uppercase;
	letter-spacing: 1px;
	transition: color 0.3s ease;
}

.service-block_one-inner.service-img-bg:hover .service-block_one-link {
	color: #ffffff;
}

/* ─────────────────────────────────────────
   SERVICES DETAIL PAGE — IMAGE BG CARDS
───────────────────────────────────────── */
.service-detail-card--img {
	position: relative;
	background-size: cover !important;
	background-position: center !important;
	min-height: 380px;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: 0 !important;
	border: none !important;
	overflow: hidden;
}

.service-detail-card__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(5,20,20,0.95) 0%, rgba(5,20,20,0.60) 55%, rgba(5,20,20,0.20) 100%);
	transition: background 0.4s ease;
	z-index: 0;
}

.service-detail-card--img:hover .service-detail-card__overlay {
	background: linear-gradient(to top, rgba(20,80,80,0.97) 0%, rgba(20,80,80,0.75) 55%, rgba(20,80,80,0.30) 100%);
}

.service-detail-card__content {
	position: relative;
	z-index: 1;
	padding: 30px 30px 30px;
}

.service-detail-card--img h3 {
	color: #ffffff !important;
	font-size: 22px !important;
	font-weight: 700 !important;
	margin-bottom: 12px !important;
	text-shadow: 0 2px 8px rgba(0,0,0,0.5);
}

.service-detail-card--img p {
	color: rgba(255,255,255,0.80) !important;
	font-size: 14px !important;
	line-height: 24px !important;
	margin-bottom: 16px !important;
}

.service-detail-card--img .service-detail-list li {
	color: rgba(255,255,255,0.75) !important;
	border-bottom-color: rgba(255,255,255,0.10) !important;
	font-size: 13px;
}

.service-detail-card--img .service-detail-list li i {
	color: var(--main-color) !important;
}

/* ─────────────────────────────────────────
   ABOUT PAGE — Stats & text on white bg fix
───────────────────────────────────────── */
.stats-one.style-two .sec-title_heading { color: #141414 !important; }
.stats-one.style-two .counter-block_one-counter { color: var(--main-color) !important; }
.stats-one.style-two .counter-block_one-text { color: #5a6464 !important; }
.stats-one.style-two .counter-block_one-inner { background: #ffffff !important; border-color: rgba(42,143,143,0.15) !important; }
.stats-one.style-two .counter-block_one-inner:before { background: var(--main-color) !important; }
/* Awards/values section on about - dark text on white */
.awards-one .awards-block_one-title { color: #141414 !important; }
.awards-one .awards-block_one-title span { color: #5a6464 !important; }
.awards-one .awards-block_one-number { color: var(--main-color) !important; }

/* ─────────────────────────────────────────
   SERVICE BLOCKS — Default teal, photo on hover
───────────────────────────────────────── */

/* Reset the old image-bg approach */
.service-block_one-inner.svc-hover-img {
	position: relative;
	padding: 35px 40px !important;
	border: 1px solid rgba(42,143,143,0.20) !important;
	background-color: #ffffff !important;
	background-size: cover !important;
	background-position: center !important;
	overflow: hidden;
	transition: all 0.5s ease;
	min-height: 140px;
}

/* Dark photo overlay — hidden by default */
.svc-hover-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(5,25,25,0.88) 0%, rgba(26,100,100,0.80) 100%);
	opacity: 0;
	transition: opacity 0.5s ease;
	z-index: 0;
}

/* Teal gradient shown by default (same as original) */
.service-block_one-inner.svc-hover-img::before {
	position: absolute;
	content: '';
	inset: -1px;
	opacity: 0;
	transform: scale(1, 0.2);
	transition: all 500ms ease;
	background: linear-gradient(135deg, var(--main-color) 0%, var(--color-two) 100%);
	z-index: 0;
}

/* On hover — show photo overlay, hide teal */
.service-block_one-inner.svc-hover-img:hover::before { opacity: 0 !important; transform: scale(1,1); }
.service-block_one-inner.svc-hover-img:hover .svc-hover-overlay { opacity: 1; }

/* Default content (teal state) */
.svc-default-content {
	position: relative;
	z-index: 2;
	transition: opacity 0.4s ease, transform 0.4s ease;
}

.svc-default-content .service-block_one-heading { color: #141414; transition: color 0.3s ease; }
.service-block_one-inner.svc-hover-img:hover .svc-default-content { opacity: 0; transform: translateY(-10px); pointer-events: none; }

/* Hover content (photo state) — hidden by default */
.svc-hover-content {
	position: absolute;
	inset: 0;
	z-index: 3;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: 30px 35px;
	opacity: 0;
	transform: translateY(10px);
	transition: opacity 0.4s ease, transform 0.4s ease;
	pointer-events: none;
}

.service-block_one-inner.svc-hover-img:hover .svc-hover-content {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}

.svc-hover-content .service-block_one-heading {
	color: #ffffff !important;
	font-size: 26px !important;
	font-weight: 700 !important;
	text-shadow: 0 2px 8px rgba(0,0,0,0.5);
	margin-bottom: 14px;
}

.service-block_one-link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	font-weight: 600;
	color: rgba(255,255,255,0.85);
	text-transform: uppercase;
	letter-spacing: 1px;
	transition: color 0.3s ease, gap 0.3s ease;
}
.service-block_one-link:hover { color: #ffffff; gap: 12px; }

/* Also update text color on default hover (teal fill) */
.service-block_one-inner.svc-hover-img:hover .svc-default-content .service-block_one-heading { color: #ffffff; }

/* ─────────────────────────────────────────
   SERVICES PAGE — PHOTO BACKGROUND CARDS
───────────────────────────────────────── */
.svc-photo-card {
	position: relative;
	min-height: 420px;
	background-size: cover !important;
	background-position: center !important;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.svc-photo-card:hover {
	transform: translateY(-5px);
	box-shadow: 0 20px 50px rgba(0,0,0,0.25);
}

.svc-photo-card__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to top,
		rgba(5, 20, 20, 0.80) 0%,
		rgba(5, 20, 20, 0.50) 55%,
		rgba(5, 20, 20, 0.20) 100%
	);
	transition: background 0.4s ease;
	z-index: 0;
}

.svc-photo-card:hover .svc-photo-card__overlay {
	background: linear-gradient(
		to top,
		rgba(10, 60, 60, 0.92) 0%,
		rgba(10, 60, 60, 0.70) 55%,
		rgba(10, 60, 60, 0.40) 100%
	);
}

.svc-photo-card__content {
	position: relative;
	z-index: 1;
	padding: 30px 35px 35px;
}

.svc-photo-card__content h3 {
	font-size: 24px !important;
	font-weight: 700 !important;
	color: #ffffff !important;
	margin-bottom: 12px !important;
	line-height: 1.3em !important;
}

.svc-photo-card__content p {
	font-size: 14px !important;
	line-height: 24px !important;
	color: rgba(255, 255, 255, 0.78) !important;
	margin-bottom: 18px !important;
}

.svc-photo-card__list {
	list-style: none;
	padding: 0;
	margin: 0 0 22px 0;
}

.svc-photo-card__list li {
	font-size: 13px;
	font-weight: 500;
	color: rgba(255, 255, 255, 0.80);
	padding: 5px 0 5px 22px;
	position: relative;
	border-bottom: 1px solid rgba(255,255,255,0.08);
}

.svc-photo-card__list li:last-child { border-bottom: none; }

.svc-photo-card__list li i {
	position: absolute;
	left: 0;
	top: 8px;
	color: var(--main-color);
	font-size: 12px;
}

.svc-photo-card__btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 11px 26px;
	font-size: 13px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: #ffffff;
	background: var(--main-color);
	transition: all 0.3s ease;
	border: 1px solid var(--main-color);
}

.svc-photo-card__btn:hover {
	background: transparent;
	color: #ffffff;
	border-color: rgba(255,255,255,0.6);
	gap: 12px;
}

/* ─────────────────────────────────────────
   WHY CHOOSE US — text turns white on hover
   (matches service card hover behaviour)
───────────────────────────────────────── */
.awards-block_one-inner:hover .awards-block_one-title { color: #ffffff !important; }
.awards-block_one-inner:hover .awards-block_one-title span { color: rgba(255,255,255,0.80) !important; }
.awards-block_one-inner:hover .awards-block_one-number { color: #ffffff !important; background: transparent !important; border-color: rgba(255,255,255,0.25) !important; }
.awards-block_one-inner:hover .awards-block_one-arrow { color: rgba(255,255,255,0.70) !important; }

/* ── OUR WORK PAGE — filter button visibility fix ── */
.work-filter-btn {
	background: #ffffff !important;
	border: 2px solid rgba(42,143,143,0.35) !important;
	color: #141414 !important;
	font-weight: 600 !important;
	opacity: 1 !important;
	visibility: visible !important;
}

.work-filter-btn:hover,
.work-filter-btn.active {
	background: #2A8F8F !important;
	border-color: #2A8F8F !important;
	color: #ffffff !important;
}

.work-filters {
	background: #f7fdfd;
	padding: 20px;
	border: 1px solid rgba(42,143,143,0.12);
	border-radius: 2px;
	margin-bottom: 40px !important;
}

/* ─────────────────────────────────────────
   ROBOT LAZY LOAD SPINNER
───────────────────────────────────────── */
.robot-spinner {
	width: 48px;
	height: 48px;
	border: 3px solid rgba(42,143,143,0.20);
	border-top-color: var(--main-color);
	border-radius: 50%;
	animation: robot-spin 0.9s linear infinite;
}

@keyframes robot-spin {
	to { transform: rotate(360deg); }
}

/* ─────────────────────────────────────────
   ABOUT PAGE — INTRO SECTION
───────────────────────────────────────── */
.about-intro {
	display: grid;
	grid-template-columns: 1fr 1.4fr;
	gap: 70px;
	align-items: start;
	padding: 20px 0 60px;
	border-bottom: 1px solid rgba(42,143,143,0.15);
	margin-bottom: 60px;
}

.about-intro__tag {
	display: inline-block;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 2px;
	color: var(--main-color);
	padding: 5px 14px;
	border: 1px solid rgba(42,143,143,0.30);
	margin-bottom: 20px;
}

.about-intro__heading {
	font-size: 42px !important;
	font-weight: 700 !important;
	line-height: 1.2em !important;
	color: #141414 !important;
	margin: 0 !important;
}

.about-intro__right p {
	font-size: 17px !important;
	line-height: 30px !important;
	color: #5a6464 !important;
	margin-bottom: 18px !important;
}

.about-intro__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 24px;
}

.about-intro__tags span {
	font-size: 12px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: var(--main-color);
	padding: 6px 16px;
	background: rgba(42,143,143,0.08);
	border: 1px solid rgba(42,143,143,0.20);
}

/* ─────────────────────────────────────────
   WHY CHOOSE US — remove arrow
───────────────────────────────────────── */
.awards-block_one-arrow { display: none !important; }

/* ─────────────────────────────────────────
   BANNER LEFT — better typography & layout
───────────────────────────────────────── */
.banner-one_heading {
	font-size: 88px !important;
	font-weight: 800 !important;
	line-height: 0.92em !important;
	letter-spacing: -4px !important;
	color: #0a2828 !important;
	text-transform: uppercase !important;
	margin-bottom: 36px !important;
}

.banner-one_text {
	font-size: 17px !important;
	line-height: 28px !important;
	color: #1a4040 !important;
	padding-top: 22px !important;
	margin-bottom: 12px !important;
	border-top: 2px solid rgba(42,143,143,0.55) !important;
	font-weight: 500 !important;
}

.banner-one_text-two {
	font-size: 15px !important;
	line-height: 25px !important;
	color: #3a5f5f !important;
	padding-bottom: 28px !important;
	margin-bottom: 0 !important;
	border-bottom: 1px solid rgba(42,143,143,0.25) !important;
}

/* ─────────────────────────────────────────
   MOBILE OPTIMISATION
───────────────────────────────────────── */

/* ── Header ── */
@media (max-width: 1023px) {
	.main-header { position: relative !important; }
	.main-header .header-lower .logo-box .logo { width: 150px; }
}

/* ── Banner ── */
@media (max-width: 991px) {
	.banner-inner-grid {
		grid-template-columns: 1fr !important;
		min-height: auto !important;
	}
	.banner-text-col {
		padding: 120px 24px 40px !important;
		order: 1 !important;
	}
	.banner-robot-col {
		order: 2 !important;
		min-height: 340px !important;
	}
	#robot-container {
		position: relative !important;
		height: 340px !important;
		bottom: auto !important;
	}
	.banner-one_heading { font-size: 58px !important; letter-spacing: -2px !important; }
}

@media (max-width: 767px) {
	.banner-one_heading { font-size: 44px !important; letter-spacing: -1px !important; }
	.banner-text-col { padding: 110px 20px 30px !important; }
	.banner-robot-col { min-height: 280px !important; }
	#robot-container { height: 280px !important; }
}

@media (max-width: 479px) {
	.banner-one_heading { font-size: 34px !important; letter-spacing: 0 !important; }
	.banner-text-col { padding: 100px 16px 24px !important; }
	.banner-robot-col { min-height: 240px !important; }
	#robot-container { height: 240px !important; }
}

/* ── Services ── */
@media (max-width: 767px) {
	.service-block_one { width: 100% !important; }
	.service-block_one-inner { padding: 24px 20px !important; }
	.service-block_one-heading { font-size: 22px !important; }
}

/* ── Why Choose Us ── */
@media (max-width: 767px) {
	.awards-block_one-content { padding-left: 80px; padding-top: 18px; }
	.awards-block_one-number { width: 60px; height: 60px; font-size: 26px; line-height: 60px; }
	.awards-block_one-title { font-size: 17px !important; }
}

/* ── Process section ── */
@media (max-width: 767px) {
	.process-block { margin-bottom: 20px; }
	.process-number { font-size: 40px; }
	.process-title { font-size: 17px !important; }
}

/* ── Stats ── */
@media (max-width: 767px) {
	.counter-block_one-counter { font-size: 46px !important; }
	.counter-block_one-text { font-size: 14px !important; }
	.counter-block_one-inner { padding: 24px 20px; }
}

/* ── Page title ── */
@media (max-width: 767px) {
	.page-title { padding: 110px 0 50px; }
	.page-title_heading { font-size: 42px !important; }
}

@media (max-width: 479px) {
	.page-title_heading { font-size: 32px !important; }
}

/* ── About page intro ── */
@media (max-width: 991px) {
	.about-intro {
		grid-template-columns: 1fr;
		gap: 30px;
	}
	.about-intro__heading { font-size: 32px !important; }
}

/* ── Services detail page ── */
@media (max-width: 767px) {
	.svc-photo-card { min-height: 340px; }
	.svc-photo-card__content { padding: 20px; }
	.svc-photo-card__content h3 { font-size: 20px !important; }
}

/* ── Our Work grid ── */
@media (max-width: 600px) {
	.projects-grid { grid-template-columns: 1fr !important; }
	.work-filters { gap: 8px; }
	.work-filter-btn { padding: 8px 14px; font-size: 11px; }
}

/* ── Single work detail ── */
@media (max-width: 767px) {
	.project-detail-grid { grid-template-columns: 1fr !important; }
	.single-work_title, .project-detail-content h1 { font-size: 28px !important; }
	.project-nav { flex-direction: column; gap: 16px; text-align: center; }
	.project-cta { padding: 30px 20px; }
}

/* ── Footer ── */
@media (max-width: 767px) {
	.main-footer .footer-column { margin-bottom: 30px; }
	.main-footer h2 { font-size: 20px !important; line-height: 1.4em !important; }
	.footer-bottom .d-flex { flex-direction: column; gap: 14px; text-align: center; }
}

/* ── Testimonials ── */
@media (max-width: 767px) {
	.testimonial-block_one-lower { padding-left: 0; margin-left: 0; }
}

/* ── Contact ── */
@media (max-width: 767px) {
	.contact-one_form-outer { padding: 24px 18px; }
	.contact-one_heading { font-size: 24px !important; }
}

/* ── General spacing fix on small screens ── */
@media (max-width: 767px) {
	.services-one, .awards-one, .stats-one, .process-section,
	.team-one, .testimonial-one, .contact-one, .gallery-one,
	.services-detail-page { padding-top: 60px !important; padding-bottom: 40px !important; }

	.sec-title_heading { font-size: 28px !important; }
	.auto-container { padding: 0 16px !important; }
}

/* ── Prevent horizontal scroll on mobile ── */
html, body {
	overflow-x: hidden !important;
	max-width: 100vw;
}

.page-wrapper {
	overflow-x: hidden !important;
}

/* ─────────────────────────────────────────
   BANNER MOBILE — clean layout like desktop
───────────────────────────────────────── */

/* On mobile: text col fills viewport, robot is compact below */
@media (max-width: 991px) {
	.banner-one {
		min-height: auto !important;
	}

	.banner-inner-grid {
		grid-template-columns: 1fr !important;
		grid-template-rows: auto !important;
		min-height: auto !important;
	}

	.banner-text-col {
		order: 1 !important;
		padding: 130px 28px 40px !important;
		min-height: auto !important;
	}

	.banner-robot-col {
		order: 2 !important;
		height: 320px !important;
		min-height: 320px !important;
		overflow: hidden !important;
	}

	#robot-container {
		position: relative !important;
		width: 100% !important;
		height: 320px !important;
		bottom: auto !important;
		top: auto !important;
		left: auto !important;
		right: auto !important;
	}

	#robot-container spline-viewer {
		height: 320px !important;
		min-height: 320px !important;
	}

	.banner-one_heading {
		font-size: 52px !important;
		letter-spacing: -2px !important;
		word-break: normal !important;
		overflow-wrap: normal !important;
	}

	.banner-one_text,
	.banner-one_text-two {
		word-break: normal !important;
		overflow-wrap: normal !important;
	}
}

@media (max-width: 600px) {
	.banner-text-col { padding: 110px 20px 32px !important; }
	.banner-one_heading { font-size: 42px !important; letter-spacing: -1px !important; }
	.banner-robot-col { height: 260px !important; min-height: 260px !important; }
	#robot-container { height: 260px !important; }
	#robot-container spline-viewer { height: 260px !important; min-height: 260px !important; }
}

@media (max-width: 400px) {
	.banner-one_heading { font-size: 34px !important; }
	.banner-text-col { padding: 100px 16px 28px !important; }
	.banner-robot-col { height: 220px !important; min-height: 220px !important; }
	#robot-container { height: 220px !important; }
}

/* Fix "Turning bold ideas intoreal-world" word break */
.banner-one_text-two {
	word-spacing: normal !important;
	letter-spacing: 0 !important;
}

/* Header background on mobile so content is readable */
@media (max-width: 1023px) {
	.main-header {
		position: fixed !important;
		top: 0 !important;
		left: 0 !important;
		right: 0 !important;
		background: #ffffff !important;
		box-shadow: 0 2px 20px rgba(0,0,0,0.10) !important;
		z-index: 1000 !important;
	}
}

/* ─────────────────────────────────────────
   CONTACT PAGE — INFO SECTION
───────────────────────────────────────── */
.contact-one_tag {
	display: inline-block;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 2px;
	color: var(--main-color);
	padding: 5px 14px;
	border: 1px solid rgba(42,143,143,0.30);
	margin-bottom: 18px;
}

.contact-one_heading {
	font-size: 34px !important;
	font-weight: 700 !important;
	line-height: 1.2em !important;
	color: #141414 !important;
	margin-bottom: 14px !important;
}

.contact-one_subtext {
	font-size: 16px !important;
	line-height: 27px !important;
	color: #5a6464 !important;
	margin-bottom: 36px !important;
}

/* Contact detail cards */
.contact-detail-cards {
	display: flex;
	flex-direction: column;
	gap: 0;
	margin-bottom: 32px;
	border: 1px solid rgba(42,143,143,0.18);
	border-bottom: none;
}

.contact-detail-card {
	display: flex;
	align-items: flex-start;
	gap: 18px;
	padding: 20px 22px;
	border-bottom: 1px solid rgba(42,143,143,0.15);
	background: #ffffff;
	transition: background 0.3s ease;
}

.contact-detail-card:hover {
	background: #f7fdfd;
}

.contact-detail-card__icon {
	width: 42px;
	height: 42px;
	background: linear-gradient(135deg, var(--main-color) 0%, var(--color-two) 100%);
	color: #ffffff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 16px;
	flex-shrink: 0;
}

.contact-detail-card__label {
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	color: #aaa;
	margin-bottom: 4px;
}

.contact-detail-card__value {
	font-size: 15px;
	font-weight: 500;
	color: #141414;
	line-height: 1.5em;
	display: block;
}

a.contact-detail-card__value {
	color: var(--main-color);
	transition: color 0.3s ease;
}
a.contact-detail-card__value:hover {
	color: var(--color-two);
}

/* Social links row */
.contact-one_socials-wrap {
	display: flex;
	align-items: center;
	gap: 16px;
	flex-wrap: wrap;
}

.contact-one_socials-label {
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: #aaa;
	white-space: nowrap;
}

.contact-one_socials {
	display: flex !important;
	flex-wrap: wrap;
	gap: 10px;
	padding: 0 !important;
	margin: 0 !important;
	list-style: none !important;
	border: none !important;
}

.contact-one_socials li { border: none !important; padding: 0 !important; }

.contact-one_socials li a {
	font-size: 13px !important;
	font-weight: 600 !important;
	color: #5a6464 !important;
	padding: 6px 16px !important;
	border: 1px solid rgba(42,143,143,0.25) !important;
	transition: all 0.3s ease !important;
}
.contact-one_socials li a:hover {
	color: #ffffff !important;
	background: var(--main-color) !important;
	border-color: var(--main-color) !important;
}

@media (max-width: 767px) {
	.contact-one_heading { font-size: 26px !important; }
	.contact-one_socials-wrap { flex-direction: column; align-items: flex-start; }
}

/* ─────────────────────────────────────────
   TEAM CARD SOCIALS — hide box until hover
───────────────────────────────────────── */
.team-block_one-socials {
	background-color: transparent !important;
	border-color: transparent !important;
	padding: 0 !important;
	margin-top: 20px !important;
	display: flex !important;
	gap: 8px !important;
	width: auto !important;
}

.team-block_one-socials a {
	width: 38px !important;
	height: 38px !important;
	line-height: 36px !important;
	text-align: center !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	border: 1px solid rgba(42,143,143,0.25) !important;
	background: #ffffff !important;
	color: var(--main-color) !important;
	font-size: 15px !important;
	opacity: 0 !important;
	transform: translateY(8px) !important;
	transition: all 0.35s ease !important;
}

.team-block_one:hover .team-block_one-socials a {
	opacity: 1 !important;
	transform: translateY(0) !important;
}

.team-block_one-socials a:hover {
	background: var(--main-color) !important;
	color: #ffffff !important;
	border-color: var(--main-color) !important;
}

.team-block_one-socials a img { display: none !important; }

/* ─────────────────────────────────────────
   SERVICE BLOCK — Font Awesome icon variant
───────────────────────────────────────── */
.service-block_one-fa-icon {
	font-size: 52px;
	color: var(--main-color);
	transition: color 0.3s ease;
	line-height: 1;
}
.service-block_one-inner:hover .service-block_one-fa-icon { color: #ffffff; }

/* ─────────────────────────────────────────
   TESTIMONIAL CARD — new design
───────────────────────────────────────── */

/* Grid on testimonials.html page */
.tcard-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
}
.tcard-wrap { position: relative; }

@media (max-width: 991px) { .tcard-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .tcard-grid { grid-template-columns: 1fr; } }

/* The card itself */
.tcard {
	position: relative;
	overflow: hidden;
	cursor: pointer;
	border: 1px solid rgba(42,143,143,0.15);
	background: #ffffff;
	transition: box-shadow 0.3s ease, transform 0.3s ease;
}
.tcard:hover { box-shadow: 0 12px 40px rgba(0,0,0,0.10); transform: translateY(-4px); }

/* Big photo — full width top */
.tcard__photo {
	width: 100%;
	height: 220px;
	overflow: hidden;
	position: relative;
}
.tcard__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top center;
	display: block;
	transition: transform 0.5s ease;
}
.tcard:hover .tcard__photo img { transform: scale(1.05); }

/* Name + designation below photo */
.tcard__info {
	padding: 18px 20px 14px;
	border-bottom: 1px solid rgba(42,143,143,0.10);
	position: relative;
	z-index: 1;
}
.tcard__name {
	font-size: 17px;
	font-weight: 700;
	color: #141414;
	margin-bottom: 4px;
	font-family: 'Clash Display', sans-serif;
}
.tcard__designation {
	font-size: 13px;
	color: var(--main-color);
	font-weight: 500;
}

/* Quote — hidden by default, slides up on hover/tap */
.tcard__quote {
	position: absolute;
	bottom: 0; left: 0; right: 0;
	background: linear-gradient(135deg, var(--color-two) 0%, var(--main-color) 100%);
	padding: 22px 20px 24px;
	transform: translateY(100%);
	transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	z-index: 5;
}
.tcard:hover .tcard__quote,
.tcard.active .tcard__quote { transform: translateY(0); }

.tcard__qicon {
	font-size: 22px;
	color: rgba(255,255,255,0.40);
	margin-bottom: 10px;
	display: block;
}
.tcard__quote p {
	font-size: 14px !important;
	line-height: 23px !important;
	color: rgba(255,255,255,0.92) !important;
	margin: 0 !important;
}

/* Swiper version (about page) */
.swiper-slide .tcard { height: 100%; }

/* ─────────────────────────────────────────
   STATS — solid dark bg, no photo
───────────────────────────────────────── */
.stats-one.stats-no-bg {
	background-image: none !important;
	background-color: #0d1a1a !important;
}

.stats-one.stats-no-bg::before {
	display: none !important;
}
