@media screen and (max-width: 767px) {
	html {
		height: 100%;
		min-width: inherit;
	}

	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: #970000;
	}

	#header_sp_sns {
		/*		text-align: center;*/
		width: calc(100% - 4.6rem);
	}

	#header_sp_sns a {
		color: #fff;
		font-size: 17pt;
		margin: 0 0.9rem;
		line-height: 4.4rem;
	}

	/*-----TOP-------*/

	#top_sp_box {
		width: 100%;
		margin-top: 4.6rem;
		overflow: hidden;
	}



	.top_new_bl_sp1 {
		width: 74.25%;
		height: auto;
		position: absolute;
		margin-top: 3.3%;
		margin-left: 22.5%;
		z-index: 20;
	}
	
	.top_new_bl_sp2 {
		width: 74.25%;
		height: auto;
		position: absolute;
		margin-top: 3.3%;
		margin-left: 22.5%;
		z-index: 20;
	}
	
	.top_new_logo_sp {
		width: 70.13%;
		height: auto;
		position: absolute;
		margin-top: 81.4%;
		margin-left: 0%;
		z-index: 20;
	}
	
	.top_new_logo_sp {
		width: 70.13%;
		height: auto;
		position: absolute;
		margin-top: 81.4%;
		margin-left: 0%;
		z-index: 20;
	}
	
	.top_new_bl_sp {
		width: 70.25%;
		height: auto;
		position: absolute;
		margin-top: 103.4%;
		margin-left: 5%;
		z-index: 20;
	}
	
	.top_new_lead_sp {
		width: 87.5%;
		height: auto;
		position: absolute;
		margin-top: 133.8%;
		margin-left: 5%;
		z-index: 20;
	}
	
	.top_new_koukai_sp {
		width: 12.75%;
		height: auto;
		position: absolute;
		margin-top: 123.8%;
		margin-left: 79.3%;
		z-index: 20;
	}
	
	

	

	.top_new_bg_sp {
		width: 100%;
		height: auto;
		margin-top: 0px;
		margin-left: 0px;
		display: block;
		z-index: 10;
	}


	#bnr_sp_box {
		width: 100%;
		text-align: center;
	}

	#bnr_sp_box img {
		display: block;
		margin: 0 auto 10px auto;
	}
	
	/*-----mvtk-------*/
	#mvtk_mado{
		width: 100%;
        height: 100vh;
        padding: 0;
        position: fixed;
        bottom: 0;
        left: 0;
        z-index: 1000;
        display: none;
		opacity: 0.0;
        filter: drop-shadow(0 0 10px rgba(0, 0, 0, 0.4));
	}
	
	.btn_mvtk_close{
		width: 4.6rem;
		right: 0;
	}
	
    #mvtk_bg {
        background: #fff;
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
        z-index: 1;
        opacity: 0.9;
    }	
	
	#mvtk_box{
		margin-top: 45vw;
		z-index: 2
	}
	

	/*-----TRAILER-------*/

	#trailer_box {
		width: 100%;
		text-align: center;
		margin: 0px;
		padding-top: 20px;
		padding-bottom: 20px;
	}

	#trailer_box iframe {
		width: 90%;
		height: calc(100vw * 0.9 * 0.9 / 1.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;
		text-align: center;
		text-decoration: none;
		background-color: #fff;
		/*  font-family: 'Noto Sans JP', serif;*/
	}

	.movie_nav_btn.selected {
		background-color: #515151;
	}

	a.movie_nav_btn:link,
	a.movie_nav_btn:visited {
		color: #515151;
	}

	a.movie_nav_btn.selected:link,
	a.movie_nav_btn.selected:visited {
		color: #fff;
	}

	.nbsp1{
		width: 100%;
	}
	
	.nbsp2{
		width: 50%;
	}



	#ftr_sp_box {
		width: 100%;
		text-align: center;
		padding-top: 20px;
		padding-bottom: 20px;
		background-color: #970000;
	}

	h3 {
		font-family: "Spectral", serif;
		font-weight: 400;
		color: #515151;
		margin-top: 50px;
		margin-bottom: 30px;
		font-size: 16pt;
	}

	#trailer_sp_box h3 {
		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%;
		height: auto;
		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;
	}


	.line {
		margin-top: 0px;
		margin-right: 0px;
		margin-left: 5px;
		margin-bottom: 0;
		float: left;
	}

	.eigacom {
		margin-left: 0px;
		text-align: left;
		float: left;
		margin-top: 0px;
		height: 60px;
		/*		width: 36px;*/
	}

	#main {
		min-width: inherit;
		overflow-x: hidden;
	}

	.sub_box {
		min-width: inherit;
		overflow-x: hidden;
	}

	.in_box {
		width: 100%;
	}

	/*----------PHOTO SCROLL------------*/

	#slide_photo_pc1{
		width: 100%;
		height: 150px;
		background: repeat-x url("../images/scrl_1_sp.jpg?2") 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: -1575px 0;
		}
	}

	@keyframes loop-sp {
		0% {
			background-position: 0 0;
		}
		100% {
			background-position: -1575px 0;
		}
	}

	#slide_photo_pc2{
		width: 100%;
		height: 150px;
		background: repeat-x url("../images/scrl_2_sp.jpg?2") left top/auto 100%;
		-webkit-animation: loop-sp2 infinite 40s linear;
		animation: loop-sp2 infinite 40s linear;
		z-index: 20;
	}

	@-webkit-keyframes loop-sp2 {
		0% {
			background-position: -1585px 0;
		}
		100% {
			background-position: 0 0;
		}
	}

	@keyframes loop-sp2 {
		0% {
			background-position: -1585px 0;
		}
		100% {
			background-position: 0 0;
		}
	}

	
	/*-----INTRODUCTION-------*/
	#intro_box {
		padding-bottom: 50px;
		background-position: center bottom;
		background-repeat: no-repeat;
		background-size: 100% auto;
	}
	
	#intro_box .in_box{
		width: 100%;
	}
	
	#intro_box .txt_box{
		text-align:justify;
	}


	.intro_lead {
		font-size: 14pt;
		margin-bottom: 30px;
		text-align: center;
	}

	.intro_leadsp {
		line-height: 1.6em;
		margin-bottom: 20px;
	}



	/*-----STORY-------*/
	#story_box {
		padding-bottom: 50px;
		background-position: center bottom;
		background-repeat: no-repeat;
		background-size: 100% auto;
	}
	
	#story_box .in_box{
		width: 100%;
	}

	.story_lead {
		font-size: 14pt;
		margin-bottom: 30px;
		text-align: center;
	}

	/*-----CAST-------*/
	#cast_box {
		padding-top: 1px;
		padding-bottom: 50px;
	}
	
	#cast_box h3{
		width: 100%;
	}
	
	#cast_box.sub_box{
	}
	
	#chart_cont{
		width: 100%;
		overflow-x: scroll;
	}
	
	#chart_box{
		width: 170%;
		max-width: inherit;
	}
	
	.prof_btn{
		width: 14.0%;
/*		height: 10%;*/
		border: 2px #b6b5b3 solid;

	}
	
	.cRed{
		width: 16.1%;
/*		height: 14.2%;*/
		border: 2px #960001 solid;
	}
	

	
	
	
	
	
	#cast_box .in_boxS{
	justify-content: space-around;
	}



	.prof_btn_ {
		width: 45%;
		max-width: 610px;
		margin: 0 0px 50px;
		color: #515151;
	}

	.prof_btn.castS{
		width: 38%;
		margin: 0 0px 50px;
	}

	.prof_btn.castS2{
		margin: 0 0px 50px;
	}
	
	.cast_spa{
		display: none;
	}
	
	.cast_spa2{
		display: block;
		width: 100%;
	}

	.cast_name {
		font-size: 12pt;
		text-align: center;
		margin-bottom: 0;
	}

	.cast_name small {
		display: block;
	}

	.cast_en {
		font-size: 11pt;
		text-align: center;
		letter-spacing: 0.2em;
		line-height: 1.1em;
	}

	.plus1 {
		width: 14%;
		height: auto;
		bottom: 4%;
		right: 4%;
	}

	.chok{
		letter-spacing: -0.1em;
	}


	/*----------Profile Mado------------*/

	.prof_mados {
		padding: 25px 20px 30px;
		color: #000;
		background: #fff;
		font-size: 11pt;
		line-height: 1.7em;
	}
	
	.cast_flex{
		display: block;
	}
	
	.cast_madoimg{
		width: 100%;
		margin: 0 0 30px;
	}

	.cast_ptS {
		width: 70%;
		height: auto;
		display: block;
		margin: 0 auto 20px;
	}

	.cast_madotxt {
		flex: none;
		text-align: justify;
		text-justify: inter-ideograph;
		height: 400px;
		padding: 20px 10px;
	}


	.prof_mados .cast_name {
		font-size: 15pt;
		margin-bottom: 10px;
	}

	.staff_madotxt .cast_name {
		font-size: 15pt;
		margin-bottom: 15px;
	}


	.prof_mados .cast_name small {
		font-size: 80%;
		display: inline
	}


	.cast_cmt {
		background-color: #bcbbbb;
		padding: 10px 10px 15px;
		margin-top: 30px;
		text-align: justify;
		text-justify: inter-ideograph;
	}

	.cast_cmtt {
		font-family: 'Crimson Pro', serif;
		font-size: 120%;
		margin-bottom: 10px;
	}
	

	/*-----STAFF-------*/
	#staff_box {
		padding-top: 1px;
		padding-bottom: 50px;
	}


	#staff_box .prof_btn {
		width: 43%;
		max-width: 610px;
		margin: 0 0px 50px;
		padding: 25px 0;
	}

	.plus2{
		position: absolute;
		top: auto;
		transform: translateY(0);
		width: 14%;
		height: auto;
		bottom: 4%;
		right: 4%;
		z-index: 20;
	}


	
	
	
	
	
	
	
	/*-----Theme Song-------*/
	#thema_box {
		padding-top: 20px;
		padding-bottom: 50px;
	}

	#thema_box .in_box{
		width: 95%;
		padding: 30px 13px 60px;
	}
	
	#thema_box .txt_box{
		display: block;
	}
	
	.thema_L{
		display: block;
		width: 100%;
	}
	
	.thema{
		width: 90%;
		max-width: 280px;
		margin: 0 auto;
	}
	
	.smalls{
		display: block;
		padding-left: 4.7em;
	}

	.song_pt{
		margin: 0 auto 30px;
	}

	.thema_L .plus2{
		bottom:30%;
		width: 30px;
		height: 30px;
		right: -10px;

	}
	



	/*-----ORIGINAL-------*/
	#original_box {
		padding-top: 20px;
		padding-bottom: 50px;
	}

	#original_box .in_box{
		width: 95%;
		padding: 30px 13px 60px;
	}
	
	#original_box .txt_box{
		display: block;
	}
	
	.orgin_L{
		display: block;
		width: 100%;
	}
	
	.gensak{
		width: 90%;
		max-width: 280px;
		margin: 0 auto;
		padding-left:1em;
		text-indent:-1em;
	}
	
	.gensak2{
		padding-left:0em;
		text-indent:0em;
	}
	
	.smalls{
		display: block;
		padding-left: 2em;
	}

	.original_pt{
		margin: 0 auto 30px;
	}

	.orgin_L .plus2{
		bottom:20%;
		width: 30px;
		height: 30px;
	}
	
	
	.share_btn{
		font-size: 21pt;
		letter-spacing: 0.4em;
	}
	
	
	/*-----Location Map-------*/
	#map_box {
		padding-top: 20px;
		padding-bottom: 50px;
	}

	#map_box .in_box{
		width: 95%;
		padding: 30px 13px 60px;
	}
	
	#map_box iframe.map{
		width: 100%;
		height: 600vw;
	}

	.icon-search-glass-plus{
		font-size: 40pt
	}
	
	/*-----Billing-------*/
	#bill_box {
		padding-top: 40px;
		padding-bottom: 40px;
	}

	#bill_box .in_box{
		font-size: 0.7pt;
		font-size: 0.25vw;
		line-height: 2.8rem;
	}
	
	footer{
/*		background-color: #970000;*/
	}
	

}

@media screen and (max-width: 330px) {
	.vsp {
		display: inline-block;
	}

}
