@charset "UTF-8";
html,body {
	height: 100%;
}
body {
	margin: 0;
	padding: 0;
}
section,div,p,h1,h2,h3,h4,h5,h6,ul,ol,li,dl,dt,dd,form,iframe,span {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}
li {
	list-style-type: none;
}
a {
	outline: none;
	text-decoration: none;
}
img {
	width: 100%;
	height: auto;
	vertical-align: bottom;
}
.sp,
.tablet {
	display: none;
}

/* --------------------
	Font Setting
--------------------*/
html {
	font-size: 62.5%;
}
body {
  font-size: 1.4rem;
	letter-spacing: 0.03em;
}
p {
	font-size: 1.4rem;
	line-height: 1.6em;
}


/* --------------------
	Style Setting
--------------------*/
.ld-overlay {
  position: fixed;
	color: #AAA;
	font-size: 12px;
	letter-spacing: 0.4pt;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
	text-indent: -9999px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #000;
  z-index: 1000;
  overflow: hidden;
}
body {
}

#wrap {
	min-width: 1200px;
	/*max-width: 1620px;*/
	margin: 0 auto;
	height: 100%;
	min-height: 768px;
	background: #000 url("../images/launch/bg_home.jpg") no-repeat center center;
	background-size: cover;
	overflow: hidden;
	position: relative;
}
#home {
	width: 1200px;
	height: 100%;
	min-height: 768px;
	margin: 0 auto 100px;
	position: relative;
	display: flex;
	flex-direction: row-reverse;
	/*background: url("../images/teaser/bk_op60.png") repeat;
	box-shadow: 0 0 50px 50px rgba(0,0,0,0.2);*/
}

#home__kv {
	width: 48%;
	height: 100%;
	min-height: 768px;
	position: relative;
	background: url("../images/launch/kv_home.jpg") no-repeat center top;
	background-size: cover;
}
#home__kv .kv_billing {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
}
#home__info {
	width: 52%;
	height: 100%;
	min-height: 768px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	margin: 0 auto;
	position: relative;
}

a#home__trailer  {
	display: block;
	width: 470px;
	height: 265px;
	margin: 20px auto auto 100px;
	text-indent: -9999px;
	background: url("../images/launch/btn_trailer.jpg") no-repeat center center;
	background-size: cover;
	overflow: hidden;
	transition: opacity 0.3s;
}
a#home__trailer:hover {
	opacity: 0.8;
}

.casting {
	width: 350px;
	margin: auto;
}
.koukai {
	/*width: 390px;
	padding-top: 10px;*/
	margin: auto auto 5px;
	width: 464px;
	padding-left: 37px;
}
.bnr-amazon {
	margin: auto auto 10px;
	width: 444px;
	padding-left: 47px;
}
.bnr-dvd {
	margin: 0 auto auto;
	width: 444px;
	padding-left: 47px;
}
.bnr-amazon a:hover,
.bnr-dvd a:hover {
	opacity: 0.8;
}
.billing {
	width: 420px;
	padding-left: 37px;
	text-align: center;
	margin: 0 auto auto;
}
.copyright {
	font-size: 10px;
	font-family: "Arial", "sans-serif";
	color: #93858d;
	text-align: center;
	margin-top: 15px;
	padding-bottom: 20px;
}

#home__nav {
	display: flex;
	width: 464px;
	padding: 0 24px;
	height: 45px;
	background: url("../images/launch/home_nav_bg.png") repeat left top;
	background-size: 90px 45px;
	flex-wrap: wrap;
	justify-content: flex-start;
	margin: 21px auto 0 104px;
	border-radius: 30px;
}
#home__nav li {

}
#home__nav li.btn-introstory {
	width: 110px;
}
#home__nav li.btn-trailer {
	width: 98px;
	background: url("../images/launch/home_nab_dot.png") no-repeat left center;
	background-size: 5px;
}
#home__nav li.btn-theater {
	width: 113px;
	background: url("../images/launch/home_nab_dot.png") no-repeat left center;
	background-size: 5px;
}
#home__nav li.btn-comments {
	width: 95px;
	background: url("../images/launch/home_nab_dot.png") no-repeat left center;
	background-size: 5px;
}
#home__nav li a {
	width: 100%;
	display: block;
	position: relative;
	height: 45px;
	background: url("../images/launch/home_nav_txt.png") no-repeat left top;
	background-size: 464px 45px;
	text-indent: -9999px;
	transition: opacity 0.3s;
}
#home__nav li.btn-introstory a {
	background-position: -24px top;
}
#home__nav li.btn-trailer a {
	background-position: -134px top;
}
#home__nav li.btn-theater a {
	background-position: -232px top ;
}
#home__nav li.btn-comments a {
	background-position: -345px top;
}
#home__nav li a:hover {
	opacity: 0.6;
}
#home__nav li a.new::after {
	content: '';
	display: block;
	width: 30px;
	height: 10px;
	position: absolute;
	top: -5px;
	left: 50%;
	margin-left: -15px;
	background: url("../images/launch/home_nav_new.png") no-repeat center top;
	background-size: 30px 10px;
}

.campaign {
	width: 455px;
	padding: 0;
	margin: auto auto 0 109px;
	background: url("../images/launch/campaign_bg_loop.png") repeat right top;
	background-size: 50px;
	border-radius: 15px;
}
.campaign a {
	transition: opacity 0.2s;
}
.campaign a:hover {
	opacity: 0.6;
}
.campaign-inner {
	padding-bottom: 40px;
	background: url("../images/launch/campaign_bg_bottom.png") no-repeat left bottom;
	background-size: 100% auto;
}
.campaign-title {
	background: url("../images/launch/campaign_bg_top.png") no-repeat left top;
	background-size: 100% auto;
}
.campaign-bnrs {
	display: flex;
	flex-wrap: wrap;
	flex-direction: row-reverse;
	justify-content: space-between;
	width: 100%;
	padding: 15px 54px;
	margin: 15px auto 0;
	background: url("../images/launch/campaign_bnrs_bg.png") repeat;
}
.campaign .campaign-btn {
	width: 309px;
	margin: 0 auto;
}
.campaign .campaign-major {
	/*margin-top: 30px;*/
}
/*.campaign .campaign-major,
.campaign .campaign-mubichike {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	width: 414px;
	margin-left: 41px;
	margin-top: 35px;
	position: relative;
}*/
.campaign .campaign-major,
.campaign .campaign-mubichike {
	width: 163px;
	position: relative;
}
.campaign .campaign-major .campaign-special {
	position: absolute;
	top: -18px;
	right: -88px;
	width: 88px;
}
.campaign .campaign-major .campaign-bnr,
.campaign .campaign-mubichike .campaign-bnr {
	/*width: 210px;*/
	width: 163px;
}
.campaign .campaign-major .campaign-t,
.campaign .campaign-mubichike .campaign-t {
	/*width: 128px;*/
}
.campaign .campaign-sub {
	font-size: 11px;
	color: #FFF;
}
.campaign-commentary .campaign-btn2 {
	display: block;
	width: 309px;
	margin: 0 auto;
}

.snsbtns {
	position: absolute;
	top: 50%;
	left: 0;
	z-index: 100;
}
.snsbtns li a {
	display: block;
	width: 50px;
	height: 50px;
	text-indent: -9999px;
	background: url("../images/launch/snsbtns.png") no-repeat left top;
	background-size: 50px 100px;
	transition: opacity 0.2s;
}
.snsbtns li.btn-twitter a {
	background-position: left top;
}
.snsbtns li.btn-instagram a {
	background-position: left bottom;
}
.snsbtns li a:hover {
	opacity: 0.8;
}

.snsbtns,
#home__nav,
#home__trailer,
.casting,
.koukai,
.bnr-amazon,
.bnr-dvd,
.billing,
.copyright {
	opacity: 0;
}

/* Comments */
#comments {
	position: relative;
	padding-right: 520px;
	width: 1200px;
	min-width: 1200px;
	margin: 0 auto;
	height: 100%;
}
#comments .comment-imgs {
	position: absolute;
	top: 0;
	right: 0;
	width: 540px;
	padding: 120px 30px 0;
}
#comments .comment-imgs img {
	display: block;
	margin-bottom: 8px;
}
#comments .comment-header {
	height: 170px;
	padding-top: 120px;
	background: url("../images/comments/comment_title_shadow.png") no-repeat left top;
	background-size: auto 170px;
}
#comments .area-title {
	width: 408px;
	margin-left: 100px;
}
#comments .comment-lists {
	width: 470px;
	margin: 0 auto;
	padding-bottom: 100px;
}
#comments .comment-lists li {
	margin-bottom: 90px;
}
#comments .bg {
	position: fixed;
	z-index: -1;
	top: 0;
	left: 0;
	width: 100%;
	text-indent: -9999px;
	height: 100%;
	background: url("../images/comments/comment_bg.jpg") no-repeat center top;
	background-size: cover;
}

#introstory {
	min-width: 1200px;
	padding: 0 0 70px;
	background: #221912 url("../images/launch/introstory_bg.jpg") no-repeat center center;
	background-size: cover;
}
#introstory .intro {
	width: 1200px;
	margin: 0 auto;
	position: relative;
}

#introstory .catch1 {
	width: 90%;
	position: absolute;
	top: 40px;
	left: 5%;
}
#introstory .story {
	width: 1200px;
	margin: 0 auto;
}
#cast {
	min-width: 1200px;
	background: #FFF;
	padding-top: 100px;
}
#cast .cast-inner {
	width: 1000px;
	margin: 0 auto;
	padding: 100px 95px 50px;
	background: url("../images/about/cast_t1.png") no-repeat center top;
	background-size: 1000px 165px;
}
#cast .area-title {
	display: none;
}
.cast-block {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	width: 770px;
}
.cast-block:nth-child(2n) {
	margin: 0 auto 65px 0;
}
.cast-block:nth-child(2n+1) {
	margin: 0 0 65px auto;
	flex-direction: row-reverse;
}
.cast-block .cast-img {
	width: 230px;
}
.cast-block .cast-text {
	width: 510px;
	color: #65306d;
}
.cast-block .cast-name {
	width: 375px;
	margin-bottom: 20px;
}

#staff {
	min-width: 1200px;
	background: #FFF;
	padding-top: 100px;
}
#staff .staff-inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	width: 1000px;
	margin: 0 auto;
	padding: 100px 75px 0;
	background: url("../images/about/staff_t1.png") no-repeat center top;
	background-size: 1000px 173px;
}
#staff .area-title {
	display: none;
}
.staff-block {
	width: 385px;
}
.staff-block:nth-child(2n) {
	margin: 0 auto 65px 0;
}
.staff-block:nth-child(2n+1) {
	margin: 0 0 65px auto;
	flex-direction: row-reverse;
}
.staff-block .staff-text {
	color: #65306d;
}
.staff-block .staff-name {
	width: 375px;
	margin-bottom: 12px;
}
.staff-footer {
	width: 750px;
	padding: 30px 0 60px;
	margin: 0 auto;
}
#gnav {
	position: fixed;
	top: -100px;
	left: 50%;
	margin-left: -462px;
	width: 925px;
	z-index: 1000;
}
#gnav ul {
	display: flex;
	margin-top: 20px;
	background: url("../images/launch/gnav_bg.png") no-repeat left top;
	background-size: 925px 45px;
	width: 925px;
	height: 45px;
}
#gnav li a {
	display: block;
	position: relative;
	width: 100%;
	height: 45px;
	text-indent: -9999px;
	background: url("../images/launch/gnav_btns.png") no-repeat left top;
	background-size: 925px 45px;
	transition: all 0.3s;
}
#gnav li a:hover {
	opacity: 0.6;
}
#gnav li a::after {
	content: '';
	display: block;
	width: 4px;
	height: 4px;
	border-radius: 4px;
	background: #FFF;
	position: absolute;
}
#gnav li:first-child a::after {
	display: none;
}
#gnav .btn1 a {width: 119px; background-position: left top;}
#gnav .btn2 a {width: 216px; background-position: -119px top;}
#gnav .btn3 a {width: 114px; background-position: -335px top;}
#gnav .btn4 a {width: 123px; background-position: -449px top;}
#gnav .btn5 a {width: 98px; background-position: -572px top;}
#gnav .btn6 a {width: 114px; background-position: -670px top;}
#gnav .btn7 a {width: 105px; background-position: -784px top;}



#trailer-btns {
	overflow: hidden;
	display: flex;
	flex-wrap: wrap;
	padding: 10px;
	background: #FFF;
}
#trailer-btns li {
	width: 30%;
	box-sizing: border-box;
}
#trailer-btns li span {
	display: block;
	letter-spacing: 0.6pt;
	background: #673260;
	line-height: 32px;
	text-align: center;
	font-size: 13px;
	color: #FFF;
	border-radius: 30px;
	cursor: pointer;
}
#trailer-btns li.v0,
#trailer-btns li.v1,
#trailer-btns li.v2 {padding-right: 10px;}

#trailer-btns li span.current {
	background: #FFF!important;
	color: #673260!important;
	border: solid 1px #673260!important;
	cursor: default!important;
}

/* SP用予告編 */
#trailer-sp {
	padding: 0 0 10px;
}
#trailer-sp #trailer-player-sp {
	padding: 20px 15px 15px;
}
#trailer-sp iframe {
	margin: 0;
	padding: 0;
	width: 100%;
	height: 54vw;
	vertical-align: bottom;
}
#trailer-sp ul#trailer-btns-sp {
	margin: 0px 15px 0;
	overflow: hidden;
	display: flex;
	flex-wrap: wrap;
}
#trailer-sp li {
	width: 50%;
	box-sizing: border-box;
	padding-bottom: 10px;
}
#trailer-sp li.v0 {
	width: 100%!important;
	box-sizing: border-box;
	padding-bottom: 10px;
}
#trailer-sp li span {
	display: block;
	letter-spacing: 0.6pt;
	background: url("../images/launch/home_nav_bg.png") repeat left top;
	background-size: 90px;
	line-height: 42px;
	text-align: center;
	font-size: 14px;
	color: #FFF;
	border-radius: 30px;
	cursor: pointer;
}
#trailer-sp li.v1,
#trailer-sp li.v2,
#trailer-sp li.v3 {
	width: 50%;
}
#trailer-sp li.v1 {padding-right: 5px;}
#trailer-sp li.v2 {padding-left: 5px;}
#trailer-sp li.v3 {padding-left: 5px;}

#trailer-sp li span.current {
	background: #FFF!important;
	color: #673260!important;
	cursor: default!important;
}


@media screen and (min-width: 1600px) {
	#home {
		margin: 0 auto 100px;
		width: 1400px;
	}
	#home__kv {
		width: 53%;
	}
	#home__info {
		width: 47%;
	}
	/*#home__nav li {
		width: 210px;
	}*/
	.casting {
		width: 450px;
	}
	.koukai {
		width: 490px;
	}
}
@media screen and (max-width: 1300px) {
	#home {
		margin: 0 auto;
		width: 1200px;
	}
}

@media screen and (max-width: 1600px) and (min-height: 900px) {
	#home {
		width: 1300px;
	}
	#home__kv {
		width: 50%;
	}
	#home__info {
		width: 50%;
	}
}
@media screen and (max-width: 1024px) {
	.tablet {
		display: block;
	}
	#wrap {
		min-width: auto;
		margin: 0 auto;
		height: 100%;
		min-height: 768px;
	}
	#home {
		margin: 0 auto;
		width: 940px;
	}
	#home__nav {
		transform: scale(0.94);
		margin: 21px auto 0 12px;
	}
	a#home__trailer  {
		transform: scale(0.92);
		margin: 0 auto 0 10px;
	}
	.snsbtns {
		top: auto;
		bottom: 30%;
		margin-top: 30px;
	}
	.campaign {
		width: 430px;
		padding: 0;
		margin: auto;
	}
	.campaign-bnrs {
		padding: 15px 39px;
	}
	.koukai {
		margin: auto;
		width: 430px;
		padding: 0;
	}
	
	#comments {
		position: relative;
		padding-right: 0;
		width: 100%;
		min-width: auto;
		margin: 0 auto;
	}
	#comments .comment-imgs {
		display: none;
	}
	
	#introstory {
		min-width: 100%;
	}
	#introstory .intro {
		width: 100%;
		margin: 0 auto;
	}

	#introstory .catch1 {
		width: 100%;
		left: 0;
		top: 0;
	}
	#introstory .story {
		width: 100%;
	}
	#cast {
		min-width: 100%;
	}
	#cast .cast-inner {
		width: 100%;
		margin: 0 auto;
		padding: 12vw 95px 50px;
		background: url("../images/about/cast_t1.png") no-repeat center top;
		background-size: 95% auto;
	}
	.cast-block {
		width: 100%;
	}
	.cast-block:nth-child(2n) {
		margin: 0 auto 6% 0;
	}
	.cast-block:nth-child(2n+1) {
		margin: 0 0 6% auto;
		flex-direction: row-reverse;
	}
	.cast-block .cast-img {
		width: 25%;
	}
	.cast-block .cast-text {
		width: 70%;
	}
	.cast-block .cast-name {
		width: 375px;
		margin-bottom: 20px;
	}
	
	#staff {
		min-width: 100%;
		padding-top: 100px;
	}
	#staff .staff-inner {
		width: 100%;
		margin: 0 auto;
		padding: 12vw 95px 0;
		background: url("../images/about/staff_t1.png") no-repeat center top;
		background-size: 95% auto;
	}
	.staff-block {
		width: 100%;
	}
	.staff-block:nth-child(2n) {
		margin: 0 auto 65px 0;
	}
	.staff-block:nth-child(2n+1) {
		margin: 0 0 65px auto;
		flex-direction: row;
	}
	.staff-block .staff-text {
		color: #65306d;
	}
	.staff-block .staff-name {
		width: 375px;
		margin-bottom: 12px;
	}
	.staff-footer {
		width: 750px;
		padding: 30px 0 60px;
		margin: 0 auto;
	}
	#gnav {
		display: none;
	}
	
}



@media screen and (max-width: 768px) {
	.sp {
		display: block;
	}
	.pc {
		display: none;
	}
	#wrap {
		min-width: auto;
		height: auto;
		min-height: auto;
	}
	#gnav {
		display: none;
	}
	#home {
		margin: 0 auto;
		width: 100%;
		height: auto;
		min-height: auto;
		flex-direction: column;
	}
	#home__kv,
	#home__info {
		width: 100%;
	}
	#home__kv {
		height: auto;
		min-height: auto;
		text-indent: 0;
		position: relative;
		background: url("../images/teaser/kv_teaser_sp.jpg") no-repeat center top;
		background-size: cover;
	}
	#home__info {
		display: block;
		height: auto;
		min-height: auto;
		background: url("../images/teaser/home_info_bg_sp.jpg") no-repeat center bottom;
		background-size: cover;
	}
	#home__nav,
	a#home__trailer {
		display: none;
	}
	#home__trailer__sp {
		padding: 15px 0;
		background: #000;
		margin-bottom: 30px;
	}
	#home__trailer__sp iframe {
		width: 100%;
		height: 56vw;
	}
	#home__nav {
		display: none;
	}
	#home__nav__sp {
		width: 100%;
		padding: 0 20px;
		margin-bottom: 30px;
		border-radius: 30px;
	}
	#home__nav__sp li {
		margin-top: 1em;
	}
	#home__nav__sp li a {
		display: block;
		background: url("../images/launch/home_nav_bg.png") repeat left top;
		background-size: 90px;
		border-radius: 30px;
		font-size: 18px;
		font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
		line-height: 3em;
		letter-spacing: 0.1em;
		text-align: center;
		color: #FFF;
	}
	#home__nav__sp li.btn-twitter {
		margin: 0 10px 30px auto;
	}
	#home__nav__sp li.btn-instagram {
		margin: 0 auto 30px 10px;
	}
	#home__nav__sp li a {
		display: block;
		width: 100%;
		position: relative;
	}
	#home__nav__sp li a.new::after {
		content: 'New';
		display: block;
		position: absolute;
		right: 15px;
		top: 0;
		color: #fffb91;
		font-size: 12px;
	}
	#snsbtn__sp {
		display: flex;
		width: 120px;
		margin: 0 auto 15px;
	}
	#snsbtn__sp li {
		width: 50%;
	}
	#snsbtn__sp li.btn-twitter {
		margin: 0 10px 30px auto;
	}
	#snsbtn__sp li.btn-instagram {
		margin: 0 auto 30px 10px;
	}
	.bnr-sp {
		margin: auto;
		width: 100%;
		padding: 15px;
		background: #000;
	}
	.bnr-amazon,
	.bnr-dvd {
		margin: 0;
		padding: 0;
		width: 100%;
	}
	.bnr-amazon {
		margin-bottom: 15px;
	}
	.bnr-dvd a:hover,
	.bnr-amazon a:hover {
		opacity: 1;
	}
	.campaign {
		width: 100%;
		padding: 0;
		margin: auto;
		border-radius: 0;
	}
	.campaign-bnrs {
		flex-direction: column;
		width: 100%;
		padding: 20px;
		margin: 20px auto 0;
		background: url("../images/launch/campaign_bnrs_bg.png") repeat;
	}
	.campaign .campaign-btn {
		margin: 0 auto;
	}
	.campaign .campaign-major,
	.campaign .campaign-mubichike {
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-start;
		width: 100%;
		margin-left: 0;
		padding-left: 7%;
		margin-top: 24px;
		position: relative;
	}
	.campaign .campaign-major {
		margin-top: 0px;
	}
	.campaign .campaign-major .campaign-special {
		position: absolute;
		top: -10px;
		right: 4px;
		width: 17%;
	}
	.campaign .campaign-major .campaign-bnr,
	.campaign .campaign-mubichike .campaign-bnr {
		width: 50%;
	}
	.campaign .campaign-major .campaign-t,
	.campaign .campaign-mubichike .campaign-t {
		width: 30%;
	}
	.campaign .campaign-sub {
		padding-top: 10px;
		font-size: 11px;
		color: #d2a1c1;
	}
	
	.casting {
		width: 100%;
		padding: 0 30px;
		margin-bottom: 30px;
	}
	.billing {
		width: 100%;
		padding: 0 30px;
		margin-bottom: 30px;
	}
	
	#comments .comment-header {
		height: 100px;
		padding-top: 40px;
		background: url("../images/comments/comment_title_shadow.png") no-repeat left top;
		background-size: auto 100px;
	}
	#comments .area-title {
		width: 100%;
		padding: 0 20px 0;
		margin-left: 0;
	}
	#comments .comment-lists {
		width: 100%;
		padding: 0 20px 3px;
	}
	#comments .comment-lists li {
		margin-bottom: 30px;
	}
	#comments .comment-name {
		margin-bottom: 30px;
	}
	#comments .comment-text {
		color: #FFF;
		font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
		font-size: 14px;
	}
	
	#introstory {
		min-width: 100%;
		margin-bottom: 0;
		background: #221912 url("../images/launch/introstory_bg_sp.jpg") no-repeat center bottom;
		background-size: cover;
	}
	#introstory .intro {
		width: 100%;
		margin: 0 auto 30px;
	}
	.intro-text {
		margin: 0 10px;
		padding: 20px;
		line-height: 1.5em;
		color: #FFF;
		font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
		font-size: 14px;
		background: url("../images/launch/introstory_intro_bg1.png") no-repeat left top;
		background-size: 100% auto;
		position: relative;
	}
	.intro-text::after {
		content: '';
		display: block;
		width: 100%;
		height: 100vw;
		background: url("../images/launch/introstory_intro_bg1.png") no-repeat left top;
		background-size: 100% auto;
		position: absolute;
		bottom: 0;
		right: 0;
		transform: rotate(180deg);
	}
	
	#introstory .catch1 {
		width: 100%;
		top: 0;
		left: 0;
	}
	#introstory .catch2 {
		margin: 20px 20px 15px;
	}
	#introstory .catch3 {
		color: #f0831e;
		letter-spacing: 0.1em;
		margin: 0px 20px 15px;
		text-align: center;
	}
	#introstory .story {
		width: 100%;
	}
	.story-catch {
		margin-bottom: 15px;
	}
	.story-text {
		margin: 0 10px;
		padding: 20px;
		line-height: 1.5em;
		color: #bcd3ea;
		font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
		font-size: 14px;
	}
	.story-title {
		width: 90px;
		float: left;
		padding: 0 10px 10px 0;
	}
	
	#cast {
		background: #FFF;
		padding-top: 50px;
	}
	#cast .cast-inner {
		width: 100%;
		margin: 0 auto;
		padding: 20vw 20px 20px;
		background: #FFF url("../images/about/cast_t1_sp.png") no-repeat center top;
		background-size: 95% auto;
	}
	#cast .area-title {
		display: none;
	}
	.cast-block {
		display: flex;
		flex-direction: column;
		flex-wrap: wrap;
		justify-content: flex-start;
		width: 100%;
		padding: 0;
	}
	.cast-block:nth-child(2n),
	.cast-block:nth-child(2n+1) {
		margin: 0 0 45px;
		flex-direction: column;
	}
	.cast-block .cast-img {
		width: 75%;
		margin: 0 auto 20px
	}
	.cast-block .cast-text {
		width: 100%;
	}
	.cast-block .cast-name {
		width: 100%;
		margin-bottom: 10px;
	}
	
	#staff {
		background: #FFF;
		padding-top: 50px;
	}
	#staff .staff-inner {
		flex-direction: column;
		justify-content: flex-start;
		width: 100%;
		padding: 20vw 20px 0;
		background: #FFF url("../images/about/staff_t1_sp.png") no-repeat center top;
		background-size: 95% auto;
	}
	#staff .area-title {
		display: none;
	}
	.staff-block {
		width: 100%;
	}
	.staff-block:nth-child(2n),
	.staff-block:nth-child(2n+1) {
		margin: 0 0 45px;
		flex-direction: column;
	}
	.staff-block .staff-name {
		width: 100%;
		margin-bottom: 10px;
	}
	.staff-footer {
		width: 100%;
		padding: 0;
	}


}


.snsbtns,
#home__nav,
#home__trailer,
.casting,
.campaign,
.koukai,
.billing,
.copyright {
	opacity: 0;
}

.is_loaded #home__nav {
  -webkit-animation-name: fadeIn;
  animation-name: fadeIn;
  -webkit-animation-duration: 1.6s;
  animation-duration: 1.6s;
	-webkit-animation-delay: 0s;
  animation-delay: 0s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}
.is_loaded #home__trailer {
  -webkit-animation-name: fadeIn;
  animation-name: fadeIn;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
	-webkit-animation-delay: 0s;
  animation-delay: 0s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}
.is_loaded .casting,
.is_loaded .campaign {
  -webkit-animation-name: fadeIn;
  animation-name: fadeIn;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
	-webkit-animation-delay: 0s;
  animation-delay: 0s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}
.is_loaded .koukai,
.is_loaded .bnr-amazon,
.is_loaded .bnr-dvd,
.is_loaded .billing,
.is_loaded .copyright,
.is_loaded .snsbtns {
  -webkit-animation-name: fadeIn;
  animation-name: fadeIn;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
	-webkit-animation-delay: 0s;
  animation-delay: 0s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

@-webkit-keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

.fadein {
  opacity : 0;
  transform: translateY(40px);
  transition: all 1.6s;
}
.fadeinLeft {
  opacity : 0;
  transform: translateY(40px) translateX(-40px);
  transition: all 1.6s;
}
.fadeinRight {
  opacity : 0;
  transform: translateY(40px) translateX(40px);
  transition: all 1.6s;
}