@charset "utf-8";
@import url('https://fonts.googleapis.com/css?family=Carter+One');


/* --------------
 common
-------------- */
body{
	/*background:#fff url(../img/bg.jpg) no-repeat center top;*/
	background: #fff;
	background-size:100% 100%;
	background-attachment:fixed;
	color: #222;
	font: normal 15px/1.6 'Lucida Grande', Meiryo, sans-serif !important;
	margin: 0;
}
h1,h2,h3,h4,h5,h6 {
	line-height: 1.2;
}
h1 {font-size: 1.5em;}
h2 {font-size: 1.3em;margin:10px 0;}
h3 {font-size: 1.1em;margin:10px 0;}

table{
	width:96%;
	margin:0 2%;
}
	
iframe{
	max-width:100% !important;
}
small{font-size:0.7em;}
img{
	max-width:100%;
}

.serif {
	font-family: "Sawarabi Mincho", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

@media screen and (max-width: 1000px) { /*以下の時*/
.in {
	overflow-x: hidden;
	overflow-y: hidden;
}
}

.carterOne {
	font-family: 'Carter One', cursive;
}


/* --------------
 clearfix
-------------- */
div:after,
ul:after,
ol:after {
	content: ""; 
	display: block;
	clear: both;
}
.both{
	clear:both;
}

/* --------------
 modules css
-------------- */

ul li,
ol li {
	list-style: none;
}

/* ---------- link */
a{color:#c70909;}
a:hover{text-decoration:none;}

a img:hover{
	opacity:0.7;
}

/* ---------- font */
.fs05 { font-size: 0.5em; }
.fs06 { font-size: 0.6em; }
.fs07 { font-size: 0.7em; }
.fs08 { font-size: 0.8em; }
.fs09 { font-size: 0.9em; }
.fs10 { font-size: 1.0em; }
.fs11 { font-size: 1.1em; }
.fs12 { font-size: 1.2em; }
.fs13 { font-size: 1.3em; }
.fs14 { font-size: 1.4em; }
.fs15 { font-size: 1.5em; }
.fs16 { font-size: 1.6em; }
.fs17 { font-size: 1.7em; }
.fs18 { font-size: 1.8em; }
.fs19 { font-size: 1.9em; }
.fs20 { font-size: 2.0em; }
.fs21 { font-size: 2.1em; }
.fs22 { font-size: 2.2em; }
.fs23 { font-size: 2.3em; }
.fs24 { font-size: 2.4em; }
.fs25 { font-size: 2.5em; }
.bold{font-weight:bold;}

.clrB{ color:#333;}
.clRed { color: #D70003; }
.clYlw { color: #FBD75B; }

/* ---------- align */
.alc { text-align: center !important;}
.alr { text-align: right !important;}
.all { text-align: left !important;}
.alj {	
	/* 文字均等割付 */
	text-align: justify !important;
	text-justify: inter-ideograph !important;
}


.ls-05 { letter-spacing: .5em; text-indent: .5em; }

/* ---------- margin,padding */
.mb0 {	margin-bottom: 0px !important;}
.mb5 {	margin-bottom: 5px !important;}
.mb10 {	margin-bottom: 10px !important;}
.mb15 {	margin-bottom: 15px !important;}
.mb20 {	margin-bottom: 20px !important;}
.mb25 {	margin-bottom: 25px !important;}
.mb30 {	margin-bottom: 30px !important;}
.mb35 {	margin-bottom: 35px !important;}
.mb40 {	margin-bottom: 40px !important;}
.mb45 {	margin-bottom: 45px !important;}
.mb50 {	margin-bottom: 50px !important;}
.mb55 {	margin-bottom: 55px !important;}
.mb60 {	margin-bottom: 60px !important;}
.mb70 {	margin-bottom: 70px !important;}
.mb80 {	margin-bottom: 80px !important;}
.mb90 {	margin-bottom: 90px !important;}
.mb100 {margin-bottom: 100px !important;}

.ml0 {	margin-left: 0px !important;}
.ml5 {	margin-left: 5px !important;}
.ml10 {	margin-left: 10px !important;}
.ml20 {	margin-left: 20px !important;}
.ml30 {	margin-left: 30px !important;}

.mr0 {	margin-right: 0px !important;}
.mr5 {	margin-right: 5px !important;}
.mr10 {	margin-right: 10px !important;}
.mr20 {	margin-right: 20px !important;}
.mr30 {	margin-right: 30px !important;}

.mt0 {	margin-top: 0px !important;}
.mt5 {	margin-top: 5px !important;}
.mt10 {	margin-top: 10px !important;}
.mt20 {	margin-top: 20px !important;}
.mt30 {	margin-top: 30px !important;}


.clWt { color: #fff; }
.clRed { color: #cd0002; }


.bgBox {
	padding: 10px;
}

.bgWt {
	background: #fff;
}
.bgGray {
	background: #D5D5D5;
}

span.bkWt {
	display: inline-block;
	margin: 2px 0;
	padding: 5px;
}



.bgBk10 {
	background: #e5e5e5;
}
.bgBk30 {
	background: #b3b3b3;
}
.bgBk50 {
	background: #808080;
}

.bgBk70 {
	background: #4d4d4d;
}



.bgRed {
	background: #cd0002;
}
.bgStripe {
	padding: 1%;
	background: repeating-linear-gradient(-45deg, #aaa, #aaa 2px, #888 0, #888 4px);
}



.btnA a {
	display: inline-block;
	padding: .5em .8em;
	font-weight: bold;
	text-decoration: none;
	color: #000;
	border: #000 solid 4px;
	border-left-style: double;
	border-right-style: double;
	background: #fff;
}
.btnA a:hover {
	background: #ddd;
}

.ulDisc li:before {
	content: "・";
}

/* =contents
------------------------------------------ */
.contents p {
	margin-bottom: .5em;

}

.ttlEn {
	font-size: 2.5em;
	text-shadow: -2px -2px 0 rgba(255,255,255,.50), 3px 3px 0 rgba(0,0,0,.35);
}



/* =pageTop
---------------------------------------------------- */
#pageTop {
	display: block;
	position: fixed;
}
#pageTop a {
	text-indent: -9999px;
	background: url(../img/arw-top.png?v2) no-repeat;
	background-size: 100% auto;
	display: block;
}

#pageTop a:hover {
	
	-webkit-animation: spin .5s linear 1;
	-moz-animation: spin .5s linear 1;
	-ms-animation: spin .5s linear 1;
	-o-animation: spin .5s linear 1;
	animation: spin .5s linear 1;
}

/* =youtube
-------------------------------------------------------------- **/
.youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}
/* =twitter timeline
-------------------------------------------------------------- **/

.twTL{
	box-sizing:border-box;
}
.twTL *{
	box-sizing:border-box;
}
.twTL:after{
	content:'';
	clear:both;
	display:block;
	width:100%;
	height:1px;
}

.timeline-footer{
	display:none !important;
}

/* =sns_area
-------------------------------------------------------------- **/
.sns_area{
}


/* 各シェアボタン */

#social {
	margin-top: 20px;
	margin-bottom: 20px;
	text-align: center;
}
#social a {
	text-decoration: none;
}
#social img {
	vertical-align: sub;
}
.sclTw,
.sclFb,
.sclLINE,
.sclGgl {
	display:inline-block;
	vertical-align: bottom;
	width: 23%;
	margin-bottom: 10px;
}
.sclTw a,
.sclFb a,
.sclLINE a,
.sclGgl a {
	display: block;
	color: #fff;
	padding: 10px 0;
	border-radius: 5px;
}
.sclTw a:hover,
.sclFb a:hover,
.sclLINE a:hover,
.sclGgl a:hover {
	text-decoration: none;
}
.sclTw a:hover img,
.sclFb a:hover img,
.sclLINE a:hover img,
.sclGgl a:hover img {
	opacity: 1;
}
.sclGgl a {
    background:#db4a39;
    box-shadow:0 5px 0 #ad3a2d;
}
.sclTw a {
    background:#00acee;
    box-shadow:0 5px 0 #0092ca;
}
.sclFb a {
    background:#3b5998;
    box-shadow:0 5px 0 #2c4373;
}
.sclLINE a {
    background:#00C300;
    box-shadow:0 5px 0 #2f9427;
}
.sclGgl a:hover {
    background:#F3705D;
}
.sclTw a:hover {
    background:#5EC5EB;
}
.sclFb a:hover {
    background:#4F6DAA;
}
.sclLINE a:hover {
    background:#4CD842;
}


/* =copyright
---------------------------------------------------- */
#copyright{	
	color: #fff;
	background: #111;
}
#copyright a{
	color:#fff;
}

/* =visual
---------------------------------------------------- */
#visual {
	background: #000;
	border-bottom: #fff solid 2px;
}

#visual .wd50 {
	width: 50%;
}
#movie {
	border-top: #fff solid 2px;
}

/* =menu
---------------------------------------------------- */
#menu {
	background: #222;
	padding: 2px 0;
}
.fixed #menu {
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 99999;
}
.fixed #menu:before {
	content: '';
	width: 60px;
	height: 25px;
	background: #222 url(../img/arw-btm.png) no-repeat center top;
	background-size: contain;
	border-radius: 0 0 20px 20px;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	margin: auto;
	z-index: -1;
}
.fixed #menu.hover:before {
	height: 0;
}

#menu li a {
	display: block;
	text-align: center;
}
#menu li a:hover img {
	opacity: 1;
	
	-webkit-animation: spin .5s linear 1;
	-moz-animation: spin .5s linear 1;
	-ms-animation: spin .5s linear 1;
	-o-animation: spin .5s linear 1;
	animation: spin .5s linear 1;
}


.fixed #menu a {
	height: 0;
	overflow: hidden;
	transition: all .5s;
	opacity: 0;
}

.fixed #menu.hover a {
	height: auto;
	opacity: 1;
}

@-webkit-keyframes spin {
	0% {-webkit-transform: rotateY(0deg);}
	100% {-webkit-transform: rotateY(360deg);}
}
@-moz-keyframes spin {
	0% {-moz-transform: rotateY(0deg);}
	100% {-moz-transform: rotateY(360deg);}
}
@-ms-keyframes spin {
	0% {-ms-transform: rotateY(0deg);}
	100% {-ms-transform: rotateY(360deg);}
}
@-o-keyframes spin {
	0% {-o-transform: rotateY(0deg);}
	100% {-o-transform: rotateY(360deg);}
}
@keyframes spin {
	0% {transform: rotateY(0deg);}
	100% {transform: rotateY(360deg);}
}

/* =news
---------------------------------------------------- */

.newsBox {
	padding: 1%;
	background: repeating-linear-gradient(-45deg, #aaa, #aaa 2px, #888 0, #888 4px);
}
.newsBox.new > .bgWt {
	height: 300px;
	overflow-y: auto;
}

.newsList li {
	padding: .5em 0;
	border-bottom: #aaa solid 1px;
}
.newsList li:first-child {
	border-top: #aaa solid 1px;
}
.newsList li dt {
	color: #555;
	font-weight: bold;
}

.newsList li dd {
	margin-left: 1em;
}


.mediaBox a {
	color: #2055B1;
}

/* =event
---------------------------------------------------- */
.expBox {
/*	border-top: #aaa double 5px;
	border-bottom: #aaa double 5px;*/
	
}

.event .inner {
	border: #771917 double 6px;
}
.shop .inner {
	border: #2c4584 double 6px;
}
.app .inner {
	border: #553372 double 6px;
}
.buy .inner {
	border: #842c2c double 6px;
}

.zerovr,
.fightvr {
	min-height: 100vh;
	position: relative;
}
.zerovr .inner,
.fightvr .inner {
	padding: 3% 0;
/*	position: absolute;
  top: 50%;
	left: 0;
	right: 0;
	margin: auto;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);*/
}

.zerovr {
	background: url(../img/bg-zero.png) no-repeat center center fixed;
	background-size: cover;
}
.fightvr {
	background: url(../img/bg-fight.png) no-repeat center center fixed;
	background-size: cover;
}

@media only screen and (orientation:portrait){
/*.zerovr {
	background: url(../img/bg-zero2.png) no-repeat center center fixed;
	background-size: cover;
}
.fightvr {
	background: url(../img/bg-fight2.png) no-repeat center center fixed;
	background-size: cover;
}*/
}


.label {
	display: inline-block;
	padding: .2em 1em;
	border: #000 solid 2px;
	background: #fff;
	vertical-align: middle;
}


/* =intro
---------------------------------------------------- */
.logoFilmBox {
	display: flex;
	flex-wrap: wrap;
}
.logoFilmBox p {
	width: 25%;
	padding: 10px;
	box-sizing: border-box;
}
