@charset "utf-8";
/* リセット
------------------------------------- */
* {
	margin:0;
	padding:0;
	box-sizing:border-box;
}

table {border-spacing:0; border-collapse:collapse;}
* html table {border-collapse:collapse;}
*:first-child+html table {border-collapse:collapse;}
caption,th {text-align:left; font-weight:normal;}
table,th,td,img {border:0;}
input {vertical-align:middle; outline:none;}
q:before,q:after {content:'';}
ul {list-style: none;}

hr,
legend,
caption {display:none;}

img {border:0; vertical-align:bottom;}

a:focus { outline:none;}


/* aタグ設定
------------------------------------- */
a {
	transition-property: all;
	transition-duration: 0.3s;
	transition-timing-function: ease;
	transition-delay: 0s;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}

/* 基本設定
------------------------------------- */
html { font-size: 62.5%; } 
body {
	-webkit-text-size-adjust: 100%;
	font-size: 1.4rem;/* =14px */
	font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo,Verdana, Roboto, "Droid Sans", "游ゴシック", YuGothic, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
#wrapper {
	min-width: 1280px;
	margin: 0 auto;
}
#fvArea #area01 {
	position: relative;
	background: url("../img/bg_halo.png") center center no-repeat;
	background-size:cover;
	height: 800px;
}
#fvArea #area01 h1 {
	position: absolute;
	top: 30px;
	left: calc(50% - 640px);
	z-index: 5;
}
#fvArea #area01 h1 span {
	position: relative;
	display: block;
}
#fvArea #area01 h1 img {
	position: absolute;
}
#fvArea #area01 h1 .item01 {
	top: 0;
	left:0;
}
#fvArea #area01 h1 .item02 {
	top: 209px;
	left:807px;
}
#fvArea #area01 h1 .item03 {
	top: 342px;
	left:474px;
	z-index: 6;
}
#fvArea #area01 h1 .item04 {
	top: 249px;
	left:348px;
}
#fvArea #area01 h1 .item05 {
	top: 262px;
	left:662px;
}
#fvArea #area01 h1 .item06 {
	top: 522px;
	left:238px;
}
#fvArea #area01 h1 .item07 {
	top: 630px;
	left:572px;
}
#fvArea #area01 .cloud {
	position: absolute;
	top: 0;
	right: 0;
}
#fvArea #area01 .mountain {
	position: relative;
	bottom: 0;
	left:0;
	z-index: 4;
	width: 100%;
	height: 193px;
	background: url("../img/bg_mountain.png") center bottom no-repeat;
	background-size: auto 193px;
}
#fvArea #area02 {
	position:relative;
	background: url("../img/bg_gradation.jpg") center center repeat-x;
	background-size: auto 100%;
	height: 856px;
	text-align: center;
	padding-top: 220px;
}
#fvArea #area02 h2 {
	margin-bottom: 37px;
}
#fvArea #area02 .hash {
	margin-top: 64px;
	position: relative;
	z-index: 2;
}
#fvArea #area02 .grass01 {
	position: absolute;
	left: 0;
	bottom: 0;
}
#fvArea #area02 .grass02 {
	position: absolute;
	right: 0;
	bottom: 0;
}
#advertisementNavArea {
	padding: 64px 0 80px;
}
#advertisementNavArea .advertisementNavList {
	width: 1146px;
	margin: 0 auto;
	transform: translateX(-5px);
}
#advertisementNavArea .advertisementNavList li {
	float: left;
	margin-right: 78px;
	text-align: center;
	display: flex;
	flex-direction:column;
	justify-content: flex-end;
	width: 330px;
	height: 213px;
	padding-bottom: 67px;
	background: url("../img/bg_navlist.png") center center no-repeat;
	background-size: auto 100%;
}
#advertisementNavArea .advertisementNavList li .btnObj img {
	width: 330px;
	height: auto;
}
#advertisementNavArea .advertisementNavList li:nth-of-type(3) {
	margin-right: 0;
}
#advertisementNavArea .advertisementNavList li:nth-of-type(4) {
	margin-left: 204px;
}
#advertisementNavArea .advertisementNavList li .txt {
	margin-bottom: 13px;
}

/* 下層ページ
------------------------------------- */
.low #wrapper {
	background: url("../img/bg_low.jpg") 0 0 repeat-x #fff;
	background-size: 379px auto;
	position: relative;
	padding-bottom: 115px;
}
.low .cloud {
	position: absolute;
	top: 0;
	right: 0;
}
.low .layout {
	width: 1100px;
	margin: 0 auto;
	padding: 132px 0 0;
}
.low h1 {
	text-align: center;
	position: relative;
	width: 522px;
	margin: 0 auto 52px;
}
.low h1 .logo {
	position: absolute;
	top: -102px;
	left: 211px;
}
.low .lead {
	text-align: center;
	margin-bottom: 55px;
}
.low .image {
	text-align: center;
}
.illustArea {
	margin-top: 75px;
}
#ieonsen .illustArea {
	margin-top:100px;
}
.illustArea .illust {
	float: left;
}
.illustArea .infoArea {
	width: 520px;
	float: right;
	padding-top: 40px;
}
#maccyo .illustArea .infoArea {
	padding-top: 14px;
}
#ieonsen .illustArea .infoArea {
	padding-top: 0;
}
.illustArea .infoArea .btnDownload {
	margin-top: 80px;
	margin-left: 120px;
}
.illustArea02 {
	text-align: center;
	margin-top: 72px;
}
.illustArea02 .infoArea .txt {
	margin: 58px 0 75px;
}
.bgmBtn {
	text-align: center;
	margin-top: 58px;
}
.illustArea .infoArea .addPlayBox + .btnDownload {
	margin-top: 58px;
}

.btnTotop {
	margin: 120px auto 0;
	width: 280px;
	transform: translateX(-5px);
}


.infoArea .btnDownload img,
.btnTotop img{
	width: 280px;
}

/* clearfix
------------------------------------- */
.clearfix:after,
#advertisementNavArea .advertisementNavList:after,
.illustArea:after{
	content : '';
	display : block;
	clear : both;
	height: 0;
}


/* レスポンシブ設定
------------------------------------- */
@media screen and (min-width:751px){
	.sp {
		display: none!important;
	}
	.bgmBtn a:hover {
		opacity:0.75;	
	}
}
@media screen and (max-width:750px){
	.pc {
		display: none!important;
	}
	img {
		width: 100%;
		height: auto;
	}
}

/*アニメーション*/
#wrapper{overflow:hidden;} 
.low .cloud{opacity:0;}
.illustArea02 .illust >*,.illustArea02 .infoArea,.illustArea >*,.low #wrapper .layout >*{position:relative;opacity:0;top:10%;}
.slideLeft{position:relative;opacity:0;left:20%;}
.slideRight{position:relative;opacity:0;left:-20%;}
.childSlideUp >*,.slideUp{position:relative;opacity:0;top:20%;}
.slideDown{position:relative;opacity:0;top:-20%;}

#fvArea #area01 .mountainOuter {
	position:absolute;
	bottom:0;
	overflow:hidden;
	width:100%;
}
