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

/*reset
------------------------------------------------------------------------------*/
*{
	box-sizing: border-box;
}
body, div, dl, dt, dd, h1, h2, h3, h4, h5, h6, pre, form, fieldset, input, textarea, p, blockquote, th, td, ul {
	margin: 0;
	padding: 0;
}
img {
	border:0;
	vertical-align: bottom;
	max-width:100%;
}

html, body{
	position: relative;
}
html{
	scroll-behavior: smooth;
}
body{
	font-family: "游ゴシック", "Yu Gothic", Yu Gothic, "游ゴシック体", "YuGothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 500;
	font-style: normal;
	width: 100%;
	color: #350909;
	font-size: 0.83vw;
	letter-spacing: 0.06em;
	line-height: 1.75;
}
button{
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
}

/*PC・スマフォで非表示
------------------------------------------------------------------------------*/
.pc_none {
	display: none;
}
.sp_none {
	display: block;
}



/*ここからcss設定
------------------------------------------------------------------------------*/

.loader{
	display: block;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1000;
	background-color: #BF2B0D;
	background-image: URL(../img/back_red_big.png);
	background-repeat: repeat;
	background-size: auto;
}
.loader_logo{
	width: 13.02vw;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.loader.start{
	animation-name: bottomout;
	animation-fill-mode: forwards;
	animation-duration: 1.5s;
}
@keyframes bottomout{
	0% {
		top: 0;
	}
	50% {
		top: 0;
	}
	100% {
		top: 100%;
	}
}

body.loading{
	overflow: hidden;
}

.btn_menu{
	position: relative;
	width: 2.6vw;
	height: 2.6vw;
	border: 1px solid #fff;
	background-color: #BF2B0D;
	color: #fff;
	border-radius: 0.26vw;
	position: fixed;
	top: 2.6vw;
	right: 2.6vw;
	z-index: 999;
}
.btn_menu:before,
.btn_menu:after{
	content:"";
	position: absolute;
	font-family: "Material Icons";
	font-size: 1.56vw;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.btn_menu:before{
	content: "\e5d2";
}
.btn_menu:after{
	content: "\e5cd";
	display: none;
}

body.open .btn_menu:before{
	display: none;
}
body.open .btn_menu:after{
	display: block;
}
nav.headernav {
	position: fixed;
	top: 0;
	right: 0;
	width: 20.31vw;
	height: 100%;
	background-color: #BF2B0D;
	background-image: URL(../img/back_red_big.png);
	background-repeat: repeat;
	background-size: auto;
	transition: all 0.2s;
	transform: translate(20.31vw);
	z-index: 990;
	padding: 6.77vw 2.86vw;
}
nav.headernav.open {
	transform: translate(0); 
}
nav.headernav ul.headernav_ul {
	margin: 0;
	list-style-type: none;
}
nav.headernav ul.headernav_ul li {
	padding: 0.78vw 0;
	border-bottom: 1px solid #fff;
}
nav.headernav ul.headernav_ul li a {
	display: block;
	text-decoration: none;
	color: #fff;
	font-size: 0.94vw;
}
.snsnav_ul{
	margin-top: 5.21vw;
	list-style-type: none;
	display: flex;
	justify-content: center;
	align-items: center;
}
.snsnav_ul li.snsnav_li{
	width: 3.65vw;
}
.snsnav_ul li.snsnav_li a{
	display: block;
	text-decoration: none;
	color: #fff;
}
.snsnav_ul li.snsnav_li + li.snsnav_li{
	margin-left: 2.6vw;
}
nav.headernav .snsnav_ul{
	width: 70%;
	margin: 0 auto;
	margin-top: 5.21vw;
}
nav.headernav .snsnav_ul li.snsnav_li + li.snsnav_li{
	margin-left: 1.56vw;
}



.mainvisual_wrap{
	position: relative;
	background-image: url(../img/mainvisual_backB.jpg);
	background-repeat: no-repeat;
	background-size: cover;
}
.mainvisual_in{
	position: relative;
	border: 2.08vw solid #BF2B0D;
	/* height: 57.29vw; */
	height: 46.88vw;
}
.mainvisual_text{
	position: absolute;
	top: 50%;
	right: 8.33vw;
	transform: translateY(-50%);
	display: flex;
	flex-direction: column;
	align-items: center;
}
.mainvisual_character{
	text-align: center;
	position: absolute;
	bottom: 1.3vw;
	left: 10.42vw;
	width: 34.58vw;
}
.site_title{
	width:36.46vw;
}
.comingsoon{
	width:31.25vw;
	margin-top: 2.34vw;
}
.pc_date{
	width:27.45vw;
	margin-top: 2.34vw;
}


.section_in{
	width:45.83vw;
	margin: 0 auto;
	position: relative;
}




#introduction{
	background-image: url(../img/se01_backC.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	padding: 5.73vw 0;
}
.se01_title{
	width: 36.56vw;
	margin: 0 auto;
	margin-top: 4.17vw;
}
.se01_boxtext_wrap{
	position: relative;
}
.se01_itemA{
	width: 13.33vw;
	position: absolute;
	top: 7.45vw;
	left: -7.45vw;
}
.se01_itemB{
	width: 11.82vw;
	position: absolute;
	bottom: -3.65vw;
	right: -3.13vw;
}

#overview{
	background-color: #FFFBF3;
	background-image: url(../img/back_white_big.png);
	background-repeat: repeat;
	background-size: auto;
	padding: 5.73vw 0;
}
.se02_boxtext_wrap{
	position: relative;
}
.se02_itemA{
	width: 9.9vw;
	position: absolute;
	top: 5.63vw;
	right: -3.13vw;
}
.se02_itemB{
	width: 9.58vw;
	position: absolute;
	bottom: -2.4vw;
	left: -4.01vw;
}
.se02_title{
	width: 44.27vw;
	margin: 0 auto;
	margin-top: 2.6vw;
}


.footer{
	background-color: #FFFBF3;
	background-image: URL(../img/back_brown_big.png);
	background-repeat: repeat;
	background-size: auto;
	color:#fff;
}
.footer_in{
	width: 45.83vw;
	margin: 0 auto;
	text-align: center;
	padding: 5.73vw 0;
}
.footer_logo{
	width: 10.42vw;
	margin: 0 auto;
}
.footer_text{
	font-size: 1.15vw;
	margin-top: 5.21vw;
}
.footer_text + .footer_text{
	margin-top: 2.6vw;
}
.footer .snsnav_ul{
	margin-top: 5.21vw;
}
.footer_copy{
	text-align: center;
	padding: 0.78vw;
}





@media screen and (max-width:768px) {
	
	.pc_none {
		display: block;
	}
	.sp_none {
		display: none;
	}
	
	img{
		width: 100%;
	}
	
	.loader{
		width:100vw;
		height: 100%;
	}
	.loader_logo{
		width:60%;
	}
	
	
	.btn_menu{
		width: 8.97vw;
		height: 8.97vw;
		border-radius: 1.28vw;
		top: 5.13vw;
		right: 5.13vw;
		position: absolute;
		opacity: 1;
	}
	.btn_menu:before,
	.btn_menu:after{
		font-size: 6.41vw;
	}
	nav.headernav{
		width:70vw;
		transform: translate(70vw);
		padding: 25vw 10vw;
	}
	nav.headernav ul.headernav_ul li a{
		font-size: 4.62vw;
	}
	nav.headernav ul.headernav_ul li{
		padding: 2.56vw 0;
	}
	
	nav.headernav .snsnav_ul{
		width:100%;
		margin-top: 25.64vw;
	}
	.snsnav_ul li.snsnav_li{
		width: 7.69vw;
	}
	.snsnav_ul li.snsnav_li + li.snsnav_li,
	nav.headernav .snsnav_ul li.snsnav_li + li.snsnav_li{
		margin-left: 5.13vw;
	}
	.btn_menu.fixed{
		position: fixed;
		animation-name: fixedin;
		animation-duration: 0.3s;
		animation-timing-function: linear;
	}
	@keyframes fixedin{
		from {
			opacity: 0;
		}
		to {
			opacity: 1;
		}
	}
	
	.mainvisual_in{
		/* height: 141.03vw;
		width: 100%;
		border: 5.13vw solid #BF2B0D; */
		border:none;
		height: auto;
	}
	.mainvisual_wrap{
		/* height: 141.03vw;
		width: 100%;
		overflow: hidden; */
		background-image: unset;
	}
	.mainvisual_text_sp{
		position: absolute;
		top: 4.62vw;
		left: 14.1vw;
	}
	.site_title{
		width: 70.26vw;
	}
	.mainvisual_character{
		width: 51.28vw;
		bottom: 13.59vw;
		left: 15.38vw;
	}
	
	.spitem_02{
		position: absolute;
		width: 100%;
		height: auto;
		top: 0;
		left: 0;
	}
	.spitem_03{
		width: 17.95vw;
		position: absolute;
		top: 34.62vw;
		right: 18.46vw;
	}
	
	.mainvisual_bottom{
		background-color: #FFFBF3;
		background-image: url(../img/back_white_big.png);
		background-repeat: repeat;
		background-size: auto;
		padding:23.08vw 0 15.38vw 0;
		position: relative;
	}
	.sp_comingsoon{
		position: absolute;
		right: 0;
		top: 6.41vw;
		width: 52.56vw;
	}
	.sp_date{
		width: 75vw;
		margin:0 auto;
	}
	
	.section_in{
		width: calc(100% - 7.69vw);
	}
	
	
	#introduction{
		padding: 12.82vw 0;
		overflow: hidden;
	}
	.se01_title{
		width: 90%;
		margin-top: 12.82vw;
	}
	.se01_itemA{
		width: 25.64vw;
		top: 16.15vw;
		left: -8.21vw;
	}
	.se01_itemB{
		width: 30.77vw;
		bottom: -8.46vw;
	}
	
	#overview{
		padding: 12.82vw 0;
		overflow: hidden;
	}
	.se02_itemA{
		width: 28.46vw;
		top: 21.03vw;
		right: -4.36vw;
	}
	.se02_itemB{
		width: 29.49vw;
		position: absolute;
		bottom: 64.1vw;
		left: -6.41vw;
	}
	.se02_title{
		width: 84.62vw;
		margin-top:-32.05vw;
	}
	
	.footer_in{
		width: 38.46vw;
		padding: 20.51vw 0 12.82vw
	}
	.footer_logo{
		width: 100%;
	}
	.footer_text{
		font-size: 4.62vw;
		margin-top: 12.82vw;
	}
	.footer_text + .footer_text{
		margin-top: 7.69vw;
	}
	.footer .snsnav_ul{
		margin-top: 12.82vw;
	}
	.footer_copy{
		font-size: 3.08vw;
		padding: 3.85vw;
	}
	
	
	
	
	
}




