/* banner */
#banner {padding: 88px 0vw 0;width: 100vw;z-index: 3;}
#banner .item { min-width: 100vw; height: 90vh; }
#banner .item .clip >* { min-width: 100vw; width: 100vw; }
#banner .item .clip iframe { position: absolute; width: 100%; height: 100%; top: 0; left: 0; }
#banner .item .clip video {overflow: hidden;position: absolute;width: 100%;height: 100%;object-fit: cover;top: 0;left: 0px;object-position: left;}
#banner .item .clip video source{}
#banner .item .clip .tit{position:absolute;top: 0;right: 0;height: 100%;}
#banner .item .clip .tit img{height:100%;width: 100%;object-fit: cover;}
#banner .item .info >div { margin: auto; width: calc(100% - 60px); }
#banner .item .info >div .txt { -webkit-transition-delay: .2s; transition-delay: .2s; }
#banner .item .info >div .txt:nth-child(2) { -webkit-transition-delay: .4s; transition-delay: .4s; }
#banner .item .info >div .txt >* { padding: 10px 15px; max-width: calc(100% - 30px); font-size: 18px; }
#banner .item .info >div .txt h3 { margin-bottom: 15px; line-height: 120%; font-size: 35px; }

@media screen and (max-width: 1280px){
	#banner { padding-top: 70px; }
}
@media screen and (max-width: 1024px){
	#banner .item { height: 50vh; }
	#banner .item .clip video{width: auto;height: 100%;}
	#banner .item .clip .tit img{object-position: 80% 0;}
}
@media screen and (max-width: 640px){
	#banner .item {height: 30vh;}
	#banner .item .clip .tit img{object-position: 84% 0;}
}