:root {
  --white: #ffffff; 
  --black: #000000;
  --grey: #f3f3f3;
  --theme-grey: #ede7e1;
  --primary-color: #d43f45;
  --primary-hover: #f1565b;
  --secondary-color: #1a5cb2;
  --secondary-hover: #317de0;
  --text-color: #333333;
}


* { box-sizing: border-box;}
html, body { margin: 0;	padding: 0;	border: 0; vertical-align: baseline; font-family: "Poppins", sans-serif; font-optical-sizing: auto; font-style: normal; font-weight: 400; list-style: none; color:var(--black); font-size: 16px;}
body { padding-top: 116px;}
a:focus,button:focus,input:focus,textarea:focus { outline:0; text-decoration:none;}
h1,h2,h3,h4,h5,h6 { margin:0; padding:0; -webkit-font-smoothing:antialiased; margin-bottom:15px; color:var(--black); line-height: normal; font-family: "Rubik", sans-serif; line-height: 1.1; font-family: "Teko", sans-serif;}
h1 { font-size:50px;}
h2 { font-size: 50px;}
h3 { font-size:25px;}
h4 { font-size:24px;}
a { color:#018aff; text-decoration:none; transition:all ease-out .3s; -webkit-transition:all ease-out .3s; -moz-transition:all ease-out .3s;-ms-transition:all ease-out .3s; -o-transition:all ease-out .3s;}
a:hover { text-decoration:none;color:#3b90ff;}
label { font-weight:400;margin:0;}
p { font-size: 16px; line-height:1.5; color: var(--text-color); margin:0; padding:0; font-weight: 400; margin-bottom:15px; font-family: "Poppins", sans-serif;}
li,ol,ul { list-style:none; margin:0; padding:0;}
focus { outline:0;}

/*========================== Commen styles ========================*/
.primary-btn { display: inline-block; background: var(--secondary-color); color: var(--white); font-size: 16px; padding: 14px 45px; line-height: 16px; font-weight: 500; transition: all ease-out 0.3s; position: relative; border: none;}
.primary-btn::before { content: ''; width: 0; height: 100%; display: block; background: var(--primary-color); transition: all ease-out 0.3s; position: absolute; left: 0; top: 0;}
.primary-btn span { color: var(--white); position: relative; z-index: 2;}
.primary-btn:hover { color: var(--white);transform: translate3d(0, -2px, 0); box-shadow: 0 12px 28px rgba(0, 0, 0, .12);}
.primary-btn:hover::before { width: 100%;}

.border-btn { display: inline-block; background: none; color: var(--black); font-size: 14px; padding: 11px 42px; line-height: 16px; font-weight: 400; transition: all ease-out 0.3s; position: relative;     box-shadow: 3px 3px 8px 1px #c8cdd3; border: 1px solid var(--secondary-color); color: var(--secondary-color); background: var(--white); box-shadow: 0 12px 28px rgba(0, 0, 0, .12); text-transform: uppercase;}
.border-btn::before { content: ''; width: 0; height: 100%; display: block; background: var(--primary-color); transition: all ease-out 0.3s; position: absolute; left: 0; top: 0;}
.border-btn span { color: var(--secondary-color); position: relative; z-index: 2;}
.border-btn:hover { color: var(--white); transform: translate3d(0, -2px, 0); border-color: var(--primary-color);}
.border-btn:hover::before { width: 100%;}
.border-btn:hover span { color: var(--white);}

section { display: block; padding: 75px 0;}
/*========================== Commen styles ========================*/

.header { display: block; position: fixed; top: 0; left: 0; width: 100%; z-index: 999; background: var(--white); box-shadow: 0 1px 5px rgba(0, 0, 0, .1);}
.header-top-block { display: block; background: var(--primary-color); position: relative;}
.header-top-block .container { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; position: relative; z-index: 3;}
.header-top-block::before { content: ''; width: 40%; height: 100%; display: block; background: var(--secondary-color); position: absolute; left: 0; top: 0; z-index: 1;}
.header-top-list { display: flex; align-items: center; flex-wrap: wrap; width: 100%; background: var(--primary-color);}
.header-top-list li { display: block; padding: 0 25px;}
.header-top-list li a { display: block; color: var(--white); font-size: 14px; padding: 10px 0; line-height: 1.3;}
.header-top-list li:first-child { background: var(--secondary-color); padding-left: 0;}
.header-top-list li a i { display: inline-block; margin-right: 5px;}

.header-main-right { display: flex; align-items: center; flex-wrap: wrap; justify-content: space-between;}

.header-main-block { display: block; padding: 10px 0;}
.header-main-block .container { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; position: relative;}
.logo { width: 238px; display: block;}
.logo a { display: inline-block;}
.logo a img { display: block;}

/* ==========================================================================
   Menu with dropdown menu begin
   ========================================================================== */
.main-menu { display:block;}
.main-menu > ul { display:block; text-align: center;}
.main-menu > ul > li { display:inline-block; margin: 0 30px 0 0;}
.main-menu > ul > li > a { color:#333333; display: block; font-size: 14px; padding: 5px 0; position: relative; line-height: 1; font-weight: 500;}
.main-menu > ul > li:hover > a, .main-menu > ul > li.active > a { color: var(--primary-color);}
.main-menu > ul > li.dropdown > a::before { content: "\f107"; font-family: "FontAwesome"; font-size: 14px; color: var(--black); display: inline-block; position: absolute; right: -8px; top: 9px;}
.main-menu > ul > li.dropdown:hover > a::before { color: var(--primary-color);}

.main-menu > ul > li > ul { display:block; position:absolute; top:37px; right: 0px; background-color: var(--primary-color); width: 200px; font-weight: 400; z-index: 10; opacity: 0; pointer-events: none; transition: all ease-out 0.3s; transform: translateY(10px);}
.main-menu > ul > li > ul > li { display:block;}
.main-menu > ul > li > ul > li:first-child { border-top:none;}
.main-menu > ul > li > ul > li > a { display: block; color: #d1e1f4; padding: 10px 15px; font-weight: 400; font-size: 14px; line-height: 18px; position: relative; text-align: left;  text-transform: uppercase;}
.main-menu > ul > li > ul > li > a:hover { background: var(--primary-color); color: var(--primary-color);}
/* .main-menu > ul > li:nth-child(6) > ul { left: inherit; right: 0px;} */
.main-menu > ul > li > ul.normal-sub-menu { width: 250px;}
.main-menu > ul > li > ul { max-height: 350px; overflow-y: auto; scrollbar-color: #f34b4b #363232; scrollbar-width: thin;}
.main-menu > ul > li > ul::-webkit-scrollbar { width: 8px;}
.main-menu > ul > li > ul::-webkit-scrollbar-track { background: var(--primary-color);}
.main-menu > ul > li > ul::-webkit-scrollbar-thumb { background-color: var(--primary-color); outline: none;}
.main-menu > ul > li:hover > ul { opacity: 1; pointer-events: all; transform: translateY(0px);}

/* Menu Second Level  */
.main-menu > ul > li > ul > li { position: relative; display: block;}
.main-menu > ul > li > ul > li> a.hoverClass { color: var(--white);}
.main-menu > ul > li > ul > li.dropdown >a:after{ content: "\f107"; position: absolute; top: 8px; right: 15px; font-family: 'FontAwesome'; transition: all ease 0.2s;}
.main-menu > ul > li > ul > li.dropdown> a.hoverClass:after{ color: var(--white); transform: rotate(-90deg);}
.main-menu > ul > li > ul > li > ul { display: block; transition: all ease 0.2s; position:absolute; top:0px; left:220px; background-color: var(--primary-color); width: 200px; font-weight: 400; opacity: 0;}
.main-menu > ul > li > ul > li > ul.pull-ul { right:200px; opacity: 1; pointer-events: auto; z-index: 3;}
.main-menu > ul > li > ul > li > ul > li { display:block; border-top:1px solid #615f5f;}
.main-menu > ul > li > ul > li > ul > li:first-child { border-top:none;}
.main-menu > ul > li > ul > li ul > li > a {display: block; color: #a6a6ac; padding: 10px 15px; font-weight: 400; font-size: 14px; position: relative; text-align: left;}
.main-menu > ul > li > ul > li ul > li > a:hover { color:#fff;}

/*======================================== Menu Style End =======================================*/
.mobile-menu ul.menu-list { padding:5px 0;}
.mobile-menu ul.menu-list > li > a:hover { background: var(--primary-color); color:#FFF;}
.mobile-menu ul.menu-list > li > ul { display:none; margin-left:0; padding:10px 0; background:#2b2a2a;}
.mobile-menu ul.menu-list> li a.open,.mobile-menu ul.menu-list > li > ul > li a:hover { background: var(--primary-color); color: var(--white);}
.mobile-menu ul.menu-list > li > ul > li a {color:#FFF; padding:10px 10px;display:block; font-size:16px; transition:all ease-out .2s;-webkit-transition:all ease-out .2s;-moz-transition:all ease-out .2s;-ms-transition:all ease-out .2s;-o-transition:all ease-out .2s;text-align:center;}
.menu-toggle { position:absolute; display:none; width:48px; height:48px; top:8px; right:20px; box-sizing:border-box; border: none; background: none; padding: 0;}
.menu-toggle span.line { position:relative; width:60%; height:2px; background: var(--primary-color); margin:6px auto; display:block; transition:all ease .3s; -webkit-transition:all ease .3s; -moz-transition:all ease .3s; -o-transition:all ease .3s; -ms-transition:all ease .3s}
.menu-toggle.active span.line { position:absolute; margin:auto; top:0; right:0; bottom:0; left:0; transform-origin:center center;}
.menu-toggle.active span.line.a { transform:rotate(45deg)}
.menu-toggle.active span.line.c { transform:rotate(-45deg)}
.menu-toggle.active span.line.b { opacity:0}
.mobile-menu { display:none;}
.mobile-menu > ul { padding:10px 0}
.mobile-menu ul > li {text-align:center; border-top: 1px solid rgba(255, 255, 255, 0.1); position: relative;}
.mobile-menu ul > li:first-child { border-top:none;}
.mobile-menu ul > li > a { display:block; color: var(--white); font-size:14px; padding:8px 20px;}
.mobile-menu ul > li > a > img { display: none;} 
.mobile-menu ul > li.dropdown > a { position:relative;}
.mobile-menu ul > li.dropdown > a:after { content: "\f107"; font-family: "FontAwesome"; font-size: 14px; color: var(--white); display: inline-block; position: absolute; right: 10px; top: 8px;}
.mobile-menu ul > li.drp > a { position:relative;}
.mobile-menu ul > li.drp > a:after { content:''; width:0; height:0; display:block; border:6px solid #fff; border-color: var(--white) transparent transparent transparent; position:absolute; right:15px; top:15px;}
.mobile-menu ul > li.drp > a.open:after { border:6px solid var(--white); border-color: transparent transparent var(--white) transparent; top:10px;}
/*======================================== Menu Style End =======================================*/

.mega-drop { border-top: none; position: absolute; width: 100%; top: 101px; left: 0; display: block; opacity: 0; pointer-events: none; /*overflow: hidden;*/ transition:all ease 0.3s; transform: scale(0.96); text-align: left; padding: 35px 0; box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0.144); background: var(--white); z-index: 9;}
.mega-drop.active { opacity: 1; pointer-events: auto; transform: scale(1); z-index: 9;}
.mega-drop-main { display: block; overflow: hidden;}
/* ==========================================================================
  Menu with dropdown menu End
  ========================================================================== */
.white-text h1,
.white-text h2,
.white-text h3,
.white-text h4,
.white-text h5,
.white-text h6,
.white-text p,
.white-text ul li,
.white-text a { color: var(--white) !important;}
.bg-style1 { background-repeat: no-repeat !important; background-position: center top !important; background-size: cover !important;}
.bg-style2 { background-repeat: no-repeat !important; background-position: center center !important; background-size: 80% !important;}
.commen-section { display: block;}
.padding-style40 { padding: 40px 0;}

.home-page { overflow: hidden;}
.home-page h2 { color: var(--secondary-color);}
.padding-style1 { padding: 115px 0;}
.bg-grey { background: var(--grey) !important;}
.bg-dark-blue { background: var(--secondary-color) !important;}
.bg-white { background: var(--white) !important;}
.bg-red { background: var(--primary-color) !important;}
.bg-blue { background: var(--secondary-color) !important;}

.banner { display: flex; align-items: center; height: 88vh; background: var(--grey); overflow: hidden; background-size: cover !important; background-repeat: no-repeat !important; background-position: center top !important; position: relative; position: relative;}
.banner video { margin: 0px; padding: 0px; bottom: 0; height: 100%; display: block; width: 100%; object-fit: cover;}
.banner-wraper { display: flex; align-items: center; width: 100%; height: 100%; position: absolute; left: 0; top: 0;}
.banner-wraper::before { content: ''; width: 100%; height: 100%; display: block; position: absolute; left: 0; top: 0; background: #00000042; z-index: 1;}
.banner-wraper .container { position: relative; z-index: 3;}
.banner-text { display: block; max-width: 750px;}
.banner-text h1 { margin-bottom: 40px; font-weight: 700; font-size: 50px; font-family: "Poppins", sans-serif; line-height: 1.4;}

.home-services-block { position: relative;}
.services-card { display: block; height: 100%; position: relative; padding: 40px 25px; border: 1px solid #ebe9e9; transition: all ease-out 0.3s;}
.services-card-body { display: block; position: relative; z-index: 2;}
.services-card-body .icon { display: inline-flex; margin-bottom: 25px;}
.services-card-body h3 { margin-bottom: 25px;}
.services-card:hover { box-shadow: 0 .5rem 1rem rgba(0, 0, 0, .15) !important; border: 1px solid #d7d7d7;}
.services-card::before { content: ""; position: absolute; width: 0; height: 0; -webkit-transition: all .3s ease-in-out 0s; -o-transition: all .3s ease-in-out 0s; transition: all .3s ease-in-out 0s; border-style: solid; visibility: hidden; top: 0; border-color: #d43f45; right: 0; border-width: 4px 4px 0 0;}
.services-card::after { content: ""; position: absolute; width: 0; height: 0; -webkit-transition: all .3s ease-in-out 0s; -o-transition: all .3s ease-in-out 0s; transition: all .3s ease-in-out 0s; border-style: solid; visibility: hidden; bottom: 0; left: 0; border-color: #1a5cb2; border-width: 0 0 4px 4px;}
.services-card:hover::before { width: 75px; height: 75px; visibility: visible;}
.services-card:hover::after { width: 75px; height: 75px; visibility: visible;}

.home-about-block { position: relative;}
.home-about-block::before { content: ''; width: 100%; height: 100%; display: block; background: #ffffffad; position: absolute; left: 0; top: 0;}
.home-about-block .container { position: relative; z-index: 3;}
.home-about-left { display: block;}
.home-about-right { display: block;}
.home-about-right h2 span { display: block; font-size: 34px; color: var(--primary-color);}
.industries-block { display: flex;}
.industries-main { display: block; background-color: #f4f4f4; border-radius: 10px 10px 10px 10px; box-shadow: 0px 0px 48px 0px rgba(162, 162, 162, 0.5); padding: 28px 40px; margin-top: -45px; position: relative; z-index: 3;}
.industries-main h3 { color: var(--primary-color); font-size: 34px;}
.industries-main ul li { font-size: 16px; color: #333333; position: relative; padding-left: 23px; margin-bottom: 7px;}
.industries-main ul li::before { content: '❖'; display: inline-block; font-size: 16px; position: absolute; left: 0; top: 0; font-size: 14px;}

.technological-resources { display: block; margin-top: 90px;}
.resources-left { display: block;}
.resources-left p { margin-bottom: 35px;}
.resources-right .row .col { position: relative;}
.resources-right .row .col::before { content: ""; z-index: -1; position: absolute; top: 43px; right: 40px; bottom: -14px; left: 10px; background-image: -webkit-gradient(linear, left top, left bottom, from(#205ba8), to(#d24f54)); border-radius: 0 171px 171px 0; box-shadow: 0 6px 8px rgba(0, 0, 0, .23) inset; transition: all 200ms linear 0ms; opacity: 1;}
.resources-card { display: block; padding: 50px 25px; border: 1px solid #ebe9e9; position: relative; z-index: 3; position: relative; background: var(--white);}
.resources-card h3 { color: var(--primary-color); font-size: 40px;}
.resources-card h4 { color: var(--secondary-color); font-size: 28px;}

.owl-carousel .owl-item img { width: auto;}
.our-features-block { display: block;}
.our-features-block .services-card-body h3 { color: var(--secondary-color); font-size: 30px;}
.cleint-logo { display: flex; justify-content: center; align-items: center;}

.footer-block { display: block; background: #dfdfdf;}
.footer-top-block { display: block; position: relative;}
.footer-top-block::before { content: ''; width: 100%; height: 100%; display: block; position: absolute; left: 0; top: 0; background: #dfdfdfe0;}
.footer-top-block .container { position: relative; z-index: 2;}
.footer-top-block h3 { color: var(--primary-color); text-transform: uppercase; font-size: 28px; font-weight: 600;}
.footer-contact { display: block;}
.footer-contact ul li { display: block; padding-left: 32px; position: relative; margin-bottom: 20px;}
.footer-contact ul li i { display: inline-block; font-size: 15px; color: var(--primary-color); position: absolute; left: 0; top: 0;}
.footer-contact ul li a { color: var(--text-color);}
.footer-links { display: block;}
.footer-services { display: block;}
.footer-services ul li,
.footer-links ul li { color: var(--text-color); margin-bottom: 15px;}
.footer-services ul li a,
.footer-links ul li a { color: var(--text-color);}

.socail-media { display: flex; align-items: center; flex-wrap: wrap;}
.socail-media a { display: flex; align-items: center; justify-content: center; width: 30px; height: 30px; border-radius: 100%; margin-right: 10px; color: var(--white); background: var(--secondary-color);}
.socail-media a:hover { background: var(--primary-color);}



/* =============== Inner Pages =============== */
.inner-page h1,
.inner-page h2 { color: var(--secondary-color);}
.zindex-container .container { position: relative; z-index: 3;}
.inner-banner { display: block;}
.inner-banner h1 { font-size: 34px;}
.inner-section { display: block;}
.commen-img { display: inline-block; position: relative; padding-left: 5px;}
.commen-img::before { content: ""; z-index: -1; position: absolute; top: 43px; right: 40px; bottom: -14px; left: -15px; background-image: -webkit-gradient(linear, left top, left bottom, from(#205ba8), to(#d24f54)); border-radius: 0 171px 171px 0; box-shadow: 0 6px 8px rgba(0, 0, 0, .23) inset; transition: all 200ms linear 0ms; opacity: 1;}
.commen-img img { position: relative; z-index: 3;}
.img-style2::before { height: 88%;}

.group-companies-block { display: block;}
.group-companies { display: block; padding: 30px 25px; background-color: rgba(255, 255, 255, .11); transition: all ease-out 0.3s; height: 100%; border-radius: 10px; margin: 0 5px;}
.group-companies:hover { box-shadow: -2px -1px 11px #cbced2;}
.group-companies h5 { font-size: 24px;}

.accordian-style1 .accordion-box { margin-bottom: 5px;}
.accordian-style1 .accordion-item { border: none; background: var(--secondary-color); color: var(--white); border: none; border-radius: 0px; padding: 10px 15px; padding-right: 40px; cursor: pointer; position: relative;}
.plus-minus { width: 12px; height: 12px; display: block; position: relative;}
.plus-minus::before { content: ''; width: 100%; height: 2px; display: block; background: var(--white); position: absolute; left: 0; top: 0; right: 0; bottom: 0; margin: auto;}
.plus-minus::after { content: ''; width: 2px; height: 100%; display: block; background: var(--white); position: absolute; left: 0; top: 0; right: 0; bottom: 0; margin: auto;}
.accordian-style1 .accordion-item .plus-minus { position: absolute; right: 15px; top: 0; bottom: 0; margin: auto;}
.accordian-style1 .accordion-item.open .plus-minus::after { display: none;}

.accordian-style1 .data { display: none; padding: 20px 15px;}
.about-services-block { display: block;}
.commen-listing ul li { font-size: 16px; color: #333333; position: relative; padding-left: 23px; margin-bottom: 7px;}
.commen-listing ul li::before { content: '❖'; display: inline-block; font-size: 16px; position: absolute; left: 0; top: 0; font-size: 14px;}

.services-box { display: block;}
.services-box figure { display: block; margin-bottom: 25px;}
.services-box .serv-head { display: block; margin-bottom: 15px; font-size: 31px; color: var(--primary-color); font-family: "Teko", sans-serif; font-weight: 500;}
.project-listing-block .services-box figure { margin: 0;}
.pro-head { display: block; background: var(--secondary-color); color: var(--white); margin: 0; padding: 10px 15px; font-family: "Teko", sans-serif; text-align: center; font-size: 24px;}
.pro-head span { line-height: 1.1; display: -webkit-box; -webkit-line-clamp: 1; line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden; text-overflow: ellipsis;}

.cyan-theme.accordian-style1 .accordion-item { background: #4e8683;}
.partners-top-block p a { color: var(--text-color);}
.client-box { display: flex; align-items: center; justify-content: center; height: 100%; border: 1px solid rgba(204, 204, 204, .45); min-height: 80px; max-height: 80px;}
.contact-top-block .services-card-body p a { color: var(--text-color);}
.contact-input { width: 100%; height: 40px; padding: 0; border: none; border-bottom: 1px solid #d6d8d9; font-size: 14px;}
.contact-textarea { width: 100%; height: 120px; border: none; border-bottom: 1px solid #d6d8d9; resize: none; font-size: 14px;}
.file-upload { font-size: 14px;}
.career-block h2 { font-family: "Roboto", sans-serif; font-size: 25px; color: var(--text-color);}
.supplier-reg p { font-size: 14px;}
.icv-certified { display: flex; flex-wrap: wrap; align-items: center;}
.icv-certified li { display: inline-block; margin-right: 20px;}
.icv-certified li label { font-size: 14px;}

.project-detail-main { display: block;}
.project-detail-main h3 { color: var(--secondary-color);}
.simple-listing ul { padding-left: 35px; margin-bottom: 20px;}
.simple-listing ul li { margin-bottom: 5px; list-style: outside;}
.simple-listing ul li::marker { font-size: 12px;}

.service-slider { padding-top: 35px;}
.service-slider .owl-nav { display: flex; align-items: center; justify-content: end; width: 100%; position: absolute; top: 0; left: 0;}
.service-slider .owl-nav button { height: 25px; width: 25px; border: 1px solid #205ba8 !important; color: #205ba8; display: block; background: #ffffff; border-radius: 100%; margin-left: 10px;}
.service-slider .owl-nav button:hover { background: #205ba8; color: #ffffff;}
.service-slider .owl-nav button span { color: #205ba8;}
.service-slider .owl-nav button:hover span { color: #ffffff;}

/* =============== Inner Pages =============== */




/* 
font-family: "Poppins", sans-serif;
font-family: "Roboto", sans-serif;
font-family: "Teko", sans-serif;
*/

/* 
:root {
  --white: #ffffff; 
  --black: #000000;
  --grey: #F5F5F5;
  --theme-grey: #ede7e1;
  --primary-color: #fa4729;
  --primary-hover: #fc6f56;
  --secondary-color: #181d4e;
  --secondary-hover: #2d3472;
}
*/