@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@200;300;400;500;600&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@200;300;400;500&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Battambang:wght@100;300;400;700;900&family=Poppins:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');
/* ========================================
   GLOBAL STYLES - 
   ======================================== */

* {
	box-sizing: border-box;
}

body {
	margin: 0;
	padding: 0;
	font-family: 'Poppins', -apple-system, BlinkMacSystemFont, sans-serif;
	overflow-x: hidden;
	color: #1a1a1a;
	font-size: 16px;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* ========================================
   TYPOGRAPHY SYSTEM
   ======================================== */

.home-headings h2 {
	font-size: clamp(32px, 5vw, 36px);
	color: #1a1a1a;
	font-weight: 600;
	line-height: 1.;
	margin: 0 0 20px 0;
	letter-spacing: -0.02em;
}

.home-headings h2 span {
	color: #FD2E35;
}

.home-headings h2 underline {
	color: #FD2E35;
}
.home-headings p {
	font-size: 22px;
	font-weight: 300;
	margin: 0, 100;
	padding: 10px 0 0 0;
}

.btn-outline {
	background: #fff;
	border: 1px solid #15243C;
	border-radius: 50px;
	color: #15243C;
	font-size: 15px;
	font-weight: 400;
	padding: 2px 20px 5px 20px;
	line-height: 1.7em;
}

.btn-outline:hover {
	background: #f9f9f9;
}



h1 {
	font-size: clamp(32px, 5vw, 36px);
	color: #ff0000;
	font-weight: 600;
	line-height: 1.2;
	margin: 0 0 20px 0;
	letter-spacing: -0.02em;
}

h1_red {
	font-size: clamp(32px, 5vw, 56px);
	color: #FD2E35;
	font-weight: 600;
	line-height: 1.2;
	display: block;
}

h1_2 {
	font-size: clamp(22px, 4vw, 32px);
	color: #333333;
	font-weight: 400;
	line-height: 1.6;
	display: block;
}

h1_2_grey {
	font-size: clamp(22px, 4vw, 32px);
	color: #3c3c3c;
	font-weight: 400;
	line-height: 1.6;
	display: block;
}

h1_3 {
	font-size: clamp(20px, 2.5vw, 28px);
	color: #2a2a2a;
	font-weight: 400;
	line-height: 1.6;
	display: block;
}

logo_name {
	font-family: 'Poppins', sans-serif;
	font-size: 18px;
	color: #1a1a1a;
	font-weight: 400;
	line-height: 1.5;;
	letter-spacing: -0.01em;
	display: block;
}
logo_symbol {
	font-family: 'Poppins', sans-serif;
	font-size: 16px;
	color: #1a1a1a;
	font-weight: 600;
	line-height: 1.5;;
	letter-spacing: -0.01em;
	display: block;
}

heading_2 {
	font-size: clamp(28px, 3.5vw, 42px);
	color: #1a1a1a;
	font-weight: 500;
	line-height: 2.6;
	margin: 0 0 16px 0;
	letter-spacing: -0.01em;
}

h2 {.scrollTop a i
	font-size: clamp(28px, 3.5vw, 42px);
	color: #1a1a1a;
	font-weight: 500;
	line-height: 1.6;
	margin: 0 0 16px 0;
	letter-spacing: -0.01em;
}

h2_regular { 
	font-size: clamp(28px, 3.5vw, 42px);
	color: #1a1a1a;
	font-weight: 500;
	line-height: 1.6;
	margin: 0 0 16px 0;
	letter-spacing: -0.01em;
}

h3 {
	font-size: clamp(20px, 2.5vw, 28px);
	color: #1a1a1a;
	font-weight: 600;
	line-height: 1.4;
	margin: 0 0 12px 0;
}

h4 {
	font-size: clamp(18px, 2vw, 22px);
	color: #1a1a1a;
	font-weight: 600;
	line-height: 1.4;
	margin: 0 0 12px 0;
}

p {
	font-size: 16px;
	font-weight: 400;
	line-height: 1.7;
	color: #333333;
	margin: 0 0 16px 0;
}

p2 {
	font-size: 16px;
	font-weight: 600;
	color: #2a2a2a;
	display: block;
}

/* ========================================
   LINKS & NAVIGATION
   ======================================== */

a {
	text-decoration: none;
	color: #333333;
	font-size: 15px;
	font-weight: 500;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

a:hover {
	color: #FD2E35;
}

/* ========================================
   NAVIGATION BAR
   ======================================== */

.navbar {
	padding: 40px 0;
	background: #fff;
	transition: all 0.3s ease;

}

.navbar-brand {
	font-size: 20px;
	font-weight: 600;
	color: #1a1a1a;
}

.nav-link {
  position: relative;
  padding: 8px 16px !important;
  font-size: 14px;
  color: #333333;
  font-weight: 500;
  text-decoration: none;
  transition: color 0.3s ease;
}

/* underline (hidden by default) */
.nav-link::after {
  content: "";
  position: absolute;
  left: 16px; 
  /* aligns with padding */
  bottom: 2px;
  width: calc(100% - 32px);
  height: 2px;
  background-color: #FD2E35;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s ease;
}

/* Hover */
.nav-link:hover {
  color: #FD2E35;
}

.nav-link:hover::after {
  transform: scaleX(1);
  opacity: 80%;
}

/* Active */
.nav-link.active {
  color: #FD2E35;
}

.nav-link.active::after {
  transform: scaleX(1);
}


.navbar-toggler {
	border: none;
	padding: 8px;
}

.navbar-toggler:focus {
	box-shadow: none !important;
}

.fa-bars {
	color: #1a1a1a;
	font-size: 24px;
}


/* ========================================
   SCROLL DOWN 
   ======================================== */
.scroll-h {
    left: calc(45% - 12px);
    top: calc(100% - -5px);
    font-size: 16px;
}
.scroll {
    position: absolute;
    top: calc(100% - 0px);
    left: calc(0% - 6px);
    bottom: 0px;
}




/* ========================================
   DROPDOWN MENUS
   ======================================== */

.dropdown-menu {
	border: none;
	box-shadow: 8px 8px 24px rgba(0, 0, 0, 0.08);
	border-radius: 8px;
	padding: 8px 0;
	margin-top: 8px;
}

.dropdown-item {
	padding: 12px 24px;
	font-size: 14px;
	font-weight: 500;
	color: #333333;
	transition: all 0.2s ease;
}

.dropdown-item:hover,
.dropdown-item:active {
	background: #FD2E35;
	color: #fff;
}

/* ========================================
   BUTTONS & INTERACTIVE ELEMENTS
   ======================================== */

button,
.button {
	background: #1a1a1a;
	color: #fff;
	font-size: 15px;
	font-weight: 500;
	border-radius: 8px;
	border: 2px solid #1a1a1a;
	padding: 12px 28px;
	cursor: pointer;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	display: inline-block;
}

button:hover,
.button:hover {
	background: #2a2a2a;
	border-color: #2a2a2a;
	transform: translateY(-2px);
	box-shadow: 0 8px 16px rgba(0, 0, 0, 0.12);
}

.white-btn {
	border: 2px solid #e0e0e0;
	border-radius: 24px;
	padding: 10px 24px;
	background: white;
	color: #333333;
	font-weight: 500;
	margin: 12px 8px;
	font-size: 14px;
	transition: all 0.3s ease;
}

.white-btn:hover {
	color: #FD2E35;
	background-color: #fff;
	border-color: #FD2E35;
	transform: translateY(-2px);
}

.btn-outline {
	background: #fff;
	border: 2px solid #1a1a1a;
	border-radius: 8px;
	color: #1a1a1a;
	font-size: 15px;
	font-weight: 500;
	padding: 12px 28px;
	transition: all 0.3s ease;
}

.btn-outline:hover {
	background: #1a1a1a;
	color: #fff;
	transform: translateY(-2px);
}

.loadingbtn {
	font-size: 16px;
	color: #333333;
	border: 2px solid #e0e0e0;
	border-radius: 8px;
	background: #fff;
	padding: 24px 32px;
	text-align: center;
	font-weight: 500;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

/* ========================================
   LAYOUT & SPACING
   ======================================== */

.section-i {
	padding: 0;
}

.inner-page {
	padding: 0 80px;
}

.container-box {
	overflow-x: hidden;
	display: flex;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	gap: 24px;
	padding-bottom: 32px;
}

.container-box::-webkit-scrollbar {
	display: none;
}

/* ========================================
   BACKGROUND COLORS
   ======================================== */

.light-gray-bg {
	background: #fafafa;
}

.light-blue-bg {
	background: #f8fbff;
}

.light-blue-bg2 {
	background: #f0f8ff;
}

.light-blue-bg3 {
	background: #f5f9ff;
}

.light-blue-bg5 {
	background: #f7fdff;
}

.light-blue-bg6 {
	background: #f9f9f9;
}

.dark-gray-bg {
	background: #f0f0f0;
}

.dark-gray-bg2 {
	background: #e8e8e8;
}

.dark-gray-bg3 {
	background: #3a4a45;
}

.dark-blue {
	background: #1a2845;
}

/* ========================================
   CARDS & PROJECT TILES
   ======================================== */

.curve-box {
	border-radius: 16px;
	overflow: hidden;
	min-height: 600px;
	max-height: 600px;
	transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
	position: relative;
}

.curve-box:hover {
	transform: translateY(-8px);
	box-shadow: 0 16px 32px rgba(0, 0, 0, 0.1);
}

.padding-box {
	padding: 32px 32px 0px;
}

.curve-box h3 {
    font-family: "Battambang", system-ui;
    font-size: 38px;
	font-weight: 400;
    padding-bottom: 0px;
}

.curve-box p {
	font-size: 16px;
	line-height: 1.6;
	font-weight: 400;
	color: #333333;
}

.curve-box a {
	color: #1a1a1a;
	font-weight: 600;
	font-size: 18px;
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.curve-box a:hover {
	color: #FD2E35;
}

.curve-box button {
	background: #fff;
	border-radius: 24px;
	border: 2px solid #e0e0e0;
	color: #333333;
	font-size: 14px;
	font-weight: 500;
	padding: 8px 20px;
	margin-top: 16px;
}

.curve-box button:hover {
	color: #FD2E35;
	border-color: #FD2E35;
	transform: none;
}

.card {
	flex: 0 0 auto;
	border: 1px solid #e8e8e8;
	background-color: #fff;
	border-radius: 12px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
	overflow: hidden;
	width: 280px;
	padding: 16px 16px;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.card:hover {
	transform: translateY(-8px);
	box-shadow: 0 12px 24px rgba(0, 0, 0, 0.08);
}

.card h4 {
	color: #1a1a1a;
	font-size: 20px;
	padding-bottom: 12px;
	font-weight: 600;
}

.card p {
	color: #333333;
	font-size: 16px;
	padding-bottom: 12px;
	line-height: 1.6;
}

/* ========================================
   WHITEBOX ELEMENTS
   ======================================== */

.whitebox {
	background: #fff;
	border-radius: 12px;
	padding: 32px;
	border: 1px solid #e8e8e8;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
	transition: all 0.3s ease;
}

.whitebox:hover {
	box-shadow: 0 8px 16px rgba(0, 0, 0, 0.08);
}

.whitebox h4 {
	color: #FD2E35;
	font-weight: 600;
	margin-bottom: 12px;
}

.greybox {
	background: #f8f8f8;
	padding: 24px;
	border-radius: 12px;
}

/* ========================================
   TEXT UTILITIES
   ======================================== */

.text-red {
	color: #FD2E35 !important;
	font-weight: 500;
}

.text-black {
	color: #1a1a1a;
}

.text-gray {
	color: #6b6b6b;
}

.d-gray {
	color: #8a8a8a;
	font-size: 20px !important;
	margin-right: 4px;
}

.yellow-text {
	color:#F5B000;
	font-weight: 600;
}


.gradient-text {
	color: #FD2E35;
	font-weight: 600;
}

.f-italic {
	font-style: italic;
}

.font-18 {
	font-size: 18px !important;
	font-weight: 500 !important;
}

.font-20 {
	font-size: 20px;
}

.fw-500 {
	font-weight: 500;
}

.fs-12 {
	color: #8a8a8a;
	font-size: 14px;
}

.fs-18 {
	font-size: 18px !important;
}

/* ========================================
   BANNER SECTION
   ======================================== */

.banner {
	position: relative;
	padding: 10px 0;
}

.banner .col-lg-7 {
	flex: 0 0 68%;
	max-width: 68%;
}

.banner .col-lg-5 {
	flex: 0 0 32%;
	max-width: 32%;
}

.banner h1 {
	font-size: clamp(52px, 6vw, 48px);
	color: #1a1a1a;
	font-weight: 600;
	line-height: 1.5;;
	margin: 0;
	display: inline;
	font-family: 'Poppins', sans-serif;
}

.banner h1_2 {
	font-size: clamp(32px, 6vw, 42px);
	color: #282828;
	font-weight: 400;
	line-height: 1.6;
	margin: 0;
	display: inline;
	font-family: 'Poppins', sans-serif;
}

.banner .gradient-text {
	color: #FD2E35;
	font-weight: 600;
}

.banner p {
	font-size: 18px;
	font-weight: 400;
	line-height: 1.6;
	color: #6b6b6b;
	margin-top: 0;
	display: block;
}

.banner p span {
	font-weight: 600;
	color: #FD2E35;
}

.banner .yellow-text { 
	color: #F5B000;
	font-weight: 500;
}
/* ========================================
   ABOUT SECTIONS
   ======================================== */

.about-headings h1 {
	font-size: clamp(42px, 4vw, 42px);
	font-weight: 400;
	color: #858585;
	text-decoration: line-through;
}

.about-headings h2 {
	font-size: clamp(28px, 3.5vw, 40px);
	font-weight: 600;
	color: #1a1a1a;
}

.about-headings h3 {
	font-size: clamp(24px, 3vw, 32px);
	font-weight: 600;
	color: #FD2E35;
}

.about-headings h4 {
	font-size: clamp(20px, 2.5vw, 28px);
	font-weight: 400;
	color: #333333;
}

.about-headings h6 {
	font-size: clamp(28px, 3.5vw, 40px);
	font-weight: 300;
	color: #1a1a1a;
}

/* ========================================
   FOOTER
   ======================================== */

.footer {
	background: #fafafa;
	padding: 0px 0 40px;
}

.footer h2 {
	color: #1a1a1a !important;
	font-size: clamp(28px, 3.5vw, 40px) !important;
	font-weight: 600 !important;
}

.footer p {
	font-size: 18px;
	font-weight: 400;
	color: #333333;
}

.copyrights {
	font-size: 16px;
	padding-top: 40px;
	color: #6b6b6b;
}

.copyrights a {
	font-size: 16px;
	font-weight: 500;
	color: #1a1a1a !important;
}

.copyrights a:hover {
	color: #FD2E35 !important;
}

/* ========================================
   NUMBERS & STATS
   ======================================== */

.nums h2 {
	font-size: clamp(32px, 4vw, 48px);
	color: #1a1a1a;
	padding-top: 32px;
	font-weight: 600;
}

.nums h3 {
	font-size: clamp(18px, 2.5vw, 24px);
	color: #333333;
	padding-bottom: 32px;
	font-weight: 500;
}

.experience h5 {
	font-weight: 600;
	font-size: 28px;
	color: #1a1a1a;
	padding: 20px;
	margin-bottom: 0;
}

/* ========================================
   FORMS
   ======================================== */

.form {
	background: #fafafa;
}

.form label {
	font-weight: 500;
	font-size: 14px;
	color: #2a2a2a;
	margin-bottom: 8px;
}

.form-control {
	border-radius: 8px;
	font-size: 15px;
	border: 2px solid #e0e0e0;
	padding: 12px 16px;
	transition: all 0.3s ease;
}

.form-control:focus {
	box-shadow: none !important;
	border-color: #FD2E35;
}

.lh-no {
	line-height: inherit !important;
	width: 100%;
	background: #FD2E35;
	border: 2px solid #FD2E35;
	color: #fff;
	border-radius: 8px;
	padding: 14px 24px;
	font-weight: 500;
	transition: all 0.3s ease;
}

.lh-no:hover {
	background: #ff5555;
	border-color: #ff5555;
	transform: translateY(-2px);
}

.required {
	color: #ff4444;
}

/* ========================================
   LISTS
   ======================================== */

ul {
	margin: 0;
	padding: 0;
}

li {
	list-style: none;
	color: #333333;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.8;
}

.list_style li {
	list-style: disc;
	margin-left: 24px;
}

/* ========================================
   SCROLL & ANIMATIONS
   ======================================== */

.scrollTop {
	position: fixed;
	right: 32px;
	bottom: 32px;
	z-index: 999;
	opacity: 0;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.scrollTop a i {
	font-size: 20px;
	color: #fff;
	background: #FD2E35;
	padding: 12px;
	font-weight: 600;
	width: 44px;
	height: 44px;
	text-align: center;
	line-height: 1.2;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.scrollTop a i:hover {
	background: #FD2E35;
	transform: translateY(-4px);
}

/* ========================================
   SCROLL BUTTONS
   ======================================== */

.button-wrapper {
	display: flex;
	justify-content: flex-end;
	gap: 16px;
	flex-wrap: wrap;
	margin-top: 24px;
}

.scroll-button {
	color: #FD2E35;
	background: none;
	border: none;
	font-size: 15px;
	font-weight: 500;
	padding: 8px 16px;
	cursor: pointer;
	transition: all 0.3s ease;
}

.scroll-button:hover {
	background: none;
	color: #ff5555;
}

.scroll-button.hidden {
	display: none;
}

/* ========================================
   SERVICES SECTION
   ======================================== */

.services {
	padding: 80px 0;
	background: #fafafa;
}

.services-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
	gap: 32px;
}

.service-item {
	background: white;
	padding: 40px;
	border-radius: 12px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	border: 1px solid #e8e8e8;
}

.service-item:hover {
	transform: translateY(-8px);
	box-shadow: 0 12px 24px rgba(0, 0, 0, 0.08);
}

.service-item h3 {
	color: #1a1a1a;
	margin-bottom: 16px;
	font-size: 24px;
	font-weight: 600;
}

.service-item p {
	margin-bottom: 20px;
	line-height: 1.7;
	color: #333333;
}

/* ========================================
   ICON ELEMENTS
   ======================================== */

.w-icons img {
	height: 56px;
	transition: all 0.3s ease;
}

.w-icons img:hover {
	transform: scale(1.1);
}

.icon-circle img {
	border: 2px solid #e0e0e0;
	border-radius: 50%;
	width: 48%;
	transition: all 0.3s ease;
}

.icon-circle img:hover {
	border-color: #FD2E35;
}

/* ========================================
   IMAGES
   ======================================== */

.logo {
	width: 140px;
	height: auto;
}

.w-55 {
	width: 55%;
}

.w-70 {
	width: 70%;
}

.w-370 {
	max-width: 804px;
}

.h-500 {
	height: 500px;
	object-fit: cover;
}

.h-350 {
	height: 350px;
	object-fit: cover;
}

.amex-img {
	width: 100%;
	max-width: 665px;
}

.cgt-img {
	width: 100%;
	max-width: 662px;
	margin-top: -80px;
}

/* ========================================
   RESPONSIVE DESIGN
   ======================================== */

@media only screen and (max-width: 1024px) {
	.section-i {
		padding: 0px 0;
	}

	.inner-page {
		padding: 0 40px;
	}
}

@media only screen and (max-width: 767px) {
	html {
		overflow-x: hidden;
	}

	.inner-page {
		padding: 0 24px !important;
	}

	.w-70,
	.w-55 {
		width: 100% !important;
	}

	.section-i {
		padding: 0px 0;
	}

	.text-end {
		text-align: center !important;
	}

	.button-wrapper {
		justify-content: center;
	}

	.card {
		width: 260px;
	}

	.curve-box {
		min-height: auto;
		max-height: none;
	}

	.padding-box {
		padding: 32px 24px;
	}

	.footer {
		padding: 60px 0 32px;
	}
}

/* Large screens */
@media only screen and (min-width: 1367px) {
	.amex-img {
		max-width: 1600px;
	}

	.cgt-img {
		max-width: 745px;
		margin-top: -80px;
	}
}

@media only screen and (min-width: 1824px) {
	.amex-img {
		max-width: 1000px;
	}

	.cgt-img {
		max-width: 956px;
		margin-top: -80px;
	}
}

/* ========================================
   UTILITY CLASSES
   ======================================== */

.mt-100 {
	margin-top: 100px;
}

.mt-150 {
	margin-top: 150px;
}

.pb-100 {
	padding-bottom: 80px;
}

.pr-3 {
	padding-right: 30px;
}

.pl-3 {
	padding-left: 30px;
}

.text-right {
	text-align: right;
}

.text-left {
	text-align: left;
}

/* ========================================
   SMOOTH SCROLLING
   ======================================== */

html {
	scroll-behavior: smooth;
}

.container-box.active {
	cursor: grabbing;
	cursor: -webkit-grabbing;
}



