/*----------------------------------------
** SUSPIRIA
** 
** style
----------------------------------------*/
a.__dis {
	pointer-events: none;
}
a.__dis img {
	opacity: 0;
}


#wrapper {
	width: 100%;
	/*min-height: 600px;*/
	height: 100%;
	font-family: YakuHanMP,'游明朝','Yu Mincho','游明朝体','YuMincho','ヒラギノ明朝 Pro W3','Hiragino Mincho Pro','HiraMinProN-W3','HGS明朝E','ＭＳ Ｐ明朝','MS PMincho',serif;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	font-size: 15px;
	position: relative;
	/*overflow-x: hidden;*/
}
section {
	width: 100%;
	position: relative;
	overflow: hidden;
}
.__inner {
	max-width: 1200px;
	width: 90%;
	margin: 0 auto;
	position: relative;
}

#canvas {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 2;
	/*   opacity: 0.3; */
}

/*-----------------------------------------
** section.__top
-----------------------------------------*/
.__top {
	background: rgba(158,18,19,1.0) url(../img/teaser/bg-red.jpg) center top no-repeat;
	background-size: cover;
	min-width: 100%;
	width: 100%;
	height: 100vh;
	margin: 0 auto;
	/*padding-top: 51.5%;*/
	/*padding-top: 100vh;*/
	position: relative;
	overflow: hidden;
	/*z-index: 2;*/
}


/*-----------------------------------------
** header
-----------------------------------------*/
header {
	width: 15%;
	position: absolute;
	bottom: 47%;
	left: 20%;
	transform: translateY(50%);
	z-index: 1;
	opacity: 0;
}
header h1 {
	margin-top: 0;
	margin-bottom: 0;
	opacity: 1;
	/*filter: blur(20px);*/
}
header h1 img {
	max-width: 100%;
	height: auto;
}

/* S LOGO
-----------------------------------------*/
.__logo-S {
	width: 30%;
	position: absolute;
	bottom: 53%;
	right: 50%;
	transform: translate(50%,50%);
	opacity: 0;
}
.__logo-S img {
	position: relative;
	z-index: 3;
}
.__logo-drop {
	width: 6%;
	position: absolute;
	bottom: 17%;
	right: 19%;
}

/* catch 01
-----------------------------------------*/
.__tx-catch-01 {
	width: 3%;
	position: absolute;
	bottom: 64.5%;
	right: 25%;
	/*transform: translateY(-50%);*/
	opacity: 0;
}

/* twitter, Instagram
-----------------------------------------*/
.__bt-twitter_pc {
	width: 6%;
	position: absolute;
	top: 1.2%;
	right: 7.7%;
	transition: 0.5s all;
	z-index: 6;
}
.__bt-twitter_pc:hover,
.__bt-instagram_pc:hover {
	filter: blur(2px);
}

.__bt-instagram_pc {
	width: 6%;
	position: absolute;
	top: 1.2%;
	right: 0.7%;
	transition: 0.5s all;
	z-index: 6;
}

/* bt credit
-----------------------------------------*/
.__bt-credit {
	width: 8.5%;
	position: absolute;
	bottom: -10px;
	right: -10px;
	cursor: pointer;
	transition: 0.5s all;
	z-index: 6;
}
.__bt-credit:hover {
	filter: blur(3px);
}

/* bt trailer
-----------------------------------------*/
.__bt-trailer {
	width: 12%;
	position: absolute;
	bottom: 17%;
	right: 21.5%;
	cursor: pointer;
	z-index: 6;
	opacity: 0;
}
.__bt-trailer::after {
	transition: 2s all;
	content: '';
	width: 8%;
	height: 50%;
	background: url(../img/teaser/logo-drop.png) 0 0 no-repeat;
	background-size: contain;
	position: absolute;
	right: 13%;
	top: 16%;
	z-index: -1;
}
.__bt-trailer:hover::after {
	content: '';
	width: 8%;
	height: 50%;
	background: url(../img/teaser/logo-drop.png) 0 0 no-repeat;
	background-size: contain;
	position: absolute;
	right: 13%;
	top: 58%;
	z-index: -1;
}

/* bt theater
-----------------------------------------*/
.__bt-theater {
	width: 12%;
	position: absolute;
	bottom: 22%;
	right: 11.5%;
	cursor: pointer;
	z-index: 6;
	opacity: 0;
}
.__bt-theater::after {
	transition: 2s all;
	content: '';
	width: 8%;
	height: 50%;
	background: url(../img/teaser/logo-drop.png) 0 0 no-repeat;
	background-size: contain;
	position: absolute;
	left: 24.7%;
	top: 16%;
	z-index: -1;
}
.__bt-theater:hover::after {
	content: '';
	width: 8%;
	height: 50%;
	background: url(../img/teaser/logo-drop.png) 0 0 no-repeat;
	background-size: contain;
	position: absolute;
	left: 24.7%;
	top: 58%;
	z-index: -1;
}



.__tw-spotify_sp {
	display: none;
}


/* catch 02
-----------------------------------------*/
.__tx-catch-02 {
	width: 50%;
	position: absolute;
	bottom: 10%;
	right: 50%;
	transform: translateX(50%);
}
/* rodshow
-----------------------------------------*/
.__tx-roadshow {
	width: 40%;
	position: absolute;
	bottom: 5%;
	right: 50%;
	transform: translateX(50%);
}


/*-----------------------------------------
** section.__blank
-----------------------------------------*/
section.__blank {
	width: 100%;
	height: 20px;
	margin-top: -20px;
	/*background: rgba(158,18,19,1.0) url(../img/teaser/bg-red.jpg) center top no-repeat;
	background-size: cover;*/
}
section.__blank::before {
	content: '';
	background: url(../img/top/bg-blank.png) center top no-repeat;
	background-size: 100% 40px;
	width: 100%;
	height: 20px;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 3;
}



/*-----------------------------------------
** section.__comment
-----------------------------------------*/
section.__comment {
	background: rgba(0,0,0,1.0) url(../img/top/bg-comment.jpg) center bottom no-repeat;
	background-size: 100% auto;
	position: relative;
	z-index: 3;
	padding: 80px 0 60%;
	color: rgba(255,255,255,1.0);
}
.__comment ul {
	list-style: none;
	margin: 0 0 0;
	padding: 0;
	text-align: center;
}
.__comment ul li {
	margin: 0 0 40px;
	text-shadow: 0 0 3px rgba(0,0,0,1.0);
}
.__comment ul li .__tx-comment {
	margin: 0 0 12px;
	font-size: 1.25rem;
}
.__comment ul li .__tx-media {
	font-family: 'Barlow Condensed', sans-serif;
	margin: 0;
	color: rgba(167,22,27,1.0);
	font-size: 1.25rem;
}
.__comment ul li .__tx-media::before {
	content: '― ';
}
.__comment .__tx-copy {
	width: 70%;
	position: absolute;
	bottom: 4%;
	right: 50%;
	transform: translateX(50%);
}
/*section.__comment::before {
	content: '';
	background: url(../img/top/bg-outro-after.png) center top no-repeat;
	background-size: 100% 40px;
	width: 100%;
	height: 40px;
	position: absolute;
	top: -30px;
	left: 0;
	z-index: 3;
}*/


/*-----------------------------------------
** section.__intro
-----------------------------------------*/
section.__intro {
	background: url(../img/top/bg-intro-before.jpg) center top no-repeat fixed;
	background-size: cover;
	padding-top: 50%;
}
section.__intro > img {
	max-width: none;
	width: 100%;
	height: auto;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}
section.__intro .__intro-wrap {
	background: rgba(158,18,19,1.0) url(../img/top/bg-intro.jpg) center top no-repeat;
	background-size: cover;
	position: relative;
	z-index: 3;
	padding: 100px 0;
	color: rgba(255,255,255,1.0);
	z-index: 3;
}
.__intro h2 {
	width: 550px;
	text-align: left;
	margin: 0 auto 40px 0;
}
/*.__intro h2 img {
	width: 450px;
	height: auto;
}*/
.__intro .__bx {
	display: flex;
}
.__intro .__bx .__pics {
	width: 40%;
}
.__intro .__bx .__text {
	margin-left: 100px;
	width: calc(100% - 40% - 120px);
}

/**/
.__intro .slider {
	/*width: 80%;*/
	margin-right: auto;
	margin-left: auto;
}
.__intro .slider h3 {
	margin: 0 0 45px;
}
.__intro .slider p {
	text-align: justify;
	line-height: 2;
	/*display: block;*/
	/*text-shadow: 0 0 2px #0F0F0F;*/
}
/**/
.slick-slide {
	margin-left: 15px;
	margin-right: 15px;
}
.slick-dots {
	position: absolute;
	bottom: -55px;
	display: block;
	width: 100%;
	padding: 0;
	margin: 0;
	list-style: none;
	text-align: center;
}
.slick-dots li {
	position: relative;
	display: inline-block;
	width: 50px;
	height: 50px;
	margin: 0 3px;
	padding: 0;
	cursor: pointer;
}
.slick-dots li button {
	font-size: 14px;
	line-height: 0;
	display: block;
	width: 50px;
	height: 50px;
	padding: 0;
	cursor: pointer;
	color: rgba(255,255,255,1.0) !important;
	border: 0;
	outline: none;
	background:url(../img/top/bg-btn-intro.png) center 2px no-repeat;
	background-size: contain;
	position: relative;
}
.slick-dots li button:before {
	font-size: 14px;
	line-height: 0;
	display: block;
	width: 50px;
	height: 50px;
	padding: 5px;
	cursor: pointer;
	color: rgba(255,255,255,1.0) !important;
	border: 0;
	outline: none;
	
	/*border-radius: 0;
	border: 1px solid rgba(255,255,255,1.0);*/
	content: none;
}
.slick-dots li.slick-active button,
.slick-dots li.slick-active button:before {
	opacity: 1.0;
	color: rgba(158,18,19,1.0) !important;
	background:url(../img/top/bg-btn-intro.png) center 2px no-repeat;
	background-size: contain;
}

.slick-dots li.slick-active button::after {
	content: '';
	width: 10px;
	height: 45px;
	background: url(../img/teaser/logo-drop.png) 0 0 no-repeat;
	background-size: contain;
	position: absolute;
	right: 14px;
	top: 58%;
	z-index: -1;
}

/*-----------------------------------------
** section.__story
-----------------------------------------*/
section.__story {
	background: rgba(158,18,19,1.0) url(../img/top/bg-story.jpg) center top no-repeat;
	background-size: cover;
	padding: 100px 0;
}
section.__story .__inner {
	position: relative;
	z-index: 3;
}
.__story h2 {
	text-align: right;
	width: 75px;
	margin: 0 0 25% auto;
}
.__story .__text {
	max-width: 550px;
	margin: 0 auto 0 0;
	text-align: justify;
	line-height: 2;
	position: relative;
}
.__story .__text::before {
	content: '';
	background: url(../img/top/bg-story-text.png) center center no-repeat;
	background-size: 100% auto;
	width: 140%;
	height: 125%;
	position: absolute;
	top: -12.5%;
	left: -20%;
	z-index: -1;
}
.__story .__text h3 {
	width: 80%;
	margin: 0 auto 25px 0;
	font-family: YakuHanJP,'Noto Sans JP','游ゴシック体', YuGothic, '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック', 'Yu Gothic', 'メイリオ', sans-serif;
	font-weight: 700;
}
.__story .__text p {
	/*font-family: YakuHanMP,'游明朝','Yu Mincho','游明朝体','YuMincho','ヒラギノ明朝 Pro W3','Hiragino Mincho Pro','HiraMinProN-W3','HGS明朝E','ＭＳ Ｐ明朝','MS PMincho',serif;*/
	margin: 0;
	letter-spacing: -.055em;
}
/*-----------------------------------------
** section.__story-after
-----------------------------------------*/
section.__story-after {
	position: relative;
	background: rgba(0,0,0,1.0);
	min-height: 400px;
	overflow: hidden;
	z-index: 3;
	padding: 20px 0;
}
.__story-after .__scroll-01 {
	background: url(../img/top/bg-story-after-01.jpg) left center repeat-x;
	background-size: auto 159px;
	width: 120%;
	height: 159px;
	margin-bottom: 25px;
	transform: rotate(-2deg);
	-webkit-animation: bg_anime01 20s linear infinite;
	animation: bg_anime01 20s linear infinite;
}
.__story-after .__scroll-02 {
	background: url(../img/top/bg-story-after-02.jpg) left center repeat-x;
	background-size: auto 159px;
	width: 120%;
	height: 159px;
	transform: rotate(-1deg);
	-webkit-animation: bg_anime02 20s linear infinite;
	animation: bg_anime02 20s linear infinite;
}


/*-----------------------------------------
** section.__prono-before
-----------------------------------------*/
section.__bg-fixed {
	background: url(../img/top/bg-fixed.jpg) center top no-repeat fixed;
	background-size: cover;
	position: relative;
	min-height: 57%;
	overflow: hidden;
	z-index: -1;
}
/*section.__bg-fixed::before {
	content: '';
	background: url(../img/top/bg-fixed.jpg) center top no-repeat;
	background-size: cover;
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0;
	left: 0;
}*/


/*-----------------------------------------
** section.__prono
-----------------------------------------*/
section.__prono {
	background: url(../img/top/bg-prono.jpg) center top no-repeat;
	background-size: cover;
	padding: 100px 0 0;
}
section.__prono .__inner {
	position: relative;
	z-index: 3;
}
.__prono h2 {
	text-align: left;
	width: 480px;
	margin: 0 auto 200px 0;
}
.__prono ul {
	list-style: none;
	letter-spacing: -.4em;
	margin: 0;
	padding: 0;
	text-align: center;
}
.__prono ul li {
	display: inline-block;
	letter-spacing: normal;
	padding: 0 5% 5%;
	margin-bottom: 70px;
	width: 40%;
	position: relative;
}
.__prono ul li a {
	display: block;
	padding: 25px 0;
	position: relative;
}
.__prono ul li a:hover {
	-webkit-filter: blur(1px);
	-moz-filter: blur(1px);
	-ms-filter: blur(1px);
	filter: blur(1px);
}
.__prono ul li img {
	max-width: none;
	width: auto;
	height: 18px;
}

[class^='__bt-']::before {
	content: '';
	position: absolute;
	/*-webkit-filter: invert(20%);
	-moz-filter: invert(20%);
	-ms-filter: invert(20%);
	filter: invert(20%);*/
}
.__bt-01::before {
	background: url(../img/top/bg-bt-prono-01.png) center center no-repeat;
	background-size: auto 110%;
	width: 140%;
	height: 150%;
	top: -38%;
	left: -20%;
}
.__bt-02::before {
	background: url(../img/top/bg-bt-prono-02.png) center center no-repeat;
	background-size: auto 116%;
	width: 120%;
	height: 150%;
	top: -35%;
	left: -14%;
}
.__bt-03::before {
	background: url(../img/top/bg-bt-prono-03.png) center center no-repeat;
	background-size: auto 100%;
	width: 120%;
	height: 150%;
	top: -45%;
	left: -10%;
}
.__bt-04::before {
	background: url(../img/top/bg-bt-prono-04.png) center center no-repeat;
	background-size: auto 100%;
	width: 120%;
	height: 150%;
	top: -45%;
	left: -10%;
}

/*-----------------------------------------
** section.__staff-cast
-----------------------------------------*/
section.__staff-cast {
	background: url(../img/top/bg-staff-cast.jpg) center top no-repeat fixed;
	background-size: cover;
	padding: 0 0 100px;
}
section.__staff-cast .__inner {
	position: relative;
	z-index: 3;
	padding: 100px 0 0;
}
.__staff-cast h2.__staff {
	text-align: right;
	width: 200px;
	margin: 0 0 80px auto;
}
.__staff-cast h2.__cast {
	text-align: left;
	width: 80px;
	margin: 0 auto 0 0;
}


.__staff-cast ul {
	list-style: none;
	letter-spacing: -.4em;
	margin: 0;
	padding: 0;
	text-align: center;
}
.__staff-cast ul li {
	display: inline-block;
	letter-spacing: normal;
	padding: 0 2.5% 5%;
	margin-bottom: 30px;
	width: calc(100% / 3);
	position: relative;
}
.__staff-cast ul li a {
	display: block;
	color: rgba(255,255,255,1.0);
	transition: 0.3s all;
}
.__staff-cast dt,
.__staff-cast dd {
	font-size: 1.15rem;
}
.__staff-cast ul li a img {
	transition: 0.3s all;
}
.__staff-cast ul li a:hover img {
	-webkit-filter: invert(100%) blur(1px);
	-moz-filter: invert(100%) blur(1px);
	-ms-filter: invert(100%) blur(1px);
	filter: invert(100%) blur(1px);
}
.__staff-cast ul li a:hover {
	/*color: rgba(227,211,190,1.0);*/
	-webkit-filter: blur(1px);
	-moz-filter: blur(1px);
	-ms-filter: blur(1px);
	filter: blur(1px);
}


/*-----------------------------------------
** section.__outro
-----------------------------------------*/
section.__outro {
	background: url(../img/top/bg-outro.jpg) center top no-repeat;
	background-size: cover;
	padding: 250px 0 80px;
	position: relative;
}
section.__outro .__inner {
	position: relative;
	z-index: 3;
}
.__outro-copy {
	max-width: 350px;
	margin: 0 10% 300px auto;
}
.__outro-roadshow {
	width: 60%;
	margin: 0 auto;
}
section.__outro::after {
	content: '';
	background: url(../img/top/bg-outro-after.png) center bottom no-repeat;
	background-size: 100% 40px;
	width: 100%;
	height: 40px;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 3;
}


/*-----------------------------------------
** section.__billing
-----------------------------------------*/
section.__billing {
	background: rgba(0,0,0,1.0);
	position: relative;
	z-index: 3;
	padding: 80px 0 0;
}
section.__billing .__inner {
	width: 800px;
}


/*-----------------------------------------
** btn effect
-----------------------------------------*/
/* rumble effect */
.__rumble:hover{
	animation: rumble 0.12s linear 2;
}

@keyframes rumble{
	0%	{transform:rotate(0deg)	translate(0,0);}
	12.5%	{transform:rotate(0.4deg)	translate(1px,-1px);}
	25%	{transform:rotate(0.8deg)	translate(0px,1px);}
	37.5%	{transform:rotate(0.4deg)	translate(-1px,0);}
	50%	{transform:rotate(0deg)	translate(0,0);}
	62.5%	{transform:rotate(-0.4deg)	translate(1px,0);}
	75%	{transform:rotate(-0.8deg)	translate(0,1px);}
	87.5%	{transform:rotate(-0.4deg)	translate(-1px,-1px);}
	100%	{transform:rotate(0deg)	translate(0,0);}
}

/* ripple efect */
.ripple__effect {
	/* 値の変更はエフェクト形体・サイズ・スピードに影響する */
	width: 150px;
	height: 150px;
	/* 必須 */
	position: absolute;
	border-radius: 100%;
	pointer-events: none;
	transform: scale(0);
	opacity: 0;
}
/* エフェクト要素の色を指定 */
.ripple__effect.is-orange { background: #FFB700;}
.ripple__effect.is-blue   { background: #4aa3df;}
.ripple__effect.is-black  { background: #999;}
/* classが付与されたらアニメーションを実行 */
.ripple__effect.is-show {
	animation: ripple 0.75s ease-out;
}
@keyframes ripple {
	from {
		opacity: 1;
		background: rgba(255,255,25,,1.0);
	}
	to {
		transform: scale(2);
		opacity: 0;
		background: rgba(255,255,25,,1.0);
	}
}

@keyframes zoomUp {
	0% {
		transform: translateX(50%) scale(1.0);
	}
	50% {
		transform: translateX(50%) scale(1.1);
	}
	100% {
		transform: translateX(50%) scale(1.0);
	}
}

/* blur efect */
@keyframes blurAnimation {
	0% {
		filter: blur(20px);
		/*margin: 0 -20px -20px -20px;*/
	}
	100% {
		filter: blur(0);
		/*margin: 0;*/
	}
}

.__blurAnimation-1s {
	animation: blurAnimation 1s linear 0s 1 normal forwards running;
}
.__blurAnimation-3s {
	animation: blurAnimation 3s linear 0s 1 normal forwards running;
}
.__blurAnimation-5s {
	animation: blurAnimation 5s linear 0s 1 normal forwards running;
}
.__blurAnimation-7s {
	animation: blurAnimation 7s linear 0s 1 normal forwards running;
}
.__blurAnimation-10s {
	animation: blurAnimation 10s linear 0s 1 normal forwards running;
}


@-webkit-keyframes bg_anime01 {
	0% {
		background-position: 0 0;
	}
	100% {
		background-position: -998px 0;
	}
}
@keyframes bg_anime01 {
	0% {
		background-position: 0 0;
	}
	100% {
		background-position: -998px 0;
	}
}
@-webkit-keyframes bg_anime02 {
	0% {
		background-position: 0 0;
	}
	100% {
		background-position: -998px 0;
	}
}
@keyframes bg_anime02 {
	0% {
		background-position: 0 0;
	}
	100% {
		background-position: 998px 0;
	}
}


/*-----------------------------------------
**
** query
**
-----------------------------------------*/
@media screen and (min-width:981px) and (max-width:1080px){
	
}
@media screen and (min-width:801px) and (max-width:980px){
	
}

@media screen and (min-width:641px) and (max-width:800px){
	
}

@media screen and (max-width:768px) {
	/*body {
		overflow-x: hidden;
		background: rgba(158,18,19,1.0) url(../img/teaser/bg-red.jpg) center center no-repeat;
		background-size: cover;
	}*/
	#wrapper {
		font-size: 13px;
	}
	.__top {
		min-width: 100%;
		width: 100%;
		height: 105vh;
		margin: 0 auto;
		/*padding-top: 51.5%;*/
		/*padding-top: 75vh;*/
		position: relative;
		/*overflow: hidden;*/
		padding-bottom: 50px;
	}
	/*-----------------------------------------
	** header
	-----------------------------------------*/
	header {
		width: 46%;
		position: absolute;
		bottom: 34%;
		left: inherit;
		right: 6%;
		transform: translateY(50%);
		z-index: 10;
	}
	header h1 {
		margin-top: 0;
		margin-bottom: 0;
		opacity: 1;
		/*filter: blur(20px);*/
	}
	header h1 img {
		max-width: 100%;
		height: auto;
	}

	/* S LOGO
	-----------------------------------------*/
	.__logo-S {
		width: 70%;
		position: absolute;
		bottom: 66%;
		right: 50%;
		transform: translate(50%,50%);
	}
	.__logo-drop {
		width: 6%;
		position: absolute;
		bottom: 17%;
		right: 19%;
	}

	/* catch 01
	-----------------------------------------*/
	.__tx-catch-01 {
		width: 11%;
		position: absolute;
		top: 3%;
		right: inherit;
		left: 3%;
		z-index: 6;
	}

	
	
	/* bt trailer
	-----------------------------------------*/
	.__bt-trailer {
		width: 40%;
		position: absolute;
		bottom: 17%;
		right: 10%;
		transform: none;
		cursor: pointer;
		z-index: 6;
		opacity: 1;
	}
	/* bt theater
	-----------------------------------------*/
	.__bt-theater {
		width: 40%;
		position: absolute;
		bottom: 17%;
		right: inherit;
		left: 7%;
		cursor: pointer;
		z-index: 6;
		opacity: 1;
	}

	

	
	/* catch 02 SP
	-----------------------------------------*/
	.__tx-catch-02 {
		display: block;
		width: 70%;
		position: absolute;
		bottom: 10%;
		right: 50%;
		transform: translateX(50%);
		cursor: pointer;
		transition: 0.5s all;
		z-index: 6;
	}
	
	/* catch 02 SP
	-----------------------------------------*/
	.__tx-roadshow {
		display: block;
		width: 70%;
		position: absolute;
		bottom: 30px;
		right: 50%;
		transform: translateX(50%);
		cursor: pointer;
		transition: 0.5s all;
		z-index: 6;
	}
	
	
	
	/*-----------------------------------------
	** section.__blank
	-----------------------------------------*/
	section.__blank {
		width: 100%;
		height: auto;
		margin: 0 0 400px;
		padding-bottom: 25px;
		background: rgba(0,0,0,1.0);
		background-size: cover;
		position: relative;
		overflow: visible;
	}
	section.__blank::before {
		content: '';
		background: url(../img/top/bg-blank.png) center bottom no-repeat;
		background-size: 100% 20px;
		width: 100%;
		height: 20px;
		position: absolute;
		top: -20px;
		left: 0;
		z-index: 3;
	}
	
	
	.__tw-spotify_sp {
		display: block;
	}
	/* twitter, instagram
	-----------------------------------------*/
	.__bt-twitter_pc,
	.__bt-instagram_pc{
		display: none;
	}
	.__bt-sns {
		display: flex;
		align-content: center;
	}
	.__bt-twitter_sp {
		width: 20%;
		margin: 0 10px 25px auto;
		transition: 0.5s all;
		z-index: 6;
	}
	.__bt-instagram_sp {
		width: 20%;
		margin: 0 auto 25px 10px;
		transition: 0.5s all;
		z-index: 6;
	}
	.__bt-twitter_sp:hover,
	.__bt-instagram_sp:hover{
		filter: blur(2px);
	}
	
	
	
	section.__blank::after {
		content: '';
		background: url(../img/top/bg-fixed_sp.jpg) center top no-repeat;
		background-size: cover;
		width: 100%;
		height: 100%;
		position: fixed;
		top: 0;
		left: 0;
		z-index: -1
	}
	
	
	/*-----------------------------------------
	** section.__comment
	-----------------------------------------*/
	section.__comment {
		background: rgba(0,0,0,1.0) url(../img/top/bg-comment.jpg) center bottom no-repeat;
		background-size: 100% auto;
		position: relative;
		z-index: 3;
		padding: 30px 0 60%;
		color: rgba(255,255,255,1.0);
	}
	.__comment ul {
		width: 100%;
		list-style: none;
		margin: 0 auto 0;
		padding: 0;
		text-align: center;
	}
	.__comment ul li {
		margin: 0 0 20px;
		text-shadow: 0 0 3px rgba(0,0,0,1.0);
	}
	.__comment ul li .__tx-comment {
		margin: 0 0 6px;
		font-size: 1rem;
		text-align: left;
	}
	.__comment ul li .__tx-media {
		font-family: 'Barlow Condensed', sans-serif;
		margin: 0;
		color: rgba(167,22,27,1.0);
		font-size: 1.05rem;
		text-align: right;
	}
	.__comment ul li .__tx-media::before {
		content: '― ';
	}
	.__comment .__tx-copy {
		width: 90%;
		position: absolute;
		bottom: 2%;
		right: 50%;
		transform: translateX(50%);
	}
	.__comment ul li .__tx-comment br {
		display: none;
	}
	
	
	/*-----------------------------------------
	** section.__intro
	-----------------------------------------*/
	section.__intro {
		background: url(../img/top/bg-intro-before.jpg) center top no-repeat scroll;
		background-size: contain;
		padding-top: 37%;
	}
	section.__intro > img {
		max-width: none;
		width: 100%;
		height: auto;
		-webkit-user-select: none;
		-moz-user-select: none;
		-ms-user-select: none;
		user-select: none;
	}
	section.__intro .__intro-wrap {
		background: rgba(158,18,19,1.0) url(../img/top/bg-intro.jpg) 15% top no-repeat;
		background-size: auto 100%;
		position: relative;
		z-index: 3;
		padding: 40px 0;
		color: rgba(255,255,255,1.0);
	}
	.__intro h2 {
		width: 275px;
		text-align: left;
		margin: 0 auto 20px 0;
	}
	/*.__intro h2 img {
	width: 450px;
	height: auto;
}*/
	.__intro .__bx {
		display: block;
	}
	.__intro .__bx .__pics {
		width: 60%;
		margin: 0 auto 20px;
	}
	.__intro .__bx .__text {
		margin-left: 0;
		margin-bottom: 60px;
		width: 100%;
	}
	
	
	
	/*-----------------------------------------
	** section.__story
	-----------------------------------------*/
	section.__story {
		background: rgba(158,18,19,1.0) url(../img/top/bg-story_sp.jpg) center top no-repeat;
		background-size: cover;
		padding: 40px 0;
		overflow: hidden;
	}
	section.__story .__inner {
		position: relative;
		z-index: 3;
	}
	.__story h2 {
		text-align: right;
		width: 38px;
		margin: 0 0 25% auto;
	}
	.__story .__text {
		max-width: 550px;
		margin: 0 auto 0 0;
		text-align: justify;
		line-height: 2;
		position: relative;
	}
	.__story .__text::before {
		content: '';
		background: url(../img/top/bg-story-text.png) center center no-repeat;
		background-size: 100% 100%;
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0%;
		left: 0%;
		z-index: -1;
	}
	.__story .__text h3 {
		width: 80%;
		margin: 0 auto 25px 0;
		font-family: YakuHanJP,'Noto Sans JP','游ゴシック体', YuGothic, '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック', 'Yu Gothic', 'メイリオ', sans-serif;
		font-weight: 700;
	}
	.__story .__text p {
		margin: 0;
		letter-spacing: -.055em;
	}
	
	
	/*-----------------------------------------
	** section.__story-after
	-----------------------------------------*/
	section.__story-after {
		position: relative;
		background: rgba(0,0,0,1.0);
		min-height: 200px;
		overflow: hidden;
		z-index: 3;
		padding: 20px 0;
	}
	.__story-after .__scroll-01 {
		background: url(../img/top/bg-story-after-01.jpg) left center repeat-x;
		background-size: auto 79.5px;
		width: 120%;
		height: 79.5px;
		margin-bottom: 25px;
		transform: rotate(-2deg);
		-webkit-animation: bg_anime01 20s linear infinite;
		animation: bg_anime01 20s linear infinite;
	}
	.__story-after .__scroll-02 {
		background: url(../img/top/bg-story-after-02.jpg) left center repeat-x;
		background-size: auto 79.5px;
		width: 120%;
		height: 79.5px;
		transform: rotate(-1deg);
		-webkit-animation: bg_anime02 20s linear infinite;
		animation: bg_anime02 20s linear infinite;
	}
	
	
	
	/*-----------------------------------------
	** section.__prono-before
	-----------------------------------------*/
	section.__bg-fixed {
		background: none;
		position: relative;
		min-height: 0;
		overflow: hidden;
		z-index: -1;
	}
	section.__bg-fixed::before {
		content: '';
		/*background: url(../img/top/bg-fixed_sp.jpg) center top no-repeat;
		background-size: cover;*/
		background: none;
		width: 100%;
		height: 100%;
		position: fixed;
		top: 0;
		left: 0;
	}


	/*-----------------------------------------
	** section.__prono
	-----------------------------------------*/
	section.__prono {
		background: url(../img/top/bg-prono.jpg) center top no-repeat;
		background-size: cover;
		padding: 40px 0 0;
	}
	section.__prono .__inner {
		position: relative;
		z-index: 3;
	}
	.__prono h2 {
		text-align: left;
		width: 240px;
		margin: 0 auto 100px 0;
	}
	.__prono ul {
		list-style: none;
		letter-spacing: -.4em;
		margin: 0;
		padding: 0;
		text-align: center;
	}
	.__prono ul li {
		display: inline-block;
		letter-spacing: normal;
		padding: 0 5% 3%;
		margin-bottom: 35px;
		width: 100%;
		position: relative;
	}
	.__prono ul li a {
		display: block;
		padding: 25px 0;
		position: relative;
	}
	.__prono ul li a:hover {
		-webkit-filter: blur(1px);
		-moz-filter: blur(1px);
		-ms-filter: blur(1px);
		filter: blur(1px);
	}
	.__prono ul li img {
		max-width: none;
		width: auto;
		height: 14px;
	}

	[class^='__bt-']::before {
		content: '';
		position: absolute;
		/*-webkit-filter: invert(20%);
		-moz-filter: invert(20%);
		-ms-filter: invert(20%);
		filter: invert(20%);*/
	}
	.__bt-01::before {
		background: url(../img/top/bg-bt-prono-01.png) center center no-repeat;
		background-size: auto 110%;
		width: 140%;
		height: 150%;
		top: -30%;
		left: -20%;
	}
	.__bt-02::before {
		background: url(../img/top/bg-bt-prono-02.png) center center no-repeat;
		background-size: auto 116%;
		width: 120%;
		height: 150%;
		top: -30%;
		left: -14%;
	}
	.__bt-03::before {
		background: url(../img/top/bg-bt-prono-03.png) center center no-repeat;
		background-size: auto 100%;
		width: 120%;
		height: 150%;
		top: -32%;
		left: -10%;
	}
	
	
	
	/*-----------------------------------------
	** section.__staff-cast
	-----------------------------------------*/
	section.__staff-cast {
		background: url(../img/top/bg-staff-cast_sp.jpg) center top no-repeat scroll;
		background-size: cover;
		padding: 0 0 40px;
	}
	section.__staff-cast .__inner {
		position: relative;
		z-index: 3;
		padding: 40px 0 0;
	}
	.__staff-cast h2.__staff {
		text-align: right;
		width: 100px;
		margin: 0 0 40px auto;
	}
	.__staff-cast h2.__cast {
		text-align: left;
		width: 40px;
		margin: 0 auto 0 0;
	}


	.__staff-cast ul {
		list-style: none;
		letter-spacing: -.4em;
		margin: 0;
		padding: 0;
		text-align: center;
	}
	.__staff-cast ul li {
		display: inline-block;
		letter-spacing: normal;
		padding: 0 1.5% 3.5%;
		margin-bottom: 30px;
		width: calc(100% / 2);
		position: relative;
		vertical-align: top;
	}
	.__staff-cast ul.__1x li {
		display: inline-block;
		letter-spacing: normal;
		padding: 0 2.5% 5%;
		margin-bottom: 10px;
		width: calc(100% / 1);
		position: relative;
		vertical-align: top;
	}
	.__staff-cast ul li a {
		display: block;
		color: rgba(255,255,255,1.0);
		transition: 0.3s all;
	}
	.__staff-cast dt,
	.__staff-cast dd {
		font-size: .85rem;
		line-height: 1.3;
		letter-spacing: -.05em;
	}
	.__staff-cast dd span {
		display: block;
	}
	.__staff-cast ul li a img {
		transition: 0.3s all;
	}
	.__staff-cast ul li a:hover img {
		-webkit-filter: invert(100%) blur(1px);
		-moz-filter: invert(100%) blur(1px);
		-ms-filter: invert(100%) blur(1px);
		filter: invert(100%) blur(1px);
	}
	.__staff-cast ul li a:hover {
		/*color: rgba(227,211,190,1.0);*/
		-webkit-filter: blur(1px);
		-moz-filter: blur(1px);
		-ms-filter: blur(1px);
		filter: blur(1px);
	}


	/*-----------------------------------------
	** section.__outro
	-----------------------------------------*/
	section.__outro {
		background: url(../img/top/bg-outro.jpg) left top no-repeat;
		background-size: cover;
		padding: 125px 0 40px;
		position: relative;
	}
	section.__outro .__inner {
		position: relative;
		z-index: 3;
	}
	.__outro-copy {
		max-width: 65%;
		margin: 0 auto 150px auto;
		-webkit-filter:drop-shadow(5px 5px 10px rgba(0, 0, 0, 0.5));
		-moz-filter:drop-shadow(5px 5px 10px rgba(0, 0, 0, 0.5));
		-ms-filter:drop-shadow(5px 5px 10px rgba(0, 0, 0, 0.5));
		filter:drop-shadow(5px 5px 10px rgba(0, 0, 0, 0.5));
	}
	/*.__outro-copy img {
		filter:drop-shadow(5px 5px 10px rgba(0, 0, 0, 0.5));
	}*/
	.__outro-roadshow {
		width: 100%;
		margin: 0 auto;
	}
	section.__outro::after {
		content: '';
		background: url(../img/top/bg-outro-after.png) center bottom no-repeat;
		background-size: 100% 40px;
		width: 100%;
		height: 40px;
		position: absolute;
		bottom: 0;
		left: 0;
		z-index: 3;
	}
	
	
	
	/*-----------------------------------------
	** section.__billing
	-----------------------------------------*/
	section.__billing {
		background: rgba(0,0,0,1.0);
		position: relative;
		z-index: 3;
		padding: 40px 0 0;
	}
	section.__billing .__inner {
		width: 90%;
		margin: 0 auto;
	}
	
}



/**/
/* column
-----------------------------------------*/
.__bn-column.__pc {
	max-width: 216px;
	height: 80px;
	position: absolute;
	bottom: 180px;
	left: 1.2%;
	/*border: 1px solid rgba(0,0,0,0.2);*/
	z-index: 6;
}

/* spotify
-----------------------------------------*/
.__spotifyPlayer.__pc {
	max-width: 216px;
	height: 80px;
	position: absolute;
	bottom: 20px;
	left: 1.2%;
	border: 1px solid rgba(0,0,0,0.2);
	z-index: 6;
}
/*.__spotifyPlayer._sp {
display: none;
}*/

/*.__tw-spotify_sp {
	display: none;
}*/

/* original
-----------------------------------------*/
.__bn-original.__pc {
	max-width: 216px;
	height: 80px;
	position: absolute;
	bottom: 100px;
	left: 1.2%;
	/*border: 1px solid rgba(0,0,0,0.2);*/
	z-index: 6;
}
/* comment
-----------------------------------------*/
.__bn-comment.__pc {
	max-width: 216px;
	height: 80px;
	position: absolute;
	bottom: 260px;
	left: 1.2%;
	/*border: 1px solid rgba(0,0,0,0.2);*/
	z-index: 6;
}
/* comment
-----------------------------------------*/
.__bn-fanart.__pc {
	max-width: 216px;
	height: 80px;
	position: absolute;
	bottom: 370px;
	left: 1.2%;
	/*border: 1px solid rgba(0,0,0,0.2);*/
	z-index: 6;
}


/* .__bn-set.__pc
-----------------------------------------*/
.__banner-set.__pc {
	max-width: 216px;
	position: absolute;
	bottom: 105px;
	left: 1.2%;
	z-index: 10;
	list-style: none;
	margin: 0;
	padding: 0;
}
.__banner-set li {
	margin: 4px 0 0;
}
.__banner-set li a {
	display: block;
}
.__bn-machiyama-yt {
	max-width: 216px;
	position: absolute;
	bottom: 30px;
	right: 1.2%;
	z-index: 10;
}
.__bt-bd-dvd {
	max-width: 180px;
	position: absolute;
	top: 125px;
	right: 15px;
	z-index: 10;
}


@media screen and (max-width:768px) {
	/* spotify
	-----------------------------------------*/
	.__spotifyPlayer.__pc {
		display: none;
	}
	.__spotifyPlayer.__sp {
		max-width: 240px;
		height: 80px;
		margin: 0 auto;
		border: 1px solid rgba(0,0,0,0.2);
		z-index: 6;
	}

	/* column
	-----------------------------------------*/
	.__bn-column.__pc {
		display: none;
	}
	.__bn-column.__sp {
		/*display: block;*/
		max-width: 240px;
		/*height: 80px;*/
		margin: 0 auto 10px;
		/*border: 1px solid rgba(0,0,0,0.2);*/
		z-index: 6;
	}

	/* comment
	-----------------------------------------*/
	.__bn-comment.__pc {
		display: none;
	}
	.__bn-comment.__sp {
		/*display: block;*/
		max-width: 240px;
		/*height: 80px;*/
		margin: 0 auto 10px;
		/*border: 1px solid rgba(0,0,0,0.2);*/
		z-index: 6;
	}
	/* fanart
	-----------------------------------------*/
	.__bn-fanart.__pc {
		display: none;
	}
	.__bn-fanart.__sp {
		/*display: block;*/
		max-width: 240px;
		/*height: 80px;*/
		margin: 0 auto 10px;
		/*border: 1px solid rgba(0,0,0,0.2);*/
		z-index: 6;
	}

	/* original
	-----------------------------------------*/
	.__bn-original.__pc {
		display: none;
	}
	.__bn-original.__sp {
		/*display: block;*/
		max-width: 240px;
		/*height: 80px;*/
		margin: 0 auto 10px;
		/*border: 1px solid rgba(0,0,0,0.2);*/
		z-index: 6;
	}
	
	/* .__bn-set.__pc
	-----------------------------------------*/
	.__banner-set.__pc {
		display: none;
	}
	.__banner-set.__sp {
		max-width: 240px;
		list-style: none;
		margin: 0 auto 10px;
		padding: 0;
	}
	.__banner-set li {
		margin: 4px 0 0;
	}
	.__banner-set li a {
		display: block;
	}
	.__bn-machiyama-yt {
		display: none;
	}
	.__bt-bd-dvd {
		display: none;
	}
}

/*-----------------------------------------
** #__pf デジタル配信
-----------------------------------------*/
section.__pf-blank {
	width: 100%;
	height: 20px;
	margin-top: -20px;
	/*background: rgba(158,18,19,1.0) url(../img/teaser/bg-red.jpg) center top no-repeat;
	background-size: cover;*/
}
section.__pf-blank::before {
	content: '';
	background: url(../img/top/bg-blank.png) center top no-repeat;
	background-size: 100% 40px;
	width: 100%;
	height: 20px;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 3;
}
.__bn-pf {
	max-width: 180px;
	position: absolute;
	top: 330px;
	right: 15px;
	z-index: 10;
}
#__pf {
	background: rgba(0,0,0,1.0);
	position: relative;
	z-index: 2;
}
#__pf::before {
	content: '';
	background: url(../img/top/bg-blank.png) center top no-repeat;
	background-size: 100% 40px;
	width: 100%;
	height: 20px;
	position: absolute;
	top: -20px;
	left: 0;
	z-index: 3;
}
#__pf .__inner {
	max-width: 1050px;
	width: 90%;
	margin: 0 auto;
	padding: 30px 0;
	color: rgba(255,255,255,1.0);
	opacity: 1;
}
#__pf h2 {
	margin: 0 0 20px 0;
	text-align: center;
	font-weight: 700;
	font-family: 'Noto Sans', sans-serif;
	font-size: 1.33rem;
}
#__pf ul {
	list-style: none;
	letter-spacing: -.4em;
	padding: 0;
	margin: 0;
}
#__pf ul li {
	display: inline-block;
	letter-spacing: normal;
	width: calc(100% / 8);
	border-radius: 3px;
	padding: 0.15%;
}
#__pf ul li a {
	display: block;
	background: rgba(255,255,255,1.0);
	border-radius: 3px;
	padding: 10px;
}
#__pf ul li img {
	max-width: 100%;
	transition: 0.2s linear;
}
#__pf ul li a:hover img {
	opacity: 0.6;
}
#__pf p {
	font-size: 75%;
	text-indent: -1em;
	padding-left: 1em;
	margin: 0;
}
#__pf .__50on {
	text-align: right;
	margin-bottom: 0.5em;
}
@media screen and (max-width:768px) {
	section.__pf-blank::after {
		content: '';
		background: url(../img/top/bg-fixed_sp.jpg) center top no-repeat;
		background-size: cover;
		width: 100%;
		position: fixed;
		top: 0;
		left: 0;
		z-index: -1
	}
	.__bn-pf {
		position: absolute;
		width: 25%;
		top: inherit;
		bottom: 30%;
		right: inherit;
		left: 15px;
		opacity: 1;
	}
	#__pf .__inner {
		max-width: 95%;
		margin: 0 auto;
		padding: 15px 0;
		color: rgba(255,255,255,1.0);
	}
	#__pf h2 {
		margin: 0 0 20px 0;
		text-align: center;
	}
	#__pf ul {
		list-style: none;
		letter-spacing: -.4em;
		padding: 0;
		margin: 0;
	}
	#__pf ul li {
		display: inline-block;
		letter-spacing: normal;
		width: calc(100% / 3);
		border-radius: 3px;
		padding: 0.5%;
	}
	#__pf ul li a {
		display: block;
		background: rgba(255,255,255,1.0);
		border-radius: 3px;
		padding: 15px;
	}
	#__pf ul li img {
		max-width: 100%;
		transition: 0.2s linear;
	}
	#__pf ul li a:hover img {
		opacity: 0.6;
	}
	#__pf p {
		font-size: 70%;
	}
	#__pf .__50on {
		text-align: right;
	}
}
