@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; }
#container .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: static; left: 0; top: 0; z-index: 10;*/ width: 100%; }
#header-content .header-body{ width: 100%; background: url(../images/img_parts/content/bg01.jpg) center 0 no-repeat; background-size: cover; position: absolute; z-index: 2000; line-height: 1.5; height: 60px; border-bottom: 1px solid rgba(255,255,255,0.5); }
#header-content.fixed-navi .header-body{ position: fixed; top: 0; }
#header-content .header-body .logo{ padding: 0 70px 0 10px; float: left; height: 60px; max-width: 357px; display: -ms-flex; display: flex; align-items: center; width: 100%; box-sizing: border-box; }
/*#header-content .header-body.limited-style .logo{ padding: 0 160px 0 10px; }*/
#header-content .header-body .logo a{ line-height: 1; flex: 1; }
#header-content .header-body .logo img{ width: 100%; height: auto; }
#header-content .header-body .name{ display: none; }
#header-content .primary-navi{ position: absolute; right: 60px; z-index: 2001; display: none; }
#header-content .fixed-navi.primary-navi{ position: fixed; top: 0; }
#header-content .primary-navi .navi-list{ display: flex; display: -ms-flex; align-items: center; }
#header-content .primary-navi .navi-list .navi{ overflow: hidden; }
#header-content .primary-navi .navi-list .navi:nth-child(n+2){ margin-left: -1px; }
#header-content .primary-navi .navi-list .navi a{ font-size: 12px; line-height: 1.5; color: #ffffff; text-decoration: none; width: 60px; height: 60px; display: flex; display: -ms-flex; justify-content: center; align-items: center; text-align: center; border: solid #999999; border-width: 0 1px; }
#header-content .primary-navi .navi-list .navi-entry a,
#header-content .primary-navi .navi-list .navi-reservation a{ background-color: rgba(132,113,62,0.8); }
#header-content .primary-navi .navi-list .navi-login a,
#header-content .primary-navi .navi-list .navi-logout a{ background-color: rgba(150,0,0,0.8); }
#header-content .primary-navi .navi-list .navi a .icon{ display: none; }
#header-content .primary-navi .navi-list .navi-login a .word .thin{ width: 142.85%; transform: scaleX(0.7); transform-origin: 0 0; display: inline-block; white-space: nowrap; }

/*--高解像度向けに画像置き換え--------------------------------------*/
@media screen and (-webkit-min-device-pixel-ratio: 1.5),screen and (min-resolution: 1.5dppx){
}



/*グローバルナビのcss*/
/*-------------------------------------------------------*/
#header-content .navi-body{  }
#header-content .navi-body .global-navi-menu{ position: absolute; width: 60px; padding-top: 60px; right: 0; background-color: rgba(255,255,255,0); z-index: 5001; cursor: pointer; color: transparent; }
#header-content.fixed-navi .navi-body .global-navi-menu{ position: fixed; top: 0; }
#header-content .navi-body .global-navi-menu::before{ content: ""; position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); box-sizing: border-box; width: 33.3333%; padding-top: 25%; border: solid #ffffff; border-width: 1px 0; }
#header-content .navi-body .global-navi-menu::after{ content: ""; position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); box-sizing: border-box; width: 33.3333%; padding-top: 1px; background-color: #ffffff; }
#header-content .navi-body .global-navi-menu.active{ position: fixed; top: 0; }
#header-content .navi-body .global-navi-menu.active::before{ border: none; padding: 0; padding-top: 1px; background-color: #666666; transform: translate(-50%,-50%) rotate(45deg); }
#header-content .navi-body .global-navi-menu.active::after{ transform: translate(-50%,-50%) rotate(-45deg); background-color: #666666; }
#header-content .navi-body .global-navi-menu .word{ position: absolute; left: 0; top: 0; }
#header-content .navi-body .global-navi-wrapper{ position: fixed; overflow-y: auto; right: 0; top: 0; background-color: #ffffff; max-height: 100vh; max-height: calc(var(--vh, 1vh) * 100); -webkit-overflow-scrolling: touch; width: 100%; max-width: 630px; display: flex; display: -ms-flex; align-items: center; justify-content: center; }
#header-content .navi-body .global-navi{ position: relative; right: auto; width: 100%; padding: 10%; margin: auto; box-sizing: border-box; }
#header-content .navi-body .global-navi .head{ font-family: 'EB Garamond','Cormorant Garamond', serif; color: #927d3f; font-size: 18px; text-align: center; margin-bottom: 10px; }
#header-content .navi-body .global-navi .navi-list{ display: block; text-align: center; }
#header-content .navi-body .global-navi .navi-list .navi{ border: solid #cccccc; border-width: 1px 0; padding: 2px 0; }
#header-content .navi-body .global-navi .navi-list .navi:nth-child(n+2){ margin: -1px auto 0; }
#header-content .navi-body .global-navi .navi-list .navi a{ font-size: 18px; color: #666666; text-decoration: none; padding: 15px 0; display: block; position: relative; }
#header-content .navi-body .global-navi .navi-list .navi a:hover{ text-decoration: none; }
#header-content .navi-body .global-navi .navi-list .navi a:active{ text-decoration: underline; }
#header-content .navi-body .global-navi .navi-list .navi.current a{ background-color: #dddac1; }
#header-content .navi-body .global-navi .navi-list .navi a::before{ content: ""; position: absolute; right: 0; top: 50%; transform: translate(-50%,-50%) translateY(-25%) rotate(45deg); border: solid rgba(0,0,0,0.3); border-width: 0 1px 1px 0; width: 3%; padding-top: 3%; }
#header-content .navi-body .global-navi .navi-list .navi.current a::before{ display: none; }
#header-content .navi-body .global-navi-wrapper{ opacity: 0; z-index: -1; -webkit-overflow-scrolling: touch; transition: opacity 0.5s; }
#header-content .navi-body .global-navi-wrapper.active{ opacity: 1; z-index: 5000; }



/*メインのcss*/
/*-------------------------------------------------------*/
#main-content{ background-color: #eae9e8; padding-top: 60px; }
#main-content .base-body{ background-color: #ffffff; padding: 7% 5%; }
#main-content .hero{ background: url(../images/img_parts/content/bg01.jpg) center center no-repeat; background-size: cover; padding: 0; }
#main-content .hero .page-name{ font-size: 24px; line-height: 1.5; color: #b1a270; text-align: center; font-family: 'EB Garamond','Cormorant Garamond', serif; padding: 5% 0; font-weight: normal; }
#main-content .hero .photo-body{ position: relative; margin: 0 auto; }
#main-content .hero .photo-body .caption{ position: absolute; right: 0; bottom: 0; padding: 2px 7px; color: #ffffff; z-index: 10; background-color: rgba(0,0,0,0.8); }

/*--レスポンシブ追加プロパティ--------------------------------------*/
@media screen and (max-width: 480px){ /*480px以下のcss*/
}



/*フッターのcss*/
/*-------------------------------------------------------*/
#footer-content{  }
#footer-content .footer-body .common-body{ text-align: center; /*background: url(../images/img_parts/content/bg01.jpg) center center;*/ background-size: cover; padding: 10% 5%; position: relative; }
#footer-content .footer-body .common-body::before,
#footer-content .footer-body .common-body::after{ content: ""; position: absolute; left: 0; width: 100%; height: 2px; background: linear-gradient(to right, rgba(212,195,132,0) 0%, rgba(212,195,132,1) 50%, rgba(212,195,132,0) 100%); }
#footer-content .footer-body .common-body::before{ top: 0; }
#footer-content .footer-body .common-body::after{ bottom: 0; }
#footer-content .footer-body .common-body .txt{ font-size: 14px; line-height: 1.72; color: #171717; text-align: left; }
#footer-content .footer-body .common-body .model-txt{ font-size: 26px; line-height: 1.2; color: #000000; }
#footer-content .footer-body .common-body .navi-list{ max-width: 480px; margin: 4% auto 0; }
#footer-content .footer-body .common-body .navi-list .navi{ width: 100%; }
#footer-content .footer-body .common-body .navi-list .navi:nth-child(n+2){ margin-top: 10px; }
#footer-content .footer-body .common-body .navi-list .navi a{ display: block; border: 1px solid; font-size: 14px; line-height: 1.5; text-decoration: none; height: 50px; display: flex; display: -ms-flex; justify-content: center; align-items: center; position: relative; }
#footer-content .footer-body .common-body .navi-list .navi01 a{ background-color: #ffffff; border-color: #666666; color: #666666; }
#footer-content .footer-body .common-body .navi-list .navi02 a{ background-color: #ffffff; border-color: #927d3f; color: #927d3f; }
#footer-content .footer-body .common-body .navi-list .navi03 a{  background-color: rgba(35,24,21,0.6); border-color: rgba(255,255,255,0.7); color: #ffffff; }
#footer-content .footer-body .common-body .navi-list .navi a .icon01{ margin-right: 10px; margin-left: -22px; width: 22px; line-height: 0; }
#footer-content .footer-body .common-body .navi-list .navi a .icon02{ line-height: 0; position: absolute; right: 10px; top: 50%; transform: translateY(-50%); width: 21px; line-height: 0; }
#footer-content .footer-body .tel-body{ text-align: center; padding: 10% 5%; }
#footer-content .footer-body .tel-body .txt{ color: #000000; }
#footer-content .footer-body .tel-body .tel{ margin: 10px auto 0; max-width: 514px; }
#footer-content .footer-body .tel-body .tel-limited{ display: none; }
#footer-content .footer-body .tel-body .tel a{ display: block; padding: 15px; border: 1px solid rgba(0,0,0,0.3); border-radius: 10px; box-sizing: border-box; background: linear-gradient(to bottom, rgba(0,0,0,0) 50%, rgba(0,0,0,0.2) 100%); }
#footer-content .footer-body .tel-body .tel+.txt-split{ margin-top: 10px; }

#footer-content .footer-caption{ position: relative; background-color: #ffffff; padding: 10px 5%; }
#sp-util{ display: -ms-flex; display: flex; border-top: 1px solid #cccccc; position: fixed; z-index: 4000; bottom: 0; left: 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: 10px; line-height: 1.2; text-decoration: none; color: #333333; background-color: #ffffff; }
#sp-util .navi a img{ display: block; margin: 0 auto; }
/*#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-contact{ flex: 1; }
#sp-util .navi-map{ flex: 1; }
#sp-util .navi-request{ flex: 1; }
#sp-util .navi-entry{ flex: 1; }
#sp-util .navi-reservation{ flex: 1; }
#sp-util .navi-login{ flex: 1; }
#sp-util .navi-logout{ flex: 1; }
#sp-util .navi-request a{ background-color: #960000; color: #ffffff; }
#sp-util .navi-entry a,
#sp-util .navi-reservation a{ background-color: rgb(132,113,62); color: #ffffff; }
#sp-util .navi-login a,
#sp-util .navi-logout a{ background-color: rgb(150,0,0); color: #ffffff; }

/*--レスポンシブ追加プロパティ--------------------------------------*/
@media screen and (max-width: 480px){ /*480px以下のcss*/
}


/*相互リンクのcss*/
/*-------------------------------------------------------*/
#link-exchange{ background-color: #f9f9f9; border-top: 1px solid #e5e5e5; padding: 70px 30px 0; text-align: center; position: relative; z-index: 5000; }
#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; }
}









/*loginの上書き*/
#container #header-content .navi-body .global-navi .navi-list .navi.limited{ display: none; }
#container.status-login #header-content .navi-body .global-navi .navi-list .navi.limited{ display: block; }

#container #header-content .primary-navi .navi-list.limited{ display: none; }
#container.status-login #header-content .primary-navi .navi-list{ display: none; }
#container.status-login #header-content .primary-navi .navi-list.limited{ display: flex; display: -ms-flex; }

#footer-content .footer-body .common-body.limited{ display: none; }
#container.status-login #footer-content .footer-body .common-body{ display: none; background: none; }
#container.status-login #footer-content .footer-body .common-body.limited{ display: block; }

#footer-content .footer-body .tel-body .txt .inner-txt.limited{ display: none; }
#container.status-login #footer-content .footer-body .tel-body .txt .inner-txt{ display: none; }
#container.status-login #footer-content .footer-body .tel-body .txt .inner-txt.limited{ display: inline; }

#container.status-login #footer-content .footer-body{ background: url(../images/img_parts/content/bg02.jpg) center center; background-size: cover; }
#container.status-login #footer-content .footer-body .common-body{ padding-bottom: 0; }

#sp-util .navi-reservation,
#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-reservation,
#container.status-login #sp-util .navi-logout{ display: block; }


#container.status-login #footer-content .footer-body .common-body::before,
#container.status-login #footer-content .footer-body .common-body::after{ display: none; }








