@font-face {
  font-family: 'DIN-Medium';
  src: url('../fonts/DIN-Medium.otf');
}
@font-face {
  font-family: 'Montserrat-SemiBold';
  src: url('../fonts/Montserrat-SemiBold.otf');
}
:root {
  --Noto-Sans-SC: 'Noto Sans SC', sans-serif;
  --Noto-Serif-SC: 'Noto Serif SC', sans-serif;
  --Song-Myung: 'Song Myung', sans-serif;
  --Roboto: 'Roboto', sans-serif;
  --Abel: 'Abel', sans-serif;
  --Barlow-Condensed: 'Barlow Condensed', sans-serif;
  --Din: 'DIN-Medium', sans-serif;
  --Montserrat-SemiBold: 'Montserrat-SemiBold', 'sans-serif';
  --Montserrat: 'Montserrat', 'sans-serif';
  --Poppins: 'Poppins', 'sans-serif';
  --Lato: 'Lato', 'sans-serif';
}
h1,
h2,
h3,
h4,
h5,
p {
  transition: all 0.5s;
}
html,
body {
  scroll-behavior: smooth;
  font-family: var(--Noto-Sans-SC);
}
body {
  overflow: visible;
}
body::-webkit-scrollbar-track {
  -webkit-box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.1);
  border-radius: 2px;
  background-color: #fff;
}
body::-webkit-scrollbar {
  width: 5px;
  background-color: #fff;
}
body::-webkit-scrollbar-thumb {
  border-radius: 2px;
  -webkit-box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.1);
  background-color: #666;
}
body:hover::-webkit-scrollbar-thumb {
  background-color: #ccc;
}
.out-header {
  height: 100px;
  width: 100%;
}
.mycontainer {
  max-width: 1600px;
  width: 85%;
  margin: 0 auto;
}
.blank {
  margin: 0 !important;
  height: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
  min-height: 0 !important;
  border: 0 !important;
}
header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
  z-index: 99;
  transition: all 0.5s;
  background-color: #fff;
}
header .mycontainer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 100px;
}
header .logo {
  width: 35%;
  text-align: center;
}
header .logo img {
  transition: all 0.5s;
}
header .lv1 {
  flex: 1;
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 100%;
}
header .lv1 > li {
  position: relative;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: clamp(16px, 1.1vw, 18px);
}
header .lv1 > li:first-child {
  margin-left: 0;
}
header .lv1 > li a {
  color: #333;
  padding: 0 .5em;
  line-height: 40px;
  text-align: center;
  transition: all 0.5s;
  text-transform: uppercase;
}
header .lv1 > li:hover a {
  color: #fff;
  background-color: #115F38;
  font-weight: 700;
}
header .lv1 > li:hover::after {
  width: 100%;
}
header .lv1 > li:hover .lv2 {
  opacity: 1;
  transform: translate(-50%, 0);
  visibility: visible;
}
header .lv1 > .active > a {
  color: #fff;
  background-color: #115F38;
  font-weight: 700;
}
header .lv1 .tel {
  line-height: 1.2;
}
header .lv1 .tel h5 {
  font-size: clamp(14px, 1vw, 16px);
  color: #115F38;
}
header .lv1 .tel h4 {
  font-size: clamp(16px, 1.1vw, 18px);
  color: #115F38;
  font-weight: 700;
}
header .lv2 {
  position: absolute;
  left: 50%;
  top: 100%;
  transform: translate(-50%, 50%);
  transition: all 0.5s;
  background-color: rgba(0, 0, 0, 0.5);
  padding: 10px;
  visibility: hidden;
  opacity: 0;
}
header .lv2 > li {
  position: relative;
  white-space: nowrap;
  text-align: center;
  padding: 2px 15px;
  min-width: 130px;
}
header .lv2 > li a {
  font-size: 16px;
  color: #fff;
}
header .lv2 > li:hover .lv3 {
  opacity: 1;
  visibility: visible;
  transform: translate(0, 0);
}
header .lv3 {
  position: absolute;
  top: 0%;
  left: 100%;
  transform: translate(50%, 0);
  transition: all 0.5s;
  background-color: rgba(0, 0, 0, 0.88);
  padding: 0 0 10px;
  visibility: hidden;
  opacity: 0;
}
header nav {
  flex: 1;
  margin-left: 1.875%;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
header .search form {
  position: relative;
}
header .search form input {
  width: 214px;
  height: 30px;
  border-radius: 15px;
  outline: none;
  font-size: 13px;
  color: #333;
  font-weight: 300;
  background-color: #fafafa;
  padding: 0 35px 0 14px;
  transition: all 0.5s;
}
header .search form input::placeholder {
  color: #5f5f5f;
  transition: all 0.5s;
}
header .search form button {
  position: absolute;
  outline: none;
  border: 0;
  background-color: transparent;
  right: 22px;
  top: 50%;
  transform: translate(0, -50%);
  cursor: pointer;
  transition: all 0.5s;
}
.pagination {
  margin-top: 2%;
  display: flex !important;
  text-align: center;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}
.pagination a {
  display: block;
  font-size: 14px;
  padding: 0 13px;
  line-height: 32px;
  background-color: #fff;
  margin: 5px;
  color: #115F38;
  transition: all 0.5s;
  font-family: var(--Din);
  border-radius: 4px;
}
.pagination span {
  display: block;
  font-size: 14px;
  padding: 0 13px;
  line-height: 32px;
  background-color: #115F38;
  margin: 5px;
  color: #fff;
  transition: all 0.5s;
  font-family: var(--Din);
  border-radius: 4px;
}
.pagination a:hover {
  color: #fff;
  background-color: #115F38;
  border-color: transparent;
}
.index-banner {
  position: relative;
}
.index-banner .swiper .swiper-slide {
  position: relative;
}
.index-banner .swiper .swiper-slide img {
  display: block;
  width: 100%;
  object-fit: cover;
  transition: all 3s;
  scale: 1.1;
}
.index-banner .swiper .swiper-slide-active h2 {
  animation: fadeInDown 2s;
}
.index-banner .swiper .swiper-slide-active h5 {
  animation: fadeInDown 2.5s;
}
.index-banner .swiper .swiper-slide-active a {
  animation: fadeInUp 2s;
}
.index-banner .swiper .swiper-slide-active img {
  scale: 1;
}
.index-banner .mycontainer {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.index-banner .banner-text {
  text-align: center;
}
.index-banner .banner-text h2 {
  font-size: 50px;
  color: #fff;
  font-weight: 700;
  line-height: 1.6;
}
.index-banner .banner-text h5 {
  font-size: 18px;
  color: #fff;
  font-weight: 500;
  line-height: 1.6;
}
.index-banner .banner-text a {
  display: inline-block;
  width: 150px;
  line-height: 50px;
  text-align: center;
  border: 1px solid #fff;
  border-radius: 25px;
  color: #fff;
  margin-top: 6.13497%;
  transition: all 0.5s;
}
.index-banner .banner-text a img {
  margin-right: 13px;
  transition: all 0.5s;
}
.index-banner .banner-text a:hover {
  box-shadow: inset -5px 5px 15px rgba(255, 255, 255, 0.3);
}
.index-banner .banner-text a:hover img {
  margin-right: 7px;
}
.index-banner .swiper-pagination {
  bottom: 5%;
}
.index-banner .swiper-pagination .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  opacity: 1;
  background-color: transparent;
  border: 1px solid #fff;
  transition: all 0.5s;
  margin: 0 6.5px;
}
.index-banner .swiper-pagination .swiper-pagination-bullet-active {
  background-color: #fff;
}
.index-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid rgba(153, 153, 153, 0.5);
  padding-bottom: 10px;
  margin-bottom: 3.125%;
}
.index-title h3 {
  font-size: clamp(20px, 2.0833333vw, 40px);
  color: #115F38;
  font-weight: 700;
  position: relative;
  line-height: 1.25;
  border-left: 4px solid #115F38;
  padding-left: 0.5em;
}
.index-title h3 span {
  font-size: clamp(12px, 1.2vw, 20px);
  color: #666;
  font-weight: 400;
  margin-left: 1em;
  text-transform: uppercase;
}
.index-title a {
  display: inline-block;
  font-size: clamp(12px, 1.2vw, 20px);
  color: #999;
  margin-right: 1.5em;
  transition: all 0.5s;
  font-weight: 400;
  border: 1px solid transparent;
  border-radius: 4px;
  line-height: 2;
  padding: 0 10px;
}
.index-title a:hover {
  color: #115F38;
  border-color: #115F38;
}
.search-banner {
  z-index: 10;
  background-color: #FAFAFA;
  padding: 1.0416667% 0;
}
.search-banner .mycontainer {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: center;
}
.search-banner .mycontainer .lt {
  width: 60%;
}
.search-banner .mycontainer .lt ul {
  display: flex;
}
.search-banner .mycontainer .lt ul li a {
  display: block;
  text-align: center;
  font-size: clamp(14px, 1.1vw, 18px);
  color: #666;
  width: 7.7777778em;
  padding: 0 ;
  line-height: 2;
  padding: 1.333333em 1em;
  margin-right: 10px;
  border-bottom: 0.2222222em solid transparent;
  transition: all 0.5s;
}
.search-banner .mycontainer .lt ul .active a {
  color: #115F38;
  border-bottom-color: #115F38;
  font-weight: 700;
}
.search-banner .mycontainer .rt {
  width: 340px;
}
.search-banner .mycontainer .rt form {
  font-size: clamp(14px, 1vw, 16px);
  display: flex;
}
.search-banner .mycontainer .rt input {
  background-color: #fff;
  border: 1px solid #999;
  border-right: 0;
  outline: none;
  height: 40px;
  padding: 0 1em;
}
.search-banner .mycontainer .rt button {
  width: 80px;
  height: 40px;
  outline: none;
  border: 0;
  background: #115F38;
  cursor: pointer;
}
.index-about {
  margin: 3.64583333% 0 7.29166667%;
}
.index-about .wrapper {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.index-about .wrapper .lt {
  width: 43.75%;
}
.index-about .wrapper .lt .pic {
  position: relative;
  overflow: hidden;
  border-radius: 12px;
  box-shadow: 0px 4px 6px -4px rgba(0, 0, 0, 0.1), 0px 10px 15px -3px rgba(0, 0, 0, 0.1);
}
.index-about .wrapper .lt .pic img {
  display: block;
  width: 100%;
  transition: all 0.5s;
}
.index-about .wrapper .lt .pic:hover img {
  scale: 1.05;
}
.index-about .wrapper .rt {
  width: 51.25%;
  font-size: clamp(14px, 1.25vw, 20px);
  color: #666;
  line-height: 2;
}
.index-about .wrapper .rt .title {
  font-size: clamp(20px, 2.0833333vw, 40px);
  font-weight: 700;
  color: #333;
  line-height: 1.6667;
  margin-bottom: 0.5em;
}
.index-about .wrapper .rt .brief {
  text-indent: 2em;
}
.index-about .wrapper .rt .brief p {
  margin-bottom: 1em;
}
.index-about .wrapper .rt a {
  display: inline-block;
  color: #115F38;
  font-weight: 500;
  border: 1px solid #115F38;
  border-radius: 0.5em;
  line-height: 2.9;
  padding: 0 1.425em;
  transition: all 0.5s;
  margin-top: 1em;
}
.index-about .wrapper .rt a:hover {
  transform: translateY(-3px);
  box-shadow: 0 3px 5px rgba(0, 0, 0, 0.2);
}
.index-prod {
  margin: 2.083333% 0 6.25%;
}
.index-prod .swiper {
  margin: 1.25% 2.5%;
}
.index-prod .swiper .swiper-slide {
  transition: all 0.5s;
}
.index-prod .swiper .swiper-slide:hover .pic img {
  scale: 1.05;
}
.index-prod .swiper .swiper-slide:hover .title {
  background-color: #115F38;
  color: #fff;
}
.index-prod .swiper .pic {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 0;
  padding-bottom: 83.333333%;
}
.index-prod .swiper .pic img {
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: all 0.5s;
}
.index-prod .swiper .title {
  position: absolute;
  width: 100%;
  bottom: 0;
  left: 0;
  font-size: clamp(14px, 1.25vw, 24px);
  color: #fff;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding: 0 0.5em;
  transition: all 0.5s;
  line-height: 2.5;
  background: -webkit-linear-gradient(top, transparent, rgba(0, 0, 0, 0.5));
}
.index-prod .swiper .title a {
  color: inherit;
}
.index-adv {
  position: relative;
  overflow: hidden;
  margin: 2% 0 2.08333%;
}
.index-adv .wrapper {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.index-adv .wrapper .lt {
  width: 50%;
}
.index-adv .wrapper .lt .pic {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 100%;
}
.index-adv .wrapper .lt .pic img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.index-adv .wrapper .rt {
  position: relative;
  z-index: 1;
  width: 50%;
  padding: 2.65625% 13.4375% 2% 0;
  background-color: #115F38;
}
.index-adv .wrapper .rt .block {
  font-size: clamp(20px, 2.0833333vw, 40px);
  display: flex;
  align-items: center;
  color: #fff;
  margin-bottom: 4.388715%;
  transform: translateX(-1.85em);
}
.index-adv .wrapper .rt .block:last-child {
  margin-bottom: 0;
}
.index-adv .wrapper .rt .block .icon {
  width: 3em;
  height: 3em;
  box-sizing: content-box;
  background-clip: content-box;
  display: flex;
  justify-content: center;
  align-items: center;
  border: 0.35em solid rgba(17, 95, 56, 0.6);
  background-color: #fff;
  border-radius: 50%;
  margin-right: 0.4em;
  box-shadow: 0 0.1em 0.25em 0 rgba(255, 255, 255, 0.2);
}
.index-adv .wrapper .rt .block .icon img {
  max-width: 50%;
  max-height: 50%;
}
.index-adv .wrapper .rt .block .text {
  flex: 1;
  text-align: center;
}
.index-adv .wrapper .rt .block .text h3 {
  color: #fff;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 0.25em;
}
.index-adv .wrapper .rt .block .text h5 {
  font-size: clamp(14px, 1.25vw, 24px);
  line-height: 1.25;
}
.index-contact {
  position: relative;
  overflow: hidden;
  background: url(../images/index-contact-bg.jpg) no-repeat;
  background-size: cover;
  padding: 3.125% 0 4.94791667%;
}
.index-contact .index-title {
  border-bottom: 1px solid rgba(255, 255, 255, 0.5);
}
.index-contact .index-title h3 {
  color: #fff;
  border-left-color: #fff;
}
.index-contact .index-title h3 span {
  color: #fff;
}
.index-contact .index-title a {
  color: #fff;
}
.index-contact .brief h2 {
  display: inline-block;
  font-size: clamp(20px, 2.6041667vw, 50px);
  font-weight: 700;
  color: #115F38;
  background-color: #fff;
  line-height: 2;
  padding: 0 0.4em;
  margin-bottom: 0.4em;
}
.index-contact .brief h3,
.index-contact .brief h4 {
  font-size: clamp(14px, 1.5625vw, 30px);
  line-height: 1.6667;
  color: #fff;
}
.index-contact .brief h4 {
  margin-bottom: 0.6667em;
}
.index-contact .brief h3 {
  font-weight: 700;
}
.index-contact .wrapper {
  margin-top: 3.4375%;
  display: flex;
  justify-content: space-between;
}
.index-contact .wrapper .block {
  width: 30%;
  padding: 1.875%;
  text-align: center;
  font-size: clamp(20px, 1.5625vw, 40px);
  color: #fff;
  transition: all 0.5s;
}
.index-contact .wrapper .block .icon {
  width: 3em;
  height: 3em;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto 0.75em;
}
.index-contact .wrapper .block .icon img {
  max-width: 100%;
  max-height: 100%;
}
.index-contact .wrapper .block h3 {
  font-weight: 700;
}
.index-contact .wrapper .block:hover {
  background-color: rgba(255, 255, 255, 0.1);
}
.index-contact .wrapper .block:hover .icon {
  animation: swing 1s;
}
.index-news {
  margin: 2% 0 3%;
}
.index-news .index-title ul {
  display: inline-block;
}
.index-news .index-title ul li {
  display: inline-block;
  font-size: clamp(14px, 1.1vw, 18px);
  color: #333;
  margin-right: 2.2222em;
  cursor: pointer;
}
.index-news .index-title ul .active {
  color: #115F38;
}
.index-news .wrapper {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  padding: 0 1.875%;
}
.index-news .wrapper .lt {
  width: 62.33766234%;
}
.index-news .wrapper .lt .content {
  display: none;
}
.index-news .wrapper .lt .content:first-child {
  display: block;
}
.index-news .wrapper .lt .block {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px dashed #9c9c9c;
  font-size: clamp(10px, 1.2vw, 20px);
  padding: 0.5em 0.5em 1em;
  margin-bottom: 2.083333%;
  transition: all 0.5s;
}
.index-news .wrapper .lt .block .date {
  width: 14.893617%;
  font-size: clamp(10px, 1.2vw, 20px);
  color: #115F38;
  white-space: nowrap;
  font-weight: 500;
}
.index-news .wrapper .lt .block .title {
  width: 84.0425532%;
}
.index-news .wrapper .lt .block .title h4 {
  font-size: clamp(14px, 1.25vw, 24px);
  color: #333;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.index-news .wrapper .lt .block .title p {
  font-size: clamp(12px, 1.1vw, 18px);
  color: #666;
  line-height: 1.6666667;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
.index-news .wrapper .lt .block .title a {
  color: inherit;
}
.index-news .wrapper .lt .block:hover {
  background-color: rgba(17, 95, 56, 0.1);
  border-color: #115F38;
}
.index-news .wrapper .lt .block:hover .title h4 {
  color: #115F38;
}
.index-news .wrapper .rt {
  width: 36.3636364%;
}
footer {
  background-color: #115F38;
  padding: 2.8645833% 0 3.90625%;
}
footer .footer-top {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-bottom: 2.125%;
}
footer .footer-top h4 {
  font-size: clamp(16px, 1.1vw, 18px);
  color: #fff;
  font-weight: 700;
  line-height: 1.6667;
  margin-bottom: 0.5556em;
}
footer .footer-top .info {
  width: 25%;
}
footer .footer-top .info .logo {
  margin-bottom: 10px;
}
footer .footer-top .info .logo h3 {
  font-size: clamp(20px, 1.5625vw, 30px);
  color: #fff;
  font-weight: 700;
  line-height: 1.3333;
}
footer .footer-top .info .logo h5 {
  font-size: 10px;
  color: #fff;
  line-height: 2;
}
footer .footer-top .info .logo img {
  margin-right: 10px;
}
footer .footer-top .info .logo h4 {
  margin-bottom: 0;
}
footer .footer-top .info .brief {
  font-size: clamp(14px, 1.2vw, 20px);
  color: #fff;
  line-height: 2;
}
footer .footer-top nav {
  width: 22.5%;
}
footer .footer-top nav ul {
  font-size: clamp(16px, 1.1vw, 18px);
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  max-height: 9em;
  gap: 0 1.5em;
}
footer .footer-top nav ul li {
  line-height: 1.6667;
  margin-bottom: 0.5556em;
}
footer .footer-top nav ul li a {
  color: #fff;
  transition: all 0.5s;
}
footer .footer-top nav ul li a:hover {
  text-decoration: underline !important;
}
footer .footer-top address {
  width: 39.375%;
}
footer .footer-top address p {
  font-size: clamp(14px, 1.1vw, 18px);
  color: #fff;
  line-height: 1.6667;
  margin-bottom: 0.5556em;
}
footer .footer-bt {
  font-size: clamp(12px, 1.1vw, 18px);
  color: #fff;
  line-height: 1.6667;
  text-align: center;
  display: flex;
}
footer .footer-bt p {
  flex: 1;
}
footer .footer-bt a {
  color: #E95412;
}
footer .footer-bt a:hover {
  text-decoration: underline !important;
}
footer .footer-bt span i {
  position: relative;
  margin-left: 20px;
  cursor: pointer;
  transform-style: preserve-3d;
  perspective: 800px;
}
footer .footer-bt span i > img {
  transition: all 0.5s;
}
footer .footer-bt span i .tip {
  position: absolute;
  visibility: hidden;
  opacity: 0;
  left: 50%;
  top: -100%;
  transform: translate(-50%, -150%) rotateX(-90deg) rotateY(90deg);
  white-space: nowrap;
  min-width: 100px;
  min-height: 100px;
  transition: all 0.5s;
}
footer .footer-bt span i .tip img {
  width: 100px;
  height: 100px;
}
footer .footer-bt span i:hover > img {
  filter: brightness(200%);
}
footer .footer-bt span i:hover .tip {
  transform: translate(-50%, -100%) rotateX(0deg) rotateY(0deg);
  visibility: visible;
  opacity: 1;
}
.anchor-fixed {
  position: relative;
  top: -100px;
}
.back-top {
  position: fixed;
  right: 1%;
  bottom: 5%;
  background-color: #115F38;
  width: 2em;
  height: 2em;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  cursor: pointer;
  font-size: clamp(12px, 1.2vw, 20px);
  border-radius: 4px;
  transition: all 0.5s;
  animation: fadeOutRight 0.5s;
  visibility: hidden;
}
.back-top:hover {
  filter: sepia(1);
}
.back-top-show {
  animation: fadeInLeft 0.5s;
  visibility: visible;
}
