@charset "UTF-8";

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

body {
    font-family: "Fira Sans", sans-serif;
}
.p-60-xb {
    font-family: "Fira Sans", sans-serif;
    font-size: 3.75rem;
    font-weight: 800;
    line-height: 3.75rem;
}
.p-60-sb {
    font-family: "Fira Sans", sans-serif;
    font-size: 3.75rem;
    font-weight: 600;
    line-height: 3.25rem;
}
.p-42-sb {
    font-family: "Fira Sans", sans-serif;
    font-size: 2.625rem;
    font-weight: 600;
    line-height: 3rem;
}
.p-40-xb {
    font-family: "Fira Sans", sans-serif;
    font-size: 2.5rem;
    font-weight: 800;
    line-height: 2.75rem;
}
.p-40-b {
    font-family: "Fira Sans", sans-serif;
    font-size: 2.5rem;
    font-weight: 700;
    line-height: 2.5rem;
}
.p-36-b {
    font-family: "Fira Sans", sans-serif;
    font-size: 2.25rem;
    font-weight: 700;
    line-height: 2.25rem;
}
.p-36-sb {
    font-family: "Fira Sans", sans-serif;
    font-size: 2.25rem;
    font-weight: 600;
    line-height: 2.25rem;
    letter-spacing: -0.02em;
}
.p-32-sb {
    font-family: "Fira Sans", sans-serif;
    font-size: 2rem;
    font-weight: 600;
    line-height: 2rem;
    letter-spacing: -0.02em;
}
.p-26-b {
    font-family: "Fira Sans", sans-serif;
    font-size: 1.625rem;
    font-weight: 700;
    line-height: 1.825rem;
}
.p-24-b {
    font-family: "Fira Sans", sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.825rem;
}
.p-20-sb {
    font-family: "Fira Sans", sans-serif;
    font-size: 1.25rem;
    font-weight: 600;
}
.p-20-m {
    font-family: "Fira Sans", sans-serif;
    font-size: 1.25rem;
    font-weight: 500;
    line-height: 1.5rem;
}
.p-20 {
    font-family: "Fira Sans", sans-serif;
    font-size: 1.25rem;
    font-weight: 400;
}
.p-18-sb {
    font-family: "Fira Sans", sans-serif;
    font-size: 1.125rem;
    font-weight: 600;
}
.p-18-m {
    font-family: "Fira Sans", sans-serif;
    font-size: 1.125rem;
    font-weight: 500;
}
.p-18-m-addr {
    font-family: "Fira Sans", sans-serif;
    font-size: 1.125rem;
    font-weight: 500;
    line-height: 1.75rem;
}
.p-18 {
    font-family: "Fira Sans", sans-serif;
    font-size: 1.125rem;
    font-weight: 400;
    letter-spacing: -0.02em;
} 
.p-16-b {
    font-family: "Fira Sans", sans-serif;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: -0.02em;
}
.p-16-sb {
    font-family: "Fira Sans", sans-serif;
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: -0.02em;
}
.p-16 {
    font-family: "Fira Sans", sans-serif;
    font-size: 1rem;
    font-weight: 400;
    letter-spacing: -0.02em;
}
.p-14-m {
    font-family: "Fira Sans", sans-serif;
    font-size: 0.875rem;
    font-weight: 500;
    line-height: 1.5rem;
} 
.p-14 {
    font-family: "Fira Sans", sans-serif;
    font-size: 0.875rem;
    font-weight: 400;
    line-height: 1.5rem;
} 
.p-14-bre {
    font-family: "Fira Sans", sans-serif;
    font-size: 0.875rem;
    font-weight: 300;
    line-height: 1.5rem;
    letter-spacing: 0.03em;
}
.hr-one {
    border-top: 4px solid #fff !important;
    width: 200px;
    margin-left: 0;
    opacity: 1 !important;
}
.hr-two {
    border-top: 3px solid #000 !important;
    width: 200px;
    margin-left: 0;
    opacity: 1 !important;
}
.hr-three {
  border: none;
  height: 1px;
  background: #b0b0b0;
  background: repeating-linear-gradient(90deg,#ccc,#ccc 6px,transparent 6px,transparent 14px);
  opacity: 1 !important;
}
.hr-four {
    border-top: 1px solid #000 !important;
    width: 200px;
    margin-left: 0;
    opacity: 1 !important;
}
.hr-five {
    border-top: 3px solid #d9d9d9 !important;
    width: 200px;
    margin-left: 0;
    opacity: 1 !important;
}

/***** text color *******/

.tx-grey-4b { color: #4b4b4b; }
.tx-grey-41 { color: #414141; }
.tx-grey-c3 { color: #c3c3c3; }
.tx-grey-30 { color: rgba(255,255,255,0.3);}

@media (min-width: 768px) {}

@media (min-width: 992px) {}


/****** desktop setup ********/

@media (min-width: 576px) {}

@media (min-width: 768px) {}

/****** end desktop setup ********/



@media (min-width: 768px) {}

@media (min-width: 992px) {}

@media (min-width: 1200px) {}


/**** Header ****/

/**** HEADER CHANGE*****/
.headers {
	z-index: 1000;
    width: 100%;
    /**background: rgb(255,255,255);**/
    background: rgba(7,28,37,0.9);
    /**background: linear-gradient(90deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0.8302171210280987) 100%);**/
	-webkit-transition: all ease-out .5s;
    -moz-transition: all ease-out .5s;
    -o-transition: all ease-out .5s;
    transition: all ease-out .5s;
}
.headers-sub {
	z-index: 1000;
    width: 100%;
    background: rgb(255,255,255,0.9);
    /**background: linear-gradient(90deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0.8302171210280987) 100%);**/
	-webkit-transition: all ease-out .5s;
    -moz-transition: all ease-out .5s;
    -o-transition: all ease-out .5s;
    transition: all ease-out .5s;
}
.activex {
  background-color: #fff;
}

.logo-v2 {
    top: 70px;
    left: 5px;  
    width: 200px;
}
.logo-v2 img {
    width: 100px;
    height: auto;
}
.logo-v3 {
    top: 70px;
    left: 5px;
    width: 200px;
}
.logo-v3 img {
    width: 100px;
    height: auto;
}

@media (min-width: 992px) {
.logo-v2 {
    top: 25px;
    left: 25px;
    }
.logo-v2 img {
    width: 120px;
    height: auto;
    }
.logo-v3 {
    top: 30px;
    left: 30px;
    }
.logo-v3 img {
    width: 120px;
    height: auto;
    }
}

@media (min-width: 992px) {
    .headers {
        background: rgb(106,185,161);
        background: linear-gradient(90deg, rgba(106,185,161,0) 0%, rgba(7,28,37,0.7) 100%);
    }
    .headers-sub {
        background: rgb(106,185,161);
        background: linear-gradient(90deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0.7) 100%);
    }
    .activex {
        background-color: #fff !important;
    }
}

/*-- Navbar****/
.navbar-nav .nav-item {
    padding: 0 8px;
}
.navbar-nav .nav-item a {
    font-family: "Fira Sans", sans-serif;
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 0.03em;
}

.nav-tabs .nav-link {
    font-weight: 500;
    padding-left: 20px;
    padding-right: 20px;
    color: #43A648;
}
.nav-tabs .nav-link.active,
.nav-tabs .nav-item.show .nav-link {
    background-color: #f7f7f7;
}

/*****background*****/
.hero {
    background-image: url(../imgs/hero-bg.jpg);
    background-size: cover;
    background-position: center center;
}
.tech {
    background-image: url(../imgs/bg-tech.jpg);
    background-size: cover;
    background-position: center center;
}
.mech {
    background-image: url(../imgs/bg-mech.jpg);
    background-size: cover;
    background-position: center top;
}
.renewal {
    background-image: url(../imgs/bg-renewal.jpg);
    background-size: cover;
    background-position: center center;
}
.science {
    background-image: url(../imgs/bg-science.jpg);
    background-size: cover;
    background-position: center center;
}
.chemical {
    background-image: url(../imgs/bg-chem.jpg);
    background-size: cover;
    background-position: center center;
}
.profile {
    background-image: url(../imgs/bg-profile.jpg);
    background-size: cover;
    background-position: center center;
}
.gallery {
    background-image: url(../imgs/bg-gallery.jpg);
    background-size: cover;
    background-position: center center;
}
.about {
    background-image: url(../imgs/bg-about.jpg);
    background-size: cover;
    background-position: center center;
}
.mission {
    background-image: url(../imgs/bg-mission.svg);
    background-size: cover;
    background-position: center right;
}
.pattern {
    background-image: url(../imgs/bg-pattern.svg);
    background-position: right top;
    background-repeat: no-repeat;
}
.quote {
   background-image: url(../imgs/quote.svg);
    background-position: left top;
    background-repeat: no-repeat; 
}
.bg-tab {
    background-color: #F7F7F7;
    background-position: top 20px;
}
.pattern-heavy {
     background-image: url(../imgs/bg-pattern-heavy.svg);
    background-position: right top;
    background-repeat: no-repeat;
}
.pattern-profile {
    background-image: none;
}

@media (min-width: 576px) {
.pattern-profile {
    background-image: url(../imgs/bg-pattern-heavy.svg);
    background-position: right top;
    background-repeat: no-repeat;
    }
}


.bg-green-1 { background: rgba(27,111,71,0.9); }
.bg-grey-1 { background-color: #D9D9D9 }
.bg-orange { background-color: #EBA13A; }
.bg-white-blur { 
    background: rgba(255,255,255,0.1); 
    backdrop-filter: blur(5px);
-webkit-backdrop-filter: blur(5px);
}
.bg-blue-addr {
    background: rgb(234,241,248);
background: linear-gradient(90deg, rgba(234,241,248,1) 0%, rgba(162,180,197,0.5) 100%);
}

/**** button *****/
a.btn-in-1 {
    border: 1px solid #fff;
    background-color: #fff;
    padding: 12px 38px 12px 30px;
    text-decoration: none;
    font-family: "Fira Sans", sans-serif;
    font-weight: 500;
    font-size: 1.125rem;
    color: #000;
}
a.btn-out-1 {
    border: 1px solid #fff;
    background-color: transparent;
    padding: 12px 38px 12px 30px;
    text-decoration: none;
    font-family: "Fira Sans", sans-serif;
    font-weight: 500;
    font-size: 1.125rem;
    color: #fff;
    transition: all .4s ease-in-out;
}
a.btn-out-1:hover {
    background-color: #fff;
    color: #000;
}
a.btn-out-2 {
    border: 1px solid #000;
    background-color: transparent;
    padding: 12px 38px 12px 30px;
    text-decoration: none;
    font-family: "Fira Sans", sans-serif;
    font-weight: 500;
    font-size: 1.125rem;
    color: #000;
    transition: all .4s ease-in-out;
}
a.btn-out-2:hover {
    background-color: #000;
    color: #fff;
}
a.btn-out-3 {
    border: 1px solid #000;
    background-color: transparent;
    padding: 10px 28px 10px 22px;
    text-decoration: none;
    font-family: "Fira Sans", sans-serif;
    font-weight: 500;
    font-size: 0.875rem;
    color: #000;
    transition: all .4s ease-in-out;
}
a.btn-out-3:hover {
    border: 1px solid #333;
    background-color: #333;
    color: #fff;
}
a.btn-out-4 {
    border: 1px solid #009192;
    background-color: transparent;
    padding: 10px 34px 10px 28px;
    text-decoration: none;
    font-family: "Fira Sans", sans-serif;
    font-weight: 500;
    font-size: 1rem;
    color: #000;
}
a.btn-empty {
    font-family: "Fira Sans", sans-serif;
    font-weight: 600;
    font-size: 1rem;
    color: black;
    text-decoration: none;
}

/****** scroll two ******/

  .gird-main {
    grid-area: main;
    padding: 0;
    overflow-x: scroll;
    overflow-y: hidden;
  }

  .itemsx {
    position: relative;
    width: 100%;
    overflow-x: scroll;
    overflow-y: hidden;
    white-space: nowrap;
    transition: all 0.9s;
    transform: scale(0.99);
    will-change: transform;
    user-select: none;
    cursor: pointer;
  }

  .itemsx.active {
    background: rgba(255, 255, 255, 0);
    cursor: grabbing;
    cursor: -webkit-grabbing;
    transform: scale(1);
  }

  .itemx {
    display: inline-block;
    min-height: 350px;
    width: 420px;
    margin: 1em 0.25em;
    padding: 0;
    color: white;
  }
  @media screen and (max-width: 500px) {
    .itemx {
      min-height: 200px;
      min-width: 200px;
    }
  }

.scroll-rail::-webkit-scrollbar {
     width: 0.125em;
    height: 0.125rem;
}
.scroll-rail::-webkit-scrollbar-track {
    -webkit-box-shadow: inset 0 0 2px #333;
}
 
.scroll-rail::-webkit-scrollbar-thumb {
  background-color: #333;
  outline: 1px solid #333;
}

.no-rel::-webkit-scrollbar {
   display: none;
}


/***** CUSTOM POSITION *****/
.home-2-box {
    bottom: 30px;
    left: 28px;
}
@media (min-width: 992px) {
    .home-2-box {
    left: 48px;
    }
}

/*-- Footer*****/
footer {
    background: url(../imgs/bg-footer.svg);
    background-size: cover;
}
footer .p-14 {
    font-family: "Fira Sans", sans-serif;
    font-size: 0.875rem;
    font-weight: 300;
    letter-spacing: 0.05em;
}
footer .p-14-m {
    font-family: "Fira Sans", sans-serif;
    font-size: 0.875rem;
    font-weight: 500;
    letter-spacing: 0.05em;
}
footer ul li {
    padding: 4px 0;
}
footer li a {
    font-family: "Fira Sans", sans-serif;
    font-size: 1rem;
    font-weight: 500;
    color: #fff;
    text-decoration: none;  
}

/*** forms ****/

/***** iFrame ******/


/*****MARGIN & PADDING EXTRA*****/

.mt-n4 {
    margin-top: -3rem !important;
}

.m-6 {
    margin: 5rem;
}
.mt-6 {
    margin-top: 5rem !important;
}
.mt-7 {
    margin-top: 7rem !important;
}
.my-6 {
    margin-top: 5rem !important;
    margin-bottom: 5rem !important;
}
.mx-6 {
    margin-left: 5rem !important;
    margin-right: 5rem !important;
}
.my-7 {
    margin-top: 7rem !important;
    margin-bottom: 7rem !important;
}
.pt-4-5 {
  padding-top: 2rem !important;
}

.px-4-5 {
  padding-left: 2rem !important;
  padding-right: 2rem !important;
}

.p-7 {
    padding: 7rem;
}
.pt-6 {
    padding-top: 5rem !important;
}
.pt-7 {
    padding-top: 7rem !important;
}
.pt-8 {
    padding-top: 7.5rem !important;
}
.pt-9 {
    padding-top: 8.5rem !important;
}
.pb-6 {
    padding-bottom: 5rem !important;
}
.pb-7 {
    padding-bottom: 7rem !important;
}
.pb-8 {
    padding-bottom: 8rem !important;
}
.pb-9 {
    padding-bottom: 15.5rem !important;
}
.px-5-5 {
    padding-left: 3.875rem !important;
    padding-right: 3.875rem !important;
}
.px-6 {
    padding-left: 5rem !important;
    padding-right: 5rem !important;
}
.py-6 {
    padding-top: 5rem !important;
    padding-bottom: 5rem !important;
}
.py-7 {
    padding-top: 7rem !important;
    padding-bottom: 7rem !important;
}
.py-8 {
    padding-top: 7.5rem !important;
    padding-bottom: 7.5rem !important;
}
.py-9 {
    padding-top: 8.5rem !important;
    padding-bottom: 8.5rem !important;
}
.py-10 {
    padding-top: 9.5rem !important;
    padding-bottom: 9.5rem !important;
}

.mt-100 {
    margin-top: 0;
}

.mt-150 {
    margin-top: 75px;
}
.mt-200 {
    margin-top: 100px;
}
.mt-250 {
    margin-top: 125px;
}
.mt-300 {
    margin-top: 150px;
}

@media (min-width: 576px) {
    .mt-sm-6 {
        margin-top: 5rem !important;
    }
    .mt-sm-7 {
        margin-top: 7rem !important;
    }
    .pt-sm-6 {
        padding-top: 5rem !important;
    }
    .pt-sm-7 {
        padding-top: 7rem !important;
    }
    .pb-sm-6 {
        padding-bottom: 5rem !important;
    }
    .pb-sm-7 {
        padding-bottom: 7rem !important;
    }
    .px-sm-6 {
        padding-left: 5rem !important;
        padding-right: 5rem !important;
    }
    .py-sm-6 {
        padding-top: 5rem !important;
        padding-bottom: 5rem !important;
    }
    .py-sm-7 {
        padding-top: 7rem !important;
        padding-bottom: 7rem !important;
    }
    .mt-150 {
        margin-top: 150px;
    }
    .mt-200 {
        margin-top: 200px;
    }
    .mt-250 {
        margin-top: 250px;
    }
    .mt-300 {
        margin-top: 300px;
    }
}

@media (min-width: 768px) {
    .mt-md-6 {
        margin-top: 5rem !important;
    }
    .mt-md-7 {
        margin-top: 7rem !important;
    }
    .pt-md-6 {
        padding-top: 5rem !important;
    }
    .pt-md-7 {
        padding-top: 7rem !important;
    }
    .pb-md-6 {
        padding-bottom: 5rem !important;
    }
    .pb-md-7 {
        padding-bottom: 7rem !important;
    }
    .px-md-6 {
        padding-left: 5rem !important;
        padding-right: 5rem !important;
    }
    .py-md-6 {
        padding-top: 5rem !important;
        padding-bottom: 5rem !important;
    }
    .py-md-7 {
        padding-top: 7rem !important;
        padding-bottom: 7rem !important;
    }
}

@media (min-width: 992px) {
        .ms-lg-n4 {
            margin-left: -3rem !important;
        }
        .ms-lg-n5 {
            margin-left: -4rem !important;
        }
        .ms-lg-n6 {
            margin-left: -5rem !important;
        }
        .ms-lg-n8 {
            margin-left: -8rem !important;
        }
        .ms-lg-n10 {
            margin-left: -15rem !important;
        }
        .mt-lg-6 {
            margin-top: 5rem !important;
        }
        .mt-lg-7 {
            margin-top: 7rem !important;
        }
        .pt-lg-6 {
            padding-top: 5rem !important;
        }
        .pt-lg-7 {
            padding-top: 7rem !important;
        }
        .pt-lg-8 {
            padding-top: 9rem !important;
        }
        .pt-lg-9 {
            padding-top: 11rem !important;
        }
        .pb-lg-6 {
            padding-bottom: 5rem !important;
        }
        .pb-lg-7 {
            padding-bottom: 7rem !important;
        }
        .pb-lg-8 {
            padding-bottom: 9rem !important;
        }
        .pb-lg-9 {
            padding-bottom: 15.5rem !important;
        }

        .px-lg-6 {
            padding-left: 5rem !important;
            padding-right: 5rem !important;
        }
        .py-lg-6 {
            padding-top: 5rem !important;
            padding-bottom: 5rem !important;
        }
        .py-lg-7 {
            padding-top: 7rem !important;
            padding-bottom: 7rem !important;
        }
        .py-lg-8 {
            padding-top: 7.825rem !important;
            padding-bottom: 7.825rem !important;
        }
        .py-lg-9 {
            padding-top: 8.5rem !important;
            padding-bottom: 8.5rem !important;
        }
        .py-lg-10 {
            padding-top: 9.5rem !important;
            padding-bottom: 9.5rem !important;
        }
        
        .mx-lg-6 {
            margin-left: 5rem !important;
            margin-right: 5rem !important;
        }
        .my-lg-6 {
            margin-top: 5rem !important;
            margin-bottom: 5rem !important;
        }
        .my-lg-7 {
            margin-top: 7rem !important;
            margin-bottom: 7rem !important;
        }
        .mt-100 {
            margin-top: 100px;
        }
    }

@media (min-width: 1200px) {
        .mt-xl-6 {
            margin-top: 5rem !important;
        }
        .mt-xl-7 {
            margin-top: 7rem !important;
        }
        .pl-xl-5{ 
            padding-left: 3rem !important;
  }
        .pt-xl-6 {
            padding-top: 5rem !important;
        }
        .pt-xl-7 {
            padding-top: 7rem !important;
        }
        .pt-xl-8 {
            padding-top: 9rem !important;
        }
        .pt-xl-9 {
            padding-top: 11rem !important;
        }
        .pb-xl-6 {
            padding-bottom: 5rem !important;
        }
        .pb-xl-7 {
            padding-bottom: 7rem !important;
        }
        .pb-xl-8 {
            padding-bottom: 9rem !important;
        }
        .pb-xl-9 {
            padding-bottom: 15.5rem !important;
        }
        .px-xl-6 {
            padding-left: 5rem !important;
            padding-right: 5rem !important;
        }
        .px-xl-7 {
            padding-left: 7rem !important;
            padding-right: 7rem !important;
        }
        .py-xl-6 {
            padding-top: 5rem !important;
            padding-bottom: 5rem !important;
        }
        .py-xl-7 {
            padding-top: 7rem !important;
            padding-bottom: 7rem !important;
        }
        .py-xl-8 {
            padding-top: 9rem !important;
            padding-bottom: 9rem !important;
        }
        .py-xl-9 {
            padding-top: 11rem !important;
            padding-bottom: 11rem !important;
        }
        .py-xl-10 {
            padding-top: 13rem !important;
            padding-bottom: 13rem !important;
        }

    }

@media (min-width: 1400px) {
    .pt-xxl-6 {
        padding-top: 5rem !important;
    }
    .pt-xxl-7 {
        padding-top: 7rem !important;
    }
    .pt-xxl-8 {
        padding-top: 9rem !important;
    }
    .pt-xxl-9 {
        padding-top: 11rem !important;
    }
    .pb-xxl-6 {
        padding-bottom: 5rem !important;
    }
    .pb-xxl-7 {
        padding-bottom: 7rem !important;
    }
    .pb-xxl-8 {
        padding-bottom: 9rem !important;
    }
    .pb-xxl-9 {
        padding-bottom: 11rem !important;
    }
}


/**********************/
