
/*---------Common---------------*/
* {
	box-sizing: border-box;
	position: relative;
}

.aplha {
	-ms-filter: "alpha( opacity=0 )";
	filter: alpha(opacity=0);
	opacity: 0.0;
}

.onalpha {
	-ms-filter: "alpha( opacity=100 )";
	filter: alpha(opacity=100);
	opacity: 1.0;
	transition: 0.2s;
	-webkit-transition: 0.2s;
	-moz-transition: 0.2s;
	cursor: default;
}

.onalpha:hover {
	-ms-filter: "alpha( opacity=80 )";
	filter: alpha(opacity=80);
	opacity: 0.8;
	transition: 0.2s;
	-webkit-transition: 0.2s;
	-moz-transition: 0.2s;
	cursor: pointer;
}


.clearfix::after {
	content: "";
	display: block;
	clear: both;
}

a:focus,
*:focus {
	outline: none;
}


.sp,
.sp_b {
	display: none;
}

.pc {
	display: inline-block;
}

.pc_b {
	display: block;
}

/*-----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;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

/*-----Header Menu-------*/

#nav_box {
	width: 100%;
	min-width: 1300px;
	height: 48px;
	position: fixed;
	top: 0;
	z-index: 300;
	background-repeat: repeat-x;
	background-position: top center;
	background-image: url(../images/menu_bg.jpg);
}

#nav_set_box {
	padding: 0;
	width: 1300px;
	height: 48px;
	margin: 0px auto 0 auto;
	box-sizing: border-box;
	z-index: 300;
	display: flex;
	justify-content: center;
}

.menu_btn {
	height: 48px;
	font-family: "M PLUS 2", sans-serif;
	font-size: 14pt;
	font-weight: 900;
	color: #11A5FF;
	border: 0;
	cursor: default;
	overflow: hidden;
	position: relative;
	padding-left: 35px;
	padding-right: 35px;
	/*	text-transform: inherit;*/
	/*	transition: color 1s;*/
	transition: 0.7s;
	-webkit-transition: 0.7s;
	-moz-transition: 0.7s;
	background-image: url(../images/menu_bg.jpg);
	background-repeat: no-repeat;
	background-position: center top;
}

.menu_btn:hover {
	cursor: pointer;
	/*	color:#01a0ca;*/
	/*	background-color: #fff;*/
	transition: 0.7s;
	-webkit-transition: 0.7s;
	-moz-transition: 0.7s;
	color: #DD0000;
	background-image: url(../images/menu_bg_on.jpg);
	background-position: center top;
}


.btn_sns {
	width: 40px;
	font-size: 16pt;
	padding-left: 0;
	padding-right: 0;
}

.share_box {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	gap: 5px;
	font-size: 0;
	line-height: 0;
	margin: 14px auto 0 auto;
	opacity: 0;
	pointer-events: none;
	transition: opacity .5s;
	width: 1050px;
}

.share_box.is-active {
	opacity: 1;
	pointer-events: auto;
}

/*-----Menu Box-------*/
.menu_box {
	position: absolute;
	top: 10px;
	right: 10px;
	z-index: 20;
}

.btn_menu {
	width: 50px;
font-family: "Murecho", sans-serif;
	font-size: 15pt;
	font-weight: 700;
	color: #e8d0c6;
	background-color: #000;
	border: 0;
	cursor: default;
	overflow: hidden;
	position: relative;
	/*	padding-left: 15px;*/
	/*	padding-right: 15px;*/
	float: left;
	/*	text-transform: inherit;*/
	/*	transition: color 1s;*/
	transition: 0.7s;
	-webkit-transition: 0.7s;
	-moz-transition: 0.7s;
	margin-left: 10px;
}

.btn_menu:hover {
	cursor: pointer;
	transition: 0.7s;
	-webkit-transition: 0.7s;
	-moz-transition: 0.7s;
	-ms-filter: "alpha( opacity=80 )";
	filter: alpha(opacity=80);
	opacity: 0.8;
}




/*-----Main-------*/
#main{
	width: 100%;
	min-width: 1300px;
	overflow:hidden;
	z-index: 1;
	margin-top: 48px;
}

.rope{
	width: 100%;
	min-width: 1300px;
	height: 8px;
	margin: 0;
	background-image: url(../images/sen_rope.jpg);
	background-position: center top;
	background-repeat: repeat-x;
	z-index: 1;
	background-size: auto 100%;
}


#top_box {
	width: 100%;
	min-width: 1300px;
	height: 1755px;
	margin: 0  auto;
	background-repeat: no-repeat;
	background-position: center top;
	overflow: hidden;
	background-image: url(../images/pre_bg.jpg);
	background-size: auto;
	background-position: center top;
	background-repeat: no-repeat;
}


@media screen and (min-width: 1800px) {
	#top_box{
		background-size: 100% auto;
	}
}




#top_set_box {
	width: 100%;
	min-width: 1300px;
	margin-top: 0;
	margin-right: auto;
	margin-left: auto;
	margin-bottom: 0px;
}


.top_bg {
	width: 100%;
	min-width: 1000px;
	height: auto;
	margin-top: 0px;
	margin-left: 0px;
	display: block;
	z-index: 10;
}

.top_logo{
	height: auto;
	margin: 200px auto 150px;
	display: block;
	z-index: 20;
}

#trailer_pc_box{
	width: 930px;
	margin: 0px auto 0px;
	padding-top: 50px;
}

#trailer_pc_box h3{
	color: #fffb26;
	font-size: 33pt;
	font-weight: 900;
	text-align: center;
	text-shadow: 3px 3px 0px #000;
	transform: rotate(-5deg);
	margin: 0 0 40px;
}

#trailer_pc_box iframe {
	width: 100%;
	height: 523px;
	margin: 0 auto;
}


.ptset{
	width: 100%;
	height: auto;
	display: block;
	margin: 0;
	z-index: 1;
}




/*-----ftr-------*/

#ftr_box {
	z-index: 40;
	margin-top: 20px;
	margin-right: 0px;
	margin-left: 0px;
	margin-bottom: 10px;
	clear: both;
	padding: 0px 0px 20px 0px;
	background-repeat: no-repeat;
	background-position: top center;
	display: none;
}


#ftr_naka {
	text-align: center;
	width: 800px;
	margin-left: auto;
	margin-right: auto;
}

.top_bl {
	display: block;
	margin: 0 auto;
}


#ftr_bnr {
	width: 1000px;
	margin: 0px auto 0px auto;
	text-align: center;
}


#ftr_bnr img {
	margin: 0px 5px 5px 0px;
}









/*------- SNS ----------------*/

#top_tw {
	position: relative;
	display: inline-block;
	z-index: 500;
	margin-top: 10px;
	margin-right: auto;
	margin-left: auto;
	margin-bottom: 0px;
	height: 25px;
}

.fb {
	margin: -6px 0px 0px 0px;
	padding: 0px;
	display: inline;
	float: left;
}

.tw {
	margin: 2px 0px 0px 5px;
	padding: 0px;
	display: inline;
	float: left;
}

.line {
	margin: 2px 0px 0px 10px;
	padding: 0px;
	display: inline;
	float: left;
}


.eigacom {
	margin: 2px 0px 0px 10px;
	padding: 0px;
	display: inline;
	float: left;
}






/*------- SUB PAGE ----------------*/
#subpage_box{
	width: 100%;
	background-image: url(../images/pre_bg.jpg);
	background-position: center top;
	background-repeat: no-repeat;
	background-size: auto 100%;
	z-index: 5;
}


.sub_box {
	width: 100%;
	min-width: 1300px;
	margin-left: auto;
	margin-right: auto;
}

.in_box {
	margin: 0 auto;
	width: 1000px;
	font-size: 10pt;
	font-weight: normal;
}

.pad_lr {
	padding-left: 13px;
	padding-right: 13px;
}

.txt_box{
	font-size: 11pt;
	line-height: 2em;
	text-align: justify;
	text-justify: inter-ideograph;
}

/*------- INTRODUCTION ----------------*/
#intro_box {
	margin-top: -1px;
	padding-top: 85px;
	padding-bottom: 30px;
	background-image: url(../images/waku_intro.png);
	background-position: center 85px;
	background-repeat: no-repeat;
}

.kiri_1{
	position: absolute;
	margin-top: -100px;
	margin-left: 1032px;
	z-index: 30;
	transform-origin: 50% -200px ;
    transform: rotate(-90deg);
}


.intro_txtbox{
	width: 1300px;
	height: 800px;
	margin: 0 auto;
}

.waku_intro_h3{
	position: absolute;
	margin-top: 0%;
	margin-left: -15px;
}

.waku_intro_txt{
	position: absolute;
	margin-top: 0%;
	margin-left: -15px;
}


/*------- STORY ----------------*/
#story_box {
	padding-top: 1px;
	padding-bottom: 30px;
	background-image: url(../images/waku_story.png);
	background-position: center 1px;
	background-repeat: no-repeat;
}

.story_txtbox{
	width: 1300px;
	height: 800px;
	margin: 0 auto;
}

.waku_story_h3{
	position: absolute;
	margin-top: 0%;
	margin-left: -15px;
}

.waku_story_txt{
	position: absolute;
	margin-top: 0%;
	margin-left: -15px;
}


/*------- CAST ----------------*/
#cast_box {
	padding-top: 1px;
	padding-bottom: 30px;
	background-image: url(../images/waku_intro.png);
	background-position: center 1px;
	background-repeat: no-repeat;
}

.cast_txtbox{
	width: 1300px;
	height: 800px;
	margin: 0 auto;
}

.waku_cast_h3{
	position: absolute;
	margin-top: 0%;
	margin-left: -15px;
}

.waku_cast_txt{
	position: absolute;
	margin-top: 0%;
	margin-left: -15px;
}






/*------- FOOTER ----------------*/

footer{
	color: #11a5ff;
	background-color: #fffb26;
	text-align: center;
	padding: 50px 13px 100px;
	font-size: 10pt;
}

footer a:link,
footer a:visited,
footer a:active {
	color: #11a5ff;
	text-decoration: underline;
}

footer a:hover{
	color: #00588e;
}

.copy{
	margin-top: 30px;
	font-size: 9pt;
	line-height: 1.4em;
}













