@charset "utf-8";
/* CSS Document */

/* =======================================================================
	ヘッダー <header>~</header>内部
   ======================================================================= */

/*全体 */
header {
	top: -30px;
}

#page-top {
	bottom: 4vw;
	right: 1vw;
}


.head-rogo{
	display: inline-block;
}
.head-rogo img{
	margin-top: 40px;
	margin-left: 6px;
	width: 100px;

}
@media screen and (min-width:450px) {
	.head-rogo img{
		margin-top: 32px;
		margin-left: 6px;
		width: 140px;
	}
}
/* ----------------------------------------------------------------------
	メインメニュー土台
   ---------------------------------------------------------------------- */
.nav-list {
	display: none;
/*	text-align: center;*/
	width: 100vw;
	height: 100vh;
	background-color: #fbf4e2;
	/* 固定 */
	position: fixed;
	top: 0px;
	left: 0px;
	z-index:1100;
	overflow-y: scroll;
}
/* メニュー表示 */
.nav-open .nav-list {
	display: block;
	/* フェードイン */
	animation: fadein 0.1s linear 0s 1;
}
/* フェードイン キーフレーム */
@keyframes fadein{
	0%{opacity:0;}100% {opacity:1;}
}

.nav-list-ul{
	margin-top: 60px;
	margin-left: 22px;
}
.nav-list-ul>ul{
	margin-top: 20px;
}

.nav-list-ul>ul>li{
	display: inline-block;
	vertical-align: middle;
}
.nav-list img{
	width: 14vw;
}
.nav-list h1{
	margin-bottom: 3px;
	font-size: 1.3em;
}

/* ------------------------------------------------------------------
	トグルボタン
   ------------------------------------------------------------------ */
#nav-trigger div {
	padding: 22px;
	margin: -10px;
}
#nav-trigger,
#nav-trigger span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}
#nav-trigger {
	position: relative;
	float: right;

	margin-top: 40px;
	margin-right: 14px;
	width: 30px;
	height: 26px;
	z-index: 1200;
}
#nav-trigger span {
	position: absolute;
	left: 0;
	width: 100%;
	height: 4px;
	background-color: #041c5a;
	border-radius: 4px;
}
#nav-trigger span:nth-of-type(1) {
	top: 0;
}
#nav-trigger span:nth-of-type(2) {
	top: 11px;
}
#nav-trigger span:nth-of-type(3) {
	bottom: 0;
}
#nav-trigger:after {
	content: "";
	clear: both;
	display: block;
}


/* ------------------------------------------------------------------
	トグルボタン アニメーション
   ------------------------------------------------------------------ */

   #nav-trigger.active span:nth-of-type(1) {
	-webkit-transform: translateY(11px) rotate(-45deg);
	transform: translateY(11px) rotate(-45deg);
  }
  #nav-trigger.active span:nth-of-type(2) {
	opacity: 0;
  }
  #nav-trigger.active span:nth-of-type(3) {
	-webkit-transform: translateY(-11px) rotate(45deg);
	transform: translateY(-11px) rotate(45deg);
  }
  .nav-open #nav-trigger span:nth-child(1) {
	  top: 11px;
	  transform:rotate(-45deg)
  }
  .nav-open #nav-trigger span:nth-child(2),
  .nav-open #nav-trigger span:nth-child(3) {
	  top: 11px;
	  transform:rotate(45deg)
  }
  

/* =======================================================================
	メイン <main>~</main>内部
   ======================================================================= */
/* ------------------------------------------------------------------
	セクション
   ------------------------------------------------------------------ */
.sec-st-top {
	margin-top: 30px;
	margin-right:  auto;
	margin-left:  auto;
}
.sec-st-top img{
	width: 100%; 
}
.sec-st-pre-reg{
	margin-top: 6vw;
	text-align: center;
}
.sec-st-pre-reg img{
	width: 80%; 
}

.sec-st-pre-reg h1{
	font-size: 1.2em;
	line-height: 0.8em;
}
.steam-reg span{
	font-size: 1.2em;
	line-height: 0.8em;
}


.sec-st-faq{
	margin-top: 4vw;
	text-align: center;
}
.sec-st-faq>h1{
	margin: 1vw 0 7vw 0;
}
.sec-st-faq span{
	font-size: 1.2em;
}
.sec-st-faq a{
	line-height: 0.1em;
}

.switch-link,.steam-link{
	text-align : center;
	margin: 20px auto 40px auto;
}

.sound-banner{
	text-align : center;
}

img.link-img {
	width: 50vw;
	max-width: 220px;
	vertical-align: bottom;
}

img.ss-img {
	margin: 20px auto 0px auto;
	width: 48vw;
	max-width: 270px;
	vertical-align: bottom;
}

@media screen and (min-width:400px) and ( max-width:749px){
	.sec-st-pre-reg h1{
		font-size: 1.4em;
	}
	.steam-reg span{
		font-size: 1.4em;
	}
}
@media screen and (min-width:750px) {
	.sec-st-pre-reg h1{
		font-size: 2.5em;
	}
	.steam-reg span{
		font-size: 2.5em;
	}
	.sec-st-faq>h1{
		margin: 4vw 0;
	}
	.sec-st-faq span{
		font-size: 2.0em;
		line-height: 1.2em;
	}
}

.dl-box {
	margin-top: 4vw;
	z-index: 500;
}
.dl-banner {
/*
	display: none
*/
	text-align: center;
	width: 100%;
	display: table;
}
.dl-banner div{
	display: table-cell;
}
img.dl-ios {
	width: 40vw;
	max-width: 260px;
}
img.dl-android {
	width: 43vw;
	max-width: 270px;
	margin-bottom: 0.5vw;
}
	
.sec-st-info{
	color: #041c5a;
}

.sec-st-notice{
	margin-top: 6vw;
	margin-left: 4vw;
	margin-right: 4vw;
	position: relative;
}

.sec-chou {
	position: absolute;
	top: -4vw;
	left: 2vw;
	max-width: 100px;
	width: 18vw;
}
.sec-pur {
	position: absolute;
	top: -4vw;
	left: 65vw;
	max-width: 100px;
	width: 18vw;
}

@media screen and (min-width:480px) {
	.sec-chou {
		top: -6vw;
		left: 4vw;
	}
	.sec-pur {
		top: -6vw;
		left: 68vw;
	}
}

.sec-st-title-p{
	text-align: center;
	font-weight: 700;
	font-size: 1.4em;
	padding: 20px;
}
@media screen and (min-width:450px) {
	.sec-st-title-p{
		font-weight: 400;
		font-size: 2.0em;
	}
}

.sec-st-noticetxt{
	border: solid 3px;
	height: 100vw;
	padding: 3vw 2vw;
	overflow: auto;
	font-size: 1.3em;
	word-break: break-all;
	background-color: #fbf4e2;
}

.sec-st-tw{
   	text-align: center;
	margin-top: 6vw;
	color: #041c5a;
	position: relative;
}

.sec-yel {
	position: absolute;
	top: -4vw;
	left: 3vw;
	max-width: 100px;
	width: 18vw;
}
.sec-miz {
	position: absolute;
	top: -4vw;
	left: 65vw;
	max-width: 170px;
	width: 29vw;
}
@media screen and (min-width:380px)  and ( max-width:749px){
	.sec-yel {
		top: -7vw;
		left: 7vw;
	}
	.sec-miz {
		top: -7vw;
		left: 65vw;
	}
	.sec-st-tw{
	 	margin-top: 9vw;
	}
}
@media screen and (min-width:750px) {
	.sec-yel {
		top: -6vw;
		left: 7vw;
	}
	.sec-miz {
		top: -6vw;
		left: 65vw;
	}
	.sec-st-tw{
		margin-top: 8vw;
   }
}

.sec-st-tw-ab iframe{
	margin-left: 4vw;
	margin-right: 4vw;
	border: solid 3px !important;
}


.sec-st-pv {
   text-align: center;
	margin-top: 2vw;
	position: relative;
	color: #041c5a;
}


.sec-st-pv iframe{
/* PV */
	width: 90vw;
	height: 60vw;
	border: solid 3px;
}

.sec-st-play{
	margin-top: 2vw;
	position: relative;
	color: #041c5a;
}
.sec-blu{
	position: absolute;
	top: -2vw;
	left: 12vw;
	max-width: 76px;
	width: 12vw;
}
.sec-gre{
	position: absolute;
	top: -2vw;
	left: 76vw;
	max-width: 76px;
	width: 12vw;
}
@media screen and (min-width:380px)  and ( max-width:749px){
	.sec-blu {
		top: -8vw;
		left: 12vw;
	}
	.sec-gre {
		top: -7vw;
		left: 78vw;
	}
	.sec-st-pv {
		 margin-top: 8vw;
	}
	.sec-st-play{
		margin-top: 8vw;
	}
}
@media screen and (min-width:750px) {
	.sec-blu {
		top: -7vw;
		left: 12vw;
	}
	.sec-gre {
		top: -7vw;
		left: 76vw;
	}
	.sec-st-pv {
		margin-top: 8vw;
    }
    .sec-st-play{
		margin-top: 8vw;
    }
}

.sec-st-play-w{
	border: solid 3px;
	margin: 1vw 4vw;
}

.sec-st-playSlider img{
	max-width: 100%;
	margin: 0 auto;
}

.sec-st-end {
	margin-top: 8vw;
}

/*--------------------------------------------------------------*/
/*--------------------------------------------------------------*/
/*--------------------------------------------------------------*/
/*~324*/
.anchor{
	margin-top: -12vw;
	padding-top: 12vw;
}
.qa-top {
	margin-top: 15vw;
}
/*straycat*/
.qa-title{ 
	padding-top: 2vw;
	padding-bottom: 2vw;
	line-height: 1.0em;
	text-align: center;
	font-size: 1.0em;
	border-bottom: 0.5vw #041c5a solid;
}
/*QA*/
.qa-qa{
	padding-top: 1vw;
	padding-bottom: 1vw;
	line-height: 1.0em;
	font-size: 1.0em;
	text-align: center;
	border-bottom: 0.8vw #041c5a solid;
}
/*よくある質問*/
.qa-any{
	padding-top: 4vw;
	padding-bottom: 1.5vw;
	text-align: center;
	line-height: 0.5em;
	font-size: 1.0em;
}
.qa-cate{
	padding-top: 6vw;
	line-height: 1.0em;
	font-size: 1.0em;
}

/*質問本体*/
.qa-base {
	max-width: 100%;
	text-align: left;
	margin: 0 3vw;
}

/*質問*/
.qa-q-ba{
	border-bottom: 0.2vw #041c5a solid;
	border-bottom-style: dashed;
}
.qa-q{
	padding: 1.0em 0 0.5em 2.0em;
	font-weight: bold;
	line-height: 1.2em;
	font-size: 0.9em;
}
.qa-q:before{
	content: "";
	width: 6vw;
	height: 6vw;
	left: 1vw;
	top: 0.8em;
	background-size: 1.0em;
}
/*答え*/
.qa-a-ba{
	border-bottom: 0.8vw #041c5a solid;
}
.qa-a{
	padding: 1.0em 0 1.0em 2.0em;
	font-weight: 800;  
	line-height: 1.2em;
	font-size: 0.9em;
}
.qa-a img{
	width: 78vw;
}

.qa-a:before{
	content: "";
	width: 6vw;
	height: 6vw;
	left: 1vw;
	top: 0.8em;
	background-size: 1.0em;
}

.nav-list-qa{
	margin-left: 0.5em;
}
.nav-list-qa>ul{
	margin-top: 0.5vw;
}
.nav-list-qa>ul>li{
	display: inline-block;
	vertical-align: middle;
}
.nav-list-qa h2{
	font-size: 0.8em;
}

@media screen and (min-width:325px)  and ( max-width:400px){
/*325~400*/
	.anchor{
		margin-top: -10vw;
		padding-top: 10vw;
	}
	.qa-top {
		margin-top: 12vw;
	}
	/*straycat*/
	.qa-title{ 
		font-size: 1.2em;
	}
	/*QA*/
	.qa-qa{
		font-size: 1.2em;
		border-bottom: 0.6vw #041c5a solid;
	}
	/*よくある質問*/
	.qa-any{
		font-size: 1.2em;
	}
	.qa-cate{
		font-size: 1.2em;
	}

	/*質問*/
	.qa-q{
		font-size: 1.0em;
	}
	.qa-q:before{
		background-size: 1.2em;
	}
	/*答え*/
	.qa-a-ba{
		border-bottom: 0.6vw #041c5a solid;
	}
	.qa-a{
		font-size: 1.0em;
	}
	.qa-a:before{
		background-size: 1.2em;
	}

	.nav-list-qa>ul{
		margin-top: 1vw;
	}

}
@media screen and (min-width:401px)  and ( max-width:700px){
/*401~700*/
	.anchor{
		margin-top: -6vw;
		padding-top: 6vw;
	}
	.qa-top {
		margin-top: 12vw;
	}
	/*straycat*/
	.qa-title{ 
		font-size: 1.5em;
	}
	/*QA*/
	.qa-qa{
		padding-top: 2vw;
		padding-bottom: 2vw;
		font-size: 1.4em;
	}
	/*よくある質問*/
	.qa-any{
		font-size: 1.4em;
	}
	.qa-cate{
		padding-top: 3vw;
		font-size: 1.4em;
	}

	.qa-q{
		padding: 1.0em 0 0.5em 2.4em;
		font-size: 1.0em;
	}
	.qa-q:before{
		background-size: 1.4em;
	}


	/*答え*/
	.qa-a-ba{
		border-bottom: 0.7vw #041c5a solid;
	}
	.qa-a{
		padding: 1.0em 0 1em 2.4em;
		font-size: 1.0em;
	}
	.qa-a:before{
		background-size: 1.4em;
	}

	.nav-list-qa{
		margin-left: 1vw;
	}
	.nav-list-qa>ul{
		margin-top: 1vw;
	}
	.nav-list-qa h2{
		font-size: 1.0em;
	}

}
@media screen and (min-width:701px) {
/*751~920*/
	.anchor{
		margin-top: -5vw;
		padding-top: 5vw;
	}
	.qa-top {
		margin-top: 6vw;
	}

	/*straycat*/
	.qa-title{ 
		padding-top: 1vw;
		padding-bottom: 1vw;
		line-height: 1.5em;
		font-size: 2.5em;
		border-bottom: 2px #041c5a solid;
	}
	/*QA*/
	.qa-qa{
		font-size: 2.5em;
		border-bottom: 4px #041c5a solid;
	}
	/*よくある質問*/
	.qa-any{
		padding-top: 2vw;
		padding-bottom: 1vw;
		line-height: 1.0em;
		font-size: 2.0em;
	}
	.qa-cate{
		padding-top: 3vw;
		font-size: 1.6em;
	}

	/*質問本体*/
	.qa-base {
		margin: 0 8vw;
	}
	/*質問*/
	.qa-q-ba{
		border-bottom: 0.1em #041c5a solid;
		border-bottom-style: dashed;
	}
	.qa-q{
		padding: 1.0em 0 0.5em 2.5em;
		font-size: 1.2em;
	}
	.qa-q:before{
		content: "";
		width: 4vw;
		height: 4vw;
		left: 0.5vw;
		top: 0.9em;
		background-size: 1.4em;
	}

	/*答え*/
	.qa-a-ba{
		border-bottom: 0.15em #041c5a solid;
	}
	.qa-a{
		padding: 1.0em 0 1em 2.5em;
		font-weight: 500;  
		font-size: 1.2em;
	}
	.qa-a:before{
		content: "";
		width: 4vw;
		height: 4vw;
		left: 0.5vw;
		top: 0.9em;
		background-size: 1.4em;
	}

	.nav-list-qa{
		margin-left: 1vw;
	}
	.nav-list-qa>ul{
		margin-top: 2vw;
	}
	.nav-list-qa h2{
		font-size: 1.2em;
	}
}

/* =======================================================================
	フッター <footer>~</footer>内部
   ======================================================================= */
.sec-link .dl-banner img{
	margin-top: 1vw;
}


/* QRコード非表示 */
.foot-dl-banner {
	display: none;
}

.foot-gm-name{
	padding-left: 2vw;
	padding-right: 1vw;
}
.foot-gm-title{
	font-size: 14px;
	padding-top: 20px;
	padding-bottom: 20px;
	line-height: 24px;
}
.foot-gm-name p{
	font-size: 14px;
	line-height: 18px;
}

.foot-gm-title-rel{
	text-align: center;
	line-height: 1.5em;
}

@media screen and (min-width:400px) and ( max-width:749px){
	.foot-gm-title{
		font-size: 17px;
		line-height: 24px;
	}
	.foot-gm-name p{
		font-size: 14px;
		line-height: 18px;
	}
}
@media screen and (min-width:750px) {
	.foot-gm-title{
		font-size: 24px;
		line-height: 32px;
	}
	.foot-gm-name p{
		font-size: 16px;
		line-height: 20px;
	}
}


.foot-link {
	padding-top: 12vw;
	margin: 4vw auto;
	position: relative;
 }
 .foot-other-logo {
	text-align: center;
	width: 66vw;
	display: table;
	position: absolute;
    top: 50%;
    left: 50%;
    -ms-transform: translate(-50%,-50%);
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
}

/* ツイッターアイコン */
.icon-sns {
	max-width: 12vw;
	vertical-align: top;
}

.foot-last-moji li{
	margin-left: 6vw;
	margin-bottom: 4vw;
	padding-left: 2vw;
	border-left: solid 2px;
}

.foot-last-img{
	text-align: center;
	margin-bottom: 2vw;
}

.foot-copyright {
	text-align: center;
	padding-top: 2vw;
	padding-bottom: 4vw;
	font-size: 12px;
}
@media screen and (min-width:450px){
	.foot-copyright {
		font-size: 15px;
	}
}
.foot-cat {
	text-align: center;
}
.sec-red{
	margin-top: 2vw;
	margin-bottom: 10vw;
	max-width: 120px;
	width: 20vw;
}

.pc {
	display: none;
}
