@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: #74858d;
		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: #000;
	}

	#header_sp_sns {
		/*		text-align: center;*/
		width: calc(100% - 4.6rem);
	}

	#header_sp_sns a {
		color: #fff;
		font-size: 17pt;
		font-size: 3.3rem;
		margin: 0 0.9rem;
		line-height: 4.4rem;
	}

	/*-----TOP-------*/

	#top_sp_box {
		width: 100%;
		margin-top: 4.6rem;
	}

	#top_sp_box {
		width: 100%;
		padding-top: 0;
	}



	.top_logo_sp {
		width: 100%;
		height: auto;
		position: absolute;
		margin-top: 0px;
		margin-left: 0px;
		z-index: 20;
	}

	.top_txt_sp {
		width: 100%;
		height: auto;
		position: absolute;
		margin-top: 0px;
		margin-left: 0px;
		z-index: 20;
	}

	.top_bg_sp {
		width: 100%;
		height: auto;
		margin-top: 0px;
		margin-left: 0px;
		display: block;
		z-index: 10;
	}





	.kino_box {
		width: 237px;
		height: 17px;
		margin: 15px auto 20px auto;
	}

	#bnr_sp_box {
		width: 100%;
		text-align: center;
		display: none;
	}

	#bnr_sp_box img {
		display: block;
		margin: 0 auto 10px auto;
	}
	
	.menubox a{
		padding: 5px 0;
		width: 150px;
		margin: 0 5px;
	}
	
	#mvtk_bnrbox img{
		width: 90%;
		max-width: 342px;
		height: auto;
		margin: 0 0 1%;
	}
	

	#trailer_sp_box {
		width: 100%;
		text-align: center;
		margin: 0px;
		background-color: #909da5;
		padding-top: 50px;
		padding-bottom: 20px;
	}

	#trailer_sp_box iframe {
		width: 90%;
		height: calc(100vw * 0.6);
		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;
		text-align: center;
		text-decoration: none;
		background-color: #909DA3;
		font-family: 'Noto Serif JP', serif;
	}

	.movie_nav_btn.selected {
		background-color: #74858D;
	}

	a.movie_nav_btn:link,
	a.movie_nav_btn:visited {
		color: #FFFFFF;
	}

	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;
		background-color: #909da5;
	}

	#trailer_sp_box h3 {
		font-family: 'Crimson Text', serif;
		margin-top: 0px;
		margin-bottom: 10px;

	}

	.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: -4px;
		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;
	}


	.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 ----------------*/
	/*---------------------------------*/

	#main {
		width: 100%;
		min-width: inherit;
		overflow: hidden;
	}

	.sub_box {
		width: 100%;
		min-width: inherit;
		margin: 0 auto;
		background-position: center top;
		background-repeat: no-repeat;
	}

	h3 {
		display: block;
		font-size: 18pt;
	}


	.sub_head {
		width: 100%;
		margin: 0;
		background-repeat: no-repeat;
		background-position: center top;
		z-index: 10;
	}

	.sub_head_inbox {
		width: 1000px;
		margin: 0 auto;
		position: relative;
		z-index: 10;
	}

	.in_box {
		margin: 0;
		width: 100%;
	}

	.txt_box {
		font-size: 11pt;
		line-height: 1.5em;
		text-align: justify;
		text-justify: inter-ideograph;
	}

	.pad_lr {
		padding-left: 20px;
		padding-right: 20px;
	}

	.w100pct {
		width: 100%;
		min-width: inherit;
		height: auto;
		margin: 0;
		display: block;
		z-index: 10;
	}

	.yokobo {
		letter-spacing: -0.1em;
		/*	<span class="yokobo">――</span>*/
	}

	/*----------PHOTO SCROLL------------*/

	#slide_photo_pc1 {
		width: 100%;
		height: 150px;
		background: repeat-x url("../images/scrl_pt_sp.jpg") left top/auto 100%;
		-webkit-animation: loop-sp infinite 40s linear;
		animation: loop-sp infinite 40s linear;
		z-index: 20;
	}

	@-webkit-keyframes loop-sp {
		0% {
			background-position: 0 0;
		}

		100% {
			background-position: -1694px 0;
		}
	}

	@keyframes loop-sp {
		0% {
			background-position: 0 0;
		}

		100% {
			background-position: -1694px 0;
		}
	}
	
	/*----------INTERVIEW------------*/

	#inte_box {
		padding-top: 1px;
		padding-bottom: 50px;
		color: #fff;
		background-color: #909da5;
	}
	
	#inte_box h3 {
		margin: 50px 0 50px;
	}

	#inte_box .txt_box{
		width: 100%;
	}
	
	#inte_box a{
		font-size: 12pt;
	}


	/*----------INTRODUCTION------------*/

	#intro_box {
		height: inherit;
		display: block;
		color: #fff;
		padding-bottom: 50px;
	}

	#intro_box .in_box {
		flex: 1;
	}

	#intro_txtbox {
		top: 0;
		-webkit-transform: none;
		transform: none;
	}


	#intro_box .txt_box {
		padding: 0 13px;
		max-width: 930px;
		margin: 0 auto;
		line-height: 1.8em;
	}
	.intro_lead1 {
		text-align: center;
		font-size: 23pt;
		line-height: 1.1em;
		margin-bottom: 20px;
	}

	.intro_lead2 {
		text-align: center;
		font-size: 18pt;
		line-height: 1.8em;
		margin-bottom: 30px;
	}

	#intro_box h3 {
		margin: 50px 0;
	}

	.intro_txt{
		height: inherit;
		overflow-y:auto;
		padding-right: 0;
	}

	/*----------STORY------------*/

	#story_box {
		padding-top: 1px;
		padding-bottom: 50px;
		color: #fff;
		background-color: #909da5
	}

	#story_box h3 {
		margin: 50px 0;
	}

	#story_box .txt_box {
		line-height: 1.8em;
		text-align: left;
	}

	#story_imgbox {
		padding-bottom: 1%;
	}

	#story_imgbox .sp_b {
		padding: 0 2.1%;
	}

	.story_pt2 {
		width: 100%;
		height: auto;
		display: block;
		margin-bottom: 2%;
		;
	}

	.story_pt_sp {
		margin-top: 60px;
	}
	
	/*----------CHART------------*/

	#chart_box {
		padding-top: 1px;
		padding-bottom: 50px;
		color: #fff;
		background-color: #000;
	}

	#chart_box h3 {
		margin: 50px 0;
	}

	.txt_box2{
		width: 100%;
		margin: 30px auto 0;
	}
	
	.txt_box2 a{
		font-size: 12pt;
	}

	/*----------Cast------------*/

	#cast_box {
		padding-bottom: 50px;
	}

	#cast_box h3 {
		margin: 50px 0 50px;
	}

	.cast_flex,
	.staff_flex{
		display: block;
	}

	.casts,
	.staffs{
		width: 100%;
		margin-bottom: 30px;
	}
	
	.staffs img.kantoku_pt{
		display: none;
	}

	/*----------PRODUCTION NOTE------------*/

	#prono_box {
		padding-top: 1px;
		padding-bottom: 50px;
	}

	#prono_box h3 {
		margin: 50px 0 50px;
	}
	
	.panel dt{
		font-size: 14pt;
		padding: 20px 41px 20px 5px;
	}
	
	.panel dt:before{
		right:0px;
		top:0;
		bottom: 0;
		margin: auto;
	}
	
	.prono_pt{
		display: block;
		float: inherit;
		width: 100%;
		height: auto;
		margin: 0 auto 10px;
	}


	/*----------COMMENT------------*/

	#cmt_box {
		padding-top: 1px;
		padding-bottom: 10px;
		color: #fff;
	}

	#cmt_box h3 {
		margin: 50px 0;
	}


	.cmt_txt {
		padding-bottom: 40px;
		margin-bottom: 40px;
	}

	.cmt_name {
		margin-bottom: 10px;
	}
	
	.cmt_tt {
		font-size: 14pt;
	}

	.cmt_prof {
		margin-top: 30px;
	}
	
	/*----------Profile Mado------------*/

	.prof_mados{
		padding: 5px 10px 30px;

		color: #000;
		 background-color: #74858d;
		font-size: 12pt;
		line-height: 1.7em;
	}

	#colorboxCast .sub_box{
		min-width: inherit;
	}

	#colorboxCast .in_box{
		width: 100%;
	}
	
	#colorboxCast .pad_lr{
		padding-left: 10px;
        padding-right: 20px;
	}
	
	#colorboxCast .cmt_txt {
		padding: 15px;
		margin-bottom: 20px;
	}

	

}

@media screen and (max-width: 375px) {
	.sp375 {
		display: inline-block;
	}
}

@media screen and (max-width: 330px) {
	.vsp {
		display: inline-block;
	}

}
