/* ! normalize.css v1.0.0 | MIT License | git.io/normalize */
@charset "UTF-8";


 .loadingWrap {
 width: 100%;/*100%で全画面表示*/
 height: 100%;/*100%で全画面表示*/
 background: #000;/*背景色*/
 position: fixed;
 top: 0;/*画面上部からの位置*/
 left: 0;/*画面左部からの位置*/
 z-index: 9999;/*レイヤー(この他にpositionを使用していない場合は不要)*/
}
.loadingWrap .loader {
	position: absolute;
    top: 50%;
    left: 50%;
	margin: auto;/*画像位置調整(-画像高さの半分 0 0 -画像幅の半分)*/
}

/*
  Set the color of the icon
*/
svg path,
svg rect{
  fill: #fff;
}

/* ==========================================================================
Buttons
========================================================================== */
.use-btn {
	width: 100%;
	height: auto;
	display: block;
    display: inline-block;
    /*margin: 0 10px 10px 0;*/
    padding: 18px 0;
    border-radius: 3px;
    background: rgba(255,255,255,0.6);
    color: #371e13;
    font-size: 14px;
	font-family: 'Mallanna', sans-serif;
	letter-spacing: 0.1em;
	border:2px solid #fff;
}

.use-btn:hover, .use-btn:focus {
	width: 100%;
	height: auto;
	display: block;
    background: none;
    color: #fff;
    text-decoration: none;
}

.learn-btn, .download-btn {
	width: 100%;
	height: auto;
	display: block;
    padding: 18px 0;
    border: 2px solid #fff;
    border-radius: 3px;
    color: #fff;
    font-size: 14px;
	font-family: 'Mallanna', sans-serif;
	letter-spacing: 0.1em;
}

.am .learn-btn {
    border: 2px solid #fff100;
    color: #fff100;
}

.am .learn-btn:hover {
    border: 2px solid #8158f4;
    color: #8158f4;
}


.learn-btn:hover,.learn-btn:focus {
    color: #fff100;
	border-color:#fff100;
    text-decoration: none;
}

.read-more-btn {
    display: inline-block;
    color: #311436;
    text-transform: uppercase;
    font-weight: 400;
}
.read-more-btn i, .download-btn i {
    margin-left: 5px;
	color:#fff;
	font-size:1.3em;
}
.showcase .download-btn {
    margin-top: 50px
}
.download .download-btn {
    margin-top: 25px
}



/* ==========================================================================
Hero
========================================================================== */

.hero {
    position: relative;
    padding: 0 0 0 0;
    color: #FFF;
	z-index: 3;
}

.hero .container {
	top: 10%;
	position: relative;
	width:auto;
	margin:0;
	padding:0;
}
.hero a.nav-toggle {
	font-family: 'Mallanna', sans-serif;
	letter-spacing: 0.1em;
}
.hero .col-md-6 {
	float: right;
	text-align: right;
}

.hero .icon_i{
	position:absolute;
    top: 60px;
    left: 10px;
    width: 47px;
}

.hero .icon_i img{
	width:100%;
	display:block;
	border-radius: 50%;	
	box-shadow: 0px 0px 15px rgba(0,0,0,0.4);
}

.hero .icon_i:hover{
	opacity:0.7;
}

.hero .images{
	width:100%;
	margin:0 auto;
	padding:0;
	position:relative;
}
.hero .images.rotate_in{
    -webkit-animation: rotate_in_anime 1.6s cubic-bezier(.65,.18,0,1.04);
    -moz-animation: rotate_in_anime 1.6s cubic-bezier(.65,.18,0,1.04);
    -ms-animation: rotate_in_anime 1.6s cubic-bezier(.65,.18,0,1.04);
    -o-animation: rotate_in_anime 1.6s cubic-bezier(.65,.18,0,1.04);
    animation: rotate_in_anime 1.6s cubic-bezier(.65,.18,0,1.04);
	/*transform-origin:right bottom;*/
/*	-webkit-transform: rotate(-10deg) scale(1.8,1.8);
	-moz-transform: rotate(-10deg) scale(1.8,1.8);
	-ms-transform: rotate(-10deg) scale(1.8,1.8);
	-o-transform: rotate(-10deg) scale(1.8,1.8);
	transform: rotate(-10deg) scale(1.8,1.8);*/
}

@-webkit-keyframes rotate_in_anime {
	0% {
		-webkit-transform: rotate(-10deg) scale(1.8,1.8);
	}
	100% {
		-webkit-transform: rotate(0deg) scale(1,1);
	}
}
@-moz-keyframes rotate_in_anime {
	0% {
		-moz-transform: rotate(-10deg) scale(1.8,1.8);
	}
	100% {
		-moz-transform: rotate(0deg) scale(1,1);
	}
}
@-ms-keyframes rotate_in_anime {
	0% {
		-ms-transform: rotate(-10deg) scale(1.8,1.8);
	}
	100% {
		-ms-transform: rotate(0deg) scale(1,1);
	}
}
@-o-keyframes rotate_in_anime {
	0% {
		-o-transform: rotate(-10deg) scale(1.8,1.8);
	}
	100% {
		-o-transform: rotate(0deg) scale(1,1);
	}
}
@keyframes rotate_in_anime {
	0% {
		transform: rotate(-10deg) scale(1.8,1.8);
	}
	100% {
		transform: rotate(0deg) scale(1,1);
	}
}

.hero img {
	width: 100%;
	height: auto;
}

.hero img.top_img_l{
	width: 100%;
	height: auto;
	position:absolute;
	top:0;
	left:0;
	opacity:1;
	transition-duration:8s;
	transition-delay:0.3s;
}

.hero img.ster{
	width: 100%;
	height: auto;
	position:absolute;
	top:0;
	left:0;
	opacity: 1;
	animation-duration:5s;
	animation-delay:0.3s;
	animation-iteration-count: infinite;
	animation-name: anime;
}

@keyframes anime {
    0% {
        opacity:0;    
    }
    50% {
        opacity:1;
    }
    100% {
        opacity:0;
    }
}


.hero img.main_img_sp{
	width: 100%;
	height: auto;
	position:absolute;
	top:0;
	left:0;
	opacity:1;
	transition-duration:5s;
	transition-delay:0.5s;
}


.hero img.top_img{
	width: 52%;
	height: auto;
	position:absolute;
	opacity:0;
    top: 0;
}

.hero img.top_img_sp{
	width: 100%;
	height: auto;
	position:absolute;
	top:0;
	left:0;
	opacity:0;
}

.hero h2 {
	margin: 0;
}





/*タイトル*/
.hero img.mov01_1{
	transition-duration:0.5s;
	transition-delay:0.3s;
	right:0;
}

.hero img.mov01_2{
	transition-duration:0.5s;
	transition-delay:0.8s;
	right:0;
}

.hero img.mov01_3{
	transition-duration:1.7s;
	transition-delay:1.5s;
	right:0;
}

/*キャスト*/
.hero img.mov02{
	transition-duration:1s;
	transition-delay:2.5s;
	top:0;
	right:0;
}

/*賞*/
.hero img.mov03{
	transition-duration:1s;
	transition-delay:3s;
    top: 0;
    right:0;
}

.hero img.date{
    right:auto;
	right: 0;
	width: 52%;
	top: 0%;
}

/*コピー*/
.hero img.mov04{
	transition-duration:2s;
	transition-delay:4s;
	right:auto;
    left: 1%;
    top: -16%;
}







/*タイトル*/
.hero img.mov01_sp{
	transition-duration:1s;
	transition-delay:0.8s;
}

/*賞*/
.hero img.mov02_sp{
	transition-duration:1s;
	transition-delay:1.7s;
}

/*コピー*/
.hero img.mov03_sp{
	transition-duration:1.5s;
	transition-delay:2.5s;
}






.hero .col-md-6.navicon {
	float: left;
	text-align: left;
	position: fixed;
	top: 30px;
	left: 15px;
	z-index: 99;
}

.hero .nav-toggle {
	right: initial;
	left: 15px;
}

.hero .navicon p {
        margin: 27px 0 0 -3px;
}

.hero .col-md-6.navicon {
	float: left;
	text-align: left;
	position: fixed;
    top: 35px;
	left: 15px;
	z-index: 9999999999;
}


/* ==========================================================================
grnv
========================================================================== */

.grnv i {
    margin-left: 8px;
	/*color:#053e7d;*/
}

/*.grnv .about i {
	color:#fff;
}
*/
.menu{
	text-align:center;
}

.grnv ul {
	width: 100%;
	height: auto;
	overflow: hidden;
	margin:0 auto;
	padding:2.5% 0;
	text-align:center;
}

.grnv02 ul {
	width: 100%;
	height: auto;
	overflow: hidden;
	margin:0 auto;
	text-align:center;
}


.grnv{
	/*background:#fff43a;*/
	margin:0;
	padding:0;
	position:relative;
	z-index:0;
	text-align:center;
	background:none !important;
}


.grnv img{
	margin:0;
	padding:0;
	width:20%;
	max-width:330px;
}

.grnv img.main_copy{
	margin:2% auto 0 auto;
	padding:0;
	width:80%;
	max-width:980px;
}

.grnv_banner{
	-webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
	-ms-transition: all 0.3s;
	-o-transition: all 0.3s;
	transition: all 0.3s;
}

.grnv_banner:hover{
	opacity:0.8;
}

.grnv ul li {
	width: 20%;
	height: auto;
	overflow: hidden;
	margin: 0 0.5% 0 0;
	list-style: none;
	float: none;
	max-width:165px;
	display:inline-block ;
	
}



.grnv ul li.director {
	width: 100%;
	height: auto;
	overflow: hidden;
	margin: 0 0.5% 0 0;
	list-style: none;
	float: none;
	max-width:9999px !important;
	display:inline-block;
	background:none;
	
}

.sns {
    width: 50%;
    margin: 10px auto 0 auto;
    display: block;
    position: relative;
    z-index: 9;
}

.sns li {
    display: inline-block;
    margin: 0;
    padding: 0;
    position: relative;
    z-index: 10;
}

.sns li:last-child {
    top: 4px;
}

.sns li:first-child {
    top: 4px;
}


.sns li {
    width: auto;
    height: auto;
    overflow: hidden;
    margin: 0 0.5% 0 0;
    list-style: none;
    float: none;
    max-width: inherit;
    display: inline-block;
}


.grnv a.banners{
	width:200px;
	display:block;
	margin:0 auto;
	padding:5px;
	background:#fff;
}

.grnv a.banners:hover{
	opacity:0.8;
}


/* ==========================================================================
grnv-end
========================================================================== */

.title{
	margin: 0;
	padding: 0;
}

.title .absolute{
	margin: 0;
	padding: 0;
	opacity: 0;
	top: 0;
	left:-15%;
	transition-duration: 2s;
}

.title h2{
	margin: 0;
	padding:0;
}


.title img.tit01{transition-delay: 0.5s;}
.title img.tit02{transition-delay: 0.8s;}
.title img.tit03{transition-delay: 1.1s;}
.title img.tit04{transition-delay: 2.4s;}
.title img.tit05{transition-delay: 2.7s;}
.title img.tit06{transition-delay: 3s;}



.award{
	margin: 0;
	padding: 0 ;
	position: relative;
	background: url(../img/aw_bg02.jpg) bottom left;
	background-size: 100% auto;
    margin-top: -26%;
}

.award .gr{
	height: 50%;
	width: 100%;
	top: 0;
	left: 0;
	position: absolute;
	background: -moz-linear-gradient(top,  rgba(0,0,0,1) 0%, rgba(0,0,0,0) 65%, rgba(0,0,0,0) 100%); /* FF3.6-15 */
	background: -webkit-linear-gradient(top,  rgba(0,0,0,1) 0%,rgba(0,0,0,0) 65%,rgba(0,0,0,0) 100%); /* Chrome10-25,Safari5.1-6 */
	background: linear-gradient(to bottom,  rgba(0,0,0,1) 0%,rgba(0,0,0,0) 65%,rgba(0,0,0,0) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#000000', endColorstr='#00000000',GradientType=0 ); /* IE6-9 */
}



.award .aw{
	width: 90%;
	margin: 0 auto;
	padding: 35% 0 45% 0;
}


.award .mia{
    width: 31.2%;
    top :49.3%;
    left: 9.8%;
    position: absolute;
    z-index: 2;
	pointer-events: none;
}

.award .mia_bg{
    width:100%;
	overflow: hidden;

}



.award .conts{
	margin: 0 auto;
	padding: 0;
	position: absolute;
	z-index: ;
	width: 100%;
	top:0;
	left: 0;
	height: 100%;
	overflow: scroll;
}





.about_tit{
	margin: 0;
	padding: 0;
	background: #fff;
}

.about_tit .right{
	margin: 0;
	padding: 30% 0 0 0;
	width:53%;
	float: right;
}

.about_tit h2{
	margin: 0;
	padding:0;
}

.about{
	margin: 0;
	padding: 0;
	background: url(../img/about_bg.jpg);
	background-size: cover;
	position: relative;
	color: #fff;
}

.about .right{
	margin: 0;
	padding: 0;
}

.about .right h3{
	margin: 0;
	padding: 0;
}

.about .left{
	margin: 0;
	padding: 5% 0;
	width: 45%;
	display: block;
	position: absolute;
	top: 0;
	left: 5%;
}

.about .left h4{
	line-height: 1.5em;
	font-size: 18px;
	font-weight: bold;
	margin: 0;
	padding: 0;
}

.about .left p{
	line-height: 1.5em;
	margin: 0;
	padding: 0;
	margin-top: 3.6%;
}

.about .abot_copy{
	margin: 0;
	padding: 2.5% 5%;
	text-align: center;
	font-size: 20px;
	color: #fff100;
	background: rgba(54, 88, 153, 0.48);
}


.about .abot_copy h4{
	line-height: 1.8em;
	margin: 0;
	padding: 0;
	font-weight: bold;
}


.story{
	margin: 0;
	padding: 18% 5% 26% 5%;
	min-height: 100vh;
	background: url(../img/story_bg.jpg) no-repeat top;
	background-attachment: fixed;
	background-size: cover;
	position: relative;
	color: #fff;
}


.about .conts h3{
	margin: 0;
	padding: 0;
}

.story .conts{
	margin: 0;
	padding:0;
	display: block;
	text-align: center;
}

.story .conts h4{
	line-height: 1.8em;
	font-size: 18px;
	font-weight: bold;
	margin: 0;
	padding: 0;
}

.story .conts p{
	line-height: 1.5em;
	margin: 0;
	padding: 0;
	margin-top: 3.6%;
}



.story02{
	margin: 0;
	padding:0 5% 3.5% 5%;
	background: url(../img/cast_bg.jpg) center top;
	background-size: cover;
	background-attachment: fixed;
	position: relative;
	color: #fff;
	overflow: hidden;
	font-size: 12px;
}

.story02 p{
	line-height: 2em;
}

.story02 .casts_img{
	position: absolute;
	bottom: 0;
	left:0;
    width: 100%;
}

.story02 .story_txt{
    margin: 0;
    padding: 30% 35% 8%;
    position: relative;
    z-index: 1;
}


.story02 .story_txt h3{
    margin: 0;
    padding: 0 0 0 0;
    width: 6em;
    margin-bottom: 20px;

}

.story02 .story_txt p{
	text-shadow: 0px 2px 4px rgba(0,0,0,0.94);
}

.story02 .profile{
	margin: 0;
	padding: 0;
	width: 23%;
	display: block;
}

.story02 .profile h4{
	margin: 0 auto;
	padding: 0;
	width: 2.5em;
}

.story02 .profile p{
	margin:15px 0 0 0;
	padding: 0;
}

.story02 .profile p span{
	margin: 0;
	padding: 0 0 0.5em 0;
	display: block;
	text-align: center;
	font-weight: bold;
	font-size: 16px;
}

.story02 .seb_p{
	float: left;
	position: relative;
	z-index: 2;

}

.story02 .mia_p{
	float: right;
	position: relative;
	z-index: 2;

}



.story03{
	margin: 0;
	padding: 0 ;
	color: #fff;
	background: #000;
}


.story03 h3{
	margin: 0 auto;
	padding: 0 0 8% 0;
	line-height: 1.5em;
	font-size: 18px;
	text-align: center;
}

.story03 h3 span{
	font-size: 20px;
	font-weight: 900;
	line-height: 2.5em;
	
}

.music{
	margin: 0;
	padding: 0;
	background: #000;
}

.music .conts{
	margin: 0;
	padding: 30% 5% 50% ;
	top: 0;
	right: 0;
	height: 100%;
	width: 100%;
	overflow: scroll;
	text-align: right;
	overflow-x:hidden;
	overflow-y:auto;
	/*perspective:300px;*/
}

.music .music_txt{
	width: 34.7%;
	text-align: left;
	display: inline-block;
	/*transform:translateZ(-300px) scale(2);*/
}

.music .gr_top{
	width: 100%;
	height: 188px;
	left: 0;
	top: 0;
	background: url(../img/m_gr_top.png) repeat-x;
	background-size: auto 100%;
}

.music .gr_bottom{
	width: 100%;
	height:245px;
	left: 0;
	bottom: 0;
	background: url(../img/m_gr_bottom.png) repeat-x;
	background-size: auto 100%;
}


.note{
	margin: 0;
	padding: 0;
	position: relative;
	overflow: hidden;
}


.note h2{
    margin: auto;
    padding: 0;
    position: absolute;
    width: 23.4%;
    top: 47.4%;
    right: 0;
    left: 0;
}


.note .note_sr{
	top: 3%;
	left: 0;
	width: 100%;
}


.note ul{
	margin: 0;
	padding: 0;
}

.note .tx05 h3 {
    margin: 0 0 40px;
    text-align: center;
    color: #eee6c3;
    font-size: 5.5vw;
    font-family: "a-otf-futo-min-a101-pr6n",sans-serif;
}

.note li{
	width: 22%;
	margin: 0 2%;
	display: block;
}

.note li a.relative:after,
.note_dit h2:after{
    content: "";
    margin: 0;
    padding: 0;
    position: absolute;
    z-index: -1;
	pointer-events: none;
    top: -8%;
    left: -12.5%;
    width: 125%;
    height: 125%;
}

.note .note01 a.relative:after,
.note_dit h2.note_dit01:after{
    background: url(../img/note/note_01_bg.png) no-repeat;
    background-size: 100%;
	 top:1%;
}

.note .note02 a.relative:after{
    background: url(../img/note/note_02_bg.png) no-repeat;
    background-size: 100%;
    z-index: -1;
}

.note .note03 a.relative:after{
    background: url(../img/note/note_03_bg.png) no-repeat;
    background-size: 100%;
    top: -5%;
}

.note .note04 a.relative:after{
    background: url(../img/note/note_04_bg.png) no-repeat;
    background-size: 100%;
    top: -6%;
}

.note .note05 a.relative:after{
    background: url(../img/note/note_05_bg.png) no-repeat;
    background-size: 100%;
    top: -1%;
}

.note .note06 a.relative:after{
    background: url(../img/note/note_06_bg.png) no-repeat;
    background-size: 100%;
    top: -6%;
}

.note .note07 a.relative:after{
    background: url(../img/note/note_07_bg.png) no-repeat;
    background-size: 100%;
    top: -3%;
}

.note .note08 a.relative:after{
    background: url(../img/note/note_08_bg.png) no-repeat;
    background-size: 100%;
    top: -6%;
}

.note .note09 a.relative:after{
    background: url(../img/note/note_09_bg.png) no-repeat;
    background-size: 100%;
    top: -6%;
}

.note_txt{
	margin-top: 5%;
}



/*.note li:nth-child(2n) img,.note li:nth-child(5) img{box-shadow: 0px 51px 79px rgba(255,211,211,0.19);}
.note li:nth-child(3n) img{box-shadow: 0px 51px 79px rgba(252,255,13,0.24);}
.note li:first-child img,.note li:nth-child(3n+1) img{box-shadow: 0px 51px 79px rgba(96,193,214,0.38);}*/


.cast{
	margin: 0;
	padding: 0;
	position: relative;
	background:#fff;
}

.cast .conts{
	margin: 0 auto;
	padding:2.5% 5% 15% 5%;
}

.cast h2{
	margin: 0 auto;
	padding: 0;
	width: 23.2%;
}

.cast .gr_top{
	background: url(../img/cast/c_gr_top.png) repeat-x;
	background-size: auto 100%;
	top: 0;
	left: 0;
	width: 100%;
	height: 50px;
}

.cast01,
.cast02{
	letter-spacing: -.40em;
	text-align: center;
	margin-top: 2%;
}


.cast02{

	margin-top: 5.6%;
}

.cast dl{
	padding: 0;
	display: inline-block;
	letter-spacing: normal; 
}

.cast .cast01 dl{
    margin: 0px 6.7%;
    width: 27.3%;
}

.cast .cast02 dl{
	width: 19%;
}

.cast .cast02 dl:nth-child(2){
	    margin: 0 15.6%;
}

.cast a{
	display: block;
}

.cast a img{
	-webkit-transition: all 0.5s;
	-moz-transition: all 0.5s;
	-ms-transition: all 0.5s;
	-o-transition: all 0.5s;
	transition: all 0.5s;
}

.cast a:hover img{
	transform: rotateY(360deg);
}


.cast dt{
	margin: 0 auto;
	padding: 0;
	position: relative;
	z-index: 1;
	overflow: inherit;
}

.cast .cast01 dt:after{
    content: "";
    margin: auto;
    padding: 0;
    position: absolute;
    top: -11%;
    left: -21.5%;
    height: 143%;
    width: 143%;
    z-index: -1;
}

.cast dt.cast01_01:after{
    background: url(../img/cast/01_bg.png) no-repeat;
    background-size: 100%;
}

.cast dt.cast01_02:after{
    background: url(../img/cast/02_bg.png) no-repeat;
    background-size: 100%;
}


.cast dt img{
	margin: 0;
	padding: 0;
	border-radius: 50%;
	border: 5px solid #fff;
}

.cast dt.cast02_05 img{
	box-shadow: 0px 24px 51px 0px rgba(2,2,0,0.35) inset;
}

.cast dd{
	margin: 15.4% auto 0;
	padding: 0;
	position: relative;
	z-index: 1;
	text-align: center;
}

.cast .cast01 dd img{
	display: inline-block;
	width: 71%;
}


.cast .cast02 dd img{
	display: inline-block;
	width: 100%;
}


.staff{
	margin: 0;
	padding: 0;
	position: relative;
	z-index: 1;
	background: url(../img/staff_bg.jpg) #e1d2bf no-repeat;
	background-position: bottom;
	background-size: 100% auto;
}

.staff .director{
	padding: 0;
	margin: auto;
	width:23.8%;
	top:-13.5%;
	left: 0;
	right: 0;
	
}

.staff .conts{
	margin: 0;
	padding: 2% 11.2% 45%;
}

.staff dl{
	padding: 0;
	margin: 0 auto;
}

.staff dt{
	margin: 0 auto;
	padding: 0;
	position: relative;
	z-index: 1;
	overflow: inherit;
}

.staff dt:after{
    content: "";
    margin: auto;
    padding: 0;
    position: absolute;
    top: -3.5%;
    left: -21.5%;
    height: 143%;
    width: 143%;
    z-index: -1;
}

.staff dt:after{
    background: url(../img/director_bg.png) no-repeat;
    background-size: 100%;
}

.staff dt img{
	margin: 0;
	padding: 0;
	border-radius: 50%;
	border: 5px solid #fff;
}

.staff dt a{
	display: block;
}

.staff dt img{
	-webkit-transition: all 0.5s;
	-moz-transition: all 0.5s;
	-ms-transition: all 0.5s;
	-o-transition: all 0.5s;
	transition: all 0.5s;
}

.staff dt a:hover img{
	transform: rotateY(360deg);
}

.staff dd{
	margin: 8% auto 0;
	padding: 0;
	position: relative;
	z-index: 1;
	text-align: center;
}

.staff dd img{
	display: inline-block;
	width: 71%;
}




.staff ul{
	margin: 0;
	padding: 0;
	position: relative;
	display: block;
	width: 23.4%;
}

.staff ul.staff01{
	float: left;
}

.staff ul.staff02{
	float: right;
}

.staff li{
	margin: 0;
	padding: 12% 2% 12% 0;
	letter-spacing: -.40em;
}

.staff li a{
	display: block;
}

.staff li a:hover{
	opacity: 0.5;
}


/*.staff li:nth-child(even){
	float: right;
}*/

.staff li:nth-child(2){
	border-top: 1px solid #FFFFFF;
	border-bottom: 1px solid #FFFFFF;
}


.staff li img{
	margin: 0;
	padding: 0 0 0 4%;
	width: 90%;
	display: inline-block;
	letter-spacing: normal;
	vertical-align: middle;
}

.staff li span{
	margin: 0;
	padding: 0;
	font-size: 1.5vw;
	color: #680898;
	vertical-align: middle;
}

.staff h2{
	margin: 2% auto;
	padding: 0;
	width: 28.5%;
}



/* ==========================================================================
news
========================================================================== */
body.news {
	background-color: #7815b7;
    background-image: url(../img/news_bg.png);
	background-size: 100% 650px;
    background-position: center top;
    background-repeat: repeat-x;
	font-weight: 600;
    min-width: inherit;
}

.news .fix{
	position:fixed;
	top:0;
	left:0;
	width:100%;
	height:100%;
	z-index:-1;	
    background-size: cover;
}

body.news .container {
	width: 100%;
    padding: 0 5%;
	max-width:1000px;
	margin:0 auto;
}
.news h1 {
	font-family: 'Raleway', sans-serif;
    letter-spacing: 2px;
	font-size: 26px;
	font-weight: normal;
    margin-bottom: 20px;
    color: #fff100;
	margin: 30px 0 0 0;
	border-bottom: #fff solid 1px;
	padding-bottom:10px;
}
.news h1 span {
	font-size: 13px;
	padding: 0 0 0 20px;
}
.news a {
    color: #fff100;
}

.news a.txt {
	text-decoration:underline;
}

.news a:hover {
    color: #fff;
}
.news dl {
	width: 100%;
	height:auto;
	margin: 0;
	padding: 30px 0;
	border-bottom: #fff dotted 1px;
	color:#fff;
}

.news dl:nth-last-of-type(1) {
	border-bottom: none;
}


.news dl dt {
	font-size: 16px;
	font-weight: bold;
	line-height: 1.5em;
	margin: 0;
	padding: 30px 0 20px 0;
    color: #fff;
}
.news dl dt:first-child {
	padding: 0 0 20px 0;
}
.news dl dt span {
	font-size: 13px;
	font-weight: 400;
	display: block;
	padding: 0 0 10px 0;
	float: right;
	color:#fff;
	font-family: 'Raleway', sans-serif;
}
.news dl dd {
	font-size: 14px;
	line-height:1.8em;
	margin: 0;
}
.news dl dd:last-child {
	border-bottom: none;
}

.news dd span{
	color:#fff100;
	font-size: 17px;
	font-weight: 500;
}


.img_box{
	width:100%;
	margin:0 auto;
}

.img_logo{
	float:left;
	margin-left:25px;
}

.img_poster{
	float:left;
	margin-left:25px;
}

.news img {
	width:100%;
	max-width:600px;
	height:auto !important;
	margin-top: 0.8em;
}

.news img.size_s {
	max-width:400px;
}

.news img.size_ss {
	width: 100%;
	max-width: 250px;
	vertical-align:bottom;
}

.news .button_cg{
	max-width: 150px;
	margin: 0 auto;
	padding: 0;
}

.news .button_cg a{
	margin: 0 auto;
	padding: 0;
	display: block;
}

.news .button_cg img{
	margin: 0 auto;
	padding: 0;
	display: block;
}


.news .top_link{
	text-align: center;
	display: block;
	width: 150px;
	margin: 0 auto;
}

.news .top_link img{
}


/* ==========================================================================
cast popup
========================================================================== */
body.cast_staff {
    background-color: #7815b7;
    background-image: url(../img/news_bg.png);
    background-size: 100% 650px;
    background-position: center top;
    background-repeat: repeat-x;
	min-width: inherit;
}


body.cast_staff .container {
	width: 100%;
	height: auto;
    padding: 50px 5% 50px 5%;
}


body.cast_staff h1 {
    font-family: 'Raleway', sans-serif;
    letter-spacing: 2px;
    font-size: 26px;
    font-weight: normal;
    margin-bottom: 20px;
    color: #fff100;
    margin: 0;
    padding-bottom: 10px;
}
body.cast_staff h1 span {
	display: block;
	padding: 5px 0 0 0;
	font-size: 18px;
}

body.cast_staff .left{
	width: 16%;
	float: left;
	border-radius: 50%;
	overflow: hidden;
}

body.cast_staff .right{
	width: 80%;
	float: right;
}

body.cast_staff p {
	font-size: 12px;
	line-height: 1.5em;
	letter-spacing: 0;
    color: #fff;
	margin: 0 0 20px 0;
}
body.cast_staff p.conts {
	line-height: 1.7em;
	letter-spacing: 0;
    color: #fff;
	margin: 0;
	padding: 0;
}

.button_cg img {
    width: 100px !important;
    padding: 0;
	margin: 0 auto;
}

/* ==========================================================================
staff popup
========================================================================== */
body.staff {
    background-color: #7815b7;
    background-image: url(../img/news_bg.png);
    background-size: 100% 650px;
    background-position: center top;
    background-repeat: repeat-x;
	min-width: inherit;
}
body.staff .container {
	width: 100%;
	height: auto;
    padding: 0 5% 50px 5%;
}
body.staff h1 {
	font-family: 'Josefin Sans', sans-serif;
	font-style:italic;
	font-size: 26px;
	font-weight: 600;
    margin-bottom: 20px;
    color: #16101D;
	margin: 50px 0 10px 0;
}
body.staff h1 span {
	display: block;
	padding: 5px 10px 0 0;
	font-size: 18px;
	float: left;
}
body.staff .col-md-12 img {
	width: 180px;
	height: auto;
	float: right;
}
body.staff p {
	font-size: 12px;
	line-height: 1.5em;
	letter-spacing: 0;
    color: #005a78;
	margin: 0 0 20px 0;
}
body.staff p.conts {
	font-size: 14px;
	line-height: 1.5em;
	letter-spacing: 0;
    color: #464646;
}


/* ==========================================================================
comment
========================================================================== */

.comments_page{
	margin: 0;
	padding: 0 ;
	position: relative;
	background: url(../img/comment_bg.jpg) bottom left;
	background-size: 100% auto;
}

.comments_page .comment_txt{
	width: 80%;
	max-width: 980px;
	margin: 0 auto;
	padding: 3.5% 0 33% 0;
}


.comments_page .mia_and_seb{
    width: 100%;
    bottom :-1px;
    left: 0;
    position: absolute;
    z-index: 2;
	pointer-events: none;
}

.comments_page .mia_bg{
    width:100%;
	overflow: hidden;

}

.comments_page .conts{
	margin: 0 auto;
	padding: 0;
	position: absolute;
	z-index: ;
	width: 100%;
	top:0;
	left: 0;
	height: 100%;
	overflow: scroll;
}

.comments_page h2{
	width: 32%;
	margin: 0 0 5% 0; 
	padding: 0;
}

.comments_page ul{
	letter-spacing: -.40em;
	text-align: center;
	margin: 0 0 1.5% 0; 
	padding: 0;
}

.comments_page ul li {
    display: inline-block;
    letter-spacing: normal; /* 文字間を通常に戻す */
    width: 32.3333333%;
    border: 1px solid #fff;
    line-height: 100px;
    text-align: center;
	position: relative;
	z-index: 1;
	box-shadow:0px 0px 8px 1px rgba(255,255,255,0.4);
}

.comments_page ul li.li_left {
	margin: 0 1.5% 0 0;
}

.comments_page ul li.li_right {
	margin: 0 0 0 1.5%;
}

.comments_page ul li.size_x2 {
    width: 66.1666666%;
}

.comments_page ul li.com_img01,
.comments_page ul li.com_img03,
.comments_page ul li.com_img05,
.comments_page ul li.com_img07,
.comments_page ul li.com_img09,
.comments_page ul li.com_img11{
	box-shadow: none;
	border: none;
	border-radius: 5px;
}

.comments_page ul li.com_img02,
.comments_page ul li.com_img04,
.comments_page ul li.com_img06,
.comments_page ul li.com_img08,
.comments_page ul li.com_img10,
.comments_page ul li.com_img12,
.comments_page ul li.com_img14{
	box-shadow: none;
	border: none;
	margin: 0 0 0 0;
	border-radius: 5px;
}

.comments_page ul li.com_img01:after{
    content: "";
    width: 115%;
    height: 115%;
    position: absolute;
    top: 0.5%;
    left:-6.5%;
    z-index: -1;
    background: url(../img/comment/img01_bg.png);
    background-size: 100% 100%;
	background-position: bottom center;
}

.comments_page ul li.com_img02:after{
    content: "";
    width: 110%;
    height: 110%;
    position: absolute;
    top: 4.5%;
    left: -5%;
    z-index: -1;
    background: url(../img/comment/img02_bg.png);
    background-size: 100% 100%;
    background-position: bottom center;
}

.comments_page ul li.com_img03:after{
    content: "";
    width: 115%;
    height: 115%;
    position: absolute;
    top: 0.5%;
    left:-6.5%;
    z-index: -1;
    background: url(../img/comment/img03_bg.png);
    background-size: 100% 100%;
	background-position: bottom center;
}

.comments_page ul li.com_img04:after{
    content: "";
    width: 110%;
    height: 110%;
    position: absolute;
    top: 4.5%;
    left: -5%;
    z-index: -1;
    background: url(../img/comment/img04_bg.png);
    background-size: 100% 100%;
    background-position: bottom center;
}

.comments_page ul li.com_img05:after{
    content: "";
    width: 110%;
    height: 110%;
    position: absolute;
    top: 4.5%;
    left: -5%;
    z-index: -1;
    background: url(../img/comment/img05_bg.png);
    background-size: 100% 100%;
    background-position: bottom center;
}

.comments_page ul li.com_img06:after{
    content: "";
    width: 110%;
    height: 110%;
    position: absolute;
    top: 4.5%;
    left: -5%;
    z-index: -1;
    background: url(../img/comment/img06_bg.png);
    background-size: 100% 100%;
    background-position: bottom center;
}

.comments_page ul li.com_img07:after{
    content: "";
    width: 115%;
    height: 115%;
    position: absolute;
    top: 0.5%;
    left:-6.5%;
    z-index: -1;
    background: url(../img/comment/img07_bg.png);
    background-size: 100% 100%;
	background-position: bottom center;
}

.comments_page ul li.com_img08:after{
    content: "";
    width: 110%;
    height: 110%;
    position: absolute;
    top: 4.5%;
    left: -5%;
    z-index: -1;
    background: url(../img/comment/img08_bg.png);
    background-size: 100% 100%;
    background-position: bottom center;
}

.comments_page ul li.com_img09:after{
    content: "";
    width: 115%;
    height: 115%;
    position: absolute;
    top: 0.5%;
    left:-6.5%;
    z-index: -1;
    background: url(../img/comment/img09_bg.png);
    background-size: 100% 100%;
	background-position: bottom center;
}

.comments_page ul li.com_img10:after{
    content: "";
    width: 110%;
    height: 110%;
    position: absolute;
    top: 4.5%;
    left: -5%;
    z-index: -1;
    background: url(../img/comment/img10_bg.png);
    background-size: 100% 100%;
    background-position: bottom center;
}

.comments_page ul li.com_img11:after{
    content: "";
    width: 115%;
    height: 115%;
    position: absolute;
    top: 0.5%;
    left:-6.5%;
    z-index: -1;
    background: url(../img/comment/img11_bg.png);
    background-size: 100% 100%;
	background-position: bottom center;
}


.comments_page ul li.com_img12:after{
    content: "";
    width: 110%;
    height: 110%;
    position: absolute;
    top: 4.5%;
    left: -5%;
    z-index: -1;
    background: url(../img/comment/img12_bg.png);
    background-size: 100% 100%;
    background-position: bottom center;
}

.comments_page ul li.com_img14:after{
    content: "";
    width: 110%;
    height: 110%;
    position: absolute;
    top: 4.5%;
    left: -5%;
    z-index: -1;
    background: url(../img/comment/img12_bg.png);
    background-size: 100% 100%;
    background-position: bottom center;
}



.comments_page ul li.com_img01 img,
.comments_page ul li.com_img02 img,
.comments_page ul li.com_img03 img,
.comments_page ul li.com_img04 img,
.comments_page ul li.com_img05 img,
.comments_page ul li.com_img06 img,
.comments_page ul li.com_img07 img,
.comments_page ul li.com_img08 img,
.comments_page ul li.com_img09 img,
.comments_page ul li.com_img10 img,
.comments_page ul li.com_img11 img,
.comments_page ul li.com_img12 img,
.comments_page ul li.com_img14 img
{
	border-radius: 5px;
}

.ulizahtml5 {
    width: 100%;
    margin: 0 auto;
}

@media screen and (max-width:1400px){
	
.music .gr_top {
    height: 188px;
}
	
.music .gr_bottom {
    height: 206px;
}
	
}




/* ----------------------------------------------------------------
	note_dit
-----------------------------------------------------------------*/



#content01,
#content02,
#content03,
#content04,
#content05,
#content06,
#content07,
#content08,
#content09{
	background:url(../img/note_modal/bg01.jpg) no-repeat;
	background-size: 100% auto;
	background-position:bottom;
	color: #fff;
}


/*.modal-contents{
	display:block;
	width:25%;
	max-width: 500px;
	margin:0 auto;
	padding-bottom: 2.5%;
}*/

.modal-contents {
    display: block;
    width: 50%;
    max-width: 800px;
    margin: 0 auto;
    padding-bottom: 2.5%;
}

.note_dit h2{
	margin:0 auto;
	padding:26% 0 5% 0;
	position: relative;
	width: 50%;
}

.note_dit h3{
	margin:0 auto;
	padding:0 0 30px 0;
	position: relative;
}

.note_dit p{
	width:100%;
	margin:0;
	padding:60px 0 0 0;
	line-height: 2em;
}

.note_dit p span{
	font-size: 15px;
	font-weight: 700;
}


.close_a{
	position:fixed;
    top: 15px;
    left: 15px;
}

.close_button{
	width:50px;
	height:50px;
	margin:0;
	padding:0;
	display:block;
}

.modal-contents .close_button{
	width:150px;
	height:auto;
	margin:3% auto;
	padding:0;
	display:block;
}

.modal-contents span.border{
	display: block;
	margin: 0 auto 5%;
	padding: 0;
	width: 1px;
	height: 140px;
	background: #fff;
}

.note_dit h2:after{
    content: "";
    margin: 0;
    padding: 0;
    position: absolute;
    z-index: -1;
	pointer-events: none;
    left: -12.5%;
    width: 125%;
    height: 125%;
}

.note_dit h2.note_dit01:after{
    background: url(../img/note/note_01_bg.png) no-repeat;
    background-size: 100%;
	top: 32%;
}

.note_dit h2.note_dit02:after{
    background: url(../img/note/note_02_bg.png) no-repeat;
    background-size: 100%;
    z-index: -1;
	top: 27%;
}

.note_dit h2.note_dit03:after{
    background: url(../img/note/note_03_bg.png) no-repeat;
    background-size: 100%;
    top: 30%;
}

.note_dit h2.note_dit04:after{
    background: url(../img/note/note_04_bg.png) no-repeat;
    background-size: 100%;
    top: 29%;
}

.note_dit h2.note_dit05:after{
    background: url(../img/note/note_05_bg.png) no-repeat;
    background-size: 100%;
    top: 31%;
}

.note_dit h2.note_dit06:after{
    background: url(../img/note/note_06_bg.png) no-repeat;
    background-size: 100%;
    top: 28%;
}

.note_dit h2.note_dit07:after{
    background: url(../img/note/note_07_bg.png) no-repeat;
    background-size: 100%;
    top: 29%;
}

.note_dit h2.note_dit08:after{
    background: url(../img/note/note_08_bg.png) no-repeat;
    background-size: 100%;
    top: 29%;
}

.note_dit h2.note_dit09:after{
    background: url(../img/note/note_09_bg.png) no-repeat;
    background-size: 100%;
    top:29%;
}


	.ending {
position:relative;
}


/***** Spotify Player *****/
iframe.player_top {
position:absolute;
top:44%;
left:4%;
}
iframe.player_about {
margin:300px 0 0;
}
iframe.player_content {
display:block;
margin:40px auto 0;
}
iframe.player_ft {
position:absolute;
top:10%;
left:50%;
width:250px;
margin:0 0 0 -125px;
}

.fancybox-inner {
     overflow:hidden !important;
}
