main { overflow: hidden; zoom: 1 }

/*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: translateY(-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: translateX(-100%) }
.slide-prev::after { border-left: 2px solid rgba(255, 255, 255, .5); transform: translate(-30%, -50%) rotate(-45deg) }
.slide-next { right: 0; transform: translateX(100%) }
.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: translateX(100%) }
.slide:hover .slide-next { transform: translateX(-100%) }
.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, .3); 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, .3); 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: rgba(255, 255, 255, 1); 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: rgba(255, 255, 255, 1) }
.slide-page .page-bullet.page-active:before { border-color: rgba(255, 255, 255, .3) }
.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 { display: flex; flex-direction: column; justify-content: center; align-items: center }
.title h2 { display: flex; flex-direction: column; justify-content: center; align-items: center; line-height: inherit; font-size: 32px; color: var(--color) }
.title h2::after { content: ""; display: block; width: 2em; height: 2px; margin-top: 5px; background: rgba(0, 0, 0, .45) }
.title span { display: block; margin-top: 5px; font-size: 20px; color: rgba(0, 0, 0, .45) }
@media(max-width:768px) {
	.title h2 { font-size: 20px }
}

/*position*/
.position { padding: 20px 0; font-size: 14px; color: rgba(0, 0, 0, .65); border-bottom: 1px solid #ddd }
.position .flex { align-items: center }
.position svg { margin-right: 5px; font-size: 16px }
.position a { padding: 0 5px; color: rgba(0, 0, 0, .65) }
.position a:hover { color: var(--hover-color) }

/*list*/
.list-box { padding-top: 50px; padding-bottom: 50px; background: #ededed }
.list { padding-top: 30px; padding-bottom: 30px }
.list li { display: flex; height: 50px; line-height: 50px; border-bottom: 1px dotted #ddd }
.list li a { flex: 1; overflow: hidden; white-space: nowrap; text-overflow: ellipsis }
.list li a:hover { color: var(--hover-color) }
.list li time { padding-left: 10px; font-size: 12px }

.list-images { padding-top: 30px; padding-bottom: 30px }
.list-images li { }
.list-images li:nth-child(n+6) { margin-top: 30px }
.list-images li a { display: block; color: var(--text-color); background-color: transparent; transition: all .1s ease; overflow: hidden }
.list-images li a figure { position: relative; width: 100%; height: 280px; margin: 0; overflow: hidden }
.list-images li a figure img { display: block; width: 100%; height: 100%; -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); -webkit-transition: all .4s ease; -moz-transition: all .4s ease; transition: all .4s ease; position: absolute; top: 0; object-fit: cover }
.list-images li a:hover figure img { transform: scale3d(1.1, 1.1, 1.1) }
.list-images li a span { display: block; width: 100%; height: 30px; padding-left: 5px; padding-right: 5px; text-align: center; line-height: 30px; font-weight: 500; font-size: 14px }
.list-images li a span { display: block; width: 100%; height: 36px; padding-left: 5px; padding-right: 5px; text-align: center; line-height: 36px; font-weight: 500; font-size: 16px }
.list-partner li a figure { width: initial; height: initial }

.list-partner li a figure::before { content: ""; display: block; background-size: cover; background-position: 50%; padding-bottom: 100% }

/*article*/
.content { padding-top: 50px; padding-bottom: 50px }
.article { position: relative; width: 100% }
.article-tit { padding-bottom: 30px; border-bottom: 1px solid #e0e0e0; text-align: center }
.article-tit h1 { padding: 20px 0; font-weight: 700; font-size: 36px; line-height: 46px; color: #242728; word-wrap: break-word; word-break: break-all }
.article-tit .profile { font-size: calc(12px + 4 * 100vw / 1920); color: #7b7b7b; line-height: 24px }
.article-tit .profile span + span { margin-left: 24px }
.article-tit .profile span i { margin-right: 5px; font-style: normal }
.article-info { overflow: hidden; padding-top: 38px }
.article-info .info { line-height: 1.8; font-size: calc(12px + 4 * 100vw / 1920) }
.article-info .info p { text-indent: 0; line-height: 32px; color: #666 }
.article-info .info img { max-width: 100%; vertical-align: top }
.article-info .info a { color: #242728 }
.article-info .info a:hover { text-decoration: underline }
.article-info .info strong, .article-info .info th { font-weight: bold }
.article-info video { width: 100%; max-width: 100% }
.fanye { margin-bottom: 10px; padding: 10px 0; line-height: 32px; border-top: 1px solid #e0e0e0 }
.fanye strong { color: #242728; font-weight: normal }

.show-box { padding-top: 50px; padding-bottom: 50px; background: #ededed }
.show-box .content { padding: 0 }
.show-box .fanye { justify-content: space-between; margin-bottom: 0; padding-top: 32px }
.show-box .fanye a span { display: flex; align-items: center; line-height: 34px; font-size: calc(12px + 5 * 100vw / 1920) }
.show-box .fanye a span svg { margin-left: 11px }
.show-box .fanye a:first-child span svg { margin-left: 0px; margin-right: 11px; -webkit-transform: rotate(180deg); transform: rotate(180deg) }

/*pages*/
.pagebar { margin-top: 30px; padding: 10px 0 }
.pagebar .pagination { display: flex; justify-content: center }
.pagebar .pagination li { min-width: 40px; height: 40px; line-height: 40px; margin: 0 6px }
.pagebar .pagination li a { display: block; width: 100%; height: 100%; text-align: center; color: rgba(170, 170, 170, 1); font-size: calc(12px + 6 * 100vw / 1920); background-color: rgb(248, 249, 250); border-radius: 2px; box-sizing: border-box; text-decoration: none; transition: all .3s ease-out 0s }
.pagebar .pagination li.page-size a { font-size: 24px }
.pagebar .pagination li.active a, .pagebar .pagination li a:hover { color: #fff; background: #3a82f8 }
.pageno { margin-top: 30px; padding: 20px 0; text-align: center; font-size: calc(12px + 4 * 100vw / 1920); color: #999 }

/*grid*/
@media (max-width:1440px) { }
@media (max-width:1280px) { }
@media (max-width:1024px) { }
@media (max-width:768px) {
	.slide { position: relative; width: 100%; height: 140px }
	.slide-page { display: none }

	/*article*/
	.article-tit { padding-bottom: 20px }
	.article-tit h1 { padding: 5px 0; line-height: 36px; font-size: 20px }
	.article-info { padding-top: 28px }

	.show-box { padding-top: 30px; padding-bottom: 30px }

	.list-images li { flex: 0 0 50%; max-width: 50% }
	.list-images li:nth-child(n+3) { margin-top: 10px }
}
@media (max-width:576px) {
	/*pages*/
	.pagebar { margin-top: 20px }
	.pagebar .pagination { justify-content: center }
	.pagebar .page-num { display: none }
}