.banner {
  position: relative
}

.banner .bg {
  width: 100%;
  display: block;
  height: 56.25vw;
  object-fit: cover
}

.banner .text {
  position: absolute;
  left: 5.20833vw;
  bottom: 6.25vw
}

.banner .text .t {
  color: #FFF;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: .13333vw;
  text-transform: capitalize
}

.banner .text .t>div:not(:last-child) {
  margin-bottom: 1.14583vw
}

.banner .text .t p:not(:last-child) {
  margin-bottom: 1.14583vw
}

.banner .text .breadmenu {
  margin-top: 2.08333vw;
  border-radius: 8.33333vw;
  background: rgba(41, 41, 41, 0.2);
  padding: .41667vw .83333vw;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: .41667vw
}

.banner .text .breadmenu a {
  color: #FFF;
  font-weight: 700
}

.banner .text .breadmenu a:hover {
  text-decoration: underline
}

.banner .text .breadmenu p {
  color: #FFF;
  opacity: .4;
  font-weight: 700
}

.banner .text .breadmenu img {
  display: block;
  width: .3125vw
}

body {
  background: #FAFBFB
}

.sec1 {
  padding: 5.72917vw 0vw 1.04167vw 8.33333vw;
  display: flex;
  justify-content: space-between;
  gap: 3.90625vw;
  position: relative;
  z-index: 5
}

.sec1 .m {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  z-index: -1;
  mix-blend-mode: darken
}

.sec1 .lbox {
  width: 11.71875vw;
  position: relative;
  z-index: 10
}

.sec1 .lbox .types {
  border-top: .05208vw solid #CDD2D8;
  position: sticky;
  left: 0;
  top: 6.25vw;
  z-index: 10
}

.sec1 .lbox .types .item {
  border-bottom: .05208vw solid #CDD2D8
}

.sec1 .lbox .types .item .d1 {
  color: #404040;
  font-weight: 600;
  line-height: 1;
  cursor: pointer;
  border-radius: 0 0 .52083vw .52083vw;
  padding: .9375vw .52083vw;
  position: relative;
  overflow: hidden;
  display: block;
  z-index: 5
}

.sec1 .lbox .types .item .d1::before {
  content: '';
  display: block;
  width: 100%;
  height: 0;
  position: absolute;
  background: linear-gradient(90deg, #DCEAFF 0%, #F2F2F2 100%);
  transition: all 600ms;
  left: 0;
  top: 0;
  z-index: -1
}

.sec1 .lbox .types .item .sub {
  padding: .625vw 0;
  display: none;
  border-bottom: .05208vw solid #CDD2D8
}

.sec1 .lbox .types .item .sub p {
  color: #7A808C;
  line-height: 1.3;
  font-weight: 500;
  padding-left: .9375vw;
  transition: all 600ms;
  cursor: pointer
}

.sec1 .lbox .types .item .sub p:not(:last-child) {
  margin-bottom: 1.04167vw
}

.sec1 .lbox .types .item .sub p:hover,
.sec1 .lbox .types .item .sub p.on {
  color: #285574;
  font-weight: 700
}

.sec1 .lbox .types .item.active {
  border-color: transparent
}

.sec1 .lbox .types .item.active .d1::before {
  height: 100%
}

.sec1 .rbox {
  width: 100%;
  flex: 1
}

.sec1 .rbox .title {
  color: #285574;
  font-weight: 700
}

.sec1 .rbox .date {
  color: rgba(0, 0, 0, 0.6);
  font-weight: 300;
  line-height: 1.8;
  margin: 1.09375vw 0 4.58333vw
}

.sec1 .rbox .flex {
  display: flex;
  gap: 3.07292vw;
  align-items: center;
  padding: 0 8.33333vw 0 0
}

.sec1 .rbox .flex .img {
  width: 32.76042vw;
  height: 20.15625vw;
  border-radius: 1.04167vw;
  overflow: hidden
}

.sec1 .rbox .flex .img img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: 1s
}

.sec1 .rbox .flex .img:hover img {
  transform: scale(1.1)
}

.sec1 .rbox .flex .p {
  /* width: 28.64583vw; */
  width: 100%;
  color: #000;
  font-weight: 300;
  line-height: 180%
}

.sec1 .rbox .p1 {
  width: 64.58333vw;
  color: #000;
  font-weight: 300;
  line-height: 150%;
  margin: 2.91667vw 0 2.8125vw
}

.sec1 .rbox .content {
  margin: 2.8125vw 0 4.6875vw;
  width: 64.58333vw
}

.sec1 .rbox .content .p {
  color: #000;
  font-weight: 300;
  line-height: 180%
}

.sec1 .rbox .content .img {
  margin: 2.08333vw 0;
  width: 64.16667vw;
  height: 36.09375vw;
  border-radius: 1.04167vw;
  overflow: hidden
}

.sec1 .rbox .content .img img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: 1s
}

.sec1 .rbox .content .img:hover img {
  transform: scale(1.1)
}

.part7 {
  margin-bottom: 4.6875vw;
  width: calc(100% + 23.958333vw);
  position: relative;
  left: -23.958333vw;
  background: linear-gradient(180deg, #425B3E 0%, #285574 119.31%);
  padding: 8.33333vw 0 6.97917vw;
  z-index: 1
}

.part7 .part_title {
  color: #FBFDFF;
  font-weight: 600;
  line-height: 180%;
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 2.08333vw
}

.part7 .btn_contact {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 11.04167vw;
  height: 2.08333vw;
  border-radius: 1.04167vw;
  background: #FFFFFF;
  border: .05208vw solid #bdc5cf;
  margin: 0 auto;
  cursor: pointer
}

.common_part1 {
  padding: .625vw 0 0;
  position: relative
}

.common_part1 .swiper {
  width: 76.04167vw;
  overflow: hidden
}

.common_part1 .swiper .swiper-pagination {
  height: .10417vw;
  background: #CDD2D8
}

.common_part1 .swiper .swiper-pagination .swiper-pagination-progressbar-fill {
  background: #425B3E
}

.common_part1 .swiper .swiper-slide {
  width: fit-content
}

.common_part1 .swiper .swiper-slide .img {
  border-radius: .83333vw;
  overflow: hidden
}

.common_part1 .swiper .swiper-slide .img img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: 1s
}

.common_part1 .swiper .swiper-slide .img:hover img {
  transform: scale(1.1)
}

.common_part1 .swiper .swiper-slide .img1 {
  width: 21.35417vw;
  height: 28.125vw
}

.common_part1 .swiper .swiper-slide .img2 {
  width: 26.61458vw;
  height: 17.03125vw
}

.common_part1 .swiper .swiper-slide .img3 {
  width: 20.36458vw;
  height: 28.125vw
}

.common_part2 {
  width: 64.58333vw
}

.common_part2 .part_top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 2.96875vw
}

.common_part2 .part_top .part_top_title {
  color: #222;
  font-weight: 700
}

.common_part2 .part_top .btns {
  display: flex;
  gap: 1.04167vw
}

.common_part2 .part_top .btns .jt {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.08333vw;
  height: 2.08333vw;
  border-radius: 50%;
  border: .05208vw dashed #425B3E;
  transition: 0.6s;
  cursor: pointer
}

.common_part2 .part_top .btns .jt img {
  display: block;
  width: 1.04167vw;
  transition: 0.6s
}

.common_part2 .part_top .btns .jt:hover {
  background: rgba(66, 91, 62, 0.5)
}

.common_part2 .part_top .btns .jt:hover img {
  filter: brightness(0) invert(1)
}

.common_part2 .part_top .btns .jt.prev img {
  transform: rotate(180deg)
}

.common_part2 .swiper {
  width: 100%;
  overflow: hidden
}

.common_part2 .swiper .swiper-slide .img {
  width: 100%;
  height: 12.23958vw;
  border-radius: 1.04167vw;
  overflow: hidden
}

.common_part2 .swiper .swiper-slide .img img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: 1s
}

.common_part2 .swiper .swiper-slide .slide_top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: .625vw 0
}

.common_part2 .swiper .swiper-slide .slide_top .h5 {
  color: #292929;
  font-weight: 600;
  line-height: 1.28;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  width: 60%
}

.common_part2 .swiper .swiper-slide .slide_top .p {
  color: #292929;
  font-weight: 400
}

.common_part2 .swiper .swiper-slide>.p {
  color: #878787;
  font-weight: 400;
  line-height: 1.6;
  padding: .41667vw 0 0;
  border-top: .05208vw solid #a9a9a9
}

.common_part2 .swiper .swiper-slide:hover .img img {
  transform: scale(1.1)
}

.cursor {
  pointer-events: none
}

.cursor .cursor_box {
  width: 3.33333vw;
  transition: 0.6s;
  opacity: 0
}

.cursor .cursor_box img {
  display: block;
  width: 100%
}

.cursor.on .cursor_box {
  opacity: 1
}

@media screen and (max-width: 768px) {
  .banner {
    margin-top: 60px
  }

  .banner .bg {
    height: 300px
  }

  .banner .text {
    left: 5%;
    right: 5%;
    bottom: 20px;
    top: auto;
    transform: none
  }

  .banner .text .t {
    font-size: 24px;
    line-height: 1.5;
    letter-spacing: 2px
  }

  .banner .text .t p:not(:last-child) {
    margin-bottom: 15px
  }

  .banner .text .breadmenu {
    width: 100%;
    margin-top: 20px;
    padding: 6px 12px;
    gap: 6px;
    justify-content: flex-start;
    flex-wrap: wrap
  }

  .banner .text .breadmenu img {
    width: 8px
  }

  .banner .text .breadmenu a,
  .banner .text .breadmenu p {
    white-space: nowrap
  }

  .banner .text .breadmenu a:nth-last-child(1) {
    white-space: unset
  }

  .sec1 {
    padding: 20px 5%;
    flex-direction: column;
    overflow: hidden;
    gap: 30px
  }

  .sec1 .m {
    display: none
  }

  .sec1 .lbox {
    width: 100%
  }

  .sec1 .lbox .types {
    position: static
  }

  .sec1 .lbox .types .item .d1 {
    padding: 12px 15px;
    border-radius: 0 0 10px 10px;
    font-size: 16px
  }

  .sec1 .lbox .types .item .sub {
    padding: 12px 0
  }

  .sec1 .lbox .types .item .sub p {
    padding-left: 20px;
    font-size: 14px
  }

  .sec1 .lbox .types .item .sub p:not(:last-child) {
    margin-bottom: 15px
  }

  .sec1 .rbox {
    width: 100%;
    overflow: unset
  }

  .sec1 .rbox .date {
    margin: 15px 0 25px
  }

  .sec1 .rbox .flex {
    display: block;
    padding: 0
  }

  .sec1 .rbox .flex .img {
    width: 100%;
    height: 55vw;
    border-radius: 12px
  }

  .sec1 .rbox .flex .p {
    margin: 15px 0 0;
    font-size: 15px;
    width: 100%
  }

  .sec1 .rbox .p1 {
    font-size: 15px;
    width: 100%;
    margin: 20px 0
  }

  .sec1 .rbox .content {
    width: 100%;
    margin-bottom: 30px
  }

  .sec1 .rbox .content .p {
    font-size: 15px
  }

  .sec1 .rbox .content .img {
    width: 100%;
    border-radius: 12px;
    margin: 20px 0;
    height: 47vw
  }

  .part7 {
    width: 100vw;
    left: -5vw;
    padding: 80px 0;
    margin-bottom: 40px
  }

  .part7 .part_title {
    font-size: 18px;
    margin-bottom: 30px
  }

  .part7 .btn_contact {
    width: 180px;
    height: 32px;
    font-size: 15px;
    border-radius: 18px
  }

  .common_part1 {
    padding: 13px 0 0
  }

  .common_part1 .swiper {
    width: 100%
  }

  .common_part1 .swiper .swiper-pagination {
    height: 2px
  }

  .common_part1 .swiper .swiper-slide .img {
    border-radius: 10px;
    width: 100% !important;
    height: unset
  }

  .common_part2 {
    width: 100%
  }

  .common_part2 .part_top {
    margin-bottom: 20px
  }

  .common_part2 .part_top .part_top_title {
    font-size: 20px
  }

  .common_part2 .part_top .btns {
    gap: 8px
  }

  .common_part2 .part_top .btns .jt {
    width: 30px;
    height: 30px
  }

  .common_part2 .part_top .btns .jt img {
    width: 14px
  }

  .common_part2 .swiper .swiper-slide .img {
    height: 46vw;
    border-radius: 12px
  }

  .common_part2 .swiper .swiper-slide .slide_top {
    margin: 8px 0
  }

  .common_part2 .swiper .swiper-slide .slide_top .h5 {
    font-size: 16px
  }

  .common_part2 .swiper .swiper-slide .slide_top .p {
    font-size: 14px
  }

  .common_part2 .swiper .swiper-slide>.p {
    font-size: 14px;
    padding: 6px 0 0
  }
}