@charset "UTF-8";

/*cssのリセット*/
/*-------------------------------------------------------*/
article,aside,figure,figcaption,footer,header,nav,section,main{ display: block; }
small{ font-size: inherit; line-height: inherit; }
body,p,h1,h2,h3,h4,h5,h6,dl,dt,dd,div{ margin: 0; padding: 0; }
ul,li,ol{ list-style: none; margin: 0; padding: 0; }
button{ background-color: transparent; border: none; cursor: pointer; outline: none; padding: 0; appearance: none; }
a img{ border: none; }




/*reset*/
/*-------------------------------------------------------*/
body{ background-color: #ffffff; }
#container p,#container div{ color:#666666; font-family: 'YakuHanJP', Lato, "メイリオ", "游ゴシック", YuGothic, "メイリオ", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", sans-serif; font-feature-settings: "pkna"; font-weight: normal; }
a{ color: #0086c5; transition: all 0.25s linear; }
#container a:active{ opacity: 0.7; }
#container{ min-height: 0!important; width: 100%; margin: 0; padding: 0!important; }
#container p,#container div{ font-size: 14px; line-height: 1.5; }
#main-content p{ line-height: 2; }
#container .ns{ font-size: 12px; line-height: 1.5; }
.breadcrumb{ display: none; }
.default-width{ margin-left: 30px; margin-right: 30px; }
.mincho,
#container .mincho{ font-family: 'YakuHanMP', 'Lora', 'Noto Serif JP', serif; }
.sw-elm .pc,.sw-elm .tb-h,.sw-elm .tb-v,.sw-elm .sp{ display: none; }
.sw-elm .tb-v{ display: block; }
.sw-elm img.tb-v{ display: inline; }
.js-inview{ opacity: 0; transition: opacity 1s ease-in; }
.show{ opacity: 1!important; }
.js-inview2{ opacity: 0; transform: translateY(30px); transition: opacity 1s ease-in, transform 1s ease-out; }
.js-inview2.show{ opacity: 1!important; transform: translateY(0); }

/*--レスポンシブ追加プロパティ--------------------------------------*/
@media screen and (max-width: 480px){ /*480px以下のcss*/
	.default-width{ margin-left: 15px; margin-right: 15px; }
	.sw-elm .tb-v,.sw-elm img.tb-v{ display: none; }
	.sw-elm .sp{ display: block; }
	.sw-elm img.sp{ display: inline; }
}



/*ヘッダーのcss*/
/*-------------------------------------------------------*/
#header-content{ position: relative; border-bottom: 1px solid #e0e0e0; z-index: 5000; background-color: #ffffff; width: 100%; height: 60px; }
#header-content.fixed-navi{ position: fixed; top: 0; }
#header-content.fixed-navi+#main-content{ padding-top: 60px; }
#header-content .logo{ padding: 0 70px 0 10px; float: left; height: 60px; max-width: 377px;  display: -ms-flex; display: flex; align-items: center; width: 100%; box-sizing: border-box; }
/*#header-content.limited-style .logo{ padding: 0 160px 0 10px; }*/
#header-content .logo a{ line-height: 1; flex: 1; }
#header-content .logo img{ width: 100%; height: auto; }
#header-content .name{ display: none; }
#header-content .primary-navi{ display: none; }

/*--高解像度向けに画像置き換え--------------------------------------*/
@media screen and (-webkit-min-device-pixel-ratio: 1.5),screen and (min-resolution: 1.5dppx){
}



/*グローバルナビのcss*/
/*-------------------------------------------------------*/
#header-content .global-navi-menu{ width: 60px; height: 60px; background: url(../images/img_parts/global_navi/icon_menu.png) 0 0 no-repeat; background-size: 100% auto; position: absolute; right: 0; cursor: pointer; color: transparent; }
#header-content .global-navi-menu.status-open{ background-position: 0 bottom; }
#header-content .global-navi{ position: absolute; width: 50%; margin-top: 61px; right: 0; border-top: 1px solid #cccccc; margin-bottom: -1px; display: none; background-color: #ffffff; max-height: calc(100vh - 112px); max-height: calc(calc(var(--vh, 1vh) * 100) - 112px); background-color: #000; overflow-y: auto; border-left: 1px solid #cccccc; }
#header-content .global-navi .navi{ border-bottom: 1px solid #cccccc; width: 100%; float: left; background-color: #ffffff; position: relative; }
/*#header-content .global-navi .navi:nth-child(2n+1):last-child{ width: 100%; }*/
#header-content .global-navi .navi::before{ content: ''; position: absolute; left: -1px; width: 1px; height: 100%; background-color: #cccccc; }
#header-content .global-navi .navi:active,
#header-content .global-navi .navi.current{ background-image: none; }
#header-content .global-navi .navi a{ display: block; height: 40px; text-align: center; position: relative; opacity: 1; text-decoration: none; color: #606060; }
#header-content .global-navi .navi a::before{ content: '〉'; position: absolute; right: 10px; top: 50%; transform: translateY(-50%) scaleY(0.5); opacity: 0.5; }
#header-content .global-navi .navi a:active,
#header-content .global-navi .navi.current a{ color: #ba9b6c; }
#header-content .global-navi .navi.icon-new a:after{ content: 'NEW'; position: absolute; left: 0; top: 0; font-size: 10px; line-height: 1.2; background-color: #cda400; color: #ffffff; padding: 0 5px; }
#header-content .global-navi .navi .word{ position: absolute; text-align: center; width: 100%; left: 0; top: 50%; transform: translateY(-50%); line-height: 1.5; }
#header-content .global-navi .navi.lock a{ background: linear-gradient(135deg, #ccbc7e 0%,#91803d 100%); color: #ffffff; }
#header-content .global-navi .navi.lock a .word::before{ content: ''; background: url(../images/img_parts/global_navi/icon_lock.png); width: 11px; height: 20px; background-size: contain; position: absolute; top: 50%; left: 5px; transform: translateY(-50%); }
#header-content .global-navi .navi.lock a .word .sub{ display: block; width: 100%; text-align: center; font-size: 10px; font-family: 'YakuHanJP', Lato, "メイリオ", "游ゴシック", YuGothic, "メイリオ", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", sans-serif; margin-bottom: -2px; }
#header-content .global-navi .navi .en{ display: none; }
#container .global-navi .navi-limited,
#container .global-navi .navi-logout{ display: none; }
#container.status-login .global-navi .navi-entry,
#container.status-login .global-navi .navi-login{ display: none; }
#container.status-login .global-navi .navi-limited,
#container.status-login .global-navi .navi-logout{ display: block; }
/*#header-content .global-navi .navi.navi-entry a{ background-color: #ba9b6c; color: #ffffff; }
#header-content .global-navi .navi.navi-brand a{ background-color: #333333; color: #ffffff; }*/



/*メインのcss*/
/*-------------------------------------------------------*/

#main-content{ padding: 0; }
#container .content-end-space{ padding-bottom: 10.42%; }
#main-content .base-wrapper{ padding-left: 5%; padding-right: 5%; }
#main-content .hero{ position: relative; margin-bottom: 10%; }
#main-content .hero .photo img{ width: 100%; height: auto; }
#main-content .hero .caption{ position: absolute; right: 0; bottom: 0; padding: 2px 7px; background-color: rgba(0,0,0,0.8); color: #ffffff; }
#main-content .page-ttl{ color: #ffffff; font-size: 28px; line-height: 1.5; font-family: 'YakuHanMP', 'EB Garamond', 'Cormorant Garamond', 'Lora', 'Noto Serif JP', serif; font-weight: normal; padding-left: 0.2em; text-align: center; letter-spacing: 0.2em; position: relative; position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); }
#main-content .ttl01{ font-size: 24px; line-height: 1.5; font-weight: normal; text-align: center; color: #485049; }
#main-content .ttl01 .s-size{ font-size: 18px; }

/*--レスポンシブ追加プロパティ--------------------------------------*/
@media screen and (max-width: 480px){ /*480px以下のcss*/
	#main-content .page-ttl{ font-size: 24px; }
}



/*フッターのcss*/
/*-------------------------------------------------------*/
#footer-content{  }
#footer-content .footer-info .entry-body{ padding: 15% 5%; background-color: #f3f2f0; text-align: center; }
#footer-content .footer-info .entry-body .en{ font-size: 22px; line-height: 1.5; color: #4c4c4c; }
#footer-content .footer-info .entry-body .copy{ font-size: 24px; line-height: 1.2; color: #372f1d; letter-spacing: 0.5em; padding-left: 0.5em; /*margin-top: 5%;*/ }
#footer-content .footer-info .entry-body .txt{ font-size: 14px; line-height: 1.5; color: #4c4c4c; margin-top: 5%; }
#footer-content .footer-info .entry-body .navi{ margin: 10% auto 0; max-width: 380px; width: 100%; }
#footer-content .footer-info .entry-body .navi a{ display: block; background: linear-gradient(to right, #372f1d 0%, #796444 100%); font-size: 15px; line-height: 1.5; color: #ffffff; text-decoration: none; padding: 20px 0; }
#footer-content .footer-info .inner-body{ text-align: center; padding: 10% 5%; position: relative; }
#footer-content .footer-info .inner-body .tel-body .tel{ margin: 10px auto 0; max-width: 556px; }
#footer-content .footer-info .inner-body .tel-body .tel a{ display: block; background-color: rgba(255,255,255,0.3); padding: 20px 10%; border-radius: 40px; border: 1px solid rgba(0,0,0,0.2); }
#footer-content .footer-info .inner-body .tel-body .tel+.txt{ margin-top: 10px; }
#footer-content .footer-info .inner-body .footer-split{ display: flex; display: -ms-flex; justify-content: space-between; max-width: 660px; margin: 7% auto 0; }
#footer-content .footer-info .inner-body .footer-split .bels{ width: 48.4848%; }
#footer-content .footer-info .inner-body .footer-split .casbee{ width: 48.4848%; }
#footer-content .footer-info .inner-body .caption{ text-align: left; }
#container .footer-caption{ margin: 0 auto; padding: 10px; }
#allWrapper{ padding-bottom: 50px; }
#sp-util{ display: -ms-flex; display: flex; border-top: 1px solid #cccccc; position: fixed; z-index: 7000; bottom: 0; width: 100%; background-color: #ffffff; }
#sp-util .navi{ flex: 1; text-align: center; position: relative; }
#sp-util .navi+.navi::before{ content: ""; position: absolute; left: 0; top: 0; width: 1px; height: 100%; background-color: #cccccc; z-index: 5; }
#sp-util .navi a{ display: -ms-flex; display: flex; justify-content: center; align-items: center; width: 100%; height: 50px; font-size: 12px; line-height: 1.2; text-decoration: none; color: #333333; background-color: #ffffff; }
#sp-util .navi a img{ display: block; margin: 0 auto; }
#container #sp-util .navi-logout{ display: none; }
#container.status-login #sp-util .navi-entry,
#container.status-login #sp-util .navi-login{ display: none; }
#container.status-login #sp-util .navi-logout{ display: block; }
#sp-util .navi-reservation a{ background-color: #ba6c6c; color: #ffffff; }
#sp-util .navi-login a{ font-size: 10px; }
#sp-util .navi-login a .word{ transform: scaleX(0.8); white-space: nowrap; display: block; }
#sp-util .navi-entry a{ background-color: #ba9b6c; color: #ffffff; }
/*#sp-util .navi-entry a .word{ transform: scaleX(0.8); white-space: nowrap; display: block; }*/

/*--レスポンシブ追加プロパティ--------------------------------------*/
@media screen and (max-width: 480px){ /*480px以下のcss*/
	#footer-content .footer-info .entry-body .copy{ letter-spacing: 0.2em; padding-left: 0.2em; }
	#footer-content .footer-info .inner-body .footer-split{ display: block; max-width: 320px; }
	#footer-content .footer-info .inner-body .footer-split .bels,
	#footer-content .footer-info .inner-body .footer-split .casbee{ width: 100%; }
	#footer-content .footer-info .inner-body .footer-split .casbee{ margin-top: 3%; }
	#container .footer-credit .credit-list{ display: block; }
	#container .footer-credit .credit-list .item{ width: 100%; }
	#container .footer-credit .credit-list .item:nth-child(n+2){ margin-top: 10%; }
	#container .footer-credit .credit-list .item:nth-child(even){ margin-left: 0; }
	#container .footer-credit .credit-list .item a{ margin-top: 0; }
}


/*相互リンクのcss*/
/*-------------------------------------------------------*/
#link-exchange{ background-color: #f9f9f9; border-top: 1px solid #e5e5e5; padding: 70px 30px 0; text-align: center; position: relative; z-index: 1000; }
#link-exchange .ttl{ font-size: 24px; line-height: 24px; color: #000000; font-weight: bold;}
#link-exchange .link-exchange-navi{ margin: 40px auto 0; }
#link-exchange .link-exchange-navi .navi{ max-width: 400px; display: block; margin: 0 auto; position: relative; }
#link-exchange .link-exchange-navi .navi+.navi{ margin-top: 40px; }
#link-exchange .link-exchange-navi .photo{ position: relative; }
#link-exchange .link-exchange-navi .photo .caption{ position: absolute; left: 0; bottom: 0; background-color: #000000; background-color: rgba(0,0,0,0.8); color: #ffffff; padding: 3px 7px; font-size: 12px; line-height: 1.5; }
#link-exchange .link-exchange-navi .name{ font-size: 18px; line-height: 24px; color: #000000; padding: 20px 0 15px; }
#link-exchange .link-exchange-navi .txt{ text-align: left; text-decoration: underline; font-size: 14px; line-height: 24px; }
#link-exchange .link-exchange-navi a{ position: absolute; width: 100%; height: 100%; left: 0; top: 0; z-index: 10; background: rgba(255,255,255,0); }
#link-exchange .link-exchange-navi a:active~.txt{ text-decoration: none; }
#link-exchange .link-exchange-navi a~*{ transition: opacity 0.25s linear; }
#link-exchange .link-exchange-navi a:active~*{ opacity: 0.7; }
#link-exchange > .caption{ margin: 80px auto 0; padding: 10px 0; text-align: left; }

/*--レスポンシブ追加プロパティ--------------------------------------*/
@media screen and (max-width: 480px){ /*480px以下のcss*/
	#link-exchange{ padding: 60px 15px 0; }
	#link-exchange .link-exchange-navi .name{ padding: 15px 0 10px; }
	#link-exchange > .caption{ margin-top: 40px; }
}


















