.border-radius{border-radius: 15px;}
.btn-default {border: solid 1px #979797;background-color: #fff;color: var(--color-black);padding: 10px 20px;border-radius: 8px;font-weight: 500;font-size: 16px;transition: all 0.5s ease;}
.btn-white-default{color: var(--color-main);border: solid 1px var(--color-main);padding: 10px 20px;border-radius: 8px;background: #fff;font-size: 18px;font-weight: 500; transition: all 0.5s ease;}
.btn-white-default:hover{background-color: var(--background-static); color:#fff;}
.btn-default:hover{color: #fff;background: var(--color-main);border-color: var(--color-main);}
.viewsAll{background: var(--color-main);font-size: 15px;color: #fff;padding: 8px 15px;border-radius: 5px;transition: all 0.5s ease;}
.viewsAll:hover{background: var(--color-red);}
.itemProject{margin-bottom: 20px;position: relative;overflow: hidden;}
.itemProject .images {
  margin: auto;
}

.itemProject .images img {
}
.itemProject:hover .info{bottom: 0px;}
.itemProject h3{font-size: 17px;color: var(--color-static);text-transform: uppercase;-webkit-line-clamp: 2;font-weight: 600;line-height: 1.5;margin-bottom: 10px;transition: all 0.5s ease;text-align: center;background: #ededed;padding: 15px 10px;margin: 0px;}
.itemProject h3:hover{color: var(--color-red);}
.itemProject .info .view{display: inline-block;color: #fff;border-radius: 8px;border: solid 1px #fff;padding: 5px 20px;margin-top: 10px; transition: all 0.5s;}
.itemProject .info .view:hover{background:#fff; color:#000;}
.effect{position: relative;overflow: hidden;display: block;}
.effect:before{position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255,255,255,.5);
    content: "";
    -webkit-transition: all .6s;
    transition: all .6s;
    z-index: 2;
    -webkit-transform: scale3d(1.9,1.4,1) rotate3d(0,0,1,-45deg) translate3d(0,-150%,0);
    transform: scale3d(1.9,1.4,1) rotate3d(0,0,1,-45deg) translate3d(0,-150%,0);}
.effect:hover:before{-webkit-transform: scale3d(1.9,1.4,1) rotate3d(0,0,1,-45deg) translate3d(0,150%,0);transform: scale3d(1.9,1.4,1) rotate3d(0,0,1,-45deg) translate3d(0,150%,0);}
.scrolly{overflow-y: scroll; height: 310px;}
.scrolly::-webkit-scrollbar {
  width: 5px;
  border-radius: 5px;
}

/* Track */
.scrolly::-webkit-scrollbar-track {
  background: #f1f1f1;
}

/* Handle */
.scrolly::-webkit-scrollbar-thumb {
  background: #888;
}

/* Handle on hover */
.scrolly::-webkit-scrollbar-thumb:hover {
  background: #555;
}
.searchService{border-left: solid 1px #ddd; padding-left: 15px; }
.searchService .item_container_search{border: 1px solid #eee;}
.searchService .item_container_search h4{padding: 10px 0 10px 15px;background: #26519B;border-radius: 4px 4px 0 0;font-size: 16px;font-weight: 600;color: #fff;margin-top: 0px;margin-bottom: 0px;}
.searchService .item_container_search .seaclass{padding: 10px;display: block;padding-bottom: 0px;}
.searchService .item_container_search .seaclass input{width: 100%;-webkit-box-sizing: border-box;box-sizing: border-box;border: 1px solid #ddd;padding: 0 0.75em;height: 2.507em;font-size: .97em;border-radius: 0;max-width: 100%;vertical-align: middle;background-color: #fff;color: #333333b8;}
.searchService .content_search{padding: 10px;}
.searchService .content_search li{
    margin-bottom: 5px;
    cursor: pointer;
}
.bannerProject{min-height: 320px;color: #fff;text-transform: uppercase;text-shadow: 1px 1px 1px #1a2f34;font-size: 2rem;font-weight: 600;margin: 2rem 0px;}
.border-top-2px{border-top: solid 2px #000; padding-top: 20px;}
.serviceDetail .name{font-weight: bold;text-transform: uppercase;margin-bottom: 20px;font-size: 2rem;}
.serviceDetail .viewsMaps{background: #26519B;color: #fff;box-shadow: 0 1px 1px 0 rgb(0 0 0 / 3%);height: 46px;width: 300px;cursor: pointer;font-size: 15px;text-transform: uppercase;padding: 0px;font-weight: 600;border-radius: 4px;float: left;margin-right: 10px;}
.serviceDetail .viewsMaps .ic{background: #1c3f5b;display: inline-block;line-height: 46px;width: 46px;text-align: center;font-size: 20px;border-bottom-left-radius: 4px;border-top-left-radius: 4px;}
.serviceDetail .viewsMaps .text{display: inline-block;width: 100%;text-align: center;}
.serviceDetail .viewsMaps:hover{color:#ff0;}
.banner{position: relative;}
.banner .title_site{position:absolute;bottom: 30%;left: 0px;width: 100%;color: var(--color-main);text-transform: uppercase;font-weight: 700;font-size: 26px;}
.banner .title_site h1, .banner .title_site span{font-weight: 900;font-size: 4rem;display: block;}
.projectList ul{background: #255b2d;border-left: solid 7px #fec010 !important;border-right: solid 7px #fec010 !important;border-radius: 0px 0px 15px 15px;}
.projectList ul li a{display: block;font-size: 16px;text-transform: uppercase;font-weight: bold;padding: 10px 30px;transition: all 0.5s ease;color: #fff;}
.projectList ul li.active a, .projectList ul li:hover a{color:#255a2c; background:#fff;}
.latestNews .title{color:#255b2d;font-weight: 900;text-transform: uppercase;font-size: 38px;margin-bottom: -30px;}
.latestNews{position: relative;padding: 40px 0px;}
.latestNews:before{content:'';background: #eee;position: absolute;width: 100%;height: 80%;top: 20%;left: 0px;z-index: -1;}
.latestNews .item .images{border-radius: 15px;transition: all 0.5s ease;overflow: hidden;border: solid 2px transparent;}
.latestNews .item:hover .images{border-color: #255b2d;}
.latestNews .item h3{color:#000; font-weight: bold;}
.latestNews .item h3:hover{color: #255b2d;}
.itemProjectContent{margin-bottom: 40px;margin-right: 20px;}
.itemProjectContent .images{box-shadow: 7px 7px 0px #255a2c;border-radius: 40px 0px;overflow: hidden;}
.itemProjectContent .images a{display: block;border-right: 3px solid var(--color-main);border-bottom: 3px solid var(--color-main);border-radius: 40px 0px;}
.itemProjectContent h3{font-weight:900; color:#255a2c; text-transform: uppercase; font-size: 20px;}
.itemProjectContent p{margin-bottom: 5px;}
.item_project_nb{position: relative;overflow: hidden;border-radius: 50px 0px;}
.item_project_nb .images img{width: 100%;}
.item_project_nb .info{position:absolute;bottom: 0px;color: #fff;background: linear-gradient(to bottom, transparent 0%, #303030 100%) !important;opacity: 0;transition: all 0.5s ease;width: 100%;}
.swiper-slide-active .item_project_nb .info{opacity: 1;}
.swiper-slide{opacity: 0.5}
.swiper-slide-active{opacity: 1;}
.item_project_nb .info p{margin: 0px;}
.item_project_nb .info a{color:#fff;}
.item_project_nb .info a span{display: inline-block;height: 70px;width: 1px;background:#fff;margin: 0px 30px;}
.item_project_nb .info .name{background:#255a2c;padding: 15px;border-radius: 20px 0px 0px;border-left: solid 3px #fec010;height: 100%;}
.aboutProject{position: relative;z-index:10}
.aboutProject .item:last-child{border: none;}
.aboutProject .item .name{font-size: 20px;text-transform: uppercase;color: var(--color-static);font-weight: bold;margin-bottom: 10px;line-height: 1.3;}
.navProject{}
.navProject li{cursor: pointer;background: url(../images/ic_project_detail.png) no-repeat left center;padding: 5px 0px;padding-left: 30px;border-bottom: solid 1px #ddd;transition: all 0.5s ease;}
.navProject li:hover, .navProject li.active{font-weight: bold;text-transform: uppercase;color: #215a2c;}
.title-project{font-size: 30px; color:#215a2c; font-weight: 500; text-transform: uppercase;}
.item_gallery a{position:relative; display: block;}
.item_gallery a:before{content:'';background: rgba(0,0,0,0.3) url(../images/ic_zoom.png) no-repeat center;position: absolute;top: 0px;left: 0px;width: 100%;height: 100%;transition: all 0.5s ease;opacity: 0;}
.item_gallery:hover a:before{opacity: 1;}
.aboutPage{position:relative;}
.aboutPage .title_about{font-size: 26px;position: relative;margin-bottom: 30px;text-transform: uppercase;font-weight: 600;color: var(--color-main);text-shadow: 1px 1px 2px #000;}
.aboutPage .title_about span{display: block;font-weight: 900;font-size: 3.5rem;line-height: 50px;color: #255b2d;}
.aboutPage .navAbout{background: var(--color-main);border-bottom: solid 1px #ddd;position: sticky;top: 82px;z-index: 1;}
.aboutPage .navAbout ul{margin: auto !important;display: flex;justify-content: space-around;}
.aboutPage .navAbout li{cursor: pointer;color: #265c2e;text-transform: uppercase;font-weight: 600;font-size: 15px;padding: 9px 20px;transition: all 0.5s ease;}
.aboutPage .navAbout li:hover, .aboutPage .navAbout li.active{background: #fff;box-shadow: 0px 0px 7px #918989 inset;}
.aboutPage #aboutUs{
    padding: 50px 0px;
    background: url(../images/bg_aboutus_top.png) no-repeat top right, url(../images/bg_aboutus_bottom.png) no-repeat bottom left;
}
.aboutPage #aboutUs .image{border-radius: 56px;overflow: hidden;display: inline-block;}
.video {
  position: relative;
  padding-bottom: 0px;
  overflow: hidden;
  width: 100%;
}

.video video {
  width: 100%;
  height: 100%;
}

.video .play, .video .mute{
  position: absolute;
  cursor: pointer;
  bottom: 10px;
  right: 10px;
  width: 32px;
  height: 32px;
  line-height: 22px;
  padding: 5px;
  border-radius: 50%;
  background-color: rgba(0, 0, 0, 0.35);
}
.video .play svg,
.video .mute svg{
  width: 22px;
  height: 22px;
  color: #fff;
}
.video .mute{
  bottom: 10px;
  right: 50px;
}
#history{background: #255b2d url(../images/bg_history.png) no-repeat center;background-size: cover;color:#fff;padding: 50px 0px;}
.item_history .name{font-family: riftbold;font-size: 3rem;position: relative;}
.item_history .name:before{content:'';width: 60px;height: 1px;background: #939393;position:absolute;left: -80px;top: 50%;}
.item_year{font-size: 30px;text-align: center;position: relative;padding-bottom: 10px;}
.item_year.slick-current:before{content: '';width: 0;height: 0;position: absolute;bottom: 0px;left: calc(50% - 15px);border-left: 15px solid transparent;border-right: 15px solid transparent;border-bottom: 15px solid #fff;}
#history .slider-nav{margin-top: 50px;border-bottom: solid 4px #252525;}
#field{background:#f5f3f3;}
#business{background: url(../images/bg_en_cl.png) no-repeat bottom center;padding: 50px 0px;padding-bottom: 190px;}
.core_value{position: relative;margin-top: -12%;}
.core_value .title{color:#fff;text-transform: uppercase;font-weight: 600;font-size: 24px;text-align: center;margin-bottom: 3rem;}
.core_value .item{text-align: center; margin-bottom: 30px;}
.core_value .name{color:#fff;font-weight: bold;font-size: 20px;margin-top: 20px;margin-bottom: 10px;}
.item_mission{margin-top: 10px;position: relative;padding: 0px 10% 8% 6%;color: #fff;}
.item_mission:before{content:'';background: var(--color-main);position: absolute;top: 0px;left: 0px;width: 100%;height: 100%;border-radius: 200px 0px;}
.item_mission .name{position:relative;text-transform: uppercase;font-size: 24px;margin-bottom: 20px;color: #255b2d;font-weight: 600;}
.item_mission .name span{color: #fff;display: block;font-weight: 900;font-size: 40px;line-height: 50px;}
#culture{background: #fff url(../images/bg_history.png);}
#partner{background: #255b2d url(../images/bg_wavy.png) no-repeat center; background-size: cover;}
.wrap-partner{background: #F5F5F5;}
.wrap-why {position: relative;z-index: 1;}
.wrap-why .title-main{position: relative;text-align: center;color: var(--color-main);}
.wrap-why .why-item {margin-bottom: 40px;position: relative;}
.wrap-why .why-item:hover .why-item_img{/* -webkit-transform: rotateY(180deg); */-moz-transform: rotateY(180deg);/* transform: rotateY(180deg); */}
.wrap-why .why-item .why-item_img {/* margin: 15px 0px; */display: block;transition: 1s;overflow: hidden;width: 64px;position: relative;}
.wrap-why .why-item .why-item_img img{max-height: 65px;transition: all 0.5s ease;}
.wrap-why .why-item .why-item_text{width: calc(100% - 64px);}
.wrap-why .why-item .why-item_text h3 {font-size: 20px;font-weight: bold;margin-bottom: 10px;}
.wrap-why .why-item .why-item_text p {margin: 0px;font-size: 15px;}
.productPage{background:#464946;}
.feedback{
    margin: 0px;
    margin-bottom: 30px;
    min-height: 165px;
    padding-top: 15px;
    font-weight: 500;
}
.feedback p{
    color: #464646;
    text-align: left;
    -webkit-line-clamp: 5;
}
.feedback .images{position: relative;padding-right: 30px;}
.feedback:nth-child(2n) .images{padding: 0px; padding-left: 30px;}
.feedback .images .icon{position: absolute;top: -20px;right: 0px;}
.feedback:nth-child(2n) .images .icon{left: 0px;}
.feedback .images >img{border-radius: 10px;}
.feedback .info{
    text-align: left;
}
.feedback .name{
    font-weight: bold;
    text-transform: uppercase;
    font-size: 17px;
}
.feedback p{font-weight: 500;font-size: 16px;}
.wrap-project{}
.wrap-project .title, .wrap-why .title{font-size: 3rem;text-transform: uppercase;color: var(--color-main);margin-bottom: 2rem;}
.wrap-project .title span, .wrap-why .title span{position: relative; display: inline-block;}
.wrap-project .title span:before, .wrap-why .title span:before{content:'';background: #a1a1a1;position: absolute;width: 200px;height: 1px;bottom: 12px;left: 102%;}
.wrap-project .title span b, .wrap-why .title span b{font-weight: 900;}
.wrap-giaiphap{position: relative;}
.control-gp, .control-product{position:absolute;top: 0px;right: 0px;/* text-align: center; */}
.control-gp button, .control-product button{border-radius: 50%;border: solid 2px #575656;background: none;width: 40px;height: 40px;text-align: center;margin-right: 15px;padding: 0px;}
.control-gp button svg, .control-product button svg{width: 30px;height: 30px;}
.item_news{position: relative;transition: all 300ms;border-radius: 3px;overflow: hidden;margin-bottom: 20px;}
.item_news .images{position: relative;}
.item_news .date{font-size: 14px;color: var(--color-main);margin-bottom: 5px;}
.item_news .date span{display: block;font-weight: bold;font-size: 25px;}
.item_news img{border-radius: 5px;}
.item_news h3{color: #000;font-weight: bold;font-size: 16px;transition: all 0.5s ease;}
.item_news .views{color: var(--color-main);font-weight: 500;transition: all 0.5s ease;}
.item_news .views:hover{color:var(--color-red); padding-left: 15px;}
.item_news.news_nb h3{font-weight: bold;font-size: 18px;}
.item_news h3:hover{color:var(--color-main);}
.item_news p{color: #3e3e3e;}

.mask {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  overflow: hidden;
  z-index: 2000;
  background: #fff;
}
.mask-inner {
  position: absolute;
  width: 20vw;
  /* height: calc(300/500*20vw); */
  top: calc(50% - (300/500*10vw));
  left: calc(50% - 10vw)
}

.mask-line,.mask-line-inner {
  position: absolute;
  width: 0;
  overflow: hidden;
  left: 0;
  transform-origin: left
}

.mask-line {
  bottom: -10px;
  height: 1px;
  background-color: rgba(255, 255, 255, 0.5);
}

.mask-line-inner {
  height: 100%;
  top: 0;
  background-color: #00656b;
}

.logo-mask,.logo-mask img {
  position: relative;
  width: 100%;
  height: auto;
  display: block;
  margin: 0
}

.logo-mask {
  overflow: hidden
}

.logo-mask img {
  transform: scale(0);
  opacity: 0
}

.mask.show .logo-mask img {
  transform: none;
  opacity: 1;
  transition: all .8s cubic-bezier(.81,.39,.19,.92)
}

.mask.show .mask-line {
  width: 100%;
  transition: width .5s ease-out .5s
}

.mask.show .mask-line-inner {
  width: 100%;
  transition: width .6s ease-out 1s
}

.mask.show .logo-mask.out img {
  transform: translateY(105%);
  transition: transform .5s cubic-bezier(.81,.39,.19,.92)
}

.mask.show .mask-line.out {
  transform: scale3d(0,1,1);
  transition: transform .8s ease-in;
  transform-origin: center
}
.mask::before {
  content: '';
  background: rgba(255,255,255,0.6);
  clip-path: circle(0 at 50% 50%);
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
}
.mask.show.out::before {
  animation-name: clipPathImg;
  animation-duration: 2s;
  animation-fill-mode: forwards;
}
.groupSlider.show {
  animation-name: clipPathImg;
  animation-duration: 2s;
  /* animation-delay: .8s; */
  animation-fill-mode: forwards;
}
.clickDown{position: absolute;bottom: 15px;left: calc(50% - 24px);z-index: 10001;animation: moveLeftBounceRight 2s linear infinite;cursor: pointer;}
@keyframes moveLeftBounceRight{0%{-webkit-transform:translateY(5px);transform:translateY(5px);}50%{-webkit-transform:translateY(-5px);transform:translateY(-5px);}100%{-webkit-transform:translateY(5px);transform:translateY(5px);}}
@keyframes clipPathImg {
  0% {
      clip-path: circle(0 at 50% 50%)
  }

  100% {
      clip-path: circle(100% at 50% 50%)
  }
}
.viewsAll:hover{color:#fff; }
.list_id a{display: inline-block;padding: 6px 10px;color: #f00;font-weight: 600;}
.list_id a:hover{color:#000;}
.filter_box{position: relative;}
.filter_box .filter-title{background-color: #fff;border: 1px solid #e0e0e0;border-radius: 4px;cursor: pointer;padding: 8px 10px;}
.filter_box .filter-title:hover, .filter_box .filter-title.active, .filter_selected a:hover{border: 1px solid #2a83e9; color:#2a83e9;     background: #e3f1fe;}
.filter_selected a{border-radius: 8px;background-color: rgba(242, 244, 247, 1);border: 1px solid #ddd;padding: 6px 10px;margin-right: 5px;color: var(--color-static);}
.filter_group{max-height: 65vh;overflow-y: auto;width: 100%;max-width: 900px;background-color: #fff;box-shadow: 0 2px 20px rgba(0, 0, 0, .5);border-radius: 4px;left: 0;position: absolute;top: 45px;white-space: normal;z-index: 3;display: none;}
.filter_group.active{display: block;}
.list-filter-active>span{font-weight: bold;}
.list-filter-active a{padding: 18px 13px;margin-right: 7px;margin-bottom: 7px;color: #333;border: 1px solid #f2f4f7;display: inline-flex;align-items: center;justify-content: center;max-height: 30px;background: rgba(242, 244, 247, 1);border-radius: 8px;}
.list-filter-active a:hover, .filter_box .item:hover, .filter_box .item.active{border: 1px solid #288ad6; color: #288ad6;}
.filter_box .title{font-weight: bold; font-size: 18px; margin-bottom: 10px; color: var(--color-main);}
.filter_box .item{padding: 8px 9px;align-items: center;border: 1px solid #e0e0e0;border-radius: 4px;color: #333;display: flex;font-size: 14px;justify-content: center;line-height: 17px;margin-bottom: 10px;margin-right: 10px;cursor: pointer;}
.close-filter{background-color: #fff;border: 1px solid #e0e0e0;border-radius: 4px;cursor: pointer;padding: 6px 16px;color: #000;display: flex;align-items: center;justify-content: center;font-size: 12px;height: 35px;}
.btn-filter-close, .btn-filter-readmore{background:#fff;border-radius: 4px;display: inline-block;font-size: 14px;line-height: 16px;margin: 0 5px;padding: 10px 0;text-align: center;width: 170px;position: relative;}
.btn-filter-close {
    border: 1px solid #dd1c1a;
    color: #dd1c1a;
}
.btn-filter-readmore {
    background-color: #288ad6;
    color: #fff;
}
.btn-filter-readmore:hover {color: #ff0;}
.cartSuccess{color: #8d9293; font-size: 13px;}
.cartSuccess h2{color:#000;font-size: 3em;margin-bottom: 20px;}
.cartSuccess .desc{margin-bottom: 15px;}
.cartSuccess .code{color:#000;display: inline-block;border: solid 1px #ddd;border-radius: 8px;padding: 7px 30px;margin-bottom: 15px;}
.cartSuccess .code span{color:#f57224;font-weight: 600;}
.cartSuccess .contact{margin-bottom: 15px;}
.cartSuccess .contact a{color:#153c93;font-weight: bold;font-size: 15px;}
.cartSuccess a.href{background:#cfdbe2;display: block;text-align: center;color: #000;padding: 10px;border-radius: 8px;font-weight: 600; transition: all 0.5s ease;}
.cartSuccess a.href:hover{background:#f57224; color:#fff;}
@media (max-width: 600px){
	.cartSuccess h2{font-size: 2em;}
}