@charset "utf-8";
/* レイアウトのためのCSS */
body {
  background: #fff;
  font-family: "Cormorant Garamond", "Noto Serif JP", sans-serif;
  color: #3e3a39;
  font-size: clamp(0.875rem, 0.85rem + 0.13vw, 1rem);
  line-height: 1.85;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  word-wrap: break-word;
}
.wf-hannari { font-family: "Hannari", "Noto Serif JP", sans-serif; }
.cormorant{font-family: "Cormorant Garamond";text-transform:none;}


* {
  box-sizing: border-box;
}
html {
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  scroll-behavior: smooth;
}
ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
a {
  color: #eee;
  text-decoration: none;
  outline: none;
}
img {
  max-width: 100%;
  height: auto;
}
@media (min-width: 769px) {
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
  }
}
@media screen and (min-width: 561px) {
  .br-pc {
    display: block;
  }
  .br-sp {
    display: none;
  }
  .pc-only {
    display: block;
  }
  .sp-only {
    display: none;
  }
}
@media screen and (max-width: 560px) {
  .br-pc {
    display: none;
  }
  .br-sp {
    display: block;
  }
  .pc-only {
    display: none;
  }
  .sp-only {
    display: block;
  }
}
.center {
  text-align: center;
}
.left {
  text-align: left;
}
.right {
  text-align: right;
}
.align-item {
  align-items: center;
}

.small{font-size: 80%;}

.indent {
  text-indent: -1em;
  padding-left: 1em;
}

.mt0 {
  margin-top: 0;
}
.mt5 {
  margin-top: 0.5rem;
}
.mt10 {
  margin-top: 10px;
}
.mt20 {
  margin-top: 20px;
}
.mt30 {
  margin-top: 30px;
}
.mt40 {
  margin-top: 40px;
}
.mt60 {
  margin-top: 60px;
}
.mt100 {
  margin-top: 100px;
}
.mb0 {
  margin-bottom: 0;
}
.mb10 {
  margin-bottom: 10px;
}
.mb20 {
  margin-bottom: 20px;
}
.mb30 {
  margin-bottom: 30px;
}
.mb40 {
  margin-bottom: 40px;
}
.mb60 {
  margin-bottom: 60px;
}
.mb100 {
  margin-bottom: 100px;
}
.mx-auto {
  margin-left: auto;
  margin-right: auto;
}
/*可変マージン（レスポンシブ）
   -------------------------------------------- */
.mt20-40 {
  margin-top: clamp(2rem, 5.5vw, 4rem);
}
.mt30-50 {
  margin-top: clamp(3rem, 7.5vw, 5rem);
}
.mt50-100 {
  margin-top: clamp(5rem, 14vw, 10rem);
}
.mb20-40 {
  margin-bottom: clamp(2rem, 5.5vw, 4rem);
}
.mb30-50 {
  margin-bottom: clamp(3rem, 7.5vw, 5rem);
}
.mb40-80 {
  margin-bottom: clamp(4rem, 9.5vw, 8rem);
}
.mb50-100 {
  margin-bottom: clamp(5rem, 14vw, 10rem);
}
.mb60-200 {
  margin-bottom: clamp(6rem, 22vw, 20rem);
}
.pt10 {
  padding-top: 1rem;
}
.pt15 {
  padding-top: 1.5rem;
}
.pt20 {
  padding-top: 2rem;
}
.pt25 {
  padding-top: 2.5rem;
}
.pt30 {
  padding-top: 3rem;
}
.pt40 {
  padding-top: 4rem;
}
.pt50 {
  padding-top: 5rem;
}
.pt60 {
  padding-top: 6rem;
}
.pt80 {
  padding-top: 8rem;
}
.pt100 {
  padding-top: 10rem;
}
.pt40-80 {
  padding-top: clamp(4rem, 9vw, 8rem);
}
.pb40-80 {
  padding-bottom: clamp(4rem, 9vw, 8rem);
}
.padding20 {
  padding: 20px;
}
/* コンテナ幅設定
   -------------------------------------------- */
[class^="width-box-"] {
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
}
/* 各幅設定 - 100px単位で拡張 */
.width-box-280 {
  max-width: 280px;
}
.width-box-300 {
  max-width: 300px;
}
.width-box-400 {
  max-width: 400px;
}
.width-box-500 {
  max-width: 500px;
}
.width-box-560 {
  max-width: 560px;
}
.width-box-600 {
  max-width: 600px;
}
.width-box-640 {
  max-width: 640px;
}
.width-box-700 {
  max-width: 700px;
}
.width-box-800 {
  max-width: 800px;
}
.width-box-900 {
  max-width: 900px;
}
.width-box-1000 {
  max-width: 1000px;
}
.width-box-1100 {
  max-width: 1100px;
}
.width-box-1200 {
  max-width: 1200px;
}
.width-box-1300 {
  max-width: 1300px;
}
.width-box-1400 {
  max-width: 1400px;
}

:target::before {
  content: ""; /* 空のコンテンツを挿入 */
  display: block;
  height: 130px; /* 固定ヘッダーの高さ分 */
  margin-top: -130px; /* 高さ分を相殺 */
}

a.anchor{
    display: block;
    padding-top: 130px;
    margin-top: -130px;
}


#container {
  overflow-x: hidden;
  /*以下、IE11用*/
  z-index: 1;
  position: relative;
}

.position-r{
	position: relative;
}

h1, h2, #service .service-area section h3, #g-nav, #footer-link, .scrolldown1 span, #vidual-area dt, .footer-logo {
  letter-spacing: 0.1em;
}
/* heading */
h2 {
  font-size: 2rem;
  margin: 0 0 50px 0;
  text-transform: uppercase;
}


#header h1 img{
	width: 180px;
	padding: 2%;
}

.header-inner {
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 30px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  text-align: center;
}

.text-white{
	color: #fff;
}

/* main */
#main-area {
  padding-top: 6%;
}

#top{
    position: relative;
    background: url("../images/main_bg01.jpg") no-repeat;
    -webkit-background-size: cover;
    background-size: cover;
    padding: 50px 0;
    height: 519px;
    background-position: 80% 50%;
}

.catch-copy{
	position: absolute;
	left: 25%;
	top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
	color: #242424;
	font-size: clamp(1.5rem, 1.3rem + 1vw, 2.5rem);
	text-align: center;
	line-height: 1.6;
}



.parallax-img{
    position: relative;
    background: url("../images/parallax01.jpg") no-repeat;
    -webkit-background-size: cover;
    background-size: cover;
    padding: 50px 0;
    height: 590px;
    background-position: 50% 50%;
}

@media screen and (max-width:1300px) {

.parallax-img{
    position: relative;
    background: url("../images/parallax01_sp.jpg") no-repeat;
    -webkit-background-size: cover;
    background-size: cover;
    padding: 50px 0;
    height: 590px;
    background-position: 50% 50%;
}

}

@media screen and (max-width:600px) {

.parallax-img{
    position: relative;
    background: url("../images/parallax01_sp3.jpg") no-repeat;
    -webkit-background-size: cover;
    background-size: cover;
    padding: 50px 0;
    height: 590px;
    background-position: 50% 50%;
}

}

@media screen and (max-width:400px) {

.parallax-img{
    position: relative;
    background: url("../images/parallax01_sp2.jpg") no-repeat;
    -webkit-background-size: cover;
    background-size: cover;
    padding: 50px 0;
    height: 590px;
    background-position: 50% 50%;
}

}

.menu-space{
	background-color: rgba(212,203,173,1.0);
	height: clamp(8.125rem, 4.375rem + 16.67vw, 24.375rem);
	position: relative;
}

.img-position{
	position: absolute;
    top: 20%;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
	width: 100%;
	z-index: 998;
}

.flex-img{	
	display: flex;
	justify-content: space-between;
}

#menu{
    position: relative;
    background: url("../images/menu-bg.png") no-repeat;
    -webkit-background-size: contain;
    background-size: contain;
    padding: 50px 0;
    background-position: 80% 0;
}

.menu-top{
	padding-top: clamp(5rem, 3.846rem + 5.13vw, 10rem);
}

.menu-img{
	position: relative;
}

.menu-img img{
	box-shadow: 10px 10px 4px rgba(62, 58, 57, .5);
}

.menu-img-deco01 {
    position: absolute;
    top: 5%;
    left: -16%;
    font-size: 14px;
    line-height: 1.0;
}

.menu-img-deco02 {
    position: absolute;
    bottom: 10%;
    right: -16%;
    font-size: 14px;
    line-height: 1.0;
}

.menu-img-sp{
	display: none;
}

.area-ttl{
	margin: 30px auto;
	font-size: clamp(1.563rem, 1.202rem + 1.6vw, 3.125rem);
	text-transform:none;
	text-align: center;
	font-weight:lighter;
}

.area-sub{
	text-align: center;
	font-size: clamp(1.25rem, 1.106rem + 0.64vw, 1.875rem);
	font-weight:normal;
}

.menu{
	width: 100%;
    border-collapse: collapse;
    margin: 0 auto 10rem;
    padding: 40px 10px;
	font-family:  "Noto Serif JP", sans-serif;
}
.menu-hr{ 
	border-top: solid 1px #877329;
    vertical-align: top;
}

.menu-hr-b{ 
	border-bottom: solid 1px #877329;
    }

.menu th{
    padding:1.4rem 30px;
	position: relative;
	font-size: clamp(1rem, 0.971rem + 0.13vw, 1.125rem);
	text-align: left;
	font-weight: normal;
}

.menu .icon:before {
    position: absolute;
  top: 39px;
    left: 5px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    content: "";
  display: block;
  width: 20px;
  height: 19px;
  background: url("../images/icon_clover.svg") no-repeat center;
  background-size: 20px 19px;
}


.menu td{
    text-align: right;
    padding:1.4rem 0.4rem;
	font-size: clamp(1.125rem, 1.082rem + 0.19vw, 1.313rem);
	line-height: 1.4;
}
.menu td:after{
    display: inline-block;
    content: "";
    width: 1em;
    font-size: clamp(1.125rem, 1.082rem + 0.19vw, 1.313rem);
}
.menu td.from:after {
    content: "〜";
}
.notes{
    font-size: clamp(0.75rem, 0.721rem + 0.13vw, 0.875rem);
	font-weight: normal;
    }

.menu-deco-r{
	position: absolute;
    top: 50%;
    right: 0%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
	z-index: -1;
}

.menu-deco-r img{
	/*width: clamp(11.25rem, 6.779rem + 19.87vw, 30.625rem);*/
	width: clamp(200px, 20vw, 490px);
}

.menu-deco-l{
	position: absolute;
    top: 75%;
    left: 0%;
    transform: translateY(-75%);
    -webkit-transform: translateY(-75%);
    -ms-transform: translateY(-75%);
}

.menu-deco-l img{
	/*width: clamp(10rem, 5.572rem + 19.68vw, 29.188rem);*/
	width: clamp(160px, 16vw, 470px);
}

#reserve{
	background-color: rgba(212,203,173,0.7);
	padding-top: 100px; 
	padding-bottom: 100px; 
}

.area-ttl02{
	margin: 40px auto 0;
	font-size: clamp(1.563rem, 1.202rem + 1.6vw, 3.125rem);
	text-transform:none;
	text-align: center;
	font-weight:lighter;
}



.reserve-list li{
	position: relative;
	text-align: left;
	padding-left: 30px;
}

.reserve-list li:before {
    position: absolute;
  top: 13px;
    left: 5px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    content: "";
  display: block;
  width: 20px;
  height: 19px;
  background: url("../images/icon_clover.svg") no-repeat center;
  background-size: 20px 19px;
}

.reserve-right-w460{
	max-width: 460px;
	margin: 0 auto;
}

.reserve-line-ttl{
	text-align: center;
	font-size: 16px;
	align-items: center;
	position: relative;
	margin-bottom: 10px;
}

.reserve-line-ttl::before {
    position: absolute;
    top: 15px;
    left: 23px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    content: "";
  display: block;
  width: 23px;
  height: 37px;
  background: url("../images/reserve_b.svg") no-repeat center;
  background-size: 23px 37px;
}

.reserve-line-ttl::after {
    position: absolute;
    top: 15px;
    right: 23px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    content: "";
  display: block;
  width: 23px;
  height: 37px;
  background: url("../images/reserve_a.svg") no-repeat center;
  background-size: 23px 37px;
}

.flex-outer {
  display: flex;
  flex-direction: row;
  gap: 20px;
  align-items: center;	
}
.flex-item {
  flex: 1;
  padding: 0 10px;
  text-align: center;
}


.flex-bt {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 20px;
  background-color: #fff;
  border: 1px #877329 solid;
  margin: 0 auto 15px;
  height: 85px;	
  }

.flex-bt2 {
    display: flex;
    justify-content: space-around;
    align-items: center;
    padding: 10px 20px 10px 40px;
    background-color: #fff;
    border: 1px #877329 solid;
    margin: 0 auto 20px;
}

.reserve-bt-ttl{
	text-align: center;
	font-size: 21px;
	color:#242424;
	line-height: 1.2;
	margin-bottom: 10px;
	font-family: "Noto Serif JP", sans-serif; 
}

.reserve-bt-ttl-sub{
	font-size: 14px;
	text-align: center;
	color:#242424;
	line-height: 1.2;
	font-family: "Noto Serif JP", sans-serif;
}

.bt-left{
	display: block;
	text-align: center;
	flex-basis: 80%;
}

.bt-right{
	flex-basis: 20%;
}


.line-qr img{
	max-width: 60px;
	vertical-align: middle;
}

.web-link img{
	max-width:32px;
	vertical-align: middle;
}

#instagram{
	background-color: #fff;
	margin: 150px auto;
}

.insta-sub{
	font-size: 18px;
	text-align: center;
}

.insta-sub a{
	color:#3e3a39;
}

.links-sub{
	font-size: 24px;
	text-align: center;
	margin: 60px auto 20px;
}

.sora-box{
	max-width: 570px;
	margin: 0 auto 100px;
}

.align-items-end{align-items: flex-end;}

.sora-line-ttl{
	text-align: center;
	font-size: 16px;
	align-items: center;
	position: relative;
	}

.sora-line-ttl::before {
    position: absolute;
    top: 15px;
    left: 0px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    content: "";
  display: block;
  width: 16px;
  height: 25px;
  background: url("../images/sora_b.svg") no-repeat center;
  background-size: 16px 25px;
}

.sora-line-ttl::after {
    position: absolute;
    top: 15px;
    right: 0px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    content: "";
  display: block;
  width: 16px;
  height: 25px;
  background: url("../images/sora_a.svg") no-repeat center;
  background-size: 16px 25px;
}

/* footer */
#footer {
  padding: 40px 0;
  background-color: #3e3a39;
}

.foot-logo{
	max-width: 180px;
	margin: 40px auto;
	text-align: center;
}

.foot-tbl{
	width: 100%;
    border-collapse: collapse;
    margin: 50px auto;
    font-family:  "Noto Serif JP", sans-serif;
}

.foot-tbl th {
    width: 30%;
    position: relative;
    font-size: 15px;
    text-align: left;
    font-weight: normal;
    color: #fff;
    padding: 5px 5px 5px 30px;
	vertical-align: top;
}
.foot-tbl .icon:before {
    position: absolute;
    top: 20px;
    left: 0px;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    content: "";
    display: block;
    width: 20px;
    height: 19px;
    background: url(../images/icon_clover_w.svg) no-repeat center;
    background-size: 20px 19px;
}


.foot-tbl td {
    text-align: left;
    font-size: 16px;
    line-height: 1.4;
    color: #fff;
	padding: 5px;
}

.copyright {
  color: #fff;
  text-align: center;
  font-size: 12px;
}

.emp-txt {
	display: inline;
	border-bottom: 4px double #fff;
	line-height: 1.75em;
}

@media screen and (max-width:1500px) {
.menu-deco-l{
	top: 84%;
    }
}
@media screen and (max-width:1300px) {
	
	.flex-img{
		display: none;
	}	
	
	.menu-img-sp{
	display: block;
}
}

@media screen and (max-width:1024px) {

.menu-deco-r{
	display: none;
}

.menu-deco-l{
	display: none;
}
	
}

@media screen and (max-width:980px) {

.catch-copy {
        position: absolute;
        top: 60%;
        left: 50%;
        transform: translate(-50%, -50%);
        -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        width: 100%;
    }
	

	
.flex-outer {
  display: block;
  }	
	
.reserve-line-ttl::before {
        left: 0;
    }

.reserve-line-ttl::after {
       right: 0;
   }	
	
.sora-box{
	max-width: 260px;
}
	

}
	

/* スマホ用（最大幅560px） */
@media (max-width: 600px) {
  
.header-inner {
  padding: 0 10px;
  display: block;
  }
	
:target::before {
  content: ""; /* 空のコンテンツを挿入 */
  display: block;
  height: 400px; /* 固定ヘッダーの高さ分 */
  margin-top: -400px; /* 高さ分を相殺 */
}
	
	a.anchor{
    display: block;
    padding-top: 400px;
    margin-top: -400px;
}
	
html {
  scroll-padding-top: 200px; 
}	
	
/*.area-ttl {
    margin: 60px auto 30px;
	}*/

#reserve {
    padding-top: 40px;
    }
	
.area-ttl02 {
    margin: 20px auto 0;
    font-size: clamp(1.563rem, 1.202rem + 1.6vw, 3.125rem);
    text-transform: none;
    text-align: center;
    font-weight: lighter;
    padding-top: 20px;
}	
	
.menu{
	margin: 0 auto 5rem;
    }	
	
.menu th,.menu td{
		width: 100%;
        display: block;
	}
	.menu td {padding: 0.4rem;}
	

  .container {
    flex-direction: column-reverse;
  }
 
  .flex-outer {
    flex-direction: column; /* 縦並び */
	gap: 0;  
  }
	
.reserve-line-ttl::before {
        top: 35px;
    }

.reserve-line-ttl::after {
        top: 35px;
   }
	
.flex-bt {
    justify-content: space-around;
	height: 125px;
    }	
	
.reserve-bt-ttl-sub {
    font-size: 12px;
	}
  
}