@import url(https://cdn.jsdelivr.net/npm/yakuhanjp@3.0.0/dist/css/yakuhanjp.min.css);
@import url(https://cdn.jsdelivr.net/npm/yakuhanjp@3.0.0/dist/css/yakuhanmp.min.css);
@import url(https://fonts.googleapis.com/earlyaccess/notosansjapanese.css);

.navi {
	left:20px;
	right: 20px;
	width: calc(100% - 40px);
}

/***********************************************************
 * header
************************************************************/
header{
	position: relative;
	margin: 0 auto;
	/*margin-top: 70px;*/
	width: calc(100% - 40px);
	padding-bottom: 105%;
	overflow: hidden;
	padding-top: 0;
}
header:after{
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	width: 100%;
	background: linear-gradient(0deg,rgba(255,255,255,1), rgba(255,255,255,.0));
	padding-top: 20%;
	display: block;
}
header img{
	display: block;
	margin: auto;
	width: 100%;
}
header > img{
	top: -90px;
}
h1{
}
h1 > img{
	position: absolute;
	top: 6%;
	bottom: auto;
	left: 0;
	right: 0;
	margin: auto;
	width: 80%;
}
header .cast {
	max-width: 75%;
}
.award{
	position: absolute;
	top: 22%;
	left: 3%;
	width: 35%;
	transition: all .5s;
}
.award img{
	display: block;
	width: 100%;
	height: 100%;
}
.award:hover img{
	opacity: 1;
}

.theme-song{
	position: absolute;
	top: 22%;
	right: 3%;
	width: 15%;
}

.theme-song a{
	line-height: 1;
	display: block;
	width: 100%;
	height: 100%;
}
.theme-song img{
	display: block;
	width: 100%;
	height: 100%;
}
.roadshow{
	position: absolute;
	top: 35%;
	left: 3%;
	width: 18%;
}
.roadshow img{
	display: block;
	width: 100%;
	height: 100%;
}
.bnr-koupen{
	position: absolute;
	top: 35%;
	right: 13%;
	width: 13%;
	transition: all .5s;
}
.bnr-koupen img{
	display: block;
	width: 100%;
	height: 100%;
}
.bnr-theater,
.bnr-event{
	position: absolute;
	bottom: 10%;
	left: 7%;
	width: 13%;
	transition: all .5s;
}
.bnr-theater img,
.bnr-event img{
	display: block;
	width: 100%;
	height: 100%;
}
.bnr-ob{
	position: absolute;
	bottom: 20%;
	right: 3%;
	width: 13%;
	transition: all .5s;
}
.bnr-ob img{
	display: block;
	width: 100%;
	height: 100%;
}
.bnr-greeting,
.bnr-comment{
	position: absolute;
	bottom: 33%;
	right: 3%;
	width: 13%;
	transition: all .5s;
}
.bnr-greeting img,
.bnr-comment img{
	display: block;
	width: 100%;
	height: 100%;
}
.bnr-stamp{
	position: absolute;
	bottom: 2%;
	left: 24%;
	width: 13%;
	transition: all .5s;
}
.bnr-stamp img{
	display: block;
	width: 100%;
	height: 100%;
}
.theme-song,
.bnr-koupen,
.bnr-theater,
.bnr-event,
.bnr-ob,
.bnr-greeting,
.bnr-stamp,
.bnr-comment,
.roadshow{
	z-index: 99;
}
.theme-song:hover,
.bnr-koupen:hover,
.bnr-theater:hover,
.bnr-event:hover,
.bnr-ob:hover,
.bnr-greeting:hover,
.bnr-stamp:hover,
.bnr-comment:hover,
.roadshow:hover{
  -webkit-animation-duration: 2s;
  animation-duration: 2s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  -webkit-animation-name: rubberBand;
  animation-name: rubberBand;
  animation-delay:0;
}
.theme-song img:hover,
.bnr-koupen img:hover,
.bnr-theater img:hover,
.bnr-event img:hover,
.bnr-ob img:hover,
.bnr-greeting img:hover,
.bnr-stamp img:hover,
.bnr-comment img:hover,
.roadshow img:hover{
	opacity: 1;
}



@-webkit-keyframes sdb {
  0% {
    -webkit-transform: rotate(-135deg) translate(0, 0);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    -webkit-transform: rotate(-135deg) translate(-5px, 5px);
    opacity: 0;
  }
}
@keyframes sdb {
  0% {
    transform: rotate(-135deg) translate(0, 0);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    transform: rotate(-135deg) translate(-5px, 5px);
    opacity: 0;
  }
}
@media screen and (max-width: 768px) {
	header{
		padding-bottom: 0;
	}
}
@media screen and (max-width: 768px) {
	header .pc{
		display: none !important;
	}
	header .sp{
		display: block!important;
	}
	header{
		background: none;
		padding-bottom: 150%;
		width: 100%;
		z-index: -1;
	}
	header:before{
		content: "";
		background: url(../img/visual-sp.jpg) no-repeat top center;
		background-size: 100% auto;
		position: fixed;
		display: block;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		z-index: -1;
	}
	header:after{
		content: "";
		position: absolute;
		bottom: -5px;
		left: 0;
		right: 0;
		width: 100%;
		background: linear-gradient(0deg,rgba(255,255,255,1), rgba(255,255,255,.0));
		padding-top: 50%;
		display: block;
	}
	header > img{
		top: 0;
		position: fixed;
	}
	h1 img{
		width: 100%;
		top: 2%;
		bottom: auto;
		left: 0;
		right: 0;
	}
}
/***********************************************************
 * contents
************************************************************/
/*-----------------------------------------
** data
-----------------------------------------*/
.data{
	padding-top: 5%;
}
.data .__inner{
	max-width: 1200px;
}
.copy{
	max-width: 90px;
	width: 7%;
	display: block;
	margin: 0 10% 0 auto;
	top: -10%;
}
.youtube-min{
	width: 360px;
	height: 202px;
	position: relative;
	margin-left: 10%;
	margin-top: 10%;
}
.youtube-min ._trailer{
	position: absolute;
	width: 195px;
	bottom: 0;
	top: auto;
	left: auto;
	right: -115px;
	transition-duration: 0.3s;
	z-index: 0;
}
.youtube-min ._trailer > img{
	width: 100%;
}
.youtube-min ._trailer > a img{
	width: 60%;
	position: static;
	z-index: 0;
}
.youtube-min ._trailer > a img{
  -webkit-animation-duration: 2s;
  animation-duration: 2s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-name: tada;
  animation-name: tada
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  animation-delay:.5;
}
@-webkit-keyframes tada {
  0% {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1)
  }
  5%,
  10% {
    -webkit-transform: scale3d(.9, .9, .9) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(.9, .9, .9) rotate3d(0, 0, 1, -3deg)
  }
  15%,
  25%,
  35%,
  45% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg)
  }
  20%,
  30%,
  40% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg)
  }
  50% {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1)
  }
  100% {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1)
  }
}
@keyframes tada {
  0% {
    -webkit-transform: scale3d(1, 1, 1);
    -ms-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1)
  }
  5%,
  10% {
    -webkit-transform: scale3d(.9, .9, .9) rotate3d(0, 0, 1, -3deg);
    -ms-transform: scale3d(.9, .9, .9) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(.9, .9, .9) rotate3d(0, 0, 1, -3deg)
  }
  15%,
  25%,
  35%,
  45% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    -ms-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg)
  }
  20%,
  30%,
  40% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    -ms-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg)
  }
  50% {
    -webkit-transform: scale3d(1, 1, 1);
    -ms-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1)
  }
  100% {
    -webkit-transform: scale3d(1, 1, 1);
    -ms-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1)
  }
}
#player{
 	position: absolute;
  	top: 0;
  	right: 0;
  	width: 100% !important;
  	height: 100% !important;
	border: solid 4px #fca5b3;
	z-index: 999;
}
.youtube-min > a{
 	position: absolute;
  	top: 4px;
  	right: 4px;
  	width: 100% !important;
  	height: 100% !important;
	z-index: 1000;
}
@media screen and (max-width: 768px) {
	.data{
		z-index: 1;
		position: relative;
		background: #fff;
		margin-top: -2px;
	}
	.data .__inner{
		padding-top: 10%;
	}
	.copy{
		top: 0;
	}
}
@media screen and (max-width: 640px) {
	/*.data{
		background: url(../img/gallery.jpg) no-repeat center bottom, #fff;
		background-size: 90% auto, cover;
	}*/
	.award{
		display: block;
		width: 90%;
		margin: 0 auto 15%;
		position: relative;
		top: 0;
		left: auto;
	}
	.copy{
		max-width: 23%;
		width: 23%;
		display: inline-block;
		margin: 0 15% 0 auto;
		vertical-align: top;
		top:10%;
	}
	.theme-song{
		position: absolute;
		top: 22%;
		right: 3%;
		width: 15%;
		background: #fff;
		padding-bottom: 15%;
		box-sizing: border-box;
		border-radius: 50%;
		transition: all .5s;
	}
	.roadshow{
		position: relative;
		width: 40%;
		background: none;
		padding-bottom: 0;
		transition: all .5s;
		display: inline-block;
		margin-left: 5%;
	}
	.banner{
		width: 90%;
		margin: 0 auto;
		padding: 0;
		text-align: left;
	}
	.banner li{
		width: 30%;
		display: inline-block;
		margin: 1%;
		vertical-align: bottom;
	}
	/*.banner > *{
		margin-bottom: 20px;
	}*/
	.youtube-min{
		width: 70%;
		padding-top: 43%;
		height: auto;
		position: relative;
		margin-left: 5%;
		margin-top: 15%;
	}
	.youtube-min ._trailer{
		position: absolute;
		width: 60%;
		bottom: 0;
		top: auto;
		left: auto;
		right: -35%;
		transition-duration: 0.3s;
	}
	.youtube-min ._trailer img{
		width: 100%;
	}
}
._title{
	width: 100%;
	margin: 5% auto;
}
/*._credit{
	max-width: 600px;
	width: 50%;
	display: block;
	margin: 0 auto 10% 2%;
}
._btn{
	max-width: 550px;
	width: 45%;
	display: block;
	margin: 18% 2% 0 auto;
	position: relative;
	clear: both;
}
._btn > img{
	display: block;
}*/
._credit{
	max-width: 600px;
	width: 50%;
	display: block;
	margin: 0 auto 0 2%;
}
._bnr-area{
	position: relative;
	width: 50%;
	max-width: 600px;
	text-align: center;
	margin-top: 50px;
}
._interview{
	position: absolute;
	bottom: 5%;
	width: 40%;
	max-width: 450px;
	margin: 0 auto 50px 8%;
}
._bnr-area > ul{
	text-align: center;
	width: 50%;
	margin: 0 auto;
}
.slider-next,
.slider-prev{
    line-height: 0;
    position: absolute;
    top: 50%;
    display: block;
    width: 20px;
    height: 20px;
    padding: 0;
    -webkit-transform: translate(0, -50%);
    -ms-transform: translate(0, -50%);
    transform: translate(0, -50%);
    cursor: pointer;
    color: #fff;
    border: none;
    outline: none;
    background: #FCA5B3;
	border-radius: 50%;
}
.slider-next{
	right: -30px;
}
.slider-prev{
	left: -30px;
}
.slider-next:before,
.slider-prev:before{
	font-size: 10px;
	color: #fff;
	line-height: 20px;
}
.slider-next:before{
	content: "▶";
}
.slider-prev:before{
	content: "◀";
}

._btn{
	max-width: 550px;
	width: 45%;
	display: block;
	margin: 40% 2% 0 auto;
	position: relative;
	max-height: 270px;
	height: 100%;
}
._btn .__about{
	position: absolute;
	width: 30%;
	max-width: 230px;
	top: -40%;
	left: 18%;
	z-index: 99;
}
._btn .__news{
	position: absolute;
	width: 17%;
	max-width: 113px;
	top: -15%;
	right: 15%;
	z-index: 99;
}
._btn .__about,
._btn .__news{
  -webkit-animation-duration: 2s;
  animation-duration: 2s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  -webkit-animation-name: rubberBand;
  animation-name: rubberBand;
  animation-delay:0;
}
._btn .__news{
  animation-delay:1s;
}
@-webkit-keyframes rubberBand {
  0% {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1)
  }
  15% {
    -webkit-transform: scale3d(1.25, .75, 1);
    transform: scale3d(1.25, .75, 1)
  }
  20% {
    -webkit-transform: scale3d(0.75, 1.25, 1);
    transform: scale3d(0.75, 1.25, 1)
  }
  25% {
    -webkit-transform: scale3d(1.15, .85, 1);
    transform: scale3d(1.15, .85, 1)
  }
  32% {
    -webkit-transform: scale3d(.95, 1.05, 1);
    transform: scale3d(.95, 1.05, 1)
  }
  37% {
    -webkit-transform: scale3d(1.05, .95, 1);
    transform: scale3d(1.05, .95, 1)
  }
  50% {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1)
  }
  100% {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1)
  }
}
@keyframes rubberBand {
  0% {
    -webkit-transform: scale3d(1, 1, 1);
    -ms-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1)
  }
  15% {
    -webkit-transform: scale3d(1.25, .75, 1);
    -ms-transform: scale3d(1.25, .75, 1);
    transform: scale3d(1.25, .75, 1)
  }
  20% {
    -webkit-transform: scale3d(0.75, 1.25, 1);
    -ms-transform: scale3d(0.75, 1.25, 1);
    transform: scale3d(0.75, 1.25, 1)
  }
  25% {
    -webkit-transform: scale3d(1.15, .85, 1);
    -ms-transform: scale3d(1.15, .85, 1);
    transform: scale3d(1.15, .85, 1)
  }
  32% {
    -webkit-transform: scale3d(.95, 1.05, 1);
    -ms-transform: scale3d(.95, 1.05, 1);
    transform: scale3d(.95, 1.05, 1)
  }
  37% {
    -webkit-transform: scale3d(1.05, .95, 1);
    -ms-transform: scale3d(1.05, .95, 1);
    transform: scale3d(1.05, .95, 1)
  }
  50% {
    -webkit-transform: scale3d(1, 1, 1);
    -ms-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1)
  }
  100% {
    -webkit-transform: scale3d(1, 1, 1);
    -ms-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1)
  }
}

@media screen and (max-width: 640px) {
	._title{
		width: 95%;
		margin: 10% auto;
		display: block;
	}
	._credit{
		max-width: 90%;
		width: 90%;
		margin: 0 auto;
		padding-left: 3%;
	}
	._bnr-area{
		position: relative;
		margin: 10% auto 10%;
		width: 100%;
		max-width: 100%;
		bottom: auto;
	}
	._interview{
		margin: 80% auto 10%;
		width: 80%;
		position: relative;
	}
	._bnr-area > ul{
		text-align: center;
		width: 60%;
		margin: 0 auto;
	}
	/*._bnr-area > ul button:before{
	  -webkit-box-sizing: content-box;
	  -webkit-appearance: button;
	  appearance: button;
	  border: none;
	  box-sizing: border-box;
	  cursor: pointer;
	}
	._bnr-area > ul button:before::-webkit-search-decoration{
	  display: none;
	}
	._bnr-area > ul button:before::focus{
	  outline-offset: -2px;
	}*/
	
	._btn{
		max-width: 90%;
		width: 90%;
		margin: 0 auto 0;
	}
	._btn .__about{
		position: relative;
		width: 30%;
		max-width: 230px; 
		display: inline-block;
		left: 0;
		right: 0;
		top: 0;
		bottom: 0;
		margin: 0 15% 0 20%;
	}
	._btn .__news{
		position: relative;
		width: 20%;
		 max-width: 113px; 
		display: inline-block;
		vertical-align: bottom;
		left: 0;
		right:0;
		top: 0;
		bottom: 0;
		text-align: right;
		margin: 0 5% 0 auto;
	}
	.data .theater{
		margin-bottom: 25%;
	}
}
/*-----------------------------------------
** gallery
-----------------------------------------*/
.gallery{
	margin: 0;
	padding: 0;
	position: relative;
	clear: both;
}
.gallery ._panel,
.gallery .panel{
	height: 100vh;
	width: 100%;
	letter-spacing: -.4em;
	position: relative;
}
.gallery ._panel img,
.gallery .panel img{
	width:100%;
    height:100%;
    max-width:100%;
    max-height:100%;
	object-fit: cover;
	font-family: 'object-fit: cover;';
}
.gallery ._panel *,
.gallery .panel *{
	letter-spacing: normal;
}
.gallery ._panel > p{
	position: absolute;
	bottom: 0;
	top: 0;
	left: 0;
	right: 0;
	margin: auto;
	font-family: 'Josefin Sans', YakuHanJP, 'Noto Sans Japanese', 游ゴシック, 'Yu Gothic Medium', 'Hiragino Sans', 'メイリオ', Meiryo, sans-serif;
	font-style: italic;
	font-weight: 300;
	font-size: 60px;
	color: #fff;
	z-index: 999;
	line-height: 1;
	height: 1em;
	text-shadow:10px 10px 3px rgba(0,0,0,0.5);
	
}

.gallery ._col-1{
	width: 100%;
	height: 100vh;
}
.gallery ._col-2{
	width: 50%;
	height: 100%;
	display: inline-block;
	vertical-align: top;
}
.gallery ._col-2-l{
	width: 65%;
	height: 100vh;
	display: inline-block;
	vertical-align: top;
}
.gallery ._col-2-s{
	width: 35%;
	height: 100vh;
	display: inline-block;
}
.gallery [class^="_col-2"] .__photo{
	height: 50vh;
}
.gallery .__last{
	object-position: 100% 100%
}
.gallery ._panel [class^="__text"],
.gallery .panel [class^="__text"]{
	position: absolute;
	top: calc(70px + 10%);
	width: 280px;
	max-width: 280px;
	display: inline-block;
	background: #fff;
	padding: 30px;
	box-sizing: border-box;
	text-align: left;
	box-shadow:10px 10px 10px 2px rgba(0,0,0,0.25);
	left: 0;
}
.gallery ._panel .__text-l,
.gallery .panel .__text-l{
	margin-right: calc(95% - 280px);
	margin-left: 5%;
}
.gallery ._panel .__text-r,
.gallery .panel .__text-r{
	margin-left: calc(95% - 280px);
	margin-right: 5%;
}
.gallery ._panel [class^="__text"] p,
.gallery .panel [class^="__text"] p{
  	font-family: YakuHanJP, 'Noto Sans Japanese', YuGothic, 游ゴシック, 'Yu Gothic Medium', 'Hiragino Sans', 'メイリオ', Meiryo, sans-serif;
	font-size: 18px;
	letter-spacing: .05em;
	font-weight: 700;
}
@media screen and (max-width: 768px) {
	.gallery{
		background: #fff;
	}
	.gallery .pc{
		display: none !important;
	}
	.gallery .sp{
		display: block!important;
	}
	.gallery ._panel,
	.gallery .panel{
		height: auto;
	}
	.gallery ._panel > p{
	display:none;
	}
	.gallery [class^="_col-"]{
		width: 100%;
		height: auto;
	}
	.gallery [class^="_col-2"] .__photo{
		height: auto;
	}
	.gallery ._panel [class^="__text"],
	.gallery .panel [class^="__text"]{
		position: relative;
		top: 0;
		width: 100%;
		max-width: 100%;
		box-shadow: none;
		text-align: center;
	}
	.gallery ._panel .__text-l,
	.gallery ._panel .__text-r,
	.gallery .panel .__text-l,
	.gallery .panel .__text-r{
		margin: 0 auto;
	}
	.gallery ._panel [class^="__text"] p,
	.gallery .panel [class^="__text"] p{
		font-size: 16px;
	}
	.fadein {
		opacity : 0;
		transform : translate(0, 50px);
		transition : all 700ms;
	}
	.fadein.scrollin {
		opacity : 1;
		transform : translate(0, 0);
		transition : all 700ms;
	}
}
/***********************************************************
 * footer
************************************************************/
footer{
	position: relative;
	background: #48a2d0;
	padding: 20px 0 0;
}

footer > img:first-child{
	display: block;
	margin:100px auto;
	max-width: 600px;
	width: 80%;
}
@media screen and (max-width: 640px) {
	footer > img:first-child{
		margin:8% auto;
	}
	footer > img{
		width: 100%;
	}
	footer p.copyright{
		font-size: 10px;
	}
}
