:root {
	--color-text-01: #6d819c;
	--color-text-02: #e4e7ec;
	--color-text-03: #179b94;
	--color-text-04: #6e2a08;
	--color-text-05: #e7f0ff;
	--color-text-06: #bdcce6;

	--normal-text : #333333;
	--light-text : #ffffff;
	--dark-text : #000;
	--dark-bg-color : #444;
  }

* {

	color:var(--normal-text);
}
*,
*::before,
*::after {
  box-sizing: border-box;
}
.clear{
	clear:both;
}
*:focus {
    outline: 0;
	background:transparent;
}

h3{
	font-weight:normal;
}
html,body{
	margin:0;
	padding:0;
	background-color:#2c2c2e;
	
}
.blind {
	font-size:15px;
	letter-spacing:2px;

}
.center{
	text-align:center;
}

input:focus,select:focus,textarea:focus{
    outline: 0;
	background:var(--light-text);
	box-shadow:0 0 10px 0 rgba(0, 174, 255, 0.3);
	border:1px solid var(--color-text-03) !important;
	transition-property:all !important;transition-duration:.2s !important
}


.hidden-scroll {
	-ms-overflow-style: none; /* IE and Edge */
	scrollbar-width: none; /* Firefox */
}
.hidden-scroll::-webkit-scrollbar {
	display: none; /* Chrome, Safari, Opera*/
}



a,img {
	text-decoration:none;
    -webkit-tap-highlight-color: rgba(0,0,0,0);
    -webkit-tap-highlight-color: transparent; /* For some Androids */

}
ul {padding:0;margin:0}
li {list-style:none;padding:0;margin:0}
.ani{transition-property:all !important;transition-duration:.2s !important}
.ani-1s{transition-property:all;transition-duration:1s}


.table{
	display: table;
	width:100%;
	border-collapse: collapse;
}
.td {
	display:table-row;
}
.td {
	display:table-cell;
}

hr {
	background:transparent;
	border:0;
	border-top:1px solid var(--color-text-02);
	margin:30px 0;
	height:0px;
	display:block;
	
}


.top-space{
	height:100px;
}


header{
	height:100px;
	box-shadow: 0 0 10px 0 rgba(0,0,0,.16);
	position:fixed;
	left:0;
	top:0;
	width:100%;
	background-color: #fff;
	z-index: 99999;
}
header > .logo_box{
	width:1080px;
	padding:0 10px;
	margin:0 auto;
}
header  .menu_list {
	float:right;
	width:780px;
	text-align:right;
}
header  .menu_list a {
	padding:39px;
	margin:1px;
	font-size:0;
	display: inline-block;
}
header  .menu_list a:hover{
	padding-bottom:36px;
	border-bottom:4px solid #18deb6;
}
.logo img{
	width:235px;
	height:57px;
	margin-top:22px;

}

.main_box_01{
	width:100%;
	background:linear-gradient( to bottom right, #0D0535, #020011);
}
.main_box_01 > div{
	margin:0 auto;
	height:980px;
	width:100%;
	background-size: 1920px;
	background-position: center top;
	background-repeat: no-repeat;
}
.main_box_01 > div > img{
	width:100%;
	display: block;
}
.main_box_02{
	width:100%;
	background:#18deb6;
	height:288px;
}
.main_box_02 > div{
	width:1080px;
	margin:0 auto;
	position: relative;
}
.main_box_02 > div > .main-title{
	position:absolute;
	width:769px;
	height:155px;
	display: block;
	right:10px;
	top:-84px;
}

.main_box_02 > div > .main-cont {
	position:absolute;
	width:1080px;
	height:409px;
	display: block;
	left:0;
	top:92px;
}

.main_box_03{
	width:100%;
	background:#0C0432;
	height:1015px;
}
.main_box_03 > div{
	width:1080px;
	margin:0 auto;
	position: relative;
}
.main_box_03 > div > .main-title-01 {
	margin-top:260px;
}
.main_box_03 > div > .main-cont-01 {
	margin-top:20px;
	margin-left:10px;
}

.main_box_04{
	width:100%;
	background:#8591FD;
	height:580px;
}
.main_box_04 > div{
	width:1080px;
	margin:0 auto;
	position: relative;
}
.btn_list{
	font-size:0;
	top:-112px;
	position: absolute;
}
.btn_list > div{
	width:340px;
	height:595px;
	display: inline-block;
	margin:0 10px;
	background-repeat: no-repeat;
	background-size: 340px;
	background-position: center top;
	border-radius: 10px;
	box-shadow: 0 10px 10px 0 rgba(0,0,0,.16);
	position:relative;
}
.btn_box_st{
	position:absolute;
	width:300px;
	height:64px;
	background:#0C0432;
	bottom:30px;
	border-radius: 32px;
	left:20px;
	text-align:right;
	padding-right:14px;
	padding-top:14px;
}
.btn_box_st:hover{
	background:#18deb6;
}

.main_box_copy{
	width:100%;
	background:#2c2c2e;
}
.main_box_copy > div{
	width:1080px;
	margin:0 auto;
	position: relative;
	padding:36px 0;
}
.main_box_copy > div > img{
	width:100%;
}



.sub_box_01{
	width:100%;
	background:linear-gradient( to bottom right, #0D0535, #020011);
}
.sub_box_01 > div{
	margin:0 auto;
	height:683px;
	width:100%;
	background-size: auto;
	background-position: center top;
	background-repeat: no-repeat;
}
.sub_box_02{
	width:100%;
	background:#18deb6;
	height:288px;
}
.sub_box_02 > div{
	width:1080px;
	margin:0 auto;
	position: relative;
}
.sub_box_02 > div > .sub-title{
	position:absolute;
	width: 965px;
	height:176px;
	display: block;
	right:10px;
	top:-84px;
}

.sub_box_03{
	width:100%;
	background:#0C0432;
	height:500px;
}
.sub_box_03 > div{
	width:1080px;
	margin:0 auto;
	position: relative;
}
.sub_box_03 > div > img{
	margin-top:-220px;
}

.sub_box_04{
	width:100%;
	background:#0C0432;
	padding-bottom:100px;
}
.sub_box_04 > div{
	width:1080px;
	margin:0 auto;
	position: relative;
}
.sub_box_04 > div > img{
	margin-top:40px;
}
#map .marker{
	display:block;
	width:169px;
	height:50px;
	background-image:url(/assets/img/map_logo_01_v2.png);background-size:169px;
	font-family:"B";
	font-weight: bold;
	color:#fff;
	padding-left: 40px;
    padding-top: 11px;
}

#map {
	display: inline-block;
	margin-top:-178px;
	border-radius: 0 50px 0 50px;
	box-shadow: 0 10px 10px 0 rgba(0,0,0,.16);
	width:1060px;
	margin-left:10px;
	height:500px;
}

.sub_box_05{
	width:100%;
	background:#8591fd;
	height:500px;
}
.sub_box_05 .btn_list{
	top:-178px;
}
.sub_box_05 > div{
	width:1080px;
	margin:0 auto;
	position: relative;
}
.sub_box_05 > div > img{
	margin-top:-320px;
}

.mo_menu {
	max-width:300px;
	width:300px;
	position:fixed;
	left:0;
	top:0;
	height:100vh;
	background:#fff;
	z-index: 100001;
	text-align:center;
}
.mo_menu_wrap{
	width:100vw;
	height:100vh;
	position:fixed;
	left:0;
	top:0;
	bottom:0;
	right:0;
	z-index: 100000;
	background:rgba(0,0,0,.5);
	opacity: 1;
}

.hide {
	left:-300px;
}
.hide2 {
	display: none;
	opacity: 0;
}

.mo_menu > div img{
	width:220px;
}
.mo_menu > a > img{
	width:240px;
	margin-top:40px;
}
.close {
	width:64px;
	height:64px;
	display: block;
}

.bottom_fixed{
	position:fixed;
	width:100%;
	padding-left:16px;
	padding-right:16px;
	text-align:center;
	bottom:0;
	font-size:0;
	z-index:99999;
	overflow:hidden;
	display:none;
}
.bottom_fixed .bf_wrap{
	position:relative;
	height:112px;
}
.bottom_fixed .bf_top{

	position:absolute;
	display:block;
	top:25px;
	background:#d04040;
	height:64px;
	z-index:10;
	width:100%;
	border-radius:20px;
	text-align:center;
	animation-name: btntop;
	animation-duration: 5s;
	animation-iteration-count: infinite;

}
.bottom_fixed .bf_top img{
	height:24px;
	margin-top:20px;
}
.bottom_fixed .bf_bottom{

	position:absolute;
	height:64px;
	z-index:10;
	bottom:15px;
	width:100%;
	background:#9f2525;
	z-index:5;
	border-radius:20px;
	box-shadow:0 10px 10px 0 rgba(50,0,0,.5);
	animation-name: btnbottom;
	animation-duration: 5s;
	animation-iteration-count: infinite;
	overflow:hidden;
}
.bfb_left{
	float:left;
	height:64px;
	width:20px;
	background:linear-gradient( to right, rgba(0,0,0,.5), rgba(0,0,0,.0));
}
.bfb_right{
	float:right;
	height:64px;
	width:20px;
	background:linear-gradient( to left, rgba(0,0,0,.5), rgba(0,0,0,.0));
}

.hand{
	background-image:url(/assets/img/m/hand_before.png);
	height:82px;
	width:82px;
	position:absolute;
	z-index:20;
	background-size:82px;
	right:calc(50% - 172PX);
	bottom:-5px;
	animation-name: handaction;
	animation-duration: 5s;
	animation-iteration-count: infinite;
	display:block;

}

@keyframes handaction {
	0% {
		bottom:-100px;
		right:0;
		background-image:url(/assets/img/m/hand_before.png);
		opacity:0;
	}

	20%{
		bottom:-5px;
		right:calc(50% - 172PX);
		opacity:1;
		
	}
	47%{
		background-image:url(/assets/img/m/hand_before.png);
	}
	48%{
		background-image:url(/assets/img/m/hand_after.png);
		bottom:-5px;
	}

	51%{
		background-image:url(/assets/img/m/hand_after.png);
		bottom:-8px;
	}
	52%{
		background-image:url(/assets/img/m/hand_before.png);
		bottom:-5px;
	}


	80%{
		bottom:-5px;
		right:calc(50% - 172PX);
		opacity:1;
	}
	100% {
		bottom:-100px;
		right:0;
		background-image:url(/assets/img/m/hand_before.png);
		opacity:0;

	}
}

@keyframes btntop {


	48%{
		    top: 25px;
			background:#d04040;
	}

	50%{
		    top: 30px;
			background:rgb(180, 76, 76);
	}
	52%{
		    top: 25px;
			background:#d04040;
	}


}
@keyframes btnbottom {


	48%{
		    box-shadow:0 10px 10px 0 rgba(50,0,0,.5);
	}

	50%{
		    box-shadow:0 0px 5px 0 rgba(50,0,0,.5);
	}
	52%{
		    box-shadow:0 10px 10px 0 rgba(50,0,0,.5);
	}


}
@import url("/assets/css/common.m.css");