@media screen and (max-width: 767px) {

	body {
		font-size: 11pt;
		line-height: 1.5em;
	}

	/*-----Sub Page-------*/
	.sub_box {
		width: 100%;
		min-width: inherit;
		margin: 0 auto;
		background-position: center top;
		background-repeat: no-repeat;
	}

	h3 {
		display: block;
		font-size: 20pt;
		font-weight: 400;
		text-align: center;
		height: 160px;
		padding-top: 39px;
		background-size: auto 100%;
		
	}

	.h3in{
		width: 300px;
		height: 75px;
		background-size: 80% auto;

	}
	


	.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: 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>*/
	}

	.d_flex {
		display: -webkit-flex;
		display: flex;
	}


	/*----------PHOTO SCROLL------------*/

	#slide_photo_pc1 {
		width: 100%;
		height: 170px;
		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: -1905px 0;
		}
	}

	#slide_photo_pc2 {
		width: 100%;
		height: 170px;
		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: -1905px 0;
		}

		100% {
			background-position: 0 0;
		}
	}



	/*----------INTRODUCTION------------*/

	#intro_box {
		padding-top: 0;
		padding-bottom: 50px;
	}



	/*----------STORY------------*/

	#story_box {
		padding-top: 0;
		padding-bottom: 50px;
	}



	/*----------CAST------------*/

	#cast_box {
		padding-top: 1px;
		padding-bottom: 50px;
	}

	.prof_btn{
		margin-bottom: 40px;
	}

	.cast_L{
		width: 44%;
	}

	.cast_M{
		width: 30%;
	}

	.cast_S{
		width: 28%;
	}

	.cast_pbox::after{
		right: 13px;
		bottom: 13px;
		width: 24px;
		height: 24px;
	}

	.cast_M .cast_pbox::after{
		right: 10px;
		bottom: 13px;
		width: 24px;
		height: 24px;
	}

	.cast_name{
		font-size: 13pt;
		margin-top: 5px;
		letter-spacing: 0.1em;
	}

	.cast_S .cast_name{
		font-size: 9pt;
		line-height: 1.3em;
		
	}

	.cast_role{
		font-size: 70%;
		margin-bottom: 0px;
	}



	/*----------Profile Mado------------*/

	.prof_mados {
		padding: 5px;;
		color: #a27b40;
		background: #000;
		font-size: 11pt;
		line-height: 1.7em;
		background-image: url('../images/cast_waku.jpg');
		background-position: center top;
		background-repeat: repeat;
	}

	.cast_flex{
		display: block;
	}

	.prof_mados .cast_ptL {
		width: 100%;
		height: auto;
		margin-top: 10px;
		margin-bottom: 15px;
	}

	.cast_ptS{
		width: 70%;
		height: auto;
		display: block;
		margin: 0 auto 20px;
	}

	.cast_madotxt,
	.staff_madotxt {
		flex: auto;
		width: 100%;}


	.prof_mados .cast_name {
		font-size: 18pt;
		margin-bottom: 15px;
	}

	.staff_madotxt .cast_name {
		font-size: 15pt;
		margin-bottom: 15px;
	}





	/*----------STAFF------------*/

	#staff_box {
		padding-top: 1px;
		padding-bottom: 50px;
	}

	#staff_box .txt_box{
		display: block;
	}

	.direc_pt{
		display: block;
		width: 44%;
		height: auto;
		margin: 0 auto 20px;
	}

	/*----------MUSIC------------*/

	#music_box{
		padding-top: 1px;
		padding-bottom: 50px;
	}

	.music_pt{
		width: 70%;
		height: auto;
		margin: 0 auto 30px;;
	}

	.music_name{
		font-size: 18pt;
		margin-bottom: 30px;
		text-align: center;
	}



	/*----------FOOTER------------*/
	#footer {
		height: 180px;
		background-size: auto 100%;
	}



}
