@charset "UTF-8";

.loading{
	width:100vw;
	height:110vh;
	position: fixed;
	left:0;
	top:0;
	z-index:1500;
	background:#f7efe8;
	display: flex;
	justify-content: center;
	align-items: center;
}

.loading figure{
	margin-top:-20vw;
	display: block;
}

.loading figure img{
	width: 24vw;
	animation: 2.5s obj72 infinite;
	display: block;
}

.loading.off figure img{
	animation: loadingEnd 1.5s;
}

.loading > div{
	opacity:0;
}

.loading > div.on{
	opacity: 1.0;
	transition: 0.3s;
	transition-delay: 0.5s;
}


@keyframes loadingEnd {
	0%{transform: scale(1.0);}
	15%{transform: scale(1.1);}
	70%{transform: scale(0.7);}
}

.loading p{  
	display: flex;
    align-items: flex-end;
    transform: scale(0.7);
    margin-top: 0.75vw;
}
.loading p span{display:block; height: 7vw;}
.loading p span img{margin-bottom: 1.5vw;}
.loading p span:nth-child(7) img{margin-bottom: 0.7vw;}
.loading p img{vertical-align: bottom; margin-right: 1.2vw;}

.loading p span:nth-child(1){animation:loading 4s infinite;}
.loading p span:nth-child(2){animation:loading 4s infinite; animation-delay:0.05s;}
.loading p span:nth-child(3){animation:loading 4s infinite; animation-delay:0.1s;}
.loading p span:nth-child(4){animation:loading 4s infinite; animation-delay:0.15s;}
.loading p span:nth-child(5){animation:loading 4s infinite; animation-delay:0.2s;}
.loading p span:nth-child(6){animation:loading 4s infinite; animation-delay:0.25s;}
.loading p span:nth-child(7){animation:loading 4s infinite; animation-delay:0.3s;}
.loading p span:nth-child(8){animation:loading 4s infinite; animation-delay:0.35s;}

.loading p span:nth-child(1) img{height:3.733333248vw; margin-right: 0.65vw;}
.loading p span:nth-child(2) img{height:2.666666vw; margin-right: 0.65vw;}
.loading p span:nth-child(3) img{height:2.666666vw; margin-right: 0.65vw;}
.loading p span:nth-child(4) img{height:3.733333248vw; margin-right: 0.5vw;}
.loading p span:nth-child(5) img{height:3.733333248vw; margin-right: 0.9vw;}
.loading p span:nth-child(6) img{height:2.666666vw; margin-right: 0.65vw;}
.loading p span:nth-child(7) img{height:3.333333248vw; margin-right: 0.8vw;}
.loading p span:nth-child(8) img{height:1.066666vw;}

.menuBtn.view{
	opacity:1.0;
	transition: 0.7s;
}

.menuBtn{
    position: fixed;
    right: 0;
    top: 3.2vw;
    margin-top: -1.3888888vw;
    background: #312928;
    height: 11.2vw;
    border-radius: 1.06666vw 0 0 1.06666vw;
    width: 11.2vw;
	display: flex;
    align-items: center;
	padding-left: 3.1944444vw;
	z-index: 300;
	transition: 0.4s;
	opacity: 0;
}

.menuBtn:hover{
	transition: 0.4s;
}
.menuBtn ul.item{
	pointer-events: none;
}

.menuBtn ul.item li:nth-child(1){position: absolute; right:3.15vw; top:4vw; background: #FEFAF7; width: 4.8vw; height: 1px; z-index: 300; transition: 0.3s; opacity:1;}
.menuBtn ul.item li:nth-child(2){position: absolute; right:3.15vw; top:5vw; background: #FEFAF7; width: 3.2vw; height: 1px; z-index: 300; transition: 0.3s; opacity:1;}
.menuBtn ul.item li:nth-child(3){position: absolute; right:3.15vw; top:6vw; background: #FEFAF7; width: 1.6vw; height: 1px; z-index: 300; transition: 0.3s; opacity:1;}

.menuBtn.on ul.item li:nth-child(1){right:3.15vw; top: 5vw; transform: rotate(45deg); transition: 0.4s;}
.menuBtn.on ul.item li:nth-child(2){right:3.15vw; width:0; transition: 0.2s;}
.menuBtn.on ul.item li:nth-child(3){right:3.15vw; top: 5vw; width:4.8vw; transform: rotate(-45deg); transition: 0.4s;}


.menuBtn > p{
	height: 0.55vw;
	position: relative;
    z-index: 500;
	opacity:1.0;
	transition: 0.5s;
}
.menuBtn:hover > p{
	opacity:0.7;
	transition: 0.5s;
}

.menuBtn.on > p{
	opacity:0;
	transition: 0.5s;
}


.menuBtn img{
	width: 2.7333333vw;
}

.menuInner{
	position:absolute;
	width: 90vw;
	right:0;
	top: 0;
	opacity: 0;
	pointer-events: none;
	background: #312928;
	border-radius: 1.666666vw 0 1.666666vw 1.666666vw;
	color: #FEFAF7;
	padding: 6.4vw 7.2vw;
	transform: scale(0.9);
	transition: 0.5s;
	z-index:100;
}

.menuInner > *{
	margin-bottom: 1.666vw;
}

.menuInner.on{
	opacity:1.0;
	transition: 0.5s;
	transform: scale(1.0);
	pointer-events: auto;
}

.menuInner p{
    font-size: 4.26666vw;
    font-weight: 600;
    margin-top: 2.4vw;
}

.menuInner ul{
	margin-left: 2.4vw;
	margin-bottom: 3vw;
}

.menuInner ul li{
	font-size: 3.73333vw;
    line-height: 2.25;
}
.menuInner a{
	color :#FEFAF7;
}

@keyframes loading{
	0%{opacity: 1.0;}
	10%{opacity: 0.5;}
	20%{opacity: 1.0;}
	100%{opacity: 1.0;}

/*
	0%{height: 2vw;}
	10%{height: 2.25vw;}
	20%{height: 2vw;}
	100%{height: 2vw;}
*/
}

@keyframes obj72{
	0%{transform: rotate(0);}
	50%{transform: rotate(3deg);}
	100%{transform: rotate(0);}
}

.loading.off{
	opacity:0;
	pointer-events: none;
	transition: 0.7s;
}

.content{
	width:100vw;
	overflow-x:hidden;
}

body{
	background:#F7EFE8;
	color: #312928;
	font-family: 'YakuHanJP', 'Zen Kaku Gothic Antique', sans-serif;
	letter-spacing: 0.1em;
	font-size: 3.2vw;
	line-height: 2.0;
	transition: 0.5s;
	width: 100vw;
	overflow-x: hidden;
}

a{
	opacity:1.0;
	transition:0.2s;
	color:  #383533
}
a:hover{
	opacity:.7;
	transition:0.2s;
}

a.btn1.bg2:before{
	background: #F8F2EF;
}

a.btn1{
	background: #383533;
	height: 17.066666vw;
	display:inline-block;
	border-radius: 1.0666666vw;
	padding: 1.94444444vw 14.133333vw;
	position: relative;
	font-size: 4.266666vw;
	color: #383533;
	box-shadow: 0.4vw 0.4vw 0 #f1ebe7;
}

a.btn1:before{
	content: "";
	position: absolute;
	left: 1.3333vw;
	top:0.5333333vw;
	background: #fefaf7;
	height: 16vw;
	width: calc(100% - 2.7vw);
}

a.btn1:after{
    content: "";
    background: url(../img/common/arrowBtn.png) no-repeat;
    background-size: contain;
    background-position: 80% 20%;
    width: 5.33333vw;
    height: 5.33333vw;
    position: absolute;
    right: 7%;
    top: 35%;
}

a.btn1 span{
	position: relative;
	font-weight: 600;
	display:block;
}

a.btn1{
	background: #383533;
    height: 14.066666vw;
    width: 100%;
    display: flex;
    border-radius: 1.0666666vw;
    padding: 1.94444444vw 14.133333vw;
    position: relative;
    font-size: 4vw;
    color: #383533;
    box-shadow: 0.4vw 0.4vw 0 #f1ebe7;
    align-items: center;
    justify-content: center;
	margin-top: 6.4vw;
}

a.btn1:before{
	content: "";
	position: absolute;
	left: 1.3333vw;
	top:0.5333333vw;
	background: #fefaf7;
	height: 13vw;
	width: calc(100% - 2.7vw);
	border-radius: 1.0666666vw;
}

a.btn1:after{
    content: "";
    background: url(../img/common/arrowBtn.png) no-repeat;
    background-size: contain;
    background-position: 80% 20%;
    width: 5.33333vw;
    height: 5.33333vw;
    position: absolute;
    right: 7%;
    top: 35%;
}

a.btn1 span{
	position: relative;
	font-weight: 600;
	display:block;
	font-size: 4vw;
	margin-top: -0.25vw;
}

a.btn2{
	background: #383533;
    height: 14.066666vw;
    display: flex;
    align-items: center;
    border-radius: 1.0666666vw;
    padding: 1.94444444vw 14.133333vw;
    position: relative;
    font-size: 4vw;
    color: #383533;
    box-shadow: 0.4vw 0.4vw 0 #f1ebe7;
    width: 100%;
    justify-content: center;
}

a.btn2:before{
	content: "";
	position: absolute;
	left: 1.3333vw;
	top:0.5333333vw;
	background: #F7EFE8;
	height: 13vw;
	width: calc(100% - 2.7vw);
}

a.btn2:after{
    content: "";
    background: url(../img/common/arrowBtn.png) no-repeat;
    background-size: contain;
    background-position: 80% 20%;
    width: 5.33333vw;
    height: 5.33333vw;
    position: absolute;
    right: 7%;
    top: 34%;
}

a.btn2 span{
	position: relative;
	font-weight: 600;
	display:block;
}

footer{
	background: #3d3837;
	color: #fefaf7;
	padding-top: 12vw;
	width: 100vw;
	overflow-x: hidden;
}

footer .footerInner{
	justify-content: center;
	padding-bottom: 3.33333vw;
	display:flex;
	flex-direction: row-reverse;
	gap:7.46666vw;
}

footer .footerInner .right{
	margin-left: 7.5vw;
}

footer .left{
	width: 80vw;
	margin: 0 auto;
	background: #fff;
	border-radius: 2.13333vw;
	text-align:center;
	padding: 4.26666vw;
	margin-bottom: 10.666vw;
	margin-top: 5.3333vw;
}

footer .left img{
	width: 43.466666vw;
	
}

footer .center{
	letter-spacing: 0.15em;

}

footer .center a{
	color: #fefaf7;
}

footer .center h3{
	font-size: 3.2vw;
	font-weight: 600;

}

footer .center h3:first-child{
	margin-right: 3.8888vw;
}

footer .center h3:nth-child(3){
	margin-top: 4.26666vw;
}

footer .center ul{
	margin-right: 0.5vw;
	line-height: 1.5;
	font-size: 2.966666vw;
}

footer .center ul a{
	color: #fefaf7;
}

footer .center li{
	position: relative;
	padding: 1.2vw 3.2vw;
}

footer .center li:before{
	content: "";
    position: absolute;
    left: 0;
    top: 3.5vw;
    width: 2.1333vw;
    height: 1px;
    background: #fefaf7;
}

footer .right img{
	width: 22.466666vw;
	margin-bottom: 2.22222vw;
}

footer .right a.en{
	display:block;
	color: #fefaf7;
	border: 1px solid #fefaf7;
	text-align: center;
	font-size: 2.4vw;
	margin-top:4.8vw;
	font-weight: 500;
}

footer .copy{
	background: #4a4442;
	color: #a19d9a;
	text-align: center;
	padding: 4.26666vw 0;
	font-size: 2.4vw;
}

.btnFixed{
	position: fixed;
	bottom: -2vw;
    right: -2.5vw;
	z-index:10;
	opacity:0;
	transition:0.7s;}

.btnFixed.on{
	opacity:1.0;
	transition:0.7s;
}

.btnFixed img{
	width: 42vw;
}

.spnone{
	display:none;
}