/*---------------------
共通
-----------------------*/

.sp_view{
	display:none !important;
}
.pc_view{
	display:block;
}

/*hover_opacity*/
.over_anim{
	transition:0.3s;
}
.over_anim:hover{
	opacity:0.8 !important;
}
/*hover_画像*/
.over_anim2 img{
	transition:0.3s;
}
.over_anim2 :hover{
	opacity:0 !important;
}

/*page_top*/
.page_top{
	position:fixed;
	width:67px;
	height:58px;
	bottom:20px;
	cursor:pointer;
	z-index:1000;
	display:none;
    left: 50%;
    margin-left: 860px;	
}
.page_top:hover{
	opacity:0.8;
}

/*---------------------
フェード ローディング
-----------------------*/
#top_fade{
	position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
	background: #fff;
	z-index: 989;	
}

.loading_wrap{
	position: fixed;
    width: 201px;
    height: 130px;
    transform: translate(-50%,-50%);
    left: 50%;
    top: 50%;
    background: url("../img/loading_logo.png") no-repeat;
    background-size: 201px auto;
}


/*---------------------
アニメーション
-----------------------*/
.top_opacity{
	opacity: 0;
}
.scale{
	opacity: 0;
	transform: scale(2);
}
.scale_small{
	opacity: 0;
	transform: scale(0.5);
}

.pop:hover img{
  animation-name: pop;
  animation-duration: 0.3s;
  animation-timing-function: linear;
  animation-iteration-count: 1;
}
@keyframes pop {
  50% {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
}

@keyframes check {
  50% { transform: translate(-5px,0);}
}

/*---------------------
navi
-----------------------*/
/*隠し*/
.left_mask{
    position: fixed;
    left:0;
    top:0;
    height: 100%;
    background: #000;
    z-index: 1001;
}
.animation{
	transition: 0.5s;
}

header{
	width: 100%;
    max-width: 1920px;
    background: #fff100;
    z-index: 9999;
    box-shadow: 0px 10px 10px -5px rgb(0 0 0 / 8%);
}
#nav_pc{
    height: 60px;
    background: #fff100;
    text-align: center;
}
.nav_pc_btn{
	display: flex;
	width: 86%;
    justify-content: center;
}
#top-head.fixed {
    margin-top: 0;
    top: 0;
    position: fixed;
    z-index: 99;
}
/*帯のナビ　ボタン*/
.bt_home{
	position: relative;
	left: 0px;
	height: 60px!important;
}

.bt_home:hover img{
	opacity: 0;
}
.bt_home:hover {
	background: url("../img/menu/home_over.jpg") no-repeat top center;
	background-size: 72px auto;
}

.bt_about{
	position: relative;
	left: 0px;
	height: 60px!important;
}
.bt_about:hover img{
	opacity: 0;
}
.bt_about:hover {
	background: url("../img/menu/about_over.jpg") no-repeat top center;
	background-size: 145px auto;
}
.bt_characters{
	position: relative;
	left: 0px;
	height: 60px !important;
}
.bt_characters:hover img{
	opacity: 0;
}
.bt_characters:hover {
	background: url("../img/menu/characters_over.jpg") no-repeat top center;
	background-size: 106px auto;
}

.bt_fanart{
	position: relative;
	left: 0px;
	height: 60px !important;
}
.bt_fanart:hover img{
	opacity: 0;
}
.bt_fanart:hover {
	background: url("../img/menu/fanart_over.jpg") no-repeat top center;
	background-size: 85px auto;
}

.bt_news{
	position: relative;
	left: 0px;
	height: 60px!important;
}
.bt_news:hover img{
	opacity: 0;
}
.bt_news:hover {
	background: url("../img/menu/news_over.jpg") no-repeat top center;
	background-size: 67px auto;
}
.bt_reviews{
	position: relative;
	left: 0px;
	height: 60px!important;
}
.bt_reviews:hover img{
	opacity: 0;
}
.bt_reviews:hover {
	background: url("../img/menu/reviews_over.jpg") no-repeat top center;
	background-size: 85px auto;
}


.bt_ticket{
	position: relative;
	left: 0px;
	height: 60px!important;
}
.bt_ticket:hover img{
	opacity: 0;
}
.bt_ticket:hover {
	background: url("../img/menu/ticket_over.jpg") no-repeat top center;
	background-size: 91px auto;
}

.bt_voicecast{
	position: relative;
	left: 0px;
	height: 60px!important;
}
.bt_voicecast:hover img{
	opacity: 0;
}
.bt_voicecast:hover {
	background: url("../img/menu/voicecast_over.jpg") no-repeat top center;
	background-size: 90px auto;
}

.bt_caststaff{
	position: relative;
	left: 0px;
	height: 60px!important;
}
.bt_caststaff:hover img{
	opacity: 0;
}
.bt_caststaff:hover {
	background: url("../img/menu/caststaff_over.jpg") no-repeat top center;
	background-size: 119px auto;
}

.bt_special{
	position: relative;
	left: 0px;
	height: 60px!important;
}
.bt_special:hover img{
	opacity: 0;
}
.bt_special:hover {
	background: url("../img/menu/special_over.jpg") no-repeat top center;
	background-size: 92px auto;
}

.bt_dvd{
	position: relative;
	left: 0px;
	height: 60px!important;
}
.bt_dvd:hover img{
	opacity: 0;
}
.bt_dvd:hover {
	background: url("../img/menu/dvd_over.jpg") no-repeat top center;
	background-size: 173px auto;
}

/*帯のナビ　DCのSNSボタン*/
.pc_dc_sns{
	position: relative;
	top: -60px;
	display: flex;
	left: 50%;
    margin-left: 443px;
}
.pc_dc_tw{
	background: url("../img/menu/dc_tw_over.jpg") no-repeat top center;
	background-size: 34px auto;
}
.pc_dc_tw:hover img{
	opacity: 0;
}
.pc_dc_ig{
	background: url("../img/menu/dc_ig_over.jpg") no-repeat top center;
	background-size: 38px auto;
}

.pc_dc_ig:hover img{
	opacity: 0;
}
.pc_hash{
	width: 130px;
	position: relative;
	bottom: 61px;
	left: 50%;
    margin-left: 443px;
	background: url("../img/menu/hush_over.jpg") no-repeat top center;
	background-size: 130px auto;
}
.pc_hash:hover img{
	opacity: 0;
	z-index: 9999;
}
.pc_hash img{
	display: block;
}
/*---------------------
SP
-----------------------*/

@media screen and (min-width: 0px) and (max-width: 800px) {
	/*---------------------
	共通
	-----------------------*/
	.sp_view{
		display:block !important;
	}
	.pc_view{
		display:none !important;
	}
	
	/*hover*/
	.over_anim{
		transition:0s;
	}
	.over_anim:hover{
		opacity:1;
	}
	
	.check1,.check2{
		width: 14%;
		left: 25%;
		top: 0;
		margin-top: 70%;
	}
	.check2{
		margin-top: 53%;/*aboutなし*/
		margin-top: 87%;/*aboutあり*/
	}
	
	/*---------------------
	ローディング
	-----------------------*/
	.loading_wrap {
		position: fixed;
		width: 40%;
		height: 110px;
		top: 50%;
		background-size: 100% auto;
	}

	/*---------------------
	header
	-----------------------*/
	#head_logo_wrap{
		background: #fff100;
	    position: relative;
		z-index: 1;
	}
	#head_logo{
		position: relative;
		z-index: 9;
		width: 127px;
		margin: 0 auto;
	}
	/*---------------------
	page_top
	-----------------------*/
	.page_top{
		left: inherit;
		margin-left: inherit;	
	}
	/*---------------------
	navi
	-----------------------*/
	#navi_sp{
		position: fixed;
		width: 100%;
		right: 0;
		top: -150%;
		z-index: 900;
		background: #fff100;
		height: 100%;
		overflow: auto;
	}
	.menu_title{
		margin-bottom: 13%!important;
	}
	.open_sp{
		position: fixed;
		top: 0;
		left: 1%;
		height: 0%;
		width: 42px;
		padding-bottom: 15%;
		z-index: 10;
		margin-top: 64px;
	}
	.close_sp{
		position: absolute;
		top: 0;
		left: 1%;
		height: 0%;
		width: 42px;
		margin-top: 4px;
	}
	.menu_item_sp{
		position: absolute;
    	top: 710px;
		z-index: 10;
	}
	.menu_title_sp{
		margin: 40px 0;
	}
	#navi_sp ul{
		margin-top:16.87%;
		padding-bottom: 65px;
	}
	#navi_sp li {
    	width: 100%!important;
		margin-bottom: 0%;
	}
	.sp_sns_title{
		margin-bottom: 1%;
	}
	.sp_sns_btn{
		display: flex;
		justify-content: center;
		margin-bottom: 60px;
	}
	.sp_tw_btn,.sp_ig_btn{
		width: 17%;
	}
	.sp_tw_btn img,.sp_ig_btn img{
		width: 100%;
	}

	/*---------------
	共通チケットボタン
	-----------------*/

	.tickets_bottom{
		position: fixed;
		bottom: 0;
		z-index: 10;
		width: 100%;
	}
	/*---------------
	homeボタン
	-----------------*/
	#sp_home{
		position: relative;
		z-index: 1;
	}	
	/*---------------
	footer上書き
	-----------------*/
/*	footer {
		position: relative;
		border: none;
		background: #FFF;
		padding: 30px 0 75px;
	}*/

}
