@charset "utf-8";

/* ===================================================
Home CSS
====================================================== */
/*@-webkit-keyframes loading_animation {
0% { background: #8e7bdf; }
50% { background: #cbc1f7;}
100% { background: #e5dffb;}

}
@keyframes loading_animation {
0% { background: #8e7bdf; }
50% { background: #cbc1f7;}
100% { background: #e5dffb;}
}*/

/*#loading {
display: flex; align-items: center; justify-content: center; flex-direction: column;
width: 100%; height: 100vh; min-height: 780px; padding: 0 0 62px;
position: fixed; top: 0; left: 0; z-index: 1000; background: #000; }
#loading div { text-align: center; }
#loading.load_start { opacity: 1; transition: opacity 1s; }
#loading.loaded { opacity: 0; pointer-events: none; }
#loading p:last-child { padding-top: 50px;}
#loading p span { width: 10px; height: 10px; border-radius: 5px; background: #8e7bdf; position: relative; display: block; -webkit-animation: loading_animation 1.6s infinite linear alternate; animation: loading_animation 1.6s infinite linear alternate; animation-delay: .5s; }
#loading p span::before,
#loading p span::after { content: ''; display: inline-block; width: 10px; height: 10px; border-radius: 5px; position: absolute; -webkit-animation: loading_animation 1.6s infinite linear alternate; animation: loading_animation 1.6s infinite linear alternate; }
#loading p span::before { background: #cbc1f7; left: -20px; animation-delay: 0s;}
#loading p span::after { background: #e5dffb; right: -20px; animation-delay: 1s;}

@media screen and (max-width: 600px) {
#loading { min-height: 500px; padding: 0 0 6vh;}
#loading .logo img { width: 33vw; max-width: 180px; }
#loading p:last-child { padding-top: 6.5vw; }
}*/

/* common */
h2 { font-size: 60px; letter-spacing: 0.1em; }
@media screen and (max-width: 600px) {
h2 { font-size: 34px; }
}

/* ---------------------------------------------------
main_img
------------------------------------------------------ */
#main_slide { position: relative;}
/* #main_img .movie, */
#main_img .slick { height: calc(100vh - 90px); min-height: 800px; overflow: hidden;}
#main_img .slick img { width: 100%; height: calc(100vh - 90px); transform: scale(1.1); transition: transform 10s linear; min-height: 800px;}
#main_img .slick-animate img { transform: scale(1.1) translateX(-5%);}
#main_img .start_btn { display: block; text-align: center; position: absolute; bottom: 50%; left: 50%; transform: translate(-50%,50%); transition: opacity 0.5s;}
#main_img .start_btn:hover {text-decoration: none; opacity: 0.75;}
#main_img .start_btn span { display: block; margin-top: 5px; text-shadow: 0 0 5px #000;}
#main_img iframe { width: calc(100% - 140px); height: 100%; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);}
#main_img #movie { display: none; width: 100%; height: 100%; position: fixed; z-index: 10000; text-align: center; background: #000; overflow: hidden; top: 0; left: 0;}
#main_img #movie .movie_close { position: absolute; top: 10px; right: 10px; z-index: 1;}

@media screen and (max-width: 600px) {
#main_img .slick { height: calc(100vh - 15vw); min-height: 0;}
#main_img .slick img { height: calc(100vh - 15vw);}
#main_img iframe { width: 100%; height: calc(100% - 100px);}
#main_img img { display: inline;}
#main_img #movie .movie_close img { width: 40px; height: 40px;}
}

/* ---------------------------------------------------
reserve_col
------------------------------------------------------ */
#reserve_col { position: relative; padding: 45px 0 30px; background: #262829;}
/*#reserve_col::before { content: ''; display: block; width: calc(99% - 90px); height: 100%; background: url(../../common/img/sec_bg01.jpg); position: absolute; top: 0; left: 0; z-index: -1;}*/
#reserve_col > div { display: flex; justify-content: space-between; width: 1000px; margin: 0 auto;}
#reserve_col .reserve { width: 100%;}
#reserve_col .reserve > dl { display: flex; justify-content: space-between; width: 90%; margin: 0 auto;}
#reserve_col .reserve > dl > dt { width: 130px; display: flex; align-items: center; font-size: 20px; position: relative;}
#reserve_col .reserve > dl > dt::before { content: ''; display: block; width: 16px; height: 16px; background: url(../../img/icon_search.svg)no-repeat center; background-size: contain; margin-right: 10px; position: absolute; left: -24px; top: 9px; /*top: 50%; transform: translateY(-50%);*/}
#reserve_col .reserve > dl > dt.tw::before { top: 50%; transform: translateY(-50%);}
#reserve_col .reserve > dl > dd { width: calc(100% - 160px);}
#reserve_col .reserve ul { margin-top: 40px; display: flex; justify-content: space-between; align-items: baseline;}
/*#reserve_col .reserve ul li + li { margin-left: 35px;}*/
#reserve_col .reserve ul li { display: flex; align-items: center;}
#reserve_col .reserve ul li::before { content: ''; display: block; width: 6px; height: 11px; background: url(../../img/icon_arrow01.svg)no-repeat center; background-size: contain; margin-right: 8px;}
#reserve_col .reserve ul li a { color: #a9a9a9; transition: color .3s; font-size: 15px;}
#reserve_col .reserve ul li a:hover{ text-decoration: none;}

#reserve_col .reserve ul li.telnum{ color: #a9a9a9;}
#reserve_col .reserve ul li.telnum::before { display: none;}
#reserve_col .reserve ul li.telnum a { color: #a9a9a9;}
#reserve_col .reserve ul li.telnum .tel-link span { font-size: 28px; font-family: "Yu Mincho", "YuMincho", serif;}

#search_489ban form { display: flex;}
#search_489ban form dt { display: block; font-size: 14px; line-height: 1;}
#search_489ban input[type="text"],
#search_489ban select { border: none; border-radius: 0; font-family: "Yu Mincho", YuMincho, "Hiragino Mincho ProN", serif; -webkit-appearance: none; -moz-appearance: none; appearance: none; outline: none; height: 50px;}
#search_489ban .inbox_489ban,
#search_489ban button { margin-left: 35px;}
#search_489ban .date_489ban input[type="text"] { font-size: 28px; color: #fff; width: 200px; height: 50px; padding: 5px 25px 5px 0; background-color: #1a1a1a; box-sizing: border-box; border-bottom: 1px solid #7c7c7c; background: url(../../img/icon_calendar.svg)no-repeat center right; letter-spacing: 1.5px; }
#search_489ban .date_489ban input[type="text"]:disabled { color: #7c7c7c;}
#search_489ban .date_489ban dd label { margin-left: 5px;}
#search_489ban .stay_489ban { position: relative;}
#search_489ban select { font-size: 16px; position: absolute; bottom: 0; left: 0; width: 100px; opacity: 0;}
#search_489ban .stay_label { font-size: 26px; width: 100%; height: 50px; border-bottom: 1px solid #7c7c7c; letter-spacing: 1px; background: url(../../img/icon_searcharrow.svg)no-repeat center right 5px; background-size: 8px 16px;}
#search_489ban button { height: 50px; font-family: "Yu Mincho", YuMincho, "Hiragino Mincho ProN", serif; flex-grow: 1; background: #474e6e; border: none; color: #fff; letter-spacing: 2px; font-size: 16px; transition: opacity .5s; margin-top: 14px;}
/*#reserve_col .txt { width: 310px; padding-top: 14px;}
#reserve_col .txt p { margin-bottom: 15px;}
#reserve_col .txt p > span { font-size: 26px; color: #a58b4b; display: flex; align-items: center; line-height: 1.2;}
#reserve_col .txt p > span .amiri { font-size: 32px;}
#reserve_col .txt p > span span:nth-of-type(2) { margin: 0 0 5px 10px;}
#reserve_col .txt .tel-link { color: #a9a9a9;}
#reserve_col .txt .tel-link span { font-size: 28px;}*/

@media screen and (hover: hover) {
#reserve_col .reserve ul li a:hover { color: #fff;}
#search_489ban button:hover { opacity: .75;}
}

@media screen and (max-width: 1350px) {
/*#reserve_col .reserve { width: calc(100% - 320px);}*/
/*#reserve_col .reserve ul li + li { margin-left: 30px;}*/
/*#reserve_col .txt { width: 302px;}*/
}

@media screen and (max-width: 1300px) {
#reserve_col .reserve ul li + li { margin-left: 18px;}
#reserve_col .reserve ul li::before { margin-right: 5px;}
#search_489ban .date_489ban dd label { display: block; margin-left: 0;}
}

@media screen and (max-width: 600px) {
#reserve_col { background: url(../../common/img/sec_bg01.jpg); padding: 30px 0 40px; position: relative;}
#reserve_col::before { content: '';}
#reserve_col > div { display: flex; justify-content: space-between; flex-wrap: wrap; width: 90%; margin: 0 auto;}
#reserve_col .reserve { width: 100%; order: 1; margin-top: 20px;}
#reserve_col .reserve > dl { display: block; border: 1px solid #666666; padding: 20px 5%;}
#reserve_col .reserve > dl > dt { width: 100%; justify-content: center;}
#reserve_col .reserve > dl > dt::before { position: static;}
#reserve_col .reserve > dl > dt.tw::before { transform: translateY(0);}
#reserve_col .reserve > dl > dd { width: 100%; margin-top: 20px; text-align: center;}
#reserve_col .reserve ul { display: block; margin-top: 25px;}
#reserve_col .reserve ul li + li { margin: 10px 0 0;}
#search_489ban form { flex-wrap: wrap;}
#search_489ban .date_489ban { margin-bottom: 25px;}
#search_489ban input[type="text"],
#search_489ban select { height: 45px;}
#search_489ban .date_489ban input[type="text"] { font-size: 24px; width: 180px; height: 45px;}
#search_489ban .date_489ban dd label { display: block; margin: 5px 0 0 0;}
#search_489ban .stay_label { font-size: 22px; padding: 5px 0; height: 45px;}
#search_489ban .inbox_489ban{ margin: 0 auto;}
#search_489ban button { margin: 15px 0 0; width: 100%; height: 45px; flex-grow: 0; flex-shrink: 1;}
/*#reserve_col .txt { width: 100%; padding-top: 0;}
#reserve_col .txt p { margin-bottom: 0; text-align: center;}
#reserve_col .txt p > span { justify-content: center;}
#reserve_col .txt .tel-link { display: block; position: absolute; bottom: 25px; left: 4%; border-bottom: 1px solid #a9a9a9; line-height: 1;}*/
}

@media screen and (max-width: 500px) {
#search_489ban .date_489ban { width: 100%;}
/*#search_489ban .inbox_489ban { margin-left: 0;}*/
/*#search_489ban button { margin: 14px 0 0 20px;}*/
}

@media screen and (max-width: 390px) {
/*#search_489ban button { width: 140px;}*/
}

@media screen and (max-width: 340px) {
/*#search_489ban .date_489ban dd label { display: block; margin-left: 0;}*/
}

/* ---------------------------------------------------
.info_box お知らせ
------------------------------------------------------ */
.info_box { margin: 40px 0 45px; }
.info_box .inner_md { padding: 30px 4%; border: 5px solid #333; text-align: center; }
.info_box .inner_md h2 { margin-bottom: 1em; font-size: 20px; }
.info_box .inner_md h2 span { display: inline-block; }
.info_box .inner_md h2+p { margin-bottom: 1.2em; line-height: 1.8; }
.info_box .inner_md a { display: inline-block; line-height: 47px; padding: 0 80px; color: #000; background: #e4e4e4; transition: background-color .5s, color .5s; }
.info_box .inner_md a:hover { text-decoration: none; }
.info_box .inner { width: 1200px; max-width: 92%; margin: 40px auto 0; text-align: center; }
.info_box .inner a { transition: opacity .5s;}

@media screen and (hover: hover) {
.info_box .inner_md a:hover { background: #474e6e; color: #fff; }
.info_box .inner a:hover { opacity: .75; }
}
@media screen and (max-width: 600px) {
.info_box .inner_md h2+p { text-align: left; }
.info_box .inner_md a { width: 220px; max-width: 100%; padding: 0 4%; }
}


/* ---------------------------------------------------
#meal_col
------------------------------------------------------ */
#meal_col { padding: 135px 0 130px; background: url(../img/top/meal_bg.jpg)no-repeat center/cover; }
#meal_col .inner_md { display: flex; flex-direction: row-reverse; }
#meal_col .txt { width: calc(100% - 520px); font-size: 17px; }
#meal_col h2 { margin-bottom: 45px; font-size: 36px; }
#meal_col .txt p { line-height: 2; }
#meal_col .txt p+p { margin-top: 1.5em; }
#meal_col .photo { width: 520px; margin-top: 25px; }
#meal_col .photo li+li { margin-top: 55px; }
#meal_col .photo li:last-of-type { padding-left: 100px; }

@media screen and (max-width: 1304px) {}
@media screen and (max-width: 600px) {
#meal_col { padding: 13vw 0 12vw; }
#meal_col .inner_md { flex-direction: column; }
#meal_col .txt, #meal_col .photo { width: 100%; }
#meal_col .txt { font-size: 15px; }
#meal_col h2 { margin-bottom: 30px; font-size: 26px; }
#meal_col .photo { display: flex; width: 100%; margin-top: 35px; }
#meal_col .photo li { width: 48%; }
#meal_col .photo li+li { margin-top: 25px; }
#meal_col .photo li:last-of-type { margin-left: auto; padding-left: 0; text-align: right; }
}


/* ---------------------------------------------------
#acc_col
------------------------------------------------------ */
@keyframes map {
0% { opacity: .3; }
50% { opacity: 1; }
100% { opacity: .3; }
}

#acc_col { position: relative; z-index: 0; padding: 90px 0 0 calc(50vw - 600px); }
#acc_col .sub { width: 70%; margin: 20px 0 65px; font-size: 30px; }
#acc_col .txt { width: 520px; padding: 0 45px 60px 0; }
#acc_col .txt p { line-height: 2; }
#acc_col .txt .map { position: relative; margin-top: 150px; text-align: center;}
#acc_col .txt .map .amiri,
#acc_col .txt .map .pin { position: absolute; }
#acc_col .txt .map .amiri { top: 100px; left: 115px; font-size: 20px; }
#acc_col .txt .map .pin { top: 50%; left: 50%; transform: translate(-100%, 0%); filter: drop-shadow(0px 2px 2.5px black); }
#acc_col .cmn_link_01 { margin-top: 60px; }
#acc_col .img { position: absolute; top: 0; left: 0; z-index: -2; width: 100%; height: 100%;}
#acc_col .img picture { display: block; height: 100%; }
/* #acc_col .point { position: absolute; bottom: calc(50% - 4vw); right: calc(50% - 16.2vw); transform: translate(-50%, -50%); line-height: 1; animation: map 1.5s ease infinite; } */

@media screen and (max-width: 1500px) {
/* #acc_col .point { bottom: calc(50% - 60px); right: calc(50% - 245px);} */
}
@media screen and (max-width: 1304px) {
#acc_col { padding-left: 4%; }
}
@media screen and (min-width: 601px) {
#acc_col::before { position: absolute; top: 0; left: 0; z-index: -1; content: ''; display: block; width: calc(50vw - 80px); min-width: calc(4% + 520px); height: 100%; background: rgba(0 0 0/70%); }
}
@media screen and (max-width: 600px) {
#acc_col { padding: 9vw 4% 0; }
#acc_col .sub { width: auto; margin: 10px 0 30px; font-size: 20px; line-height: 1.7; }
#acc_col .txt { width: 100%; padding: 0; }
#acc_col .txt p { order: 1; text-shadow: 0 0 3px #000; }
#acc_col .txt .map { order: 3; margin-top: 66vw; text-align: right; backdrop-filter: drop-shadow(0 0 10px #000) drop-shadow(0 0 10px #000); }
#acc_col .txt .map .pin { top: 53.5%; left: auto; right: 33.5%; transform: none; width: 20px; }
#acc_col .txt .map .amiri { /*top: 90px; left: auto; right: 165px;*/ left: auto; top: 48%; right: 50%; font-size: 16px; }
#acc_col .txt .map>img { /*width: 260px;*/ width: 60vw; }
#acc_col .cmn_link_01 { order: 2; margin-top: 8vw; }
#acc_col .img { padding-top: 22%; }
#acc_col .img picture img { object-fit: contain; }
/* #acc_col .point { right: auto; left: calc(50% - 13.5vw); bottom: calc(50% - 19.2vw); }
#acc_col .point img { width: 12px } */
}


/* ---------------------------------------------------
#sight_col
------------------------------------------------------ */
#sight_col { position: relative; z-index: 0; padding: 95px 0 85px; }
#sight_col h2 { text-align: center; }
#sight_col ul { display: flex; flex-wrap: wrap; justify-content: space-between; flex-direction: column; width: 1016px; height: 557px; margin: 50px auto 0; }
#sight_col ul li { position: relative; }
#sight_col ul li span {  position: absolute; bottom: 0; left: 0; background: rgba(0 0 0/60%); width: 100%; padding: 8px 20px; box-sizing: border-box; }
#sight_col .cmn_link_01 { margin-top: 60px; }
#sight_col.sa::before { opacity: 1; }

@media screen and (min-width: 601px) {
#sight_col::before { opacity: 0; position: absolute; top: 0; right: 0; z-index: -1; content: ''; display: block; width: 479px; height: 565px; background: url(../img/cmn/circle.png)no-repeat center/cover; transition: opacity .6s ease; transition-delay: 3s; }
}
@media screen and (max-width: 600px) {
#sight_col { padding: 11vw 0 10vw; }
#sight_col ul { flex-direction: row; width: 100%; height: auto; margin-top: 30px; }
#sight_col ul li { width: 49%; }
#sight_col ul li:first-of-type { width: 100%; height: 49vw; margin-bottom: 2%; }
#sight_col ul li span { padding: 4px 12px; }
#sight_col .cmn_link_01 { margin-top: 10vw; }
}


/* ---------------------------------------------------
#service_col
------------------------------------------------------ */
#service_col { padding-top: 50px; }
#service_col>h2 { text-align: center; letter-spacing: .1em; }
#service_col>p { margin-top: 10px; font-size: 30px; text-align: center; }
#service_col>a { position: relative; display: block; height: 500px; overflow: hidden; }
#service_col>a:not(:last-of-type) { margin-bottom: 10px; }
#service_col>a .inner_md { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 1; display: flex; flex-direction: column; justify-content: center; height: 100%; padding-left: 50px; text-shadow: 0 0 10px rgb(0 0 0), 0 0 5px rgb(0 0 0 / 70%); }
#service_col>a:hover { text-decoration: none; }
#service_col>a h2 { font-size: 50px; }
#service_col>a p { font-size: 20px; }
#service_col>a .img { height: 100%; transition: transform .75s, opacity .75s;}
#cuisine { margin-top: 60px; }

@media screen and (hover: hover) {
#service_col>a:hover .img { transform: scale(1.05); opacity: .6; }
}
@media screen and (max-width: 600px) {
#service_col { padding-top: 7vw; }
#service_col>p { font-size: 16px; }
#service_col>a { height: 56vw; }
#service_col>a .inner_md { padding-left: 0; text-align: center; }
#service_col>a .inner_md h2 { font-size: 33px; }
#service_col>a p { font-size: 16px; }
}


/* ---------------------------------------------------
#info_col
------------------------------------------------------ */
#info_col { padding: 130px 0 160px; }
#info_col h2 { margin-bottom: 80px; text-align: center; }

@media screen and (max-width: 600px) {
#info_col { padding: 14vw 0 20vw; }
#info_col h2 { margin-bottom: 30px; }
}
