@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Zen+Old+Mincho&display=swap');

:root{--spacing:0.05em;}
*{letter-spacing:var(--spacing);}
html, body, div, span, object, iframe,h1, h2, h3, h4, h5, h6, p, blockquote, pre,abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,small, strong, sub, sup, var,b, i,dl, dt, dd, ol, ul, li,fieldset, form, label, legend,table, caption, tbody, tfoot, thead, tr, th, td,article, aside, canvas, details, figcaption, figure,footer, header, hgroup, menu, nav, section, summary,time, mark, audio, video{
	margin:0;padding:0;border:0;outline:0;vertical-align:baseline;background:transparent;box-sizing:border-box;}
html{font-size:62.5%;}
body{
	font-family:"Zen Old Mincho","游明朝", YuMincho, "Noto Serif","Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-size:1.6rem;
	color:#2b2c2e;
	background:#f7f7f7;
	line-height:2;
	-webkit-text-size-adjust:100%; 
	max-width:100%;
	min-width:320px;
	text-align:left;
}
h1, h2, h3, h4, h5, h6{font-size:inherit;font-weight:inherit;}
article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block;}
ul{list-style:none;}
blockquote, q{quotes:none;}
blockquote:before, blockquote:after,q:before, q:after{content:'';content:none;}
li{list-style-type:none;}
ins{text-decoration:none;}
mark{font-style:italic;font-weight:bold;}
del{text-decoration:line-through;}
abbr[title], dfn[title]{border-bottom:1px dotted;cursor:help;}
table{border-collapse:collapse;border-spacing:0;}
hr{display:block;height:1px;margin:1em 0;padding:0;border:0;border-top:1px solid #cccccc;}
input, select{vertical-align:middle;margin:0;box-sizing:border-box;}
input,textarea{-webkit-appearance:none;font-family:inherit;box-sizing:border-box;}
input:focus,textarea:focus,select:focus{outline:0;}
button{font-family:inherit;background-color:transparent;border:none;cursor:pointer;outline:none;padding:0;appearance:none;box-sizing:border-box;}
button::-moz-focus-inner{border:0;}
input:placeholder-shown{color:#ccc;}
input::-webkit-input-placeholder{color:#ccc;}
input:-moz-placeholder{color:#ccc;opacity:1;}
input::-moz-placeholder{color:#ccc;opacity:1;}
input:-ms-input-placeholder{color:#ccc;}
pre{white-space:pre-wrap;font-family:inherit;}
img{border:none;vertical-align:bottom;max-width:100%;height:auto;}
small{font-size:75%;}
a{color:#2b2c2e;margin:0;padding:0;font-size:100%;vertical-align:baseline;background:transparent;text-decoration:none;box-sizing:border-box;outline:none;transition:.3s ease;}
a[href^="tel:"]{cursor:text;}
a:hover{color:#2b2c2e;}
*:focus-visible,
select:focus-visible{outline:2px solid #323232;transition:outline 0s!important;}
.clearfix:after{content:"";clear:both;display:block;}
p + p{margin-top:15px;}
#wrapper{padding-top:140px;background:#f7f7f7;}

@media screen and (max-width:999px){
	#wrapper{padding-top:70px;}
}
@media screen and (min-width:1px) and (max-width:622px){
	body{font-size:1.6rem;}
}

/* -------------------------------------------------- */
/* header */
/* -------------------------------------------------- */
header{width:100%;height:140px;display:flex;align-items:center;justify-content:space-between;padding:0 40px;position:fixed;top:0;left:0;z-index:1000;background:#f7f7f7;gap:20px;transition:height .25s ease;backdrop-filter:blur(10px);background:rgba(247,247,247,0.92);}
header .gnav-list{display:flex;gap:40px;}
header .gnav-list a:hover{opacity:0.7;}
header.fixed{height:80px;}
header #header-btn{display:none;}

@media screen and (max-width:999px){
	header{padding:0 0 0 18px;}
	header{height:70px!important;}
	header .logo{width:230px;margin-bottom:4px;}
	header #gnav{display:none;max-width:400px;position:fixed;top:70px;right:0;background:rgba(43,44,46,0.95);width:100%;height:calc(100vh - 70px);color:#fff;overflow-y:auto;padding-bottom:60px;;}
	header .gnav-list{display:block;text-align:center;padding:40px 5% 0;font-size:1.8rem;}
	header .gnav-list a{color:#fff;display:inline-block;padding:20px;}
	header .gnav-list > li + li{border-top:1px solid rgba(255,255,255,0.2);}
	header #header-btn{width:70px;height:70px;position:fixed;top:0;right:0;z-index:104;cursor:pointer;display:block;}
	header #header-btn span{display:inline-block;transition:all .2s;box-sizing:border-box;width:30px;position:absolute;top:50%;right:19px;height:1px;background-color:#2b2c2e;}
	header #header-btn span:nth-of-type(1){transform:translateY(-6px);}
	header #header-btn span:nth-of-type(3){transform:translateY(6px);}
	header #header-btn.active span:nth-of-type(2){opacity:0;}
	header #header-btn.active span:nth-of-type(1){transform:rotate(30deg);}
	header #header-btn.active span:nth-of-type(3){transform:rotate(-30deg);}
}
@media screen and (max-width:622px){
	header #gnav{max-width:100%;}
}

/* -------------------------------------------------- */
/* footer */
/* -------------------------------------------------- */
footer{font-size:1.2rem;background:#fff;}
footer .footer-inner{border-top:1px solid #2b2c2e;padding:75px 0;}
footer .footer-bottom{display:flex;align-items:flex-end;justify-content:space-between;gap:40px;margin-top:35px;}
footer .link{display:flex;flex-wrap:wrap;}
footer .link > li + li{margin-left:15px;padding-left:15px;position:relative;}
footer .link > li + li::before{content:"";display:block;width:1px;height:40%;background:#bbbbbc;position:absolute;left:0;top:30%;}
footer .link > li a:hover{opacity:0.7;}
footer .copyright{color:#626367;}

@media screen and (max-width:999px){
	footer{text-align:center;}
	footer .logo{max-width:75%;margin:auto;}
	footer .footer-inner{padding:50px 0;}
	footer .footer-bottom{display:block;margin-top:25px;}
	footer .link{justify-content:center;margin-bottom:20px;}
}
@media screen and (max-width:622px){
	footer .link{display:block;}
	footer .link > li + li{padding-left:0;margin-left:0;}
	footer .link > li + li::before{display:none;}
	footer .link > li a{display:inline-block;padding:5px;}
}

/* -------------------------------------------------- */
/* common */
/* -------------------------------------------------- */
.v-sp{display:none!important;}
.v-pc{display:block!important;}

/* container */
.container{max-width:1400px;padding:0 40px;margin:auto;position:relative;}
section > .container,.section > .container{padding:120px 40px;}

/* ttl */
.common-ttl01{margin-bottom:50px;}
.common-ttl01 small{font-size:6rem;letter-spacing:0;display:block;line-height:1;}
.common-ttl01 span{color:#626367;display:block;margin-top:20px;}

@media screen and (min-width:1px) and (max-width:1399px){
	.container{padding:0 6%;}
	section > .container,.section > .container{padding:120px 6%;}
}
@media screen and (min-width:1px) and (max-width:999px){
	section > .container,.section > .container{padding:100px 6%;}
}
@media screen and (min-width:1px) and (max-width:622px){
	.v-pc{display:none!important;}
	.v-sp{display:block!important;}
	section > .container,.section > .container{padding:70px 6%;}
	
	.common-ttl01{margin-bottom:30px;}
	.common-ttl01 small{font-size:4rem;}
	.common-ttl01 span{margin-top:10px;}
}

/* -------------------------------------------------- */
/* animation */
/* -------------------------------------------------- */
.animation{visibility:hidden;}
.animation.animated{visibility:visible;}

@keyframes fadeInUp{0%{opacity:0;transform:translate3d(0,80px,0)}to{opacity:1;transform:translateZ(0)}}
.fadein{animation-duration:1.2s;animation-fill-mode:both;opacity:0.01;}
.fadein.animated{animation-name:fadeInUp;}

/* -------------------------------------------------- */
/* #block-mv */
/* -------------------------------------------------- */
#block-mv{padding:0 40px;margin-bottom:40px;opacity:0;}
#block-mv .video{overflow:hidden;position:relative;width:100%;height:0;padding-bottom:46.7%;}
#block-mv .video video{width:100%;height:100%;position:absolute;left:0;top:0;left:0;object-fit:cover;transform:scale(1.08);}

#block-mv.animated{opacity:1;transition:opacity .8s ease .2s;}
#block-mv.animated .video video{transform:none;transition:1s ease .2s;}

@media screen and (min-width:1600px){
	#block-mv .video{padding-bottom:0;height:700px;}
}
@media screen and (max-width:999px){
	#block-mv{padding:0 30px;}
	#block-mv .video{padding-bottom:60%;}
}
@media screen and (max-width:767px){
	#block-mv{padding:0 15px;margin-bottom:0;}
	#block-mv .video{padding-bottom:100%;}
}
@media screen and (max-width:622px){
	#block-mv .video{padding-bottom:calc(100vh - 85px);}
}

/* -------------------------------------------------- */
/* #block-about */
/* -------------------------------------------------- */
#block-about{overflow:hidden;}
#block-about .container{display:flex;flex-direction:row-reverse;align-items:center;gap:60px;}
#block-about .inner{flex:1;font-size:2rem;-ms-writing-mode:tb-rl;writing-mode:vertical-rl;}
#block-about .inner p + p{margin-top:0;margin-right:1.5em;}
#block-about .inner .ttl{font-size:4rem;line-height:1.6;margin-left:1em;}
#block-about .txt{animation-delay:.2s;}
#block-about .img{width:calc(60% + (100vw - 1320px) / 2);height:0;padding-bottom:48.5%;padding-bottom:42.7vw;position:relative;margin-left:calc((-100vw + 1320px) / 2);overflow:hidden;}
#block-about .img img{width:100%;height:100%;position:absolute;top:0;left:0;object-fit:cover;opacity:0;transform:scale(1.1);z-index:1;}
#block-about .img::before{content:"";display:block;width:100%;height:50%;background:#f7f7f7;position:absolute;top:0;left:0;z-index:2;}
#block-about .img::after{content:"";display:block;width:100%;height:50%;background:#f7f7f7;position:absolute;bottom:0;left:0;z-index:3;}
#block-about .img.animated img{transform:none;opacity:1;transition:1s ease;}
#block-about .img.animated::before{height:0;transition:1s ease;}
#block-about .img.animated::after{height:0;transition:1s ease;}

@media screen and (max-width:1399px){
	#block-about .img{width:calc(60% + 6vw);margin-left:-6vw;}
}
@media screen and (max-width:999px){
	#block-about .container{display:block;padding-bottom:0;}
	#block-about .inner{font-size:1.8rem;margin:auto;}
	#block-about .inner .ttl{font-size:3.6rem;}
	#block-about .img{width:calc(100% + 12vw);padding-bottom:70%;margin:40px -6vw 0;}
}
@media screen and (max-width:622px){
	#block-about .inner{font-size:1.5rem;}
	#block-about .inner .ttl{font-size:2.8rem;margin-left:0.8em;}
	#block-about .inner p + p{margin-right:0.8em;}
}

/* -------------------------------------------------- */
/* .block-places */
/* -------------------------------------------------- */
.block-places{overflow:hidden;}
.block-places .block{padding:120px 0;}
.block-places .container{display:flex;gap:110px;}
.block-places .inner{flex:1;display:flex;flex-direction:column;justify-content:space-between;}
.block-places .img{width:64.7%;text-align:right;position:relative;overflow:hidden;}
.block-places .img img{opacity:0;transform:scale(1.1);}
.block-places .img::before{content:"";display:block;width:50%;height:100%;background:#fff;position:absolute;top:0;left:0;z-index:2;}
.block-places .img::after{content:"";display:block;width:50%;height:100%;background:#fff;position:absolute;bottom:0;right:0;z-index:3;}
.block-places .img.animated img{transform:none;opacity:1;transition:1s ease;}
.block-places .img.animated::before{width:0;transition:1s ease;}
.block-places .img.animated::after{width:0;transition:1s ease;}

.block-places .info{display:flex;flex-direction:column;justify-content:flex-end;height:100%;opacity:0;transform:translateX(60px);}
.block-places .info .ttl{font-size:4.8rem;line-height:1.3;margin-bottom:15px;word-break:break-all;}
.block-places .info .txt01{font-size:1.2rem;color:#626367;position:relative;padding-left:25px;margin-bottom:10px;}
.block-places .info .txt01::before{content:"";display:block;width:10px;height:10px;border:1px solid #626367;border-radius:100%;position:absolute;left:0;top:0.5em;}
.block-places .info .txt02{color:#626367;}
.block-places .info .icon{display:flex;flex-wrap:wrap;gap:10px;margin-top:32px;}
.block-places .info .icon > li{font-size:1.1rem;text-align:center;width:80px;height:80px;display:flex;align-items:center;justify-content:center;flex-direction:column;position:relative;padding:8px 5px 5px;}
.block-places .info .icon > li::before{content:"";display:block;width:92%;height:92%;border-top:1px solid #2b2c2e;border-right:1px solid #2b2c2e;position:absolute;right:0;top:0;}
.block-places .info .icon > li::after{content:"";display:block;width:92%;height:92%;border-bottom:1px solid #2b2c2e;border-left:1px solid #2b2c2e;position:absolute;left:0;bottom:0;}
.block-places .info .icon > li span::before{content:"";display:block;width:40px;height:40px;background:url(../img/icon01.png) no-repeat center center;background-size:contain;margin:0 auto;}
.block-places .info .icon > li.icon02 span::before{background-image:url(../img/icon02.png);}
.block-places .info .icon > li.icon03 span::before{background-image:url(../img/icon03.png);}
.block-places .info .icon > li.icon04 span::before{background-image:url(../img/icon04.png);}
.block-places .info .btn{margin-top:30px;}
.block-places .info .btn a{display:inline-block;font-size:1.8rem;border:1px solid #2b2c2e;background:#2b2c2e;color:#fff;width:100%;max-width:350px;text-align:center;padding:15px;}
.block-places .info .btn a:hover{background:transparent;color:#2b2c2e;}
.block-places .info .btn.disabled a{pointer-events:none;opacity:0.3;font-size:2rem;}
.block-places .info.animated{transform:none!important;opacity:1;transition:1s ease;}
.block-places .place02 .ttl{letter-spacing:0;}
.block-places .block:nth-child(odd){background:#fff;}
.block-places .block:nth-child(even) .container{flex-direction:row-reverse;}
.block-places .block:nth-child(even) .img{text-align:left;}
.block-places .block:nth-child(even) .img::before,
.block-places .block:nth-child(even) .img::after{background:#f7f7f7;}
.block-places .block:nth-child(even) .info{transform:translateX(-60px);}

@media screen and (min-width:1px) and (max-width:1399px){
	.block-places .container{gap:50px;}

}
@media screen and (min-width:1px) and (max-width:1319px){
	.block-places .common-ttl01{text-align:center;}
	.block-places .container{display:block;max-width:calc(853px + 12%);}
	.block-places .inner{display:block;}
	.block-places .img{width:100%;text-align:center;margin-top:40px;}
	.block-places .info-inner{display:flex;gap:80px;}
	.block-places .info{transform:translateX(-60px);}
	.block-places .info .txt01{display:inline-block;}
	.block-places .info .txt02{text-align:left;}
	.block-places .info .ttl{white-space:nowrap;}
	.block-places .info .icon{margin-top:25px;}
	.block-places .block:nth-child(even) .img{text-align:center;}
}
@media screen and (min-width:1px) and (max-width:999px){
	.block-places .block{padding:100px 0;}
}
@media screen and (max-width:767px){
	.block-places .info-inner{display:block;}
	.block-places .info .btn a{max-width:100%;}
}
@media screen and (min-width:1px) and (max-width:622px){
	.block-places .block{padding:70px 0;}
	.block-places .info .ttl{font-size:3rem;}
	.block-places .info .txt01{margin-bottom:5px;}
	.block-places .info .txt02{font-size:1.4rem;}
	.block-places .info .icon{gap:8px;}
	.block-places .info .icon > li{width:72px;height:72px;}
	.block-places .info .icon > li span::before{width:32px;height:32px;}
	.block-places .info .btn{margin-top:20px;}
	.block-places .info .btn a{font-size:1.6rem;padding:12px;}
	.block-places .info .btn.disabled a{font-size:1.8rem;}
	.block-places .img{margin-top:30px;}
}

/* -------------------------------------------------- */
/* #block-room */
/* -------------------------------------------------- */
#block-room{position:relative;height:55.8vw;overflow:hidden;clip-path:inset(0);}
#block-room img{position:fixed;top:0;left:0;width:100%;height:100%;object-fit:cover;z-index:-1;}

@media screen and (min-width:1px) and (max-width:622px){
	#block-room{height:100vw;}
}

/* -------------------------------------------------- */
/* #block-map */
/* -------------------------------------------------- */
#block-map{background:#fff;}
#block-map .common-ttl01{text-align:center;}
#block-map #map{width:100%;height:600px;position:relative;}
#block-map #map iframe{width:100%;height:100%;position:absolute;top:0;left:0;filter:grayscale(100%);}

@media screen and (min-width:1px) and (max-width:622px){
	#block-map #map{height:100vw;}
}


/* -------------------------------------------------- */
@media screen and (min-width:1px) and (max-width:374px){
	html{font-size:52%;}
	.block-places .info .icon{gap:5px;}
	.block-places .info .icon > li{width:65px;height:65px;}
	.block-places .info .icon > li span::before{width:28px;height:28px;}

}