@charset "utf-8";
/*****************************
common.css
*****************************/
/*---------------------

PC

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

/*---------------------
全体
-----------------------*/
html {
	scroll-behavior: smooth;
}
body{
	position:relative;
	margin-right: 100px;
}
#container{
    position: relative;
    width: 100%;
    margin: 0 auto;
    overflow: hidden;
	transform-origin: center center;
	opacity: 0;
	min-width: 1200px;
}

/*---------------
ローディング
-----------------*/
#load_fade{
	position: fixed;
	width:100%;
	height: 100%;
	left:0;
	top:0;
	background: #FFF;
	z-index: 9999;
}
#load_logo{
  position: absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:176px;
  height: 191px;
}
#load_a{
  position: absolute;
  left:0;
  top:0;
  background: url("../img/loader.jpg") no-repeat center top;
  background-size:100% auto;
  width:100%;
  height: 100%;
  overflow: hidden;
}
#load_b{
  position: absolute;
  left:0;
  bottom:0;
  background: url("../img/loader_b.jpg") no-repeat center bottom;
  background-size:100% auto;
  width:100%;
  height: 0;
  overflow: hidden;
}
/* 
#top_fade{
	position: relative;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #fff;
	z-index: 989;
}
.loading_wrap{
	position:fixed;
	width:50px;
	height:50px;
	left: calc(50% - 25px);
	top: calc(50% - 25px);
	border-radius: 100%;
	background: linear-gradient(45deg, #fff, #777, #000);
	background-size: 100% 100%;
	-webkit-animation: loadeing 1s linear infinite;
	-moz-animation: loadeing 1s linear infinite;
	animation: loadeing 1s linear infinite;
}
.loading_wrap:after{
    display: block;
    content: "";
    width: 46px;
    height: 46px;
    position: absolute;
    top: 2px;
    left: 2px;
    border-radius: 100%;
    background: #fff;
}
.loading_wrap2{
	position:fixed;
	width:50px;
	height:50px;
	left: calc(50% - 25px);
	top: calc(50% - 25px);
	border-radius: 100%;
	background: linear-gradient(45deg, #dfe9be, #a3e0c3, #4fb0a8);
	background-size: 100% 100%;
	-webkit-animation: loadeing 1s linear infinite;
	-moz-animation: loadeing 1s linear infinite;
	animation: loadeing 1s linear infinite;
}
.loading_wrap2:after{
	display: block;
	content: "";
	width: 46px;
	height: 46px;
	position: absolute;
	top: 2px;
	left: 2px;
	border-radius: 100%;
	background: #fff;
}
@-webkit-keyframes loadeing {
    0%{transform:rotate(0deg)}
    100%{transform:rotate(360deg)}
}
@-moz-keyframes loadeing {
    0%{transform:rotate(0deg)}
    100%{transform:rotate(360deg)}
}
@keyframes loadeing {
    0%{transform:rotate(0deg)}
    100%{transform:rotate(360deg)}
} */

/*---------------------
ヘッダーメニュー
-----------------------*/
.header_wrap {
	width: 100%;
	min-width: 1200px;
	margin-right: 0;
	position: relative;
}
.header_logo {
	margin: 10px 50px;
}
.header_menu {
	display: block;
	position: absolute;
	right: 0;
	top: 0;
}
.header_menu ul {
	display: flex;
	margin-right: 30px;
}
.header_menu ul li {
	font-size: 14px;
	font-weight: bold;
	letter-spacing: 1px;
	line-height: 6em;
}
.header_menu ul li a {
	display: block;
	padding: 0 15px;
	color: #fff;
}
.header_menu ul li a:hover {
	color: #fe0000;
}
@media screen and (min-width: 801px) and (max-width: 1300px) {
	.header_menu ul {
		margin-right: 120px;
	}
}

/*---------------
footer
-----------------*/
footer {
    position: relative;
    bottom: 0;
    width: 100%;
    border-top: 1px solid #262733;
    box-sizing: border-box;
	background: #000;
	padding-top: 10px;
    overflow: hidden;
	min-width: 1200px;
}
.footer_in {
	height: 100px !important;
}
#official {
	position: relative;
    left: 20px;
    bottom: 20px;
    padding-top: 30px;
}
#official_title {
	color: #9fa0a0;
	font-size: 10px;
	margin-bottom: 10px;
}
#official_set {
	display: flex;
}
.sns_icon {
	margin: 0 5px;
}
.sns_icon {
	width: 20px;
}
.address {
	position: absolute;
    bottom: 25px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    font-style: normal;
    color: #9fa0a0;
    font-size: 10px;
    text-align: center;
}
/*footer右側*/
.right {
	position: absolute;
	right: 30px;
	bottom: 25px;
}
.links {
	display: flex;
	justify-content: space-between;
	-webkit-justify-content: space-between;
	width: 180px;
	height: 20px;
	line-height: 20px;
	font-size: 11px;
}
.links,
.links a {
	color: #9fa0a0;
	font-size: 10px;
}
/*footer左側*/
.left {
	position: relative;
    width: 100%;
    bottom: 0;
    left: 0;
    padding: 30px 0 0;
}
#sns_btns {
	display: flex;
	justify-content: center;
}
.share_btn {
	margin-top: -4px;
	cursor: pointer;
}
/*ムビチケ*/
.common_tickets_index{
	display: flex;
    justify-content: space-between;
    width: 302px;
    margin: 0 auto ;
	padding: 30px 0 0;
}
.common_ma{
	width: 146px;
}
.common_mv{
	width: 146px;
}

/* 旧字フォント */
.taku{
	font-family: 'Noto Sans SC', sans-serif;
}


/*---------------------

SP

-----------------------*/

@media screen and (min-width: 0px) and (max-width: 800px) {
	.sp_view{
		display:block !important;
	}
	.pc_view{
		display:none !important;
	}
	/*---------------------
	全体
	-----------------------*/
	body{
		margin-right: 0;
	}
	/*---------------
	ローディング
	-----------------*/
	.loading_wrap{
		position:fixed;
		width:50px;
		height:50px;
		left: 44%;
		top: 45%;
	}
	.loading_wrap:after{
		width: 46px;
		height: 46px;
		top: 2px;
		left: 2px;
	}
	.loading_wrap2{
		position:fixed;
		width:50px;
		height:50px;
		left: 44%;
		top: 45%;
	}
	.loading_wrap2:after{
		width: 46px;
		height: 46px;
		top: 2px;
		left: 2px;
	}

	/*---------------------
	navi
	-----------------------*/
	#header_sp {
		position: fixed;
		width: 100%;
		height: 56px;
		top: 0;
		left: 0;
		z-index: 999;
		display: flex;
		background-color: #000;
		justify-content: space-between;
	}
	#navi_sp {
		position: fixed;
		width: 100%;
		height: calc(100% - 50px);
		right: 0;
		top: 50px;
		z-index: 900;
		background: #000;
		overflow: auto;
		transition: all 0.8s ease;
		transform: translate(0, calc(-100vh - 130px));
	}
	#navi_sp.active {
		transform: translate(0, 0);
	}
	.menu_title{
		margin-bottom: 13%!important;
	}
	.open_btn {
		position: absolute;
		width: 26px;
		height: 30px;
		top: 50%;
		right: 15px;
		transform: translate(0, -50%);
		overflow: hidden;
	}
	.open_sp{
		position: absolute;
		top: 0;
		left: 0;
		height: 100%;
		width: 100%;
	}
	.open_sp.active {
		transform: translate(100%, 0);
	}
	.close_sp {
		position: absolute;
		top: 0;
		left: 0;
		height: 100%;
		width: 100%;
		transform: translate(100%, 0);
	}
	.close_sp.active {
		transform: translate(0, 0);
	}
	.menu_item_sp{
		position: absolute;
    	top: 710px;
		z-index: 10;
	}
	.menu_title_sp{
		margin: 40px 0;
	}
	#navi_sp .sp_menu_btn{
		margin-top: 16.87%;
		padding-bottom: 16%;
		z-index: 100;
	}
	#navi_sp .sp_menu_btn li {
    	width: 100%;
		margin-bottom: 0%;
	}
	
	/*---------------
	footer
	-----------------*/
	footer {
		height: auto;
		box-sizing: border-box;
		padding-bottom: 0;
		padding-top: 10%;
		min-width: inherit;
	}
	.footer_in {
		position: relative;
		padding: 30px 0 0;
	}
	#official {
		padding-top: 0px;
		position: relative;
		left: inherit;
		bottom: inherit;
	}
	#official_title {
		text-align: center;
		margin-bottom: 15px;
		color: #9fa0a0;
	}
	#official_set {
		display: flex;
		justify-content: center;
		width: 190px;
		margin: 0 auto;
	}
	.left {
		position: relative;
		width: 100%;
		bottom: inherit;
		left: inherit;
		padding: 0 0 7%;
		box-sizing: border-box;
	}
	.right {
		position: relative;
		right: inherit;
		bottom: inherit;
	}
	.sns_icon {
		margin: 0 7px;
	}
	#sns_btns {
		display: flex;
		justify-content: center;
	}
	.links {
		display: flex;
		justify-content: center;
		margin: 26px auto 33px;
		width: 180px;
		height: inherit;
		line-height: inherit;
		font-size: inherit;
	}
	.links li {
		margin: 0 5px;
	}
	.links a {
		color: #9fa0a0;
	}
	.address {
		position: relative;
		text-align: center;
		width: 100%;
		font-size: 10px;
		padding-top: 20px;
	}
	/*ムビチケ*/
	.common_tickets_index{
		padding-top: 0;
    	padding-bottom:7%;
	}

	

}
