@media screen and (max-width: 767px) {
	html {
		height: 100%;
	}

	body {
		height: 100%;

	}

	.sp {
		display: inline-block;
	}

	.sp_b {
		display: block;
	}

	.vsp {
		display: none;
	}

	.pc,
	.pc_b {
		display: none;
	}

	/*-----Loading-------*/
	#loading {
		position: fixed;
		width: 100%;
		height: 100%;
		top: 0;
		z-index: 999;
		background: #fff;
		text-align: center;
		color: #fff;
		display: none;
	}

	#loading_logo {
		position: absolute;
		width: 100%;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
	}

	#loading_logo img {
		width: 90%;
		height: auto;
	}

	/*-----HEADER-------*/
	#header_sp {
		width: 100%;
		height: 4.6rem;
		position: fixed;
		top: 0;
		z-index: 300;
		color: #fff;
		background-color: #fff;
		background-image: url(../images/menu_bg.jpg);
		background-position: center top;
		background-size: auto 100%;
		background-repeat: repeat-x;
	}

	#header_sp_sns {
		/*		text-align: center;*/
		width: calc(100% - 4.6rem);
	}

	#header_sp_sns a {
		color: #11A5FF;
		font-size: 17pt;
		margin: 0 0.9rem;
		line-height: 4.4rem;
	}

	#header_sp_sns a {
		color: #11A5FF;
		font-size: 17pt;
		margin: 0 0.9rem;
		line-height: 4.4rem;
	}

	.share_box_sp {
		display: flex;
		justify-content: flex-end;
		align-items: center;
		gap: 5px;
		font-size: 0;
		line-height: 0;
		margin: 10px auto 0 auto;
		opacity: 0;
		pointer-events: none;
		transition: opacity .5s;
		width: 90%;
		text-align: center;
	}

	.share_box_sp.is-active {
		opacity: 1;
		pointer-events: auto;
	}

	/*-----TOP-------*/
	#main {
		min-width: inherit;
		margin-top: 4.6rem;
	}

	.rope {
		height: 4px;
		background-size: auto 100%;
		min-width: inherit;
	}

	#top_sp_box {
		width: 100%;
		/*		aspect-ratio: 486 / 978;*/
		height: calc(100vh - 4.6rem);
		margin-top: 0;
	}



	.top_logo_sp {
		width: 100%;
		height: auto;
		margin: 60vw 0 20vw;
		z-index: 20;
		position: absolute;
		top: -2.3em;
		left: 0;
		right: 0;
		bottom: 0;
		margin: auto;
	}

	.top_bg_sp {
		width: 100%;
		height: auto;
		margin-top: 0px;
		margin-left: 0px;
		display: block;
		z-index: 10;

	}

	.bnr_bigguy_link_sp {
		width: 80%;
		position: absolute;
		left: 0;
		right: 0;
		margin: auto;
		bottom: 5%;
		z-index: 20;
		display: block;
	}

	.bnr_bigguy_sp {
		width: 100%;
		height: auto;
		margin: 0;
		z-index: 20;
		display: block;
	}


	#video_box_sp {
		position: absolute;
		margin-top: 0%;
		margin-left: 0%;
		width: 100%;
		height: 100%;
		background-color: #fff;
	}

	#video_box_sp::before {
		z-index: 2;
		content: '';
		display: block;
		position: absolute;
		width: 100%;
		height: 100%;
		top: 0;
		left: 0;
		background: url(../images/bgpatternb.png) center top/3px 3px;
	}

	#video_box_sp video {
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0%;
		left: 0%;
		object-fit: cover;
	}


	#bnr_sp_box {
		width: 100%;
		text-align: center;
	}

	#bnr_sp_box img {
		display: block;
		margin: 0 auto 10px auto;
	}

	#trailer_sp_box {
		width: 100%;
		text-align: center;
		margin: 0px;
		padding-top: 20px;
		padding-bottom: 30px;
	}

	#trailer_sp_box h3 {
		color: #fffb26;
		font-size: 20pt;
		font-weight: 900;
		text-align: center;
		text-shadow: 3px 3px 0px #000;
		transform: rotate(-5deg);
		margin: 0 0 20px;

	}

	#trailer_sp_box iframe {
		width: 90%;
		height: calc(100vw * 9 / 16);
		margin: 0 auto;
	}








	.movie_nav {
		width: 90%;
		display: -webkit-flex;
		display: flex;
		-webkit-flex-wrap: wrap;
		flex-wrap: wrap;
		margin-top: 7px;
		margin-right: auto;
		margin-left: auto;
		margin-bottom: 0;
		padding: 0;
	}

	.movie_nav_box {
		width: 50%;
		padding: 1px;
	}

	.movie_nav_box_long {
		width: 100%;
		padding: 1px;
	}

	.movie_nav_btn {
		display: block;
		/*		min-height: 40px;*/
		/*		line-height: 40px;*/
		/*		letter-spacing: 3px;*/
		padding: 5px 0;
		text-align: center;
		text-decoration: none;
		background-color: #fffb26;
		/*  font-family: 'Noto Sans JP', serif;*/
	}

	.movie_nav_btn.selected {
		background-color: #11A5FF;
		border: 1px #fff solid;
	}

	a.movie_nav_btn:link,
	a.movie_nav_btn:visited {
		color: #454545;
	}

	a.movie_nav_btn.selected:link,
	a.movie_nav_btn.selected:visited {
		color: #fff;
	}





	#ftr_sp_box {
		width: 100%;
		text-align: center;
		padding-bottom: 20px;
		display: none;
	}


	.pre_bl_sp {
		width: 95%;
		height: auto;
		display: block;
		margin: 0 auto;
	}

	#ftr_sp_bnr {
		width: 100%;
		text-align: center;
		padding-top: 15px;
	}

	#ftr_sp_bnr img {
		width: 90%;
		margin: 0 auto 8px auto;
	}

	#top_sp_tw {
		display: inline-block;
		margin-top: 15px;
		margin-right: auto;
		margin-left: auto;
		margin-bottom: 0px;
		padding-right: 0px;
		padding-left: 0px;
		padding-bottom: 10px;
		clear: both;
		height: 100px;
		/*		width: 233px;*/
		/*		width: 157px;*/
	}

	.sns {
		margin-top: 0px;
		margin-right: 7px;
		margin-bottom: 0;
		float: left;
		margin-left: 0;
	}


	.fb {
		margin-top: 0px;
		margin-right: 0px;
		margin-bottom: 0;
		float: left;
		margin-left: 0;
	}


	.tw {
		margin-top: 0px;
		margin-right: 0px;
		margin-left: 5px;
		margin-bottom: 0;
		float: left;
		width: 36px;
	}


	.lineb {
		margin-top: 0px;
		margin-right: 0px;
		margin-left: 5px;
		margin-bottom: 0;
		float: left;
		width: 37px;
	}

	.eigacom {
		margin-left: 0px;
		text-align: left;
		float: left;
		margin-top: 0px;
		height: 60px;
		/*		width: 36px;*/
	}

	/*------- SUB PAGE ----------------*/
	#subpage_box {
		width: 100%;
		background-image: url(../images/pre_bg_sp.jpg);
		background-position: center top;
		background-repeat: no-repeat;
		background-size: auto 100%;
	}

	.sub_box {
		min-width: inherit;
	}

	.in_box {
		width: 100%;
	}

	/*----------PHOTO SCROLL------------*/

	#slide_photo_pc1 {
		width: 100%;
		height: 160px;
		background: repeat-x url("../images/scrl_1_sp.jpg") left top/auto 100%;
		animation: loop-sp infinite 40s linear;
		z-index: 20;
	}

	@keyframes loop-sp {
		0% {
			background-position: 0 0;
		}

		100% {
			background-position: -1390px 0;
		}
	}
	

	#slide_photo_pc2 {
		width: 100%;
		height: 160px;
		background: repeat-x url("../images/scrl_2_sp.jpg") left top/auto 100%;
		animation: loop-sp2 infinite 40s linear;
		z-index: 20;
	}

	@keyframes loop-sp2 {
		0% {
			background-position: -1390px 0;
		}

		100% {
			background-position: 0 0;
		}
	}


	#slide_photo_pc3 {
		width: 100%;
		height: 160px;
		background: repeat-x url("../images/scrl_3_sp.jpg") left top/auto 100%;
		animation: loop-sp3 infinite 40s linear;
		z-index: 20;
	}

	@keyframes loop-sp3 {
		0% {
			background-position: 0 0;
		}

		100% {
			background-position: -1390px 0;
		}
	}

	/*----------MOVIE------------*/

	#movie_box {
		padding-top: 1px;
		padding-bottom: 80px;
		background-image: url(../images/pre_bg_sp.jpg);
	}

	#movie_box h3 {
		font-size: 20pt;
		margin-top: 30px;
		margin-bottom: 30px;
	}

	#movie_box .pad_lr {
		padding-left: 6px;
	}


	.yokoku_slidebox {
		width: 300px;
		height: 168px;
	}

	.yokoku {
		width: 300px;
		height: 168px;
	}

	.yokoku iframe {
		width: 300px;
		height: 168px;
	}


	/*------- INTRODUCTION ----------------*/
	#intro_box {
		height: auto;
		padding-top: 11vw;
		padding-bottom: 30px;
		background-image: url(../images/waku_intro_sp.png), url(../images/pre_bg_sp.jpg);
		background-position: center 11vw, center top;
		background-repeat: no-repeat;
		background-size: 100% auto;
		/*		overflow-x: hidden;*/
	}

	.kiri_1 {
		margin-top: -13vw;
		margin-left: auto;
		right: 5px;
		width: 38vw;
		height: auto;
	}

	.intro_txtbox {
		width: 100%;
		height: 106vw;
	}

	.waku_intro_h3 {
		width: 100%;
		height: auto;
		margin: 0;
	}

	.waku_intro_h3_sp,
	.waku_intro_txt_sp {
		position: absolute;
		margin-top: 0%;
		margin-left: 0%;
		width: 100%;
		height: auto;
	}


	/*------- STORY ----------------*/
	#story_box {
		height: auto;
		padding-top: 1px;
		padding-bottom: 30px;
		background-image: url(../images/waku_story_sp.png), url(../images/pre_bg_sp.jpg);
		background-position: center 1px, center top;
		background-repeat: no-repeat;
		background-size: 100% auto;
	}

	.story_txtbox {
		width: 100%;
		height: 136vw;
	}

	.waku_story_h3_sp,
	.waku_story_txt_sp {
		position: absolute;
		margin-top: 0%;
		margin-left: 0%;
		width: 100%;
		height: auto;
	}


	/*------- CAST ----------------*/
	#cast_box {
		height: auto;
		padding-top: 1px;
		padding-bottom: 30px;
		background-image: url(../images/waku_intro_sp.png), url(../images/pre_bg_sp.jpg);
		background-position: center 1px, center top;
		background-repeat: no-repeat;
		background-size: 100% auto;
	}

	.cast_txtbox {
		width: 100%;
		height: 114vw;
	}

	.waku_cast_h3_sp,
	.waku_cast_txt_sp {
		position: absolute;
		margin-top: 0%;
		margin-left: 0%;
		width: 100%;
		height: auto;
	}













}

@media screen and (max-width: 330px) {
	.vsp {
		display: inline-block;
	}

}
