@media screen and (max-width: 767px) {

	body {
		font-size: 11pt;
		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;
		overflow: hidden;
	}

	h3 {
		display: block;
		font-family: "Oswald", serif;
		font-optical-sizing: auto;
		font-size: 35pt;
		font-weight: 400;
		/*	letter-spacing: 0.1em;*/
		text-align: center;
	}


	.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: 12pt;
		line-height: 1.6em;
		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: 201px;
		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: -1800px 0;
		}
	}

	@keyframes loop-sp {
		0% {
			background-position: 0 0;
		}

		100% {
			background-position: -1800px 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;
		}
	}



	/*----------INTRODUCTION------------*/
	#intro_box1 {
		padding-top: 0;
		padding-bottom: 50px;
		background-image: none;
		height: auto;
	}
	
	.intro_bg_sp{
		width: 100%;
		height: auto;
		z-index: 1;
	}
	
	#intro_box1 h3{
		transform: rotate(0deg);
		width: inherit;
		font-size: 35pt;
	}
	
	#intro_box1 .h3_box{
		position: relative;
		z-index: 20;
		top:inherit;
		right: inherit;
		margin-top: -20vw;
		margin-bottom: 30px;
	}
	
	#intro_pc{
		display: none;
	}
	
	#intro_sp{
		padding: 0 13px;
		z-index: 20;
	}

	.intro_midasi1_sp,
	.intro_midasi2_sp{
		width: 100%;
		height: auto;
	}
	
	.intro_midasi2_sp{
		margin-top: 20px;
	}
	
	/*----------INTRO2------------*/

	#intro_box2{
		padding-top:0;
		padding-bottom: 50px;
		background-image:  none;
		height: auto;
	}
	
	#intro2_body_sp{
		z-index: 10;
		margin-top: -19vw;
	}
	
	.intro2_midasi_sp{
		width: 100%;
		height: auto;
		margin-bottom: 10px;
	}
	
	.intro_lead2{
		display: none;
	}
	
	
	/*----------INTRO3------------*/

	#intro_box3{
		padding-top:0;
		padding-bottom: 50px;
		background-image:  none;
		height: auto;
	}
	
	#intro3_body_sp{
		z-index: 10;
		margin-top: -19vw;
	}
	
	.intro3_midasi_sp{
		width: 100%;
		height: auto;
		margin-bottom: 10px;
	}
	
	.intro_lead3{
		display: none;
	}
	
	/*----------INTRO4------------*/

	#intro_box4{
		padding-top:0;
		padding-bottom: 50px;
		background-image:  none;
		height: auto;
	}
	
	#intro4_body_sp{
		z-index: 10;
		margin-top: -19vw;
	}
	
	.intro4_midasi_sp{
		width: 100%;
		height: auto;
		margin-bottom: 10px;
	}
	
	.intro_lead4{
		display: none;
	}
	

	/*----------STORY------------*/

	#story_box {
		padding-top:0;
		padding-bottom: 50px;
		background-image:  none;
		height: auto;
	}
	
	.story_bg_sp{
		width: 100%;
		height: auto;
		z-index: 1;
	}
	
	#story_body{
		position: relative;
		bottom: inherit;
		left: inherit;
		z-index: 10;
		margin-top: -17%;
	}
	
	#story_body .txt_box{
		padding: 0 13px;
		text-align:justify
	}
	



	/*----------CAST------------*/

	#cast_box {
		padding-top: 0px;
		padding-bottom: 0px;
	}
	
	.casts{
		width: 100%;
	}

	#cast_box h3{
		display: none;
	}

	/*----------Profile Mado------------*/

	.prof_mados {
		padding: 40px 20px 30px;
		color: #fff;
		background: #000;
		font-size: 11pt;
		line-height: 1.7em;
	}

	.prof_mados .cast_ptL {
		width: 100%;
		height: auto;
		margin-top: 10px;
		margin-bottom: 15px;
	}

	.cast_madotxt,
	.staff_madotxt {
		text-align: justify;
		text-justify: inter-ideograph;
	}


	.prof_mados .cast_name {
		font-size: 18pt;
		margin-bottom: 15px;
	}

	.staff_madotxt .cast_name {
		font-size: 15pt;
		margin-bottom: 15px;
	}


	.prof_mados .cast_name small {
		font-size: 80%;
		font-family: 'Crimson Pro', serif;
	}


	.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;
	}

	.kantoku_pt {
		width: 150px;
		height: auto;
		float: left;
		margin-right: 10px;
		margin-bottom: 10px;
	}




	/*----------STAFF------------*/

	#staff_box {
		padding-top: 1px;
		padding-bottom: 50px;
	}
	
	#staff_txtbox{
		display: block;
	}

	#staff_box h3{
		margin: 30px;
	}
	
	.staff_pt{
		width: 70%;
		height: auto;
		display: block;
		margin: 0 auto 20px;
	}
	
	#staff_txtbox .txt_box{
		flex: initial;
		padding-left: 0;
		font-size: 11pt;
	}

	.staff_name{
		text-align: center;
		margin-bottom: 20px;
	}


	/*----------FOOTER------------*/
	#footer {
		padding-top: 50px;
		padding-bottom: 50px;
		background-color: #fff;
		text-align: center;
	}

	.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;
	}



}
