main { overflow: hidden; zoom: 1 }

.main { padding-top: 40px; padding-bottom: 60px }

/*slide*/
.slide { position: relative; width: 100%; height: 500px }
.slide .swiper-slide img { display: block; width: 100%; height: 100%; object-fit: cover }
.slide .swiper-slide video { width: 100%; height: 100%; object-fit: cover }
.slide .slide-title { display: none; position: absolute; top: 50%; left: 50%; max-width: 1200px; margin-left: -685px; z-index: 8; color: #fff; transform: translateY(-50%) }
.slide .slide-title span { font-size: 30px; line-height: 1; letter-spacing: 2px; opacity: 0; visibility: hidden; transform: translateY(100%) }
.slide .slide-title .btitle { margin-top: 24px; margin-bottom: 36px; line-height: 1; font-size: 42px }
.slide .slide-title .btitle h3 { font-weight: normal; opacity: 0; visibility: hidden; transform: translateY(60%); font-weight: 600 }
.slide .slide-title .btitle h3 b { color: var(--hover-color) }
.slide .slide-title p { font-size: 16px; line-height: 1; letter-spacing: 2px; opacity: 0; visibility: hidden; transform: translateY(200%) }
.slide .slide-title a { display: flex; justify-content: space-between; width: 180px; height: 46px; margin-top: 50px; background: var(--hover-color); border-radius: 23px; font-size: 14px; color: #fff; line-height: 46px; padding-left: 30px; padding-right: 30px; cursor: pointer; box-sizing: border-box; opacity: 0; visibility: hidden; transform: translateY(100%) }
.slide .slide-title-black { color: rgba(0, 0, 0, .85) }
.slide .swiper-slide.swiper-slide-active .slide-title p, .slide .swiper-slide.swiper-slide-active .slide-title .btitle h3, .slide .swiper-slide.swiper-slide-active .slide-title span, .slide .swiper-slide.swiper-slide-active .slide-title a { opacity: 1; visibility: visible; transform: translateY(0); transition: 1s 0.6s cubic-bezier(0.15, 1, 0.35, 1) }
.slide .swiper-slide.swiper-slide-active .slide-title .btitle p { transition: all 3s cubic-bezier(0.15, 1, 0.35, 1) 0.75s }
.slide .swiper-slide.swiper-slide-active .slide-title .btitle h3 { transition: all 1.5s cubic-bezier(0.15, 1, 0.35, 1) 0.75s }
.slide .swiper-slide.swiper-slide-active .slide-title a { transition: all 2s cubic-bezier(0.15, 1, 0.35, 1) 0.75s }
.slide-prev, .slide-next { position: absolute; top: 50%; z-index: 9; width: 50px; height: 50px; transform: translate(0, -50%); border: 2px solid rgba(255, 255, 255, 0.1); border-radius: 50%; cursor: pointer; transition: 0.3s; background: transparent }
.slide-prev::after, .slide-next::after { content: ''; position: absolute; left: 50%; top: 50%; width: 33%; height: 33%; border-top: 2px solid rgba(255, 255, 255, .5) }
.slide-prev { left: 0; transform: translate(-100%, -50%); }
.slide-prev::after { border-left: 2px solid rgba(255, 255, 255, .5); transform: translate(-30%, -50%) rotate(-45deg) }
.slide-next { right: 0; transform: translate(100%, -50%); }
.slide-next::after { border-right: 2px solid rgba(255, 255, 255, .5); transform: translate(-70%, -50%) rotate(45deg) }
.slide-prev:hover, .slide-next:hover { background-color: var(--hover-color); border-color: transparent }
.slide-prev:hover::after, .slide-next:hover::after { border-color: #fff }
.slide:hover .slide-prev { transform: translate(100%, -50%); }
.slide:hover .slide-next { transform: translate(-100%, -50%); }
.slide-page { display: block; position: absolute; bottom: 20px; left: 0; z-index: 2; width: 100%; height: 20px; text-align: center }
.slide-page .page-bullet { display: inline-block; position: relative; height: 20px; width: 20px; background: none; text-align: center; margin: 0 10px; cursor: pointer }
.slide-page .page-bullet:after { content: ""; width: 6px; height: 6px; border-radius: 50%; background: rgba(255, 255, 255, .6); position: absolute; left: 50%; top: 50%; margin-left: -3px; margin-top: -3px; -webkit-transition: all .35s ease-in-out; transition: all .35s ease-in-out; -webkit-transform: scale(0.8); transform: scale(0.8); opacity: 1 }
.slide-page .page-bullet:before { content: ""; width: 100%; height: 100%; border: 2px solid rgba(255, 255, 255, .6); border-radius: 50%; position: absolute; left: 0; top: 0; opacity: 1 }
.slide-page .page-bullet svg { position: absolute; top: 0; right: 0; width: 20px; height: 20px; -webkit-transform: rotateY(-180deg) rotateZ(-90deg); transform: rotateY(-180deg) rotateZ(-90deg) }
.slide-page .page-bullet svg circle { stroke-dasharray: 113px; stroke-dashoffset: 0px; stroke-linecap: round; stroke-width: 0; stroke: var(--hover-color); fill: none; animation: none; animation-play-state: paused; animation-fill-mode: none }
.slide-page .page-bullet.page-active { color: #fff; background: none }
.slide-page .page-bullet.page-active:after { opacity: 1; -webkit-transform: scale(1); transform: scale(1); background: var(--hover-color) }
.slide-page .page-bullet.page-active:before { border-color: rgba(255, 255, 255, .6) }
.slide-page .page-bullet.page-active svg circle { animation-play-state: running; stroke-width: 2px; -webkit-animation: countdown 7s linear forwards; animation: countdown 7s linear forwards }
@-webkit-keyframes countdown {
	from { -webkit-stroke-dashoffset: 113px; stroke-dashoffset: 113px }
	to { -webkit-stroke-dashoffset: 0; stroke-dashoffset: 0 }
}
@keyframes countdown {
	from { -webkit-stroke-dashoffset: 113px; stroke-dashoffset: 113px }
	to { -webkit-stroke-dashoffset: 0; stroke-dashoffset: 0 }
}

/*title*/
.title { justify-content: space-between; align-items: center; width: 100%; height: 50px; line-height: 50px; border-bottom: 1px solid #d8d8d8 }
.title h2 { display: flex; align-items: center; position: relative; height: 100%; line-height: 50px; font-weight: 600; font-size: 18px; color: var(--color) }
.title h2::after { position: absolute; bottom: 0; content: ""; display: block; width: 100%; height: 3px; border-radius: 4px; background: var(--hover-color) }
.title h2 svg { color: var(--hover-color) }
.title h2 span { margin-left: 10px }
.title h3 { display: flex; align-items: center; position: relative; height: 100%; line-height: 50px; font-weight: 600; font-size: 18px; color: var(--color) }
.title h3::after { position: absolute; bottom: 0; content: ""; display: block; width: 100%; height: 3px; border-radius: 4px; background: var(--hover-color) }
.title h3 svg { color: var(--hover-color) }
.title h3 span { margin-left: 10px }
.title a { display: flex; align-items: center; font-size: 16px; color: #9e9e9e; transition: color .3s ease-in-out }
.title a:hover { color: var(--hover-color) }
.title a svg { margin-left: 3px }
.title-key { height: 60px; line-height: 60px }
.title-key h2 { display: flex; align-items: center; position: relative; height: 100%; line-height: 50px; font-weight: 600; font-size: 24px; color: var(--color) }
@media(max-width:768px) {
	.title h2 { font-size: 20px }
	.title h2::after { height: 3px }
	.title h3 { font-size: 20px }
	.title h3::after { height: 3px }
}

/*headlines*/
.headlines-box { }
.headlines { width: 100%; margin-top: 25px }
.headlines-img { display: block; width: 100%; height: 258px; overflow: hidden }
.headlines-img img { display: block; width: 100%; height: 100%; object-fit: cover; -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); -webkit-transition: all .4s ease; transition: all .4s ease }
.headlines-img:hover img { transform: scale3d(1.1, 1.1, 1) }
.headlines-info { width: 100%; background: #54a48a; padding: 41px 26px; position: relative; box-sizing: border-box }
.headlines-info h4 { line-height: 30px; font-weight: normal; display: block; width: 100%; overflow: hidden; white-space: nowrap; text-overflow: ellipsis }
.headlines-info h4 a { color: color:var(--color) }
.headlines-info time.date { display: flex; flex-direction: column; justify-content: center; align-items: center; position: absolute; left: 26px; top: -29px; width: 58px; height: 58px; text-align: center; color: var(--white); background: linear-gradient(180deg, #2b68dd, #458ccc); border-radius: 3px; -webkit-appearance: none }
.headlines-info time.date span { margin-top: 5px; font-family: Arial; font-size: 14px; color: var(--white) }
.headlines-page { position: absolute; bottom: 15px; width: 100%; left: 0; text-align: center; -webkit-transition: .3s opacity; -o-transition: .3s opacity; transition: .3s opacity; -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); z-index: 10 }
.headlines-page .page-bullet { display: inline-block; background: #afadad; width: 8px; height: 8px; text-align: right; border-radius: 100%; margin: 0 8px; cursor: pointer }
.headlines-page .page-active { background: var(--hover-color); opacity: 1 }
.headlines .swiper-slide:hover .headlines-info h4 a { color: var(--hover-color) }

.headlines-list { width: 100%; margin-top: 25px }
.headlines-list ul { width: 100%; padding: 6px 0 5px; border-left: 1px dashed #afadad }
.headlines-list ul li { width: 100%; position: relative; margin-bottom: 14px; padding-left: 15px }
.headlines-list ul li:last-of-type { margin-bottom: 0 }
.headlines-list ul li::before { content: ""; width: 8px; height: 8px; display: block; background: #afadad; border-radius: 100%; position: absolute; left: 0; top: 9px; transform: translateX(-50%) }
.headlines-list ul li.on::before { background: var(--hover-color) }
.headlines-list ul li a { width: 100%; font-size: 16px; color: var(--color); line-height: 26px; transition: 0.2s all; display: -webkit-box; -webkit-box-orient: vertical; overflow: hidden; overflow-wrap: break-word; -webkit-line-clamp: 1; text-overflow: ellipsis }
.headlines-list ul li time.date { display: flex; align-items: center; width: 100%; height: 0; margin-top: 6px; padding-left: 5px; line-height: 25px; font-family: Arial; color: var(--hover-color); background: linear-gradient(90deg, #54a48a, #fff); visibility: hidden; opacity: 0; transition: 0.2s all }
.headlines-list ul li time.date span { display: inline-block; padding-left: 8px; font-size: 14px }
.headlines-list ul li.on a { -webkit-line-clamp: 2; height: 52px; color: var(--hover-color) }
.headlines-list ul li.on time { visibility: inherit; opacity: 1; height: 25px }

/*notice*/
.notice-box { }
.notice-list { margin-top: 25px }
.notice-list ul { }
.notice-list ul li { display: flex; align-items: center; height: 82px; margin-top: 14px; padding-bottom: 14px; border-bottom: 1px dashed #b9b9b9 }
.notice-list ul li a { position: relative; padding-left: 12px; line-height: 26px; color: var(--color); font-size: 16px; transition: color .3s ease-in-out; flex: 1 }
.notice-list ul li a:hover { color: var(--hover-color) }
.notice-list ul li time.notice-date { display: flex; flex-direction: column; justify-content: center; align-items: center; width: 68px; height: 68px; line-height: 1; font-family: Arial; color: var(--hover-color); background-color: #54a48a; border-radius: 100%; transition: color .2s ease }
.notice-list ul li time.notice-date .big { font-size: 17px }
.notice-list ul li time.notice-date .mini { margin-top: 3px; font-size: 14px }
.notice-list ul li:hover time.notice-date { color: var(--white); background: var(--hover-color) }

/*list*/
.list-box { margin-top: 40px }
.list ul { margin-top: 20px }
.list ul li { display: flex; align-items: center; height: 56px; line-height: 56px; color: var(--color); border-bottom: 1px dashed #b9b9b9 }
.list ul li a { display: block; position: relative; padding-left: 25px; padding-right: 25px; color: var(--color); font-size: 16px; transition: color .3s ease-in-out; flex: 1; overflow: hidden; white-space: nowrap; text-overflow: ellipsis }
.list ul li a:hover { color: var(--hover-color) }
.list ul li a::before { content: ""; display: block; position: absolute; top: 50%; left: 10px; width: 4px; height: 4px; transform: translateY(-50%); background: var(--color); border-radius: 100%; transition: color .3s ease-in-out }
.list ul li a:hover::before { background: var(--hover-color) }
.list ul li time { font-family: Arial; font-size: 14px }

/*service*/
.service { padding: 40px 0 50px; background: #54a48a url(../images/service_bg.jpg) no-repeat center / cover; }
.service .title { display: inline-flex; border: none; }
.service-box { position: relative; }
.service-scroll-prev, .service-scroll-next { position: absolute; top: 50%; width: 80px; height: 80px; border-radius: 50%; cursor: pointer; transition: 0.3s; background: transparent; transform: translateY(-50%); box-sizing: border-box }
.service-scroll-prev { left: -80px; }
.service-scroll-next { right: -80px; margin-left: 20px }
.service-scroll-prev::after, .service-scroll-next::after { content: ''; position: absolute; left: 50%; top: 50%; width: 50%; height: 50%; border-top: 5px solid #033e83 }
.service-scroll-prev::after { border-left: 5px solid #033e83; transform: translate(-30%, -50%) rotate(-45deg) }
.service-scroll-next::after { border-right: 5px solid #033e83; transform: translate(-70%, -50%) rotate(45deg) }
.service-scroll-prev:hover::after, .service-scroll-next:hover::after { border-color: var(--hover-color) }
.service-scroll { display: flex; align-items: center; margin-top: 42px }
.service-scroll li a { display: block; transition: all .1s ease; cursor: initial; overflow: hidden; cursor: pointer; }
.service-scroll li a figure { display: flex; justify-content: center; align-items: center; width: 100%; height: 160px; margin: 0; overflow: hidden }
.service-scroll li a figure img { display: block; width: 142px; height: 142px; -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); -webkit-transition: all .4s ease; transition: all .4s ease }
.service-scroll li a:hover figure img { transform: scale3d(1.1, 1.1, 1.1) }
.service-icon-box { display: flex; justify-content: center; align-items: center; width: 100%; height: 160px; margin: 0; overflow: hidden }
.service-icon-ww { display: flex; justify-content: center; align-items: center; width: 142px; height: 142px; color: #fff; background: linear-gradient(180deg, #066646, #007751); border-radius: 100%; -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); -webkit-transition: all .4s ease; transition: all .4s ease }
.service-scroll li a:hover .service-icon-ww { transform: scale3d(1.1, 1.1, 1.1) }
.service-scroll li a span { display: block; width: 100%; margin-top: 20px; padding-left: 15px; padding-right: 15px; text-align: center; font-weight: 600; font-size: 18px; box-sizing: border-box }

/*grid*/
@media (max-width:1600px) { }
@media (max-width:1440px) {
	.slide { height: auto }
}
@media (max-width:1280px) { }
@media (max-width:1024px) {
	.service-scroll-prev, .service-scroll-next { display: none }
}
@media (max-width:768px) {
	.slide { height: 320px; }
	.slide-prev, .slide-next { display: none; }
	.slide-page { bottom: 15px; }
	.headlines-box, .notice-box, .list-box { flex: 0 0 100%; max-width: 100% }
}
@media (max-width:576px) {
	.slide { height: 240px; }
	.slide-page { height: 14px; }
	.slide-page .page-bullet { margin: 0 5px; height: 14px; width: 14px; }
	.slide-page .page-bullet:after { width: 4px; height: 4px; margin-left: -2px; margin-top: -2px; }
	.slide-page .page-bullet:before { border: 1px solid rgba(255, 255, 255, .6); }
	.slide-page .page-bullet svg { width: 14px; height: 14px; }
	.slide-page .page-bullet.page-active svg circle { stroke-width: 1px; }
	.notice-box, .list-box { margin-top: 20px }
	.service-scroll { margin-top: 30px }
	.service-scroll li a figure { height: 120px; }
	.service-scroll li a figure img { width: 100px; height: 100px; }
	.service-icon-box { height: 120px; }
	.service-icon-ww { width: 100px; height: 100px; }
	.service-icon-ww svg { width: 60px; height: 60px; }
	.service-scroll li a:hover .service-icon-ww { transform: scale3d(1.1, 1.1, 1.1) }
	.service-scroll li a span { margin-top: 10px; font-size: 16px }
}