@media screen and (max-width: 767px) {
	body {
		font-size: 10pt;
		line-height: 1.5em;
	}

	/*-----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_box1{
		padding: 10px 0;
		margin: 30px 0 30px;background-image: url(../images2/h3_line1_sp.png);
	}
	
	.h3_box2{
		padding: 10px 0;
		margin: 30px 0 30px;
		background-image: url(../images2/h3_line2_sp.png);
	}
	
	

	h3 {
		font-size: 15pt;
	}


	.sub_head {
		width: 100%;
		min-width: inherit;
		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: 13px;
		padding-right: 13px;
	}

	.w100pct {
		width: 100%;
		min-width: inherit;
		height: auto;
		margin: 0;
		display: block;
		z-index: 10;
	}

	.yokobo {
		letter-spacing: -0.1em;
		/*	<span class="yokobo">――</span>*/
	}

	.d_flex {
		display: -webkit-flex;
		display: flex;
	}


	/*----------PHOTO SCROLL------------*/

	#slide_photo_pc1 {
		width: 100%;
		height: 144px;
		background: repeat-x url("../images/scrl1_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: -1400px 0;
		}
	}

	@keyframes loop-sp {
		0% {
			background-position: 0 0;
		}

		100% {
			background-position: -1400px 0;
		}
	}

	#slide_photo_pc2 {
		width: 100%;
		height: 200px;
		background: repeat-x url("../images/scrl2_sp.jpg") 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: -1267px 0;
		}

		100% {
			background-position: 0 0;
		}
	}

	@keyframes loop-sp2 {
		0% {
			background-position: -1267px 0;
		}

		100% {
			background-position: 0 0;
		}
	}
	
	/*----------MOVIE------------*/

	#movie_box{
		padding-top:1px;
		padding-bottom: 30px;
	}

	.yokoku_sp {
		width: 100%;
		height: calc(100vw * 0.6);
		margin: 0 auto;
	}

	/*----------NEWS------------*/

	#news_box{
		padding-top:1px;
		padding-bottom: 30px;
	}
	
	a.news_line{
		display: block;
		height: inherit;
		padding-bottom: 10px;
	}
	
	.news_title{
		overflow:inherit;
		white-space:inherit;
		text-overflow:inherit;
		display: inline;
	}
	
	.news_arrow{
		display: inline;
	}
	
	a.more_btn{
		width: 300px;
		height: 67.76px;
		line-height: 67.76px;
		font-size: 12pt;
	}


	/*----------SCHEDULE------------*/

	#sche_box {
		padding-top: 1px;
		padding-bottom: 30px;
	}
	
	.nittei{
		text-align: center;
		margin-bottom: 20px;
		line-height: 2em;
		font-size: 14pt;
	}
	
	.theater_add{
		font-size: 12pt;
		line-height: 1.6em;

	}
	
	.sche_sp{
		width: 100%;
		height: auto;
		margin-bottom: 20px;
	}
	
	a.sche_btn{
		margin-top: 15px;
	}

	/*----------THEATER------------*/

	#theater_box{
		padding-top:1px;
		padding-bottom: 30px;
	}
	
	/*----------TICKET------------*/

	#ticket_box{
		padding-top:1px;
		padding-bottom: 30px;
	}
	
	.size18{
		font-size: 14pt;
		line-height: 1.8em
	}
	.ticket_price{
		font-size: 19pt;
		margin-bottom: 30px;
	}
	
	.ticket_tokuten{
		width: 100%;
		max-width: 297.9px;
		background-size: 90% auto;
		font-size: 16pt;
/*		height: 80px;*/
/*		max-height: 70px;*/
		margin-bottom: 20px;
	}
	
	.ticket_tokuten_txt{
		font-size: 14pt;
		line-height: 2.0em;
		margin-bottom: 30px;
	}
	
	.ticket_senko{
		width: 100%;
		text-align: left;
		padding: 20px 10px;
	}
	
	.ticket_senko_ttl{
		text-align: center;
		font-size: 16pt;
		margin-bottom: 10px;
	}
	
	.ticket_fcbox{
		width: 90%;
		margin: 20px auto 0;
		text-align: left;
		font-size: 70%;
		line-height: 1.4em;
	}


	
	.tike{
		display: block;
		line-height: 1.4em;
	}

	.tikeL{
		width: 100%;
		text-align: left;
		margin-bottom: 0;
	}

	.tikeR{
		width: 100%;
		text-align: left;
		font-size: 80%;
		margin-bottom: 15px;
	}

	.tike2{
		width: 100%;
		font-size: 70%;
		text-align: left;
		margin: 0 auto;
	}


	/*----------GOODS------------*/

	#goods_box{
		padding-top:1px;
		padding-bottom: 30px;
	}
	
	.good_inbox{
		margin-bottom: 40px;
		padding: 0 13px;
		justify-content: space-between;
	}
	
	.goods{
		width: 48%;
		padding: 10px;
		margin: 0 0px 12px;
		font-size: 11pt;
		line-height: 1.6em;
	}
	
	.goods img{
		width: 100%;
		height: auto;
		margin-bottom: 10px;
	}
	
	.goods img.goods_btn{
		width: 30px;
		height: auto;
		bottom: -7px;
		right: 5px;
	}


	/*----------GOODS Mado------------*/

	.goods_mados {
		padding: 30px 20px 30px;
		color: #000;
		background: #ddf1ff;
		font-size: 11pt;
		line-height: 1.7em;
	}
	
	.goods_flex{
		display:block;
	}

	.goods_madotxt {
		width: 100%;
		padding-left: 0;
	}


	.goods_mados .goods_name {
		font-size: 14pt;
		margin-bottom: 15px;
	}
	
	.goods_img{
		width: 100%;
		height: auto;
	}


	/*----------INTRODUCTION------------*/

	#intro_box {
		padding-top: 30px;
		padding-bottom: 30px;
	}



	/*----------STORY------------*/

	#story_box {
		padding-top: 1px;
		padding-bottom: 30px;
	}



	/*----------CAST------------*/

	#cast_box {
		padding-top: 1px;
		padding-bottom: 30px;
	}
	
	#cast_box .size18{
		font-size: 12pt;
		line-height: 2.1em
	}

	
	.casts{
		width: 45%;
		margin: 0 2% 30px;
	}
	
	.casts__::before{
		content: url(../images/cast_btn.png);
		position: absolute;
		width: 12%;
		height: auto;
		top: 65%;
		right: 19%;
		z-index: 10;
	}


	/*----------相関図------------*/

	#diagram_box{
		padding-top:30px;
		padding-bottom: 30px;
	}

	.musi{
		font-size: 23pt;
		position: absolute;
		margin-top: -4%;
		margin-left: 4%;
	}

	
	
	
	/*----------NOTICE------------*/

	#notice_box{
		padding-top:1px;
		padding-bottom: 30px;
	}

	.notice_lead{
		text-align: left;
		margin-bottom: 30px;
	}
	
	#notice_box .h3_box{
		margin: 30px 0 40px;
	}
	

	/*----------STAFF------------*/

	#staff_box {
		padding-top: 1px;
		padding-bottom: 30px;
	}

	#staff_box .txt_box{
		font-size: 13pt;
	}

	.sfl{
		margin-top: 15px;
	}
	
	/*----------STAFF------------*/
	#contact_box h3{
		font-size: 11pt;
	}



	/*-----PARA-------*/
	.para_box {
		background-position: center top;
		background-repeat: no-repeat;
		background-size: auto;
		background-attachment: scroll;
		width: 100vw;
	}

	#para_pt1 {
		background-image: url(../images/para_pt1_sp.jpg);
		height: 55vw;
		background-size: 120% auto;
	}

	#para_pt2 {
		background-image: url(../images/para_pt2_sp.jpg);
		height: 55vw;
		background-size: 120% auto;
		background-position: left top;
	}

	#para_pt3 {
		background-image: url(../images/para_pt3_sp.jpg);
		height: 55vw;
		background-size: 120% auto;
	}

	#para_pt4 {
		background-image: url(../images/para_pt4_sp.jpg);
		height: 55vw;
		background-size: 120% auto;
		background-position: left top;
	}

	#para_pt5 {
		background-image: url(../images/para_pt5_sp.jpg);
		height: 52vw;
		background-size: 140% auto;
	}

	/*----------STAFF------------*/

	#pt_box {
		padding-top: 1px;
		height: 135vw;
		background-color: #fff;
	}

	#pt_box img {
		position: absolute;
		height: auto;
	}

	.sub_ftrpt_1 {
		margin-top: 10%;
		margin-left: 8%;
		width: 61.1%;
		z-index: 50;
	}

	.sub_ftrpt_2 {
		margin-top: 54%;
		margin-left: 63%;
		width: 25.44%;
		z-index: 20;
	}

	.sub_ftrpt_3 {
		margin-top: 79%;
		margin-left: 14%;
		width: 43%;
		z-index: 30;
	}

	.sub_ftrpt_4 {
		margin-top: 103%;
		margin-left: 41%;
		width: 41.72%;
		z-index: 40;
	}


	/*----------FOOTER------------*/
	footer {
		padding-top: 50px;
		padding-bottom: 30px;
		text-align: center;
		min-width: inherit;
	}

	.sub_logo {
		width: 60%;
		height: auto;
	}

	.totop_box {
		margin-top: 50px;
	}

	.btn_back {
		width: 175px;
		height: 175px;
		text-align: center;
		background-color: #000;
		color: #fff;
		border-radius: 50%;
		-webkit-border-radius: 50%;
		-moz-border-radius: 50%;
		font-family: 'Crimson Pro', serif;
		font-size: 16pt;
		padding-top: 52px;
		margin: 0 auto;
		cursor: default;
		transition: 0.7s;
		-webkit-transition: 0.7s;
		-moz-transition: 0.7s;
	}



}

@media screen and (max-width: 320px) {
	.stfk{
		font-size: 85%;
	}
}





