@charset "UTF-8";

/*reset*/
/*-------------------------------------------------------*/
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; }




/*initialize*/
/*-------------------------------------------------------*/
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; }
#footerNavArea #slideWrap .slideNav a{ line-height: 0; }
#container a:hover{ opacity: 0.7; }
#allWrapper{ z-index: 10; min-width: 1112px; width: 100%; overflow: hidden; }
#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; }
.default-width{ max-width: 1112px; margin-left: auto; margin-right: auto; padding: 0 10px; }
#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 .pc{ display: block; }
.sw-elm img.pc{ display: inline; }
.js-inview{ opacity: 0; transition: opacity 1s ease-in; }
.show{ opacity: 1!important; }
.js-inview2{ opacity: 0; transform: translateY(50px); transition: opacity 1s ease-in, transform 1s ease-out; }
.js-inview2.show{ opacity: 1!important; transform: translateY(0); }

/*--レスポンシブ追加プロパティ--------------------------------------*/
@media screen and (max-width: 1112px){ /*1112px以下のcss*/
	#allWrapper{ min-width: 940px; }
	.sw-elm .pc,.sw-elm img.pc{ display: none; }
	.sw-elm .tb-h{ display: block; }
	.sw-elm img.tb-h{ display: inline; }
}



/*ヘッダーのcss*/
/*-------------------------------------------------------*/
#header-content{ /*position: static; left: 0; top: 0; z-index: 10;*/ width: 100%; }
#header-content .header-body{ width: 100%; min-width: 1112px; background: url(../images/img_parts/content/bg01.jpg) center 0 no-repeat; background-size: cover; position: fixed; z-index: 2000; line-height: 1.5; height: 110px; }
#header-content .header-body::before{ content: ""; position: absolute; left: 50%; top: 0; width: 100vw; height: 100%; background: linear-gradient(to bottom, rgba(35,24,21,0.8) 0%, rgba(35,24,21,0.5) 100%); transform: translateX(-50%); }
#header-content .name-body{ position: absolute; left: 50%; top: 50%; margin-left: -556px; transform: translateY(-50%); }
#header-content .logo{ width: 277px; }
#header-content .logo a{ display: block; }
#header-content .name{ font-size: 14px; line-height: 1.2; color: #ffffff; font-weight: normal; margin-top: 10px; }
#header-content .primary-navi{ position: fixed; z-index: 2001; top: 55px; right: 50%; margin-right: -466px; transform: translateY(-50%); }
#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: 5px; }
#header-content .primary-navi .navi-list .navi a{ font-size: 12px; line-height: 1.5; color: #ffffff; text-decoration: none; width: 80px; height: 80px; display: flex; display: -ms-flex; justify-content: center; align-items: center; text-align: center; border-radius: 50%; }
#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{ width: 20px; display: block; line-height: 0; margin: 2px auto 0; }
#header-content .primary-navi .navi-list .navi-login a .word .thin{ width: 125%; transform: scaleX(0.8); transform-origin: 0 0; display: inline-block; white-space: nowrap; }

/*--レスポンシブ追加プロパティ--------------------------------------*/
@media screen and (max-width: 1112px){ /*1112px以下のcss*/
	#header-content .header-body{ min-width: 940px; }
	#header-content .header-body::before{ width: 1112px; }
	#header-content .name-body{ margin-left: -470px; }
	#header-content .primary-navi{ margin-right: -380px; }
}
@media screen and (max-width: 940px){ /*940px以下のcss*/
	#header-content .primary-navi{ margin-right: 90px; right: 0; }
}

/*--高解像度向けに画像置き換え--------------------------------------*/
@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: fixed; width: 110px; padding-top: 110px; right: 50%; top: 0; background-color: rgba(255,255,255,0); z-index: 5001; cursor: pointer; color: transparent; margin-right: -586px; }
#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{ right: 0; margin-right: 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: 80%; 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: 20px; 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; }

/*--レスポンシブ追加プロパティ--------------------------------------*/
@media screen and (max-width: 1112px){ /*1112px以下のcss*/
	#header-content .navi-body .global-navi-menu{ margin-right: -500px; }
}
@media screen and (max-width: 940px){ /*940px以下のcss*/
	#header-content .navi-body .global-navi-menu{ margin-right: -20px; right: 0; }
}

/*--高解像度向けに画像置き換え--------------------------------------*/
@media screen and (-webkit-min-device-pixel-ratio: 1.5),screen and (min-resolution: 1.5dppx){
}



/*パンくずのcss*/
/*-------------------------------------------------------*/
#header-content .breadcrumb{ padding: 8px 0; width: 100%; max-width: 1112px; margin: 0 auto; display: flex; display: -ms-flex; text-align: left; box-sizing: border-box; position: fixed; top: 110px; left: 50%; z-index: 2000; transform: translateX(-50%); }
#header-content .breadcrumb::before{ content: ""; position: absolute; left: 50%; top: 0; width: 100vw; height: 100%; background: rgba(35,24,21,0.5); transform: translateX(-50%); box-sizing: border-box; border: solid rgba(255,255,255,0.5); border-width: 1px 0; }
#header-content .breadcrumb .item{ color: #ffffff; font-size: 12px; line-height: 1.3; position: relative; }
#header-content .breadcrumb .item:nth-child(n+2){ padding-left: 18px; }
#header-content .breadcrumb .item:nth-child(n+2)::before{ content: '〉'; position: absolute; left: 6px; top: 50%; transform: translateY(-50%) scaleY(0.5); }
#header-content .breadcrumb .item a{ color: #ffffff; text-decoration: none; }

/*--レスポンシブ追加プロパティ--------------------------------------*/
@media screen and (max-width: 1112px){ /*1112px以下のcss*/
	#header-content .breadcrumb{ max-width: 940px; }
	#header-content .breadcrumb::before{ width: 1112px; }
}




/*メインのcss*/
/*-------------------------------------------------------*/
#container{ position: relative; padding-bottom: 136px!important; }
#container::before{ content: ""; position: absolute; left: 50%; top: 142px; margin-left: -556px; width: 1px; height: 100%; background-color: #8d8d8f; border-right: 1px solid #ffffff; z-index: 900; pointer-events: none; transform: translateX(65px); }
#container::after{ content: ""; position: absolute; left: 50%; top: 0; width: 1112px; margin-left: -556px; height: 100%; box-shadow: 0 0 28px rgba(0,0,0,0.2); z-index: 900; pointer-events: none; }
#main-content{ background-color: #eae9e8; padding-top: 110px; }
#main-content .base-body{ width: 1112px; margin: 0 auto; box-sizing: border-box; position: relative; background-color: #ffffff; padding: 90px 65px 70px 130px; }
#main-content .base-body::before{ content: "PREMIST TENNOJI GOJO"; position: absolute; left: 0; top: 0; transform: rotate(90deg); transform-origin: 0 0; margin: 1em 0 0 2em; font-size: 14px; line-height: 1.5; color: #927d3f; font-family: 'EB Garamond','Cormorant Garamond', serif; z-index: 100; }
#main-content .hero{ background: url(../images/img_parts/content/bg01.jpg) center center no-repeat; background-size: cover; padding-bottom: 70px; position: relative; }
#main-content .hero .inner-body{ position: relative; width: 1112px; margin: 0 auto; }
#main-content .hero .inner-body .page-name{ font-size: 24px; line-height: 1.5; color: #b1a270; text-align: center; font-family: 'EB Garamond','Cormorant Garamond', serif; letter-spacing: 0.3em; font-weight: normal; position: absolute; right: 20px; top: 50%; transform: translateY(-50%); z-index: 10; text-shadow: black 1px 1px 8px, black -1px 1px 8px, black 1px -1px 8px, black -1px -1px 8px; }
#main-content .hero .inner-body .photo-body{ position: relative; }
#main-content .hero .inner-body .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); }
/*#main-content .base-body::before,
#main-content .base-body::after{ content: ""; position: absolute; top: 0; width: 28px; height: 100%;  }
#main-content .base-body::before{ right: 100%; background: linear-gradient(to right, rgba(0,0,0,0) 0%, rgba(0,0,0,0.2) 100%); }
#main-content .base-body::after{ left: 100%; background: linear-gradient(to left, rgba(0,0,0,0) 0%, rgba(0,0,0,0.2) 100%); }*/

/*--レスポンシブ追加プロパティ--------------------------------------*/
@media screen and (max-width: 1112px){ /*1112px以下のcss*/
	#container::before{ margin-left: -480px; }
	#container::after{ width: 940px; margin-left: -470px; }
	#main-content .base-body{ width: 940px; padding: 90px 40px 70px 95px; }
	#main-content .hero .inner-body{ width: 940px; }
}


/*フッターの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: 60px 0; 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: 18px; line-height: 1.72; color: #171717; }
#footer-content .footer-body .common-body .model-txt{ font-size: 44px; line-height: 1.2; color: #000000; letter-spacing: 0.2em; }
#footer-content .footer-body .common-body .navi-list{ max-width: 640px; margin: 30px auto 0; display: flex; display: -ms-flex; justify-content: center; }
#footer-content .footer-body .common-body .navi-list .navi{ width: 48%; }
#footer-content .footer-body .common-body .navi-list .navi:nth-child(n+2){ margin-left: 4%; }
#footer-content .footer-body .common-body .navi-list .navi a{ border: 1px solid; font-size: 18px; line-height: 1.5; text-decoration: none; height: 70px; 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 .common-body .navi-list .navi a svg{ width: 100%; height: auto; }
#footer-content .footer-body .tel-body{ text-align: center; padding: 60px 0; }
#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+.txt{ margin-top: 10px; }
#footer-content .footer-body .tel-body .txt-split{ display: flex; display: -ms-flex; justify-content: center; margin-top: 10px; }
#footer-content .footer-body .tel-body .txt-split .txt+.txt{ margin-left: 1em; }
#footer-content .footer-caption{ width: 1112px; margin: 0 auto; box-sizing: border-box; position: relative; background-color: #ffffff; padding: 10px 65px 10px 130px; }
#sp-util{ display: none; }

/*--レスポンシブ追加プロパティ--------------------------------------*/
@media screen and (max-width: 1112px){ /*1112px以下のcss*/
	#footer-content .footer-caption{ width: 940px; padding: 10px 40px 10px 95px; }
}


/*相互リンクのcss*/
/*-------------------------------------------------------*/
#link-exchange{ background-color: #f9f9f9; border-top: 1px solid #e5e5e5; padding-top: 50px; 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{ /*width: 840px;*/ width: 400px; margin: 50px auto 0; }
#link-exchange .link-exchange-navi .navi{ /*width: 400px;*/ width: 100%; display: inline-block; vertical-align: top; position: relative; }
#link-exchange .link-exchange-navi .navi:nth-child(n+2){ margin-left: 2.72%; }
/*#link-exchange .link-exchange-navi .navi:nth-child(2n+2){ margin-left: 30px; }
#link-exchange .link-exchange-navi .navi:nth-child(n+3){ margin-top: 40px; }*/
#link-exchange .link-exchange-navi .photo{ position: relative; }
#link-exchange .link-exchange-navi .photo img{ width: 100%; height: auto; }
#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:hover~.txt{ text-decoration: none; }
#link-exchange .link-exchange-navi a~*{ transition: opacity 0.25s linear; }
#link-exchange .link-exchange-navi a:hover~*{ opacity: 0.7; }
#link-exchange > .caption{ margin: 100px auto 0; padding: 10px; max-width: 1112px; text-align: left; }

/*--レスポンシブ追加プロパティ--------------------------------------*/
@media screen and (max-width: 1112px){ /*1112px以下のcss*/
	/*#link-exchange .link-exchange-navi{ width: 940px; }*/
	/*#link-exchange .link-exchange-navi > .navi{ width: 293px; }*/
}



/*common cssの相殺*/
#container::before,
#container::after{ display: none; }
#main-content{ background-color: #ffffff; }
#main-content .base-body{ padding: 50px 0 100px; }
#main-content .base-body::before{ display: none; }
#footer-content .footer-caption{ padding: 10px 0; }
@media screen and (max-width: 768px){ /*768px以下のcss*/
	#footer-content .footer-caption{ padding: 10px 5%; }
}
#container.status-login::before,
#container.status-login::after{ display: block; }
#container.status-login #main-content{ background-color: #eae9e8; }
#container.status-login #main-content .base-body{ padding: 90px 65px 70px 130px; }
#container.status-login #main-content .base-body::before{ display: block; }
#container.status-login #footer-content .footer-caption{ padding: 10px 65px 10px 130px; }
@media screen and (max-width: 1112px){ /*1112px以下のcss*/
	#container.status-login #main-content .base-body{ padding: 90px 40px 70px 95px; }
	#container.status-login #footer-content .footer-caption{ padding: 10px 40px 10px 95px; }
}
#container.status-login #header-content .breadcrumb::before{ background-color: #84713e; border: none; }



/*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; }

#container.status-login #footer-content .footer-body .common-body::before,
#container.status-login #footer-content .footer-body .common-body::after{ display: none; }