/* ****************

    common.css

**************** */

/*

ブラウン > #796141
ブラック > #282828

*/

:root {

    --color_pink: #c78c95;
    --color_black: #282828;
    --color_dark: #383838;
    --color_gray: #4A4A4A;
    --color_brown: #796141;
    --color_white: #ffffff;

    --header_z-index: 1800;
    --gnavi_menu_drawer_z-index:1900;
    --gnavi_btn_outerwrap_z-index: 2000;
  
}

/* img{ background-color: rgba(0,0,0,0.05); } */

a{
opacity: 1;
transition: opacity 0.5s ease;
}

a:has(>img){
display: block;
}
a > img {
    display: block;
    margin: 0;
    vertical-align: middle;
}

body{
    background: url("../img/common/background_SX096_1000x1000px.jpg") repeat;
}
body.loading *:not(#nowload_wrapper):not(#nowload_wrapper *){
    opacity: 0;
    /* transition: opacity 0.8s ease; */
}
body *{
    transition: opacity 0.5s ease;
    opacity: 1;
}


/* lazyload class ---------------------------- */
/* lazyload_fadein.js */
*:has(> img[loading="lazy"].lazyload){
    border: rgba(121,97,65,0.20) solid 1px;
}
*:has(> img[loading="lazy"]){
    border: none;
    transition: all 1s;
}
img[loading="lazy"].lazyload {
  opacity: 0;
}
img[loading="lazy"]{
    -webkit-transition: opacity 1s;
    transition: all 1s;
    opacity:1;
}


/* ------------------------------------------- */

@media print, screen and (min-width:1025px) {
    .pc_none {display: none;}
}
@media print, screen and (min-width:768px) {
    .pc_pd_none {display: none;}
	a:hover{ opacity: 0.5; }
}
@media screen and (max-width:1024px) {
    .sp_pd_none {display: none;}
}
@media screen and (max-width:767px) {
    .sp_none {display: none;}
}

/* outer & contents_width ******************* */
.outer_wrap{
width: 100%;
position: relative;
}
.contents_width{
max-width: 1280px;
margin: 0 auto;
}
.contents_width_narrow{ 
max-width: 1080px;
margin: 0 auto;
}
.contents_width_narrow2{ 
max-width: 700px;
margin: 0 auto;
}

/*.contents_width,
.contents_width_narrow{
margin: auto;
}*/
@media print, screen and (min-width:1025px) {
    .contents_width, .contents_width_narrow {padding-left: 4rem; padding-right: 4rem;}
}
@media screen and (min-width: 768px) and (max-width:1024px) {
    .contents_width, .contents_width_narrow {padding-left: 3rem; padding-right: 3rem;}
}
@media screen and (max-width:767px) {
    .contents_width, .contents_width_narrow, .contents_width_narrow2 {padding-left: 2rem; padding-right: 2rem;}
}

/* Google Material Symbols & icon ******************* */

.after_icon{
display: flex;
/* justify-content: flex-start;*/
gap:3px;
align-items: center;
}
.after_icon::after{
/* font-family: "Material Symbols Outlined"; */
display: block;
content: "";
background-position: center;
background-repeat: no-repeat;
background-size: contain;
}
.arrow_forward::after{
width: 18px;
height: 18px;
background-image: url("../img/common/google_icon/arrow_forward_24dp_5F6368_FILL0_wght400_GRAD0_opsz24.svg");
}

/*
.after_icon.arrow_forward::after{
font-size: 2rem;
vertical-align:sub;
}
*/


/* header ******************** */
#header{
position: absolute;
top:0;
left: 0;
}
#gnavi_btn_outerwrap{ position: fixed; }
#header{
--header_logo_en_width: 184px;
--header_logo_en_hight: 36px;
--header_logo_jp_width: 150px;
--header_logo_jp_hight: 54.53px;
}

#gnavi_btn_outerwrap{ z-index: var( --gnavi_btn_outerwrap_z-index ); }
#header{ z-index: var( --header_z-index ); }

#header{
top: 0;
padding: 30px;
width: calc( var( --header_logo_en_width ) + 60px );
height: calc( var( --header_logo_jp_hight ) + 60px );
}
/* .customize-support #header{ top: 32px; } */
#header_logo{
position: relative;
width: var( --header_logo_en_width );
height: var( --header_logo_jp_hight );
}
.header_logo_en,
.header_logo_jp{
position: absolute;
transition: opacity 0.5s ease;
}
.header_logo_en{
width: var( --header_logo_en_width );
height: var( --header_logo_en_hight );
}
.header_logo_jp{
width: var( --header_logo_jp_width );
height: var( --header_logo_jp_hight );
}
@media print, screen and (min-width:768px) {
	#header{
	padding: 30px;
	width: calc( var( --header_logo_en_width ) + 60px );
	height: calc( var( --header_logo_jp_hight ) + 60px );
	}
}
@media screen and (max-width: 767px) {
	#header{
	padding: 20px;
	width: calc( var( --header_logo_en_width ) + 40px );
	height: calc( var( --header_logo_jp_hight ) + 40px );
	}
}

/* global navigation ******************** */
.customize-support #gnavi_btn_outerwrap{ top:52px; }
#gnavi_btn_outerwrap{
right:0;
top:clamp(10px, 1.56vw, 20px);
}
.gnavi_btn_wrap{
position: relative;
width:clamp(80px, 7.8vw, 100px);
display: flex;
flex-direction: column;
align-items: center;
}
[for="drawer_input"]{
opacity: 1;
transition: opacity 0.5s ease;
}
[for="drawer_input"]:hover{
opacity: 0.5;
}

/* global navigation button ******************** */

/* チェックボックスを非表示にする */
#drawer_input { display: none; }

/* ハンバーガーアイコンの設置スペース */
.drawer_input_label {
display: flex;
height: 60px;
width: 60px;
justify-content: center;
align-items: center;
position: relative;
z-index: 100;/* 重なり順を一番上にする */
cursor: pointer;
}

/* ハンバーガーメニューのアイコン */
.drawer_input_label span,
.drawer_input_label span::before,
.drawer_input_label span::after {
content: '';
display: block;
height: 3px;
width: 38px;
transition: 0.5s;
position: absolute;
}

/* 三本線の一番上の棒の位置調整 */
.drawer_input_label span::before { bottom: 12px; }
/* 三本線の一番下の棒の位置調整 */
.drawer_input_label span::after { top: 12px; }

/* アイコンがクリックされたら真ん中の線を透明にする */
#drawer_input:checked ~ .drawer_input_label span {
  background-color: rgba(255,255,255,0);
}

/* アイコンがクリックされたらアイコンが×印になように上下の線を回転 */
#drawer_input:checked ~ .drawer_input_label span::before {
  bottom: 0;
  transform: rotate(45deg);
}

#drawer_input:checked ~ .drawer_input_label span::after {
  top: 0;
  transform: rotate(-45deg);
}

.gnavi_btn_txt{
position: absolute;
line-height: 1;
text-align: center;
width: 100%;
top:50px;
left:0;
}

#drawer_input ~ .gnavi_btn_txt{ transition: opacity 0.8s ease; }

#drawer_input ~ .gnavi_txt_menu,
#drawer_input:checked ~ .gnavi_txt_close{ opacity: 1; }

#drawer_input:checked ~ .gnavi_txt_menu,
#drawer_input ~ .gnavi_txt_close{ opacity: 0; }


.gnavi_btn_reserve{
position: relative;
width: 38px;
margin-top: 36px;
left: 11px;
padding: 30px 0 25px;
}
.gnavi_btn_reserve::before,
.gnavi_btn_reserve::after{
position: absolute;
left:0;
content:"";
display: block;
width: 100%;
height: 10px;
border-style: solid;
}
.gnavi_btn_reserve::before{
top: 0;
border-width: 4px 2px 0px 2px;
}
.gnavi_btn_reserve::after{
bottom:0;
border-width: 0px 2px 4px 2px;
}
.gnavi_btn_reserve a span{
display: block;
writing-mode: vertical-rl;
width: 38px;
line-height: 38px;
font-size: 20px;
font-weight: 600;
letter-spacing: 0.35em;
margin-top: 20px;
color: #fff;
}

.gnavi_btn_reserve a::before,
.gnavi_btn_reserve a::after{
content: "";
display: block;
width: 24px;
height: 24px;
background-position: center;
background-repeat: no-repeat;
background-size: contain;
position: relative;
left: 7px;
}
.gnavi_btn_reserve a::before{
background-image: url("../img/common/google_icon/calendar_month_24dp_FFFFFF_FILL0_wght400_GRAD0_opsz24.svg");
}
.gnavi_btn_reserve a::after{
background-image: url("../img/common/google_icon/arrow_outward_24dp_FFF_FILL0_wght400_GRAD0_opsz24.svg");
margin-top: 10px;
}

.color-light .drawer_input_label span,
.color-light .drawer_input_label span::before,
.color-light .drawer_input_label span::after{
background-color: var( --color_white );
}
.color-light .gnavi_btn_reserve::before,
.color-light .gnavi_btn_reserve::after{
border-color: var( --color_white );
}
.color-light .gnavi_btn_txt,
.color-light .gnavi_btn_reserve a span{
color: var( --color_white );
}
.color-light .gnavi_btn_reserve{ 
background-color: rgba(0,0,0,0.3); 
}

.drawer_input_label span,
.drawer_input_label span::before,
.drawer_input_label span::after{
background-color: var( --color_gray );
}
.gnavi_btn_reserve::before,
.gnavi_btn_reserve::after{
border-color: var( --color_gray);
}
.gnavi_btn_txt /*,
.color-dark .gnavi_btn_reserve a span */{
color: var( --color_gray );
}

.gnavi_btn_reserve{ background-color: rgba(0,0,0,0.45); }

@media screen and (min-width: 1025px) and (max-width:1360px) {
	.color-light .gnavi_btn_reserve{ 
	display: block;
	}
}
@media screen and (max-width:1024px) {
	.gnavi_btn_reserve{
	display: none;
	}
}

/* gnavi menu drawer ******************** */


#gnavi_menu_drawer{
position: fixed;
width: 100%;
height: 100vh;
z-index: var( --gnavi_menu_drawer_z-index );
background-color: rgba(0,0,0,0);
-webkit-backdrop-filter: blur(15px);
backdrop-filter: blur(15px);
left:-100%;
top:0px;
transition: all 0.8s ease;
padding-right: 100%;
transform: translate3d(0, 0, 0);
}
#gnavi_menu_drawer.drawer_open{
background-color: rgba(0,0,0,0.2);
transform: translate3d(100%, 0px, 0);
padding-right: clamp(80px, 7.8vw, 100px);
}
.gnavi_menu_wrap{
background-color: rgba(255,255,255,0.9);
width: 100%;
height: 100vh;
display: flex;
justify-content: center;
align-items: center;
overflow:auto;
padding-bottom: 20svh;
margin-left: -5%;
}

.gnavi_menu_ul{
position: relative;
font-size: 2.5rem;
line-height: 2.3;
}
.gnavi_menu_item{
width: 100%;
}
.gnavi_menu_item a{
display: block;
}


.gnavi_menu_item a{
/*font-size: 2.5rem;*/
font-size: clamp(1.8rem, calc(1.2rem + 0.9375vw), 2.4rem);
letter-spacing: 0.02;
display: flex;
align-items: center;
line-height: 2.2;
}
.gnavi_menu_item a::before{
display: block;
content: "";
width: 30px;
height: 30px;
background-image: url("../img/common/google_icon/arrow_right_24dp_796141_FILL1_wght400_GRAD0_opsz24.svg");
background-position: center;
background-size: contain;
background-repeat: no-repeat;
margin-top: 5px;
opacity: 0.7;
}



/* main ******************** */

.front-page #main_contents{ padding: 0px; }
/*#main_contents{ min-height: 100svh; }*/

@media print, screen and (min-width:1280px) {
	#main_contents{ 
	padding: 150px 0 100px; 
	}
}
@media screen and (min-width: 1025px) and (max-width: 1279px) {
	#main_contents{ 
	padding: 150px 0 80px; 
	}
}
@media screen and (min-width: 768px) and (max-width:1024px) {
	#main_contents{ 
	padding: 150px 0 60px; 
	}
}
@media screen and (max-width:767px) {
	#main_contents{ 
	padding: 150px 0 40px; 
	}
}
/* sectioin title ******************** */

.section_title h2 span{
display: block;
}
.section_title_ja{
line-height: 1.1;
}
.section_title_en{
line-height: 1.2;
}
.section_title h2{
border-left: var( --color_brown ) solid 2px;
padding-left: 20px;
}
@media print, screen and (min-width:1280px) {
	.section_title{
	flex-basis: 250px;
	}
	.section_title_ja{
	font-size: 2.6rem;
	margin-bottom: 10px;
	}
	.section_title_en{
	font-size: 1.6rem;
	}
}
@media screen and (min-width: 1025px) and (max-width: 1279px) {
	.section_title{
	display: flex;
	justify-content: space-between;
	margin-bottom: 30px;
	}
	.section_title_ja{
	font-size: 2.6rem;
	margin-bottom: 10px;
	}
	.section_title_en{
	font-size: 1.6rem;
	}
}
@media screen and (min-width: 768px) and (max-width:1024px) {
	.section_title{
	display: flex;
	justify-content: space-between;
	margin-bottom: 30px;
	}
	.section_title_ja{
	font-size: 2.4rem;
	margin-bottom: 8px;
	}
	.section_title_en{
	font-size: 1.5rem;
	}
}
@media screen and (max-width:767px) {
	.section_title{
	margin-bottom: 20px;
	}
	.section_title_ja{
	font-size: 2.0rem;
	margin-bottom: 6px;
	}
	.section_title_en{
	font-size: 1.4rem;
	}
}
/* footer ******************** */


#footer{
background-color: rgba(51,51,51,0.98);
color: #D4D4D4;
}
#footer.fixed-footer {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
}
    
.footer_wrap{
display: flex;
justify-content: space-between;
}
.footer_logomark{
width: clamp(90px, calc(9.375vw), 120px);
/* margin: auto; */
}
.footer_logomark img{
width: 100%;
height: auto;
}
.footer_menu_item a{
display: flex;
align-items: center;
line-height: 1.6;
}
.footer_menu_item a::before{
display: block;
content: "";
width: 24px;
height: 24px;
background-image: url("../img/common/google_icon/arrow_right_24dp_FFF_FILL1_wght400_GRAD0_opsz24.svg");
background-position: center;
background-size: contain;
background-repeat: no-repeat;
margin-top: 5px;
opacity: 0.7;
}
.footer_reserve_link a{
position: relative;
display: flex;
justify-content: space-between;
width: 100%;
border: #D4D4D4 solid 1px;
border-radius: 5px;
padding: 30px 20px 30px 35px;
align-items: center;
}
.footer_reserve_link a::before,
.footer_reserve_link a::after,
.footer_googlemap_link a::before{
content: "";
display: block;
background-position: center;
background-repeat: no-repeat;
background-size: contain;
}
.footer_reserve_link a::before{
background-image: url("../img/common/google_icon/calendar_month_24dp_FFFFFF_FILL0_wght400_GRAD0_opsz24.svg");
width: 30px;
height: 30px;
opacity: 0.8;
}
.footer_reserve_link a::after{
background-image: url("../img/common/google_icon/arrow_outward_24dp_FFF_FILL0_wght400_GRAD0_opsz24.svg");
width: 20px;
height: 20px;
position: absolute;
bottom: 3px;
right: 3px;
opacity: 0.6;
}
.footer_reserve_link a span{
display: block;
vertical-align: bottom;
line-height: 1;
letter-spacing: 0.75em;
}
.footer_zip_address{
display: block;
}
.footer_googlemap_link a{
display: flex;
align-items: center;
}
.footer_googlemap_link a::before{
background-image: url("../img/common/google_icon/location_on_24dp_FFF_FILL0_wght400_GRAD0_opsz24.svg");
width: 20px;
height: 20px;
opacity: 0.8;
margin-right: 5px;
}

@media print, screen and (min-width:1280px) {
	.footer_wrap{
	padding-top: 100px;
	padding-bottom: 100px;
	}
	.footer_menu_item a{
	font-size: 1.6rem;
	}
}
@media screen and (min-width: 1025px) and (max-width: 1279px) {
	.footer_wrap{
	padding-top: 80px;
	padding-bottom: 80px;
	}
	.footer_menu_item a{
	font-size: 1.5rem;
	}
}
@media screen and (min-width: 768px) and (max-width:1024px) {
	.footer_wrap{
	padding-top: 60px;
	padding-bottom: 60px;
	}
	.footer_menu_item a{
	font-size: 1.5rem;
	}
}
@media print, screen and (min-width:768px) {
	.footer_logomark_wrap{
	flex-grow: 2;
	}
	#footer_nav{ 
	width: max( 20%, 200px );
	margin-left: 2.5%;
	}
	.footer_address_wrap{
	width: max( 25%, 300px );
	margin-left: 2.5%;
	position: relative;
	}
	.footer_copyright{
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	}
	.footer_reserve_link a{
	justify-content: space-between;
	}
	.footer_reserve_link{
	margin-bottom: 50px;
	}
	.footer_zip_address{
	margin-bottom: 10px;
	}
	.footer_reserve_link a span{
	font-size: 2.6rem;
	}
}
@media screen and (min-width: 501px) and (max-width:767px) {
	.footer_wrap{
	padding-top: 50px;
	padding-bottom: 50px;
	flex-direction:column;
	}	
	.footer_menu_ul {
	display: flex;
	flex-wrap: wrap;
	width: 460px;
	margin: 40px auto 0;
	padding-top: 40px;
	border-top: solid 1px #d4d4d4;
	}
	.footer_menu_item{
	width: 50%;
	}
	.footer_menu_item a{
	font-size: 1.5rem;
	}
	.footer_address_wrap{
	width: 460px;
	margin: 40px auto 0;
	text-align: center;
	}
	.footer_reserve_link a{
	justify-content: center;
	}
	.footer_reserve_link a span {
	margin-left: 20px;
	font-size: 2.6rem;
	}
	.footer_reserve_link{
	margin-bottom: 30px;
	}
	.footer_googlemap_link a{
	justify-content:center;
	padding: 10px 0;
	}
}
@media screen and (max-width:500px) {
	.footer_wrap{
	padding-top: 50px;
	padding-bottom: 50px;
	flex-direction:column;
	}	
	.footer_menu_ul {
	display: flex;
	flex-direction:column;
	margin: 40px auto 0;
	border-top: solid 1px #d4d4d4;
	}
	.footer_menu_item {
	border-bottom: dotted 1px #B2B2B2;
	}
	.footer_menu_item a{
	font-size: 1.5rem;
	flex-direction:row-reverse;
	justify-content: space-between;
	padding: 8px 0;
	}
	.footer_address_wrap{
	margin: 40px 0 0;
	text-align: center;
	}
	.footer_reserve_link a{
	justify-content: center;
	}
	.footer_reserve_link a span {
	margin-left: 20px;
	}
	.footer_reserve_link{
	margin-bottom: 30px;
	}
	.footer_googlemap_link a{
	justify-content:center;
	padding: 10px 0;
	}
	.footer_reserve_link a span{
	font-size: 2.4rem;
	letter-spacing: 0.5em;
	}
}


/* Go Page Top */

#go_pagetop{
position: fixed;
width: 40px;
height: 40px;
border-radius: 2px;
/* bottom: 30px; */
bottom: -100px;
right:30px;
background-color: rgba(74,74,74,0.50);
color: rgba(0,0,0,0.00);
overflow: hidden;
z-index: 10;
opacity: 0;
transition: bottom 0.7s ease, opacity 0.7s ease;
transform: translate3d( 0,0,0);
}

#go_pagetop.visible{
bottom: 30px;
opacity: 1;
}

body:has(.grecaptcha-badge) #go_pagetop.visible{
    bottom: 100px;
}

#go_pagetop::after{
display: block;
position: absolute;
width: 40px;
height: 40px;
top: 0;
left:0;
content: "";
background-image: url("../img/common/google_icon/stat_2_24dp_FFF_FILL0_wght400_GRAD0_opsz24.svg");
background-position: center;
background-size: 30px;
background-repeat: no-repeat;
}


/* now loading */
#nowload_wrapper{
position: fixed;
z-index: -1;
width: 0;
height: 0;
display: none;
opacity: 0;
background: url("../img/common/background_SX096_1000x1000px.jpg") repeat;
overflow: hidden;
}

#nowload_wrapper.visible{
position: fixed;
display: block;
z-index: 12000;
width: 100%;
height: 100svh;
opacity: 1;
transition: opacity 1s;
}
#nowload_wrapper.fadeout{
position: fixed;
display: block;
z-index: 12000;
width: 100%;
height: 100svh;
opacity: 0;
transition: opacity 1s;
}

#nowload_logomark{
position: absolute;
width: 9.8%;
max-width: 126px;
}
#nowload_logomark .logomark_set{
display: block;
width: 100%;
animation: nowloadaction;
animation-duration: 2s;
animation-iteration-count:infinite;
opacity: 0.3;
}
@keyframes nowloadaction{
    0%{
    opacity: 0.3;
    }
    50%{
       opacity: 1; 
    }
    100%{
    opacity: 0.3;
    }
}

#nowload_logomark .logomark_set img {
width: 100%;
height: auto;
}
#nowload_logomark .logomark_set_mark{
opacity: 0.8;
margin-bottom: 22%;
}

@media print, screen and (min-width:1025px) {

	#nowload_logomark{
	top:50%;
	left:50%;
	transform: translate(-50%,-50%);
	}

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

	#nowload_logomark{
	top:130px;
	left:50%;
	transform: translateX(-50%);
	}
    
}
@media print, screen and (min-width:768px) {
	#nowload_logomark{
	min-width: 110px;
	}
}
@media screen and (max-width:767px) {

	#nowload_logomark{
	top:130px;
	left:50%;
	transform: translateX(-50%);
	min-width: 96px;
	}

}