@charset "utf-8";

/*
******************************************************************
* MJP top.css
******************************************************************
*/
#wrp-all{
	background-color:#000;
	overflow: hidden;
}

/*
******************************************************************
* #contents
******************************************************************/
#contents .main {
	position: relative;
	z-index: 0;
}
#contents .main > *{
	position: absolute;
}
#contents .main h1 {
    z-index: 100;
    left: 1%;
    top: 0;
    width: 33%;
    margin-top: 4%;
}
#contents .main h2 {
	left: 50%;
	z-index: 150;
	top: 645px;
	margin-left: -299px;
}
#contents .main .chara {
    position: relative;
    z-index: 10;
    width: 100%;
}
#contents .main .chara img {
    position: relative;
    margin-top: 1.8%;
    margin-left: -29.5%;
    width: 204%;
}
#contents .main .bg_img01 {
	width: 100%;
	z-index: 1;
	top: 0;
	left: 0;
}
#contents .main .bg_img01 img {
	width: 100%;
}
#contents .main .bg_img03 {
    z-index: 2;
    top: 20.5%;
    left: 2%;
    width: 26%;
}
#contents .main .bg_txt {
    width: 24%;
    z-index: 2;
    right: 15.5%;
    top: 18%;
}
#contents .main .txt01 {
    top: 11%;
	left: 0;
    z-index: 11;
    width: 100%;
    padding: 0;
    box-sizing: border-box;
}

body.show.retreat .bg_img03 {
	-webkit-transform: scale(0.4) translate(195px, -150px);
	transform: scale(0.4) translate(195px, -150px);
}
body.show.retreat .bg_txt {
	-webkit-transform: scale(0.4) translate(-125px, -162px);
	transform: scale(0.4) translate(-125px, -162px);
}
body.show.retreat .txt01 {
	-webkit-transform: scale(0.4) translate(0, -320px);
	transform: scale(0.4) translate(0, -320px);
}

.main02 {
    opacity: 0;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
	background-image: url(../../common/img/main_bg.png);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
    -webkit-transform: scale(2.0);
    transform: scale(2.0);
    -webkit-transition: all 0.8s ease;
    transition: all 0.8s ease;
    -webkit-transition-delay: 0.2s;
    transition-delay: 0.2s;
}
.main02 img {
	opacity: 0;
}

#contentsWrap {
	position: relative;
    z-index: 2;
    margin: -10.5% 0 15px;
}

#contents .content01 {
	width: 100%;
	margin: 12px 0 0;
	position: relative;
	z-index: 4;
}
#contents .content02 {
	width: 100%;
    margin: 12px 0 0;
    position: relative;
    z-index: 3;
}

.next_btn {
	padding: 0 2.5%;
}
