@charset "UTF-8";

::selection {
	background: #f5e5da;
	color: #2b2522;
}


.loading{
	width:100vw;
	height:100vh;
	position: fixed;
	left:0;
	top:0;
	z-index:1500;
	background:#f7efe8;
	display: flex;
	justify-content: center;
	align-items: center;
	color: #3C3130;
}

.loading > div{
	opacity:0;
}

.loading > div.on{
	opacity: 1.0;
	transition: 0.3s;
	transition-delay: 0.5s;
}

.loading figure{
	display: block;
}

.loading figure img{
	width: 8vw;
	animation: 2.5s obj72 infinite;
	display: block;
}

.loading.off figure img{
	animation: loadingEnd 1.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.25vw;
}
.loading p span{display:block; height: 2vw;}
.loading p span img{margin-bottom: 0.5vw;}
.loading p span:nth-child(7) img{margin-bottom: 0.3vw;}
.loading p img{vertical-align: bottom; margin-right: 0.3vw;}

.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:0.9722222vw; margin-right: 0.25vw;}
.loading p span:nth-child(2) img{height:0.6944444vw; margin-right: 0.25vw;}
.loading p span:nth-child(3) img{height:0.6944444vw; margin-right: 0.25vw;}
.loading p span:nth-child(4) img{height:0.9722222vw; margin-right: 0.22vw;}
.loading p span:nth-child(5) img{height:0.9722222vw; margin-right: 0.3vw;}
.loading p span:nth-child(6) img{height:0.6944444vw; margin-right: 0.25vw;}
.loading p span:nth-child(7) img{height:0.9027777vw; margin-right: 0.24vw;}
.loading p span:nth-child(8) img{height:0.2777777vw;}

body{
    opacity:0;
    transition: 1.0s;
}

body.on{
    opacity:1.0;
    transition: 1.0s;
}

.menuBtn.view{
	opacity:1.0;
	transition: 0.4s;
}

.menuBtn.view.off{
	opacity:0;
	transition:0.4s;
}

.menuBtn{
    position: fixed;
    right: 0;
    top: 50%;
    margin-top: -1.3888888vw;
    background: #3d3837;
    height: 2.8888888vw;
    border-radius: 0.555555vw 0 0 0.555555vw;
    width: 7.2222222vw;
	display: flex;
    align-items: center;
	padding-left: 3.1944444vw;
	z-index: 1200;
	transition: 0.4s;
	opacity: 0;
/*    border: 1px solid #F7EFE8;*/
}

.menuBtn:hover{
	transition: 0.4s;
}


.menuBtn ul.item li:nth-child(1){position: absolute; left:1.25vw; top:1.11111vw; background: #FEFAF7; width: 1.25vw; height: 1px; z-index: 300; transition: 0.3s; opacity:1;}
.menuBtn ul.item li:nth-child(2){position: absolute; left:1.7vw; top:1.388888vw; background: #FEFAF7; width: 0.83333vw; height: 1px; z-index: 300; transition: 0.3s; opacity:1;}
.menuBtn ul.item li:nth-child(3){position: absolute; left:2.15vw; top:1.666666vw; background: #FEFAF7; width: 0.41666vw; height: 1px; z-index: 300; transition: 0.3s; opacity:1;}
.menuBtn:hover ul.item li{width:0; transition: 0.3s; opacity:0.5;}

.menuBtn.on ul.item li:nth-child(1){left:5vw; top:1.388888vw; transform: rotate(45deg); transition: 0.4s;}
.menuBtn.on ul.item li:nth-child(2){left:5vw; width:0; transition: 0.4s;}
.menuBtn.on ul.item li:nth-child(3){left:5vw; top:1.388888vw; width:1.25vw; transform: rotate(-45deg); transition: 0.4s;}

.menuBtn.on:hover ul.item li:nth-child(1){width: 1.25vw;}
.menuBtn.on:hover ul.item li:nth-child(3){width: 1.25vw;}

.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: 19.791666661vw;
	right:0;
	top: 0;
	opacity: 0;
	pointer-events: none;
	background: #3d3837;
	border-radius: 1.666666vw 0 1.666666vw 1.666666vw;
	color: #FEFAF7;
	padding: 3.33333vw;
	transform: scale(0.9);
	transition: 0.5s;
}

.menuInner.on{
	opacity:1.0;
	transition: 0.5s;
	transform: scale(1.0);
	pointer-events: auto;
}

.menuInner p{
	font-size: 1.1111vw;
	font-weight: 600;
}

.menuInner ul{
	margin-left: 0.83333vw;
}

.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{
	opacity:1.0;
    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: 0.97222222vw;
	line-height: 2.0;
	width: 100vw;
	transition: 0.5s;
	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: 4.722222vw;*/
    display: flex;
    border-radius: 0.2777777vw;
    position: relative;
    font-size: 1.111111vw;
    color: #383533;
    box-shadow: 0.4vw 0.4vw 0 #f1ebe7;
    align-items: center;
    width: fit-content;
    padding: 1vw 5vw;
}

a.btn1:before{
	content: "";
	position: absolute;
	left: 0.4166666vw;
	top:0.1388888vw;
	background: #fefaf7;
	height: 3.733333vw;
	width: calc(100% - 0.833333vw);
}

a.btn1:after{
	content:"";
	background: url("../img/common/arrowBtn.png") no-repeat;
	background-size: cover;
	background-position: 80% 20%;
	width: 1.5972222vw;
	height: 1.5972222vw;
	position: absolute;
	right:7%;
	top:31%;
}

a.btn1 span{
	position: relative;
	font-weight: 600;
	display:block;
    font-size: 1.041vw
}

a.btn2{
	background: #383533;
/*	height: 4.722222vw;*/
	display:inline-block;
	border-radius: 0.2777777vw;
	padding: 0.97vw 5.97222222vw;
	position: relative;
    font-size: 1.041vw;
	color: #383533;
}

a.btn2:before{
	content: "";
	position: absolute;
	left: 0.4166666vw;
	top:0.1388888vw;
	background: #F7EFE8;
	height: 3.69333vw;
	width: calc(100% - 0.833333vw);
}

a.btn2:after{
	content:"";
	background: url("../img/common/arrowBtn.png") no-repeat;
	background-size: cover;
	background-position: 80% 20%;
	width: 1.5972222vw;
	height: 1.5972222vw;
	position: absolute;
	right:7%;
	top:35%;
}

a.btn2 span{
	position: relative;
	font-weight: 600;
/*	margin-top: -0.65vw;*/
	display:block;
}

footer{
	background: #3d3837;
	color: #fefaf7;
	padding-top:3.88888vw;
	position: relative;
	z-index: 1001;
}

footer .footerInner{
	display: flex;
	justify-content: center;
	padding-bottom: 3.888888vw;}

footer .left{
	margin-right: 3.9vw;
	
}

footer .center{
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
	letter-spacing: 0.15em;
	margin-top: 0.3vw;
}


footer .center h3{
	font-size: 1.25vw;
	font-weight: 600;
}

footer .center h3:first-child{
	margin-right: 3.8888vw;
}

footer .center h3:nth-child(3){
	margin-right: 1.3333vw;
}

footer .center ul{
	margin-right: 0.5vw;
	line-height: 2.0;
}

footer .center li{
	position: relative;
	padding-top: 1.0416666666vw;
}

footer .center li a{
	color: #fefaf7;
}

footer .center li:before{
	content: "";
	position: absolute;
	left:0.96vw;
	top:0;
	width: 1px;
	height: 0.4861111vw;
	background: #fefaf7;
}

footer .right{
	margin-top: 0.15vw;
	margin-right: 1.11111vw;
}

footer .right img{
	width: 7.8472222vw;
	margin-bottom: 2.22222vw;
}

footer .right a.en{
	display:block;
	color: #fefaf7;
	border: 1px solid #fefaf7;
	text-align: center;
	font-size: 0.76388888vw;
    border-radius: 0.13333vw;
    padding-bottom: 0.2vw;
}

footer .copy{
	background: #4a4442;
	color: #a19d9a;
	text-align: center;
	padding: 0.5555vw 0;
	font-size: 0.76388888vw;
}


.btnFixed{
	position: fixed;
	bottom: 0;
	right:0;
	z-index:10;
	opacity:0;
	transition:0.4s;
	transform: scale(1.0);
	cursor: pointer;
}

.btnFixed:hover{
	transform: scale(0.9);
	transition: 0.3s;
}

.btnFixed a:hover{
	opacity: 1.0;
}

.btnFixed.on{
	opacity:1.0;
	transition:0.4s;
}

.btnFixed img{
	width: 17.083333vw;
}
.btnFixed.off{
	opacity:0;
	transition:0.4s;
}

.pcnone{
	display:none;
}

