:root {
	--primary-color: #10699D;
	--primary-color-light: #F5F2E7;
	--secondary-color: #2d3434;
	--accent-color: #6574cc;
	--accent-color-light: #8c9cf8;
}

body {
	font-family: 'Open Sans', sans-serif !important;
	font-weight: 400;
	font-size: 15px;
	background: #fff;
	color: #354259;
	line-height: 1.7;
	overflow-x: hidden;
	counter-reset: Serial;
}

a {color: var(--accent-color); transition: 0.3s ease;}
a:hover {color: var(--accent-color-light);}
p {margin-bottom: 0;}

h1,
h2,
h3,
h4,
h5,
h6 {
	/* font-family: 'Nunito', sans-serif; */
	font-family: 'Paytone One', sans-serif;
	color: var(--secondary-color);
	font-weight: 800;
}
h1 { font-size: 2.75rem; }
h2 { font-size: 2.5rem; }
h3 { font-size: 2.25rem; }
h4 { font-size: 2rem; }
h5 { font-size: 1.75rem; }
h6 { font-size: 1.5rem; }

ul {
	margin: 0;
	padding: 0;
}

ul li {
	list-style-type: none;
}

a {
	text-decoration: none;
}

.sp { padding: 5rem 0; }
.mb_xl { margin-bottom: 6rem; }
.primary_bg { background: var(--primary-color); }
.primary_light_bg { background: var(--primary-color-light); }
.primary_color { color: var(--primary-color); }
.primary_light_color { color: var(--primary-color-light); }

.scroll_to_top {
    position: fixed;
    bottom: 0;
    right: 2rem;
    border: 2px solid var(--accent-color);
    background-color: transparent;
    z-index: 99;
    transition: 0.3s ease bottom, 0.5s ease background-color;
	visibility: hidden;
}
.scroll_to_top.active {
	bottom: 2rem;
	visibility: visible;
}
.scroll_to_top a {
	display: flex;
    align-items: center;
    justify-content: center;
	height: 2.2rem;
    width: 2rem;
}
.scroll_to_top a i {
	font-size: 2rem;
}
.scroll_to_top:hover {
    background-color: var(--accent-color);
}
.scroll_to_top:hover i {
    color: #fff;
}
.btn-primary {
	--bs-btn-bg: var(--accent-color);
	--bs-btn-border-color: var(--accent-color-light);
	--bs-btn-hover-bg: var(--accent-color-light);
}
.form-control:focus {
	color: #354259;
	border-color: var(--primary-color);
	box-shadow: 0 0 0 .25rem rgb(16, 105, 157, 0.25);
}

/*==============================
        HEADER AREA CSS
============================== */
.header_top {
	padding: 0.8rem 0;
	font-size: 0.85rem;
	color: var(--primary-color-light);
}

.header_top i {
	font-size: 1.1rem;
	display: inline-block;
	color: #fff;
}

/* NAVBAR */
.navbar {
	background: #fff;
}

.logo img {
	max-width: 300px;
	transition: 0.4s ease;
}

.navbar .menu {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
}

.navbar .menu .menu_item {
	position: relative;
	display: inline-block;
	padding: 0.85rem 0.75rem;
}
.navbar .menu .menu_item:last-child {
	padding-right: 0;
}

.navbar .menu .menu_link {
	text-transform: uppercase!important;
	display: inline-block;
	color: var(--accent-color);
	font-size: 0.9rem;
	margin-right: 10px;
	font-weight: 600;
	transition: 0.2s ease;
}

.navbar .menu .menu_link:hover {
	color: var(--accent-color-light);
}

.navbar .menu .menu_item::before {
	content: '';
	display: inline-block;
	position: absolute;
	top: 0;
	left: 0;
	height: 3px;
	width: 0;
	background-color: var(--primary-color);
	transition: 0.3s ease;
}

.navbar .menu .has_submenu {
	position: relative;
}

.navbar .menu .submenu, 
.navbar .menu .sub_submenu {
	background: var(--primary-color);
	position: absolute;
	padding: 0.65rem 0;
	top: 100%;
	left: -2rem;
	z-index: 20;
	border-radius: 5px;
	visibility: hidden;
	transition: 0.3s ease top, 0.3s ease left;
}
.navbar .menu .sub_submenu {
	top: -2rem;
	left: 100%;
}
.navbar .menu .submenu .menu_item {
	display: block;
	padding: 0.25rem 0.85rem;
	white-space: nowrap;
	width: 100%;
}
.navbar .menu .submenu .menu_link {
	color: #fff;
	display: block;
	transition: 0.3s ease;
}
.navbar .menu .submenu .menu_link:hover {
	color: var(--accent-color-light);
}
.navbar .has_submenu:hover .submenu {
	visibility: visible;
	left: 0;
}

.navbar .menu .submenu .has_submenu:hover .sub_submenu {
	visibility: visible;
	top: 0;
}

	/* MOBILE MENU */

.sticky {
	top: 0;
	position: fixed;
	width: 100%;
	left: 0;
	right: 0;
	z-index: 999;
}
.navbar {
	transition: 0.4s ease;
}
.sticky.navbar {
	box-shadow: 3px 0 8px 1px rgba(0,0,0,0.35);
}
.sticky .logo img {
	max-width: 215px;
}
.mobile_menu_toggle, .mobile_menu_close {
	background: none;
	border: none;
	border-radius: 5px;
}
.mobile_menu_toggle i, .mobile_menu_close i {
	font-size: 1.5rem;
	color: var(--secondary-color);
}
.mobile_menu {
	position: fixed;
	top: 0;
	right: -320px;
	/* right: 0; */
	bottom: 0;
	width: 300px;
	min-height: 100vh;
	max-height: 100vh;
	padding: 25px;
	overflow: hidden auto;
	background: #fff;
	box-shadow: 3px 0 10px 2px rgba(0,0,0,0.45);
	transition: 0.3s ease;
	z-index: 99;
}
.mobile_menu.active {
	right: 0;
}
.mobile_nav .menu_item,
.mobile_nav .submenu .menu_item  {
	display: block;
	width: 100%;
	padding: 0.7rem 1rem;
	font-size: 1rem;
	font-weight: 600;
}
.mobile_nav .submenu .menu_item, .mobile_nav .sub_submenu .menu_item  {
	padding: 0.5rem 1rem;
}
.mobile_nav .menu_link {
	display: block;
	width: 100%;
}
.mobile_nav .submenu, .mobile_nav .sub_submenu {
	display: none;
	margin-top: 0.5rem;
	border-radius: 0.5rem;
	background-color: #fafafa;
}
.mobile_nav .sub_submenu {
	background-color: #f5f5f5;
}
.mobile_nav .submenu .menu_link {
	font-size: 0.95rem;
	transition: 0.3s ease;
}
.mobile_nav .has_submenu .menu_link {
	position: relative;
	font-size: 0.95rem;
	transition: 0.3s ease;
}
.has_submenu > .menu_link::after {
	content: '';
	background-image: url('../images/svg/rounded-down.svg');
	background-size: contain;
	height: 20px;
	width: 20px;
	background-repeat: no-repeat;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translate(0, -50%);
	color: var(--accent-color);	
}
.menu .submenu .has_submenu > .menu_link::after {
	background-image: url('../images/svg/rounded-right.svg');
}


/*==============================
        HERO AREA  CSS
============================== */
.bg-video {
	width: 100%;
	height: auto;
}


/*==============================
        ABOUT AREA CSS
============================== */
#about .highlight_text {
	position: relative;
	margin-right: 1rem;
	color: var(--primary-color);
	font-size: 1.4rem;
	font-weight: 400;
}
#about .highlight_text::after {
	content: '';
	height: 80%;
	width: 6px;
	background-color: var(--primary-color);
	position: absolute;
	top: 50%;
	left: calc(100% + 10px);
	transform: translate(0, -50%);
}
#about .about_text {
	line-height: 1.9;
}
#about .service_single {
	position: relative;
	height: 0;
	width: 100%;
	padding-top: 56.25%;
	background-size: cover;
	background-position: center;
	border-radius: 0.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 3px solid var(--primary-color-light);
	transition: 0.4s ease;
	overflow: hidden;
}
#about .service_single::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	height: 100%;
	width: 100%;
	background-color: rgba(0,0,0,0.15);
	z-index: 1;
	transition: 0.4s ease;
}
.service_single .service_info {
	position: absolute;
	top: 10px;
	z-index: 10;
	transition: 0.4s ease;
}
.service_single .service_info * {
	color: #fff;
	font-size: 1.2rem;
	transition: 0.4s ease;
}
.service_single .overlay {
	height: 100%;
	width: 100%;
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	z-index: 9;
	visibility: hidden;
	transition: 0.4s ease;
}
#about .about_service:hover .service_single .overlay {
	top: 0;
	background-color: var(--accent-color);
	visibility: visible;
}
#about .about_service:hover .service_single .service_info {
	top: 50%;
	transform: translate(0, -50%);
}
#about .about_service:hover .service_single .service_info * {
	font-size: 1.5rem;
}
#about .service_single:hover {
	font-size: 1.5rem;
	border: 3px solid var(--accent-color);
}

/*==============================
        CONTRACT AREA CSS
============================== */
#contract {
	background-color: var(--primary-color-light);
	/* background-image: linear-gradient(to right bottom, rgb(245, 242, 231, 0.25), rgb(139, 156, 248, 0.25)); */
}

.img_container {
	position: relative;
	padding-top: 100%;
	display: flex;
	-webkit-align-items: center;
	-moz-box-align: center;
	align-items: center;
	-webkit-justify-content: center;
	-moz-box-pack: center;
	justify-content: center;
	overflow: hidden;
	background-color: #fff;
}
.img_container .inner_img {
	padding-top: 100%;
	display: -webkit-flex;
	display: -moz-box;
	display: flex;
	-webkit-align-items: center;
	-moz-box-align: center;
	align-items: center;
	-webkit-justify-content: center;
	-moz-box-pack: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}
.inner_img .image {
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	margin: auto;
	max-width: 100%;
	max-height: 100%;
	transition: all .3s ease-in-out;
	-webkit-transition: all .3s ease-in-out;
}

.slick-slide {
	margin: 4px;
}
.slick-next,
.slick-prev {
	top: calc(100% + 30px);
	width: 2.15rem;
	height: 2.15rem;
	background: var(--primary-color);
}
.slick-prev {
	right: 3rem;
	left: initial;
}
.slick-next {
	right: 0px;
}
.slick-prev:hover, .slick-prev:focus, .slick-next:hover, .slick-next:focus {
	color: #fff;
	outline: none;
	background: var(--primary-color);
}

/* SINGLE PRODUCT */
.product_banner {
	background-color: var(--primary-color);
}
.product_banner img {
	width: 100%;
}
.subtitle {
	font-size: 1.6rem;
}
.product_image .product_image_more img {
	border: 3px solid var(--primary-color-light);
	transition: 0.4s ease;
}
.product_image .product_image_more:hover img {
	border: 3px solid var(--accent-color);
}
.product_image .product_image_more img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 0.5rem;
}
.product_desciption .attachment_icon {
	height: 2.15rem;
	width: 2.15rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background-color: var(--primary-color);
	border-radius: 50%;
	color: #fff;
}
.nav-tabs .nav-item.show .nav-link, .nav-tabs .nav-link.active {
	color: #fff;
	background-color: var(--primary-color);
	border-color: var(--primary-color);
}
.nav-link {
	color: var(--primary-color);
}

/* PRODUCT CSS */
#our_product .product_home_single .img_container {
	background-color: #f8f8f8;
}
.product_home_single .product_title {
	font-weight: 600;
	font-size: 1.3rem;
	line-height: 1.2;
}
.product_home_single img {
	border-radius: 0.5rem;
}


/* EQUIPMENT */
.equipment tbody tr td:first-child:before {
  counter-increment: Serial;
  content: counter(Serial);
}
.equipment_images .img_container {
	border: 3px solid #ddd;
	border-radius: 0.5rem;
	background-color: #e0e0e0;
	transition: 0.4s ease;
}
.equipment_images .img_container img {
	filter: saturate(10%);
	transition: 1s ease;
}
.equipment_images .img_container:hover {
	border: 3px solid var(--accent-color);
	background-color: #f9f9f9;
}
.equipment_images .img_container:hover img {
	filter: saturate(150%);
	transform: scale(1.5);
}
.lightbox .lb-image {
    filter: saturate(150%)!important;
}


/* TECHNICAL ASPECT */
.parts_single .parts_image {
	max-height: 260px;
	width: 100%;
	object-fit: cover;
}
/* =======================
	ABOUT 
=========================*/

/* WHO WE ARE */
.short_desc {
	margin-bottom: 6rem;
}
.desc_list li {
	padding: 0.2rem 0;
}
.desc_list li::before {
	content: '*';
	padding-right: 0.5rem;
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--primary-color);
}


/* FOOTER */

footer {
	background-color: #141e26;
	color: #f0f0f0;
	line-height: 1.8;
}
footer * {
	font-size: 0.95rem;
}
.footer_head {
	display: block;
	font-size: 1.25rem;
	font-weight: 800;
	margin-bottom: 0.5rem;
}
.footer_bottom {
	background-color: #082135;
	color: #aaa;
	font-size: 0.85rem;
}
.footer_bottom * {
	font-size: 0.85rem;
}