@charset "utf-8";

/* reset */
#page {
    font-family: unset;
    line-height: unset;
    overflow: unset;
    width: unset;
    min-width: unset;
    color: unset;
    font-weight: unset;
}
/* /reset */

/* all */
* { box-sizing: border-box;}
#page { color: #222222;}
#page a {
    opacity: 1;
	transition: opacity .25s ease-in-out;
    text-decoration: none;
}
#page a:hover {
    opacity: .65;
    text-decoration: none;
}
img { width: 100%;}

figure,
picture {
    display: block;
}

.btn_common {
    width: 176px;
    height: 32px;
    margin-inline: auto;
    background-color: #FFF;
    border: solid 1px #000000;
    border-radius: 100vmax;
    font-size: 14px;
    color: #222;
    display: flex;
    flex-direction: row;
    align-items: center;
}
.btn_common::before {
    content: "";
    display: block;
    width: 7%;
    height: auto;
    padding-block: 3%;
    margin-left: 8.5%;
    background-image: url(../../common/img/icon_vector_member-hotel01.svg);
    background-repeat: no-repeat;
    background-size: 100%;
}
.btn_common span {
    display: block;
    width: 70%;
    text-align: center;
}
@media screen and (max-width: 700px) {
    .btn_common {
        font-size: 3.7334vw;
        width: 46.9334vw;
        height: auto;
        padding-block: 0.27%;
    }
}
/* /all */

/* kv */
#content {
    font-family: yu-gothic-pr6n, sans-serif;
    font-style: normal;
    font-weight: 400;
}

.kv_slide {
    max-width: 1440px;
    width: 100%;
    height: 580px;
    margin-inline: auto;
    margin-bottom: 40px;
    position: relative;
    overflow: hidden;
}
.kv_slide picture {
    object-fit: cover;
}
@keyframes zoom {
	0% { transform: scale(1);}
	100% { transform: scale(1.15);}
}
.kv_slide .swiper-slide-active div,
.kv_slide .swiper-slide-duplicate-active div,
.kv_slide .swiper-slide-prev div {
	animation: zoom 10s linear 0s normal both;
}
.kv_slide .swiper-slide div {
    height: 580px;
    background-position: center center;
    background-size: 100%;
    background-repeat: no-repeat;
}
.kv_slide .swiper-slide .kv01 {
    background-image: url(../../img/kv_slide_pc01.webp);
    background-image: image-set(url(../../img/kv_slide_pc01.webp) 1x, url(../../img/kv_slide_pc01@2x.webp) 2x);
    background-image: -webkit-image-set(url(../../img/kv_slide_pc01.webp) 1x, url(../../img/kv_slide_pc01@2x.webp) 2x);
}
.kv_slide .swiper-slide .kv02 {
    background-image: url(../../img/kv_slide_pc02.webp);
    background-image: image-set(url(../../img/kv_slide_pc02.webp) 1x, url(../../img/kv_slide_pc02@2x.webp) 2x);
    background-image: -webkit-image-set(url(../../img/kv_slide_pc02.webp) 1x, url(../../img/kv_slide_pc02@2x.webp) 2x);
}
.kv_slide .swiper-slide .kv03 {
    background-image: url(../../img/kv_slide_pc03.webp);
    background-image: image-set(url(../../img/kv_slide_pc03.webp) 1x, url(../../img/kv_slide_pc03@2x.webp) 2x);
    background-image: -webkit-image-set(url(../../img/kv_slide_pc03.webp) 1x, url(../../img/kv_slide_pc03@2x.webp) 2x);
}
.kv_slide .swiper-slide .kv04 {
    background-image: url(../../img/kv_slide_pc04.webp);
    background-image: image-set(url(../../img/kv_slide_pc04.webp) 1x, url(../../img/kv_slide_pc04@2x.webp) 2x);
    background-image: -webkit-image-set(url(../../img/kv_slide_pc04.webp) 1x, url(../../img/kv_slide_pc04@2x.webp) 2x);
}
.kv_slide .swiper-slide .kv05 {
    background-image: url(../../img/kv_slide_pc05.webp);
    background-image: image-set(url(../../img/kv_slide_pc05.webp) 1x, url(../../img/kv_slide_pc05@2x.webp) 2x);
    background-image: -webkit-image-set(url(../../img/kv_slide_pc05.webp) 1x, url(../../img/kv_slide_pc05@2x.webp) 2x);
}

.kv_slide .kv_text {
    width: 217px;
    height: 419px;
    background-color: rgb(255 255 255 / 0.9);
    position: absolute;
    top: 79px;
    right: 0;
    left: 0;
    margin: 0 auto;
    z-index: 1;
    padding-block: 24px 6px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    border: 1px solid #444444;
}
.kv_slide .kv_text::after {
    content: "";
    display: block;
    width: 228px;
    height: 431px;
    background-image: url(../../img/kv_frame_pc.webp);
    background-repeat: no-repeat;
    background-size: 100%;
    position: absolute;
    top: -7px;
    left: -7px;
    margin: 0 auto;
    z-index: 2;
    pointer-events: none;
}
.kv_slide .kv_text hgroup {
    writing-mode: vertical-rl;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    height: 100%;
    position: absolute;
    top: 73px;
    left: 0;
    right: 0;
    margin: 0 auto;
    padding-left: 4px;
}

.kv_slide .kv_text hgroup p {
    font-size: 30px;
    line-height: 1.6;
    color: #222;
    letter-spacing: 3px;
    white-space: nowrap;
    padding-left: 6px;
}
.kv_slide .kv_text hgroup p span {
    text-indent: 1em;
    display: block;
}
.kv_slide .kv_text hgroup h1 {
    font-size: 20px;
    font-weight: 400;
    color: #000;
    padding-top: 139px;
    letter-spacing: 2px;
    display: flex;
    white-space: nowrap;
}
.kv_slide .kv_text hgroup + p {
    font-size: 13px;
    text-align: center;
    color: #A37E39;
}

@media screen and (max-width: 1440px) {
    .kv_slide .swiper-slide div {
        background-size: 1440px 580px;
    }
}
@media screen and (max-width: 700px) {
    .kv_slide {
        height: auto;
        aspect-ratio: 1 / 1.12;
        margin-bottom: 10.6%;
    }
    .kv_slide .swiper-slide div {
        background-size: 100%;
        height: auto;
        aspect-ratio: 1 / 1.12;
    }
    .kv_slide .swiper-slide .kv01 {
        background-image: url(../../img/kv_slide_sp01.webp);
        background-image: image-set(url(../../img/kv_slide_sp01.webp) 1x, url(../../img/kv_slide_sp01.webp) 2x);
        background-image: -webkit-image-set(url(../../img/kv_slide_sp01.webp) 1x, url(../../img/kv_slide_sp01.webp) 2x);
    }
    .kv_slide .swiper-slide .kv02 {
        background-image: url(../../img/kv_slide_sp02.webp);
        background-image: image-set(url(../../img/kv_slide_sp02.webp) 1x, url(../../img/kv_slide_sp02.webp) 2x);
        background-image: -webkit-image-set(url(../../img/kv_slide_sp02.webp) 1x, url(../../img/kv_slide_sp02.webp) 2x);
    }
    .kv_slide .swiper-slide .kv03 {
        background-image: url(../../img/kv_slide_sp03.webp);
        background-image: image-set(url(../../img/kv_slide_sp03.webp) 1x, url(../../img/kv_slide_sp03.webp) 2x);
        background-image: -webkit-image-set(url(../../img/kv_slide_sp03.webp) 1x, url(../../img/kv_slide_sp03.webp) 2x);
    }
    .kv_slide .swiper-slide .kv04 {
        background-image: url(../../img/kv_slide_sp04.webp);
        background-image: image-set(url(../../img/kv_slide_sp04.webp) 1x, url(../../img/kv_slide_sp04.webp) 2x);
        background-image: -webkit-image-set(url(../../img/kv_slide_sp04.webp) 1x, url(../../img/kv_slide_sp04.webp) 2x);
    }
    .kv_slide .swiper-slide .kv05 {
        background-image: url(../../img/kv_slide_sp05.webp);
        background-image: image-set(url(../../img/kv_slide_sp05.webp) 1x, url(../../img/kv_slide_sp05.webp) 2x);
        background-image: -webkit-image-set(url(../../img/kv_slide_sp05.webp) 1x, url(../../img/kv_slide_sp05.webp) 2x);
    }
    .kv_slide .kv_text {
        width: 43.6294%;
        top: 12.4%;
        padding-block: 2% 3.8%;
        height: auto;
        aspect-ratio: 1 / 1.795;
    }
    .kv_slide .kv_text hgroup {
        display: block;
        height: auto;
        aspect-ratio: 1 / 1.516;
        top: 11.8%;
        padding-left: 1.7%;
    }
    .kv_slide .kv_text figure {
        width: 36.971vw;
    }
    .kv_slide .kv_text hgroup p {
        font-size: 5.9654vw;
        letter-spacing: 0.13em;
        position: absolute;
        padding-right: 0;
        padding-left: 0;
        right: 18%;
        font-weight: 600;
    }
    .kv_slide .kv_text hgroup h1 {
        font-size: 4.2614vw;
        position: absolute;
        bottom: 0;
        right: 65%;
        padding-top: 0;
        padding-right: 0;
    }
    .kv_slide .kv_text hgroup + p {
        font-size: 2.504vw;
    }
    .kv_slide .kv_text::after {
        width: 107.14%;
        height: auto;
        aspect-ratio: 1 / 1.75;
        background-image: url(../../img/kv_frame_sp.webp);
        background-size: 100% 100%;
        top: -2%;
        left: -3.5%;
    }
}
/* /kv */

/* 緊急のお知らせ */
.notice {
    max-width: 980px;
    margin-inline: auto;
    padding-block: 17px;
    border: #CD0614 1px solid;
    margin-bottom: 22px;
}
.notice p {
    color: #CD0614;
    text-align: center;
}
.notice p.notice-heading {
    font-size: 22px;
    font-weight: 600;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    padding-bottom: 5px;
}
.notice p.notice-heading::before,
.notice p.notice-heading::after {
    content: "";
    display: block;
    width: 20px;
    aspect-ratio: 1 / 0.1;
    margin-inline: 13px;
    background-color: rgb(205 6 20 / .4);
    flex-shrink: 0;
}
.notice p.notice-text {
    font-size: 15px;
    padding-inline: 20px;
    line-height: 2.2;
}
.notice p.notice-text a {
    color: #CD0614;
    text-decoration: underline!important;
}
@media screen and (max-width: 1020px) {
    .notice { margin-inline: 20px;}
}
@media screen and (max-width: 700px) {
    .notice {
        margin-inline: 3.33%;
        padding-block: 3.4% 5%;
        margin-bottom: 7.7%;
    }
    .notice p.notice-heading {
        font-size: 4.8vw;
        padding-bottom: 3.2%;
    }
    .notice p.notice-heading::before,
    .notice p.notice-heading::after {
        width: 4.5334vw;
    }
    .notice p.notice-text {
        font-size: 3.7334vw;
        padding-inline: 8%;
        text-align: left;
    }
}
/* /緊急のお知らせ */

/* バナースライドエリア */
#topics {
    width: 100%;
    position: relative;
}
#topics {
    height: 310px;
    margin-bottom: 29px;
}

#topics .subheading {
    width: 880px;
    font-size: 20px;
    display: flex;
    justify-content: left;
    align-items: center;
    position: absolute;
    top: 18px;
    left: 0;
    right: 0;
    margin: 0 auto;
    z-index: 1;
}
#topics .subheading::before {
    content: "";
    display: block;
    width: 4px;
    aspect-ratio: 1 / 5.5;
    background-color: #A37E39;
    margin-right: 10px;
    flex-shrink: 0;
}
@media screen and (max-width: 1200px) {
    #hotel-plan::before { height: 460px;}
}
@media screen and (max-width: 980px) {
    #topics .subheading {
        width: unset;
        left: 50px;
    }
}
@media screen and (max-width: 700px) {
    #topics {
        height: auto;
        margin-bottom: 5.5%;
    }
    #topics .subheading {
        font-size: 4.5334vw;
        top: 0;
        left: 8.7%;
        line-height: 2.9;
    }
    #topics .subheading::before {
        width: 0.9067vw;
        margin-right: 2.4vw;
    }
}
/* /topics */

/* swiper */
.swiper-slide img {
    width: 100%;
}
.swiper_carousel {
    width: 100%;
    padding-block: 62px 50px;
    overflow: hidden;
    position: relative;
}
.swiper_carousel::before,
.swiper_carousel::after {
    content: "";
    display: block;
    width: calc((100% - 1200px) / 2);
    height: 310px;
    background-color: rgb(255 255 255 / .9);
    position: absolute;
    top: 0;
    z-index: 2;
}
.swiper_carousel::before { left: 0;}
.swiper_carousel::after { right: 0;}

.swiper_carousel .swiper-slide {
    width: 287px;
    height: 191px;
}

.swiper-button-next,
.swiper-button-prev {
    width: 80px;
    height: var(--swiper-navigation-size);
    margin-top: calc(0px - (var(--swiper-navigation-size) / 2));
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: unset;
    position: absolute;
    z-index: 10;
    opacity: 1;
	transition: opacity .25s ease-in-out;
}

.swiper-button-next:hover,
.swiper-button-prev:hover {
    opacity: .65;
    text-decoration: none;
}

.swiper-button-prev,
.swiper-button-next,
.swiper-rtl .swiper-button-prev,
.swiper-rtl .swiper-button-next {
    top: 34px;
    left: 50%;
    transform: translateX(-50%);
}
.swiper-button-prev,
.swiper-rtl .swiper-button-next {
    margin-left: 320px;
}
.swiper-button-next,
.swiper-rtl .swiper-button-prev {
    margin-left: 404px;
}
.swiper-button-prev::after { content: 'Prev';}
.swiper-button-next::after { content: 'Next';}

.swiper-button-prev::after,
.swiper-button-next::after {
    display: block;
    font-family: unset;
    background-repeat: no-repeat;
    background-size: 48%;
    font-size: 14px;
    line-height: 2.3;
    width: 68px;
    height: 33px;
}
.swiper-button-next::after {
    background-image: url(../../common/img/swiper_btn_next.webp);
    background-position: 0 0;
    text-align: right;
}
.swiper-button-prev::after {
    background-image: url(../../common/img/swiper_btn_prev.webp);
    background-position: 35px 0;
}

.swiper-horizontal > .swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-pagination-custom,
.swiper-pagination-fraction {
    bottom: 9px;
}
.swiper-pagination-bullet {
    background: #D9D9D9;
    opacity: 1;
}
.swiper-pagination-bullet-active {
    background: #222;
}
.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 8px;
}

.swiper_rsp-only {
    width: 100%;
    overflow: hidden;
    position: relative;
    padding-top: 62px;
}
.swiper_rsp-only .swiper-slide {
    width: 287px;
    height: auto;
}
.swiper_rsp-only .swiper-wrapper {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
}
.swiper_rsp-only .swiper-button-prev,
.swiper_rsp-only .swiper-button-next { display: none;}

@media screen and (min-width: 1201px) {
    /* swiper-init_member-top-rsp.js用 */
    /* ウインドウ幅を変動させたとき、1201px以上でswiperが適用されないようにする指定 */
    .swiper_rsp-only .swiper-wrapper {
        transform: translate3d(0px, 0px, 0px) !important;
    }
    .swiper_rsp-only .swiper-pagination {
        display: none;
    }
    .swiper_rsp-only .swiper-slide-duplicate {
        display: none;
    }
}
@media screen and (max-width: 1200px) {
    .swiper_rsp-only {
        padding-block: 62px 10px;
    }
    .swiper_rsp-only .swiper-button-prev,
    .swiper_rsp-only .swiper-button-next {
        display: flex;
    }
    .swiper_rsp-only .swiper-pagination {
        position: unset;
        padding-block: 16px;
    }
}
@media screen and (max-width: 980px) {
    .swiper-button-next, .swiper-rtl .swiper-button-prev {
        margin-left: unset;
    }
    .swiper-button-prev,
    .swiper-button-next,
    .swiper-rtl .swiper-button-prev,
    .swiper-rtl .swiper-button-next {
        left: unset;
        transform: unset;
    }
    .swiper-button-prev,
    .swiper-rtl .swiper-button-next {
        right: 127px;
        margin-left: unset;
    }
    .swiper-button-next,
    .swiper-rtl .swiper-button-prev {
        right: 43px;
    }
}
@media screen and (max-width: 700px) {
    .swiper_carousel {
        padding-block: 14.2% 12.6%;
    }
    .swiper_rsp-only {
        padding-block: 14.2% 0;
    }
    .swiper_carousel .swiper-slide,
    .swiper_rsp-only .swiper-slide {
        width: 48%;
        height: auto;
        aspect-ratio: 1 / 0.6642;
    }
    .swiper-button-next,
    .swiper-button-prev {
        width: 21.3334vw;
    }
    .swiper-button-prev::after,
    .swiper-button-next::after {
        font-size: 3.1734vw;
        width: 72%;
        height: auto;
        aspect-ratio: 1 / 0.5036;
        background-size: 50%;
    }
    .swiper-button-prev::after {
        background-position: 100% 0;
    }
    .swiper-button-prev,
    .swiper-rtl .swiper-button-next {
        right: 21.9%;
    }
    .swiper-button-next,
    .swiper-rtl .swiper-button-prev {
        right: 3%;
    }
    .swiper-button-prev,
    .swiper-button-next,
    .swiper-rtl .swiper-button-prev,
    .swiper-rtl .swiper-button-next {
        top: 0;
        height: auto;
        padding-top: 3%;
        margin: 0;
    }
    .swiper-horizontal > .swiper-pagination-bullets,
    .swiper-pagination-bullets.swiper-pagination-horizontal,
    .swiper-pagination-custom,
    .swiper-pagination-fraction {
        bottom: 6%;
    }
    .swiper_rsp-only .swiper-pagination {
        padding-block: 4.3%;
    }
    .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
    .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
        margin: 0 6px;
    }
    .swiper-pagination-bullet {
        width: 6px;
        height: 6px;
    }
}
/* /swiper */

/* common-tab */
#hotel-list {
    max-width: 1260px;
    margin-inline: auto;
    padding-inline: 30px;
}
#hotel-list .subheading {
    font-size: 20px;
    text-align: center;
    padding-bottom: 7px;
}
#hotel-list .subheading + p {
    font-size: 16px;
    text-align: center;
    padding-bottom: 32px;
}
#hotel-list .tab_btn ul {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: flex-start;
    width: 100%;
    margin-inline: auto;
    padding-bottom: 40px;
}
#hotel-list .tab_btn ul li {
    width: 50%;
    font-size: 18px;
    color: #999999;
    text-align: center;
    font-weight: 600;
    background-image: linear-gradient(transparent 0%, transparent 94%, #EDEDED 94.1%, #EDEDED 100%);
    transition: unset !important;
    cursor: pointer;
    padding-block: 0 9px;
}
#hotel-list .tab_btn ul li.active-tab {
    color: #A48966;
    background-image: linear-gradient(transparent 0%, transparent 94%, currentColor 94.1%, currentColor 100%);
    position: relative;
}
#hotel-list .btn_wrapper {
    max-width: 1200px;
    height: 88px;
    margin-inline: auto;
    background-color: #f6f3ec;
    padding-top: 28px;
}
@media screen and (max-width: 700px) {
    #hotel-list {
        padding-inline: 0;
    }
    #hotel-list .subheading {
        font-size: 4.5334vw;
        padding-bottom: 4.6%;
    }
    #hotel-list .subheading + p {
        width: 89.3334%;
        font-size: 3.7334vw;
        text-align: left;
        line-height: 1.7;
        margin-inline: auto;
        padding-bottom: 6.3%;
    }
    #hotel-list .tab_btn {
        display: none;
    }
    #hotel-list .tab_btn ul {
        width: 92%;
        padding-bottom: unset;
    }
    #hotel-list .tab_btn ul li {
        font-size: 3.7334vw;
        background-image: linear-gradient(transparent 0%, transparent 94%, #EDEDED 94.1%, #EDEDED 100%);
        padding-block: 3.6% 2.5%;
    }
    /*spエリア別非表示のための指定*/
    #hotel-list .tab_btn ul li {
        width: 100%;
        pointer-events: none;
    }
    #hotel-list .tab_btn ul li[data-flogo="all"] {
        display: none;
    }
    /* /spエリア別非表示のための指定*/
    #hotel-list .btn_wrapper {
        width: 92%;
        height: auto;
        aspect-ratio: 1 / 0.2551;
        padding-top: 7.5%;
    }
}
/* /common-tab */

/* PC-tab */
#hotel-list .pc_tab .brand_wrapper {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
    padding-bottom: 40px;
}
#hotel-list .pc_tab .brand_wrapper .slide-image {
    width: 50%;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: 1fr;
    overflow: hidden;
}
#hotel-list .pc_tab .brand_wrapper .slide-image__item {
    grid-column: 1 / -1;
    grid-row: 1 / -1;
    opacity: 0;
    visibility: hidden;
    transition:
        opacity 0.45s cubic-bezier(0.65, 0, 0.35, 1),
        visibility 0.45s cubic-bezier(0.65, 0, 0.35, 1);
}
#hotel-list .pc_tab .brand_wrapper .slide-image__item.current {
    opacity: 1;
    visibility: visible;
    transition:
        opacity 0.45s cubic-bezier(0.65, 0, 0.35, 1),
        visibility 0.45s cubic-bezier(0.65, 0, 0.35, 1);
}
#hotel-list .pc_tab .brand_wrapper .text_container {
    width: 45%;
}
#hotel-list .pc_tab .text_container .logo_box {
    width: 65px;
    margin-inline: auto;
    padding-bottom: 28px;
}
#hotel-list .pc_tab .courtyard .text_container .logo_box {
    width: 143px;
    padding-top: 24px;
    padding-bottom: 30px;
}
#hotel-list .pc_tab .laforet .text_container .logo_box {
    width: 83px;
    padding-bottom: 21px;
}
#hotel-list .pc_tab .text_container p {
    font-size: 14px;
    line-height: 1.8;
    text-align: center;
    background-color: #f8f5f0;
    padding: 16px 16px 14px;
}
#hotel-list .pc_tab .text_container ul {
    display: flex;
    flex-direction: row;
    justify-content: left;
    flex-wrap: wrap;
    padding-top: 37px;
}
#hotel-list .pc_tab .text_container li {
    width: 50%;
    font-size: 17px;
    padding-bottom: 8px;
}
#hotel-list .pc_tab .courtyard .text_container li,
#hotel-list .pc_tab .laforet .text_container li:last-of-type {
    width: 100%;
}
#hotel-list .pc_tab .text_container li:nth-of-type(2),
#hotel-list .pc_tab .text_container li:nth-of-type(4) {
    padding-left: 20px;
}
#hotel-list .pc_tab .courtyard .text_container li:nth-of-type(2),
#hotel-list .pc_tab .courtyard .text_container li:nth-of-type(4) {
    padding-left: 0;
}
#hotel-list .pc_tab .text_container li.contract-facility {
    width: 100%;
}
#hotel-list .pc_tab .text_container li.contract-facility .fs-small {
    display: block;
    font-size: 13px;
    line-height: 2.1;
}
#hotel-list .pc_tab .text_container li a {
    color: #222;
    display: inline-flex;
    flex-direction: row;
    align-items: flex-start;
    line-height: 1.4;
}
#hotel-list .pc_tab .text_container li a::before {
    content: "";
    display: block;
    width: 19px;
    aspect-ratio: 1 / 1;
    background-image: url(../img/icon_vector-circle.webp);
    background-repeat: no-repeat;
    background-size: 100%;
    border-radius: 50%;
    margin-top: 1.2%;
    margin-right: 7px;
    flex-shrink: 0;
}

#hotel-list .pc_tab .tab_area {
    padding-bottom: 52px;
}
#hotel-list .pc_tab .map-container {
    width: 1000px;
    height: 440px;
    margin-inline: auto;
    background-image: url(../../img/search_hotels/map.webp);
    background-image: image-set(url(../../img/search_hotels/map.webp) 1x, url(../../img/search_hotels/map@2x.webp) 2x);
    background-image: -webkit-image-set(url(../../img/search_hotels/map.webp) 1x, url(../../img/search_hotels/map@2x.webp) 2x);
    background-size: 100%;
    background-repeat: no-repeat;
    position: relative;
}
#hotel-list .pc_tab .map-container .subheading {
    color: #A48966;
    font-size: 18px;
    display: flex;
    flex-direction: row;
    align-items: center;
    padding-bottom: 6px;
}
#hotel-list .pc_tab .map-container .kantou .subheading {
    padding-left: 60px;
}
#hotel-list .pc_tab .map-container .chubu .subheading {
    padding-left: 68px;
}
#hotel-list .pc_tab .map-container .kinki .subheading {
    padding-left: 58px;
}
#hotel-list .pc_tab .map-container .subheading::before,
#hotel-list .pc_tab .map-container .subheading::after {
    content: "";
    width: 50px;
    height: 1px;
    background-color: #A48966;
    margin-inline: 12px;
}
#hotel-list .pc_tab .map-container .kantou {
    width: 380px;
    position: absolute;
    top: 92px;
    left: 648px;
}
#hotel-list .pc_tab .map-container .chubu {
    width: 430px;
    position: absolute;
    top: -6px;
    left: 72px;
}
#hotel-list .pc_tab .map-container .kinki {
    width: 600px;
    position: absolute;
    top: 302px;
    left: 23px;
}
#hotel-list .pc_tab .map-container li {
    padding-bottom: 10px;
}
#hotel-list .pc_tab .map-container li a:hover {
    opacity: 1;
}
#hotel-list .pc_tab .map-container li a::after {
    content: "";
    display: block;
    width: 18px;
    height: 24px;
    background-image: url(../../img/search_hotels/map_point.webp);
    background-repeat: no-repeat;
    background-size: 100%;
    position: absolute;
}
#hotel-list .pc_tab .map-container li.lf-shuzenji a::after,
#hotel-list .pc_tab .map-container li.lf-shuzenji_g a::after {
    background-image: none;
}
#hotel-list .pc_tab .map-container li a:hover::after {
    background-image: url(../../img/search_hotels/map_point_hover.webp);
    z-index: 5;
}

#hotel-list .pc_tab .map-container li.lf-nasu a::after {
    top: 149px;
    left: -88px;
}
#hotel-list .pc_tab .map-container li.lf-gora a::after {
    top: 232px;
    left: 99px;
}
#hotel-list .pc_tab .map-container li.tmh a::after {
    top: 193px;
    left: -91px;
}
#hotel-list .pc_tab .map-container li.lf-zmh a::after {
    top: 358px;
    left: 651px;
    z-index: 5;
}
#hotel-list .pc_tab .map-container li.lf-shuzenji a::after {
    top: 358px;
    left: 651px;
    z-index: 6;
}
#hotel-list .pc_tab .map-container li.lf-shuzenji_g a::after {
    top: 358px;
    left: 651px;
    z-index: 5;
}
#hotel-list .pc_tab .map-container li.lf-ito a::after {
    top: 358px;
    left: 677px;
}
#hotel-list .pc_tab .map-container li.lf-ymh a::after {
    top: 306px;
    left: 655px;
}
#hotel-list .pc_tab .map-container li.lf-kmh a::after {
    top: 269px;
    left: 452px;
}
#hotel-list .pc_tab .map-container li.lf-cyh a::after {
    top: 259px;
    left: 438px;
}
#hotel-list .pc_tab .map-container li.lf-bmh a::after {
    top: -3px;
    left: 439px;
}
#hotel-list .pc_tab .map-container li.lf-smh a::after {
    top: 44px;
    left: 423px;
}
#hotel-list .pc_tab .map-container li.cyo a::after {
    top: 9px;
    left: 422px;
}

#hotel-list .pc_tab .map-container a {
    display: inline-flex;
    flex-direction: row;
    align-items: flex-start;
}
#hotel-list .pc_tab .map-container a > span {
    display: block;
    width: 64px;
    height: 18px;
    border-radius: 100vmax;
    background-color: #A48966;
    border: 1px solid #A48966;
    font-size: 15px;
    color: #FFF;
    text-align: center;
    line-height: 1.2;
    flex-shrink: 0;
    margin-top: 3px;
}

#hotel-list .pc_tab .map-container a:hover > span {
    color: #A48966;
    background-color: #F6F2EB;
}
#hotel-list .pc_tab .map-container .hotel-name {
    font-size: 17px;
    font-weight: 400;
    color: #222222;
    line-height: 1.4;
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    flex-wrap: wrap;
    padding-left: 7px;
}

#hotel-list .pc_tab .map-container a:hover .hotel-name {
    color: #A48966;
}
#hotel-list .pc_tab .map-container .hotel-name::before {
    content: "";
    display: block;
    width: 19px;
    height: 19px;
    background-image: url(../img/icon_vector-circle.webp);
    background-repeat: no-repeat;
    background-size: 100%;
    border-radius: 50%;
    margin-top: 3px;
    margin-right: 7px;
    flex-shrink: 0;
}
#hotel-list .pc_tab .map-container a:hover .hotel-name::before {
    background-image: url(../img/icon_vector-circle_hover.webp);
}
#hotel-list .pc_tab .map-container .hotel-name span {
    width: 100%;
    font-size: 13px;
    padding-left: 27px;
}
br.map-rsp-only {
    display: none;
}
@media screen and (max-width: 1180px) {
    #hotel-list .pc_tab .text_container ul {
        display: block;
        padding-top: 20px;
    }
    #hotel-list .pc_tab .text_container li:nth-of-type(2),
    #hotel-list .pc_tab .text_container li:nth-of-type(4) {
        padding-left: unset;
    }
    #hotel-list .pc_tab .text_container li {
        width: 270px;
        padding-bottom: 15px;
    }
    #hotel-list .pc_tab .text_container .logo_box {
        padding-bottom: 15px;
    }
}
@media screen and (max-width: 1060px) {
    br.map-rsp-only {
        display: inline;
    }
    #hotel-list .pc_tab .map-container {
        width: 820px;
        background-size: 1000px 440px;
        background-position: center;
    }
    #hotel-list .pc_tab .map-container .kantou {
        width: 310px;
        left: 510px;
    }
    #hotel-list .pc_tab .map-container .chubu {
        width: 400px;
        left: 0px;
    }
    #hotel-list .pc_tab .map-container .kinki {
        width: 400px;
    }
    #hotel-list .pc_tab .map-container .hotel-name { font-size: 16px;}
    #hotel-list .pc_tab .map-container .hotel-name span { font-size: 12px;}
    #hotel-list .pc_tab .map-container a > span { font-size: 14px;}

    #hotel-list .pc_tab .map-container li.lf-nasu a::after { left: -40px;}
    #hotel-list .pc_tab .map-container li.tmh a::after { left: -44px;}
    #hotel-list .pc_tab .map-container li.lf-gora a::after { left: 147px;}
    #hotel-list .pc_tab .map-container li.lf-cyh a::after { left: 420px;}
    #hotel-list .pc_tab .map-container li.lf-kmh a::after { left: 434px;}
    #hotel-list .pc_tab .map-container li.lf-ito a::after { left: 659px;}
    #hotel-list .pc_tab .map-container li.lf-ymh a::after { left: 637px;}
    #hotel-list .pc_tab .map-container li.lf-zmh a::after,
    #hotel-list .pc_tab .map-container li.lf-shuzenji a::after,
    #hotel-list .pc_tab .map-container li.lf-shuzenji_g a::after {
        left: 633px;
    }
    #hotel-list .pc_tab .map-container li.lf-bmh a::after { left: 349px;}
    #hotel-list .pc_tab .map-container li.lf-smh a::after { left: 333px;}
    #hotel-list .pc_tab .map-container li.cyo a::after { left: 332px;}
}
@media screen and (max-width: 880px) {
    #hotel-list .pc_tab .map-container {
        width: 640px;
    }
    #hotel-list .pc_tab .map-container .hotel-name {
        font-size: 15px;
        padding-left: 5px;
    }
    #hotel-list .pc_tab .map-container a > span {
        width: 52px;
        height: 16px;
        font-size: 13px;
    }
    #hotel-list .pc_tab .map-container .chubu {
        width: 360px;
    }
    #hotel-list .pc_tab .map-container .kantou {
        width: 280px;
        left: 360px;
    }
    #hotel-list .pc_tab .map-container .kinki {
        left: 0;
    }
    #hotel-list .pc_tab .map-container .hotel-name span {
        font-size: 11px;
        padding-left: 21px;
    }
    #hotel-list .pc_tab .map-container .hotel-name::before {
        width: 17px;
        height: 17px;
        margin-right: 5px;
    }
    #hotel-list .pc_tab .map-container li {
        padding-bottom: 8px;
    }
    #hotel-list .pc_tab .map-container .subheading {
        font-size: 17px;
        padding-bottom: 5px;
    }
    #hotel-list .pc_tab .map-container .kantou .subheading,
    #hotel-list .pc_tab .map-container .chubu .subheading,
    #hotel-list .pc_tab .map-container .kinki .subheading {
        padding-left: 44px;
    }
    #hotel-list .pc_tab .map-container .subheading::before,
    #hotel-list .pc_tab .map-container .subheading::after {
        width: 47px;
        margin-inline: 10px;
    }
    #hotel-list .pc_tab .map-container li.lf-nasu a::after { left: 20px;}
    #hotel-list .pc_tab .map-container li.lf-gora a::after { left: 207px;}
    #hotel-list .pc_tab .map-container li.tmh a::after { left: 16px;}
    #hotel-list .pc_tab .map-container li.lf-cyh a::after { left: 330px;}
    #hotel-list .pc_tab .map-container li.lf-kmh a::after { left: 344px;}
    #hotel-list .pc_tab .map-container li.lf-ymh a::after { left: 547px;}
    #hotel-list .pc_tab .map-container li.lf-ito a::after { left: 569px;}
    #hotel-list .pc_tab .map-container li.lf-zmh a::after,
    #hotel-list .pc_tab .map-container li.lf-shuzenji a::after,
    #hotel-list .pc_tab .map-container li.lf-shuzenji_g a::after {
        left: 543px;
    }
    #hotel-list .pc_tab .map-container li.lf-bmh a::after { left: 282px;}
    #hotel-list .pc_tab .map-container li.lf-smh a::after { left: 266px;}
    #hotel-list .pc_tab .map-container li.cyo a::after { left: 265px;}
}
/* /PC-tab */

/* SP-tab */
.sp_hotel-list { display: none;}

@media screen and (max-width: 700px) {
    .pc_hotel-list { display: none;}

    #hotel-list .sp_hotel-list {
        display: block;
        width: 92%;
        margin-inline: auto;
    }
    #hotel-list .refineby {
        padding-top: 5.8%;
    }
    #hotel-list .refineby ul {
        display: flex;
        flex-direction: row;
        justify-content: space-between;
        padding-bottom: 9.2%;
    }
    #hotel-list .refineby ul li {
        width: 22.9%;
        aspect-ratio: 1 / 0.7469;
        border-radius: 0.3em;
        box-sizing: border-box;
        background-color: #F8F5F0;
        border: 2px solid #F8F5F0;
        font-size: 3.7vw;
        text-align: center;
        line-height: 1.4;
        display: flex;
        justify-content: center;
        align-items: center;
        cursor: pointer;
    }
    #hotel-list .refineby ul li.onimg,
    #hotel-list .refineby ul li.ontext {
        border: 2px solid #A48966;
        background-color: #FFF;
    }
    #hotel-list .refineby .brand ul li[data-flogo="MARRIOTT"] img { width: 75%;}
    #hotel-list .refineby .brand ul li[data-flogo="COURTYARD"] img { width: 92%;}
    #hotel-list .refineby .brand ul li[data-flogo="LAFORET"] img { width: 83%;}

    #hotel-list .sp_tab_container .hotel-name_wrapper {
        display: flex;
        flex-direction: row;
        justify-content: center;
        align-items: flex-start;
        padding-block: 5.4% 9.8%;
    }
    #hotel-list .sp_tab_container .hotel-name_wrapper span {
        display: block;
        width: 15.6522%;
        line-height: 1.5;
        text-align: center;
        flex-shrink: 0;
        background-color: #F6F2EB;
        font-size: 3.2vw;
        color: #A48966;
        border-radius: 100vmax;
        margin-right: 3%;
    }
    #hotel-list .sp_tab_container .hotel-name_wrapper .hotel-name {
        padding-right: 5.5%;
        line-height: 1.2;
    }
    #hotel-list .sp_tab_container .hotel-name_wrapper .hotel-name.cyo {
        line-height: 1.4;
        margin-top: -0.5%;
    }
    #hotel-list .sp_tab_container .hotel-name_wrapper h3 a {
        font-size: 4vw;
        text-decoration: underline;
        color: #555555;
    }
    #hotel-list .sp_tab_container .contract-facility p {
        font-size: 3.2vw;
        text-align: center;
        color: #555555;
        padding-bottom: 7%;
    }
    #hotel-list .sp_tab_container .contract-facility .hotel-name_wrapper {
        padding-block: 5.4% 1.3%;
    }

}
/* /SP-tab */

/* benefit */
#benefit {
    padding-top: 59px;
}
#benefit .subheading {
    font-size: 20px;
    text-align: center;
    padding-bottom: 0.7cqi;
}
#benefit .subheading + p {
    max-width: 910px;
    margin-inline: auto;
    font-size: 16px;
    text-align: center;
    padding-inline: 30px;
}
#benefit .swiper_carousel {
    padding-block: 23px 38px;
}
#benefit .swiper-button-prev::after,
#benefit .swiper-button-next::after {
    content: "";
}

#benefit .swiper-button-prev::after,
#benefit .swiper-button-next::after {
    width: 40px;
    background-size: 100%;
    height: auto;
    aspect-ratio: 1 / 1;
}
#benefit .swiper-button-prev::after {
    background-image: url(../../common/img/swiper_btn_next.webp);
    background-position: 0;
    transform: scale(-1, 1);
}
#benefit .swiper-button-prev,
#benefit .swiper-button-next,
#benefit .swiper-rtl .swiper-button-prev,
#benefit .swiper-rtl .swiper-button-next {
    top: 47.5%;
}
#benefit .swiper-button-next,
#benefit .swiper-rtl .swiper-button-prev {
    margin-left: 600px;
}
#benefit .swiper-button-prev,
#benefit .swiper-rtl .swiper-button-next {
    margin-right: 600px;
}
#benefit .swiper-button-prev,
#benefit .swiper-rtl .swiper-button-next {
    left: unset;
    right: 50%;
    transform: translateX(50%);
}
#benefit .swiper-horizontal > .swiper-pagination-bullets,
#benefit .swiper-pagination-bullets.swiper-pagination-horizontal,
#benefit .swiper-pagination-custom,
#benefit .swiper-pagination-fraction {
    bottom: 0;
}
#benefit .hotel-name {
    width: 100%;
    height: 40px;
    font-size: 13px;
    color: #FFF;
    text-align: center;
    font-weight: 400;
    line-height: 1.2;
    background-color: #444444;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-top: -1px;
    position: relative;
    z-index: 11;
}
#benefit .btn_wrapper {
    padding-top: 19px;
}
#benefit .swiper_carousel .swiper-slide {
    overflow: hidden;
}
#benefit .swiper_carousel .swiper-slide {
    width: 287px;
    height: 230px;
    opacity: 1;
	transition: opacity .25s ease-in-out;
    text-decoration: none;
}
#benefit .swiper_carousel .swiper-slide:hover {
    opacity: .65;
    text-decoration: none;
}

#benefit .swiper_carousel .swiper-slide img {
    transition: transform 0.2s ease-out;
}
#benefit .swiper_carousel .swiper-slide:hover img {
    transform: scale(1.1);
    position: relative;
    z-index: 10;
}
#benefit .swiper_carousel .swiper-slide a:hover {
    opacity: 1;
}
@media screen and (max-width: 1300px) {
    #benefit .swiper-button-next,
    #benefit .swiper-rtl .swiper-button-prev {
        margin-left: 0;
        left: unset;
        transform: unset;
        right: 0!important;
    }
    #benefit .swiper-button-prev,
    #benefit .swiper-rtl .swiper-button-next {
        margin-inline: 0;
        right: unset;
        transform: unset;
        left: 0!important;
    }
}
@media screen and (max-width: 700px) {
    #benefit {
        padding-top: 12.5%;
    }
    #benefit .subheading {
        font-size: 4.5334vw;
        padding-bottom: 3.4%;
    }
    #benefit .swiper_carousel {
        padding-block: 6.4% 10.5%;
    }
    #benefit .hotel-name {
        font-size: 3.2vw;
        height: auto;
        aspect-ratio: 1 / 0.1445;
    }
    #benefit .idn .hotel-name,
    #benefit .cyo .hotel-name,
    #benefit .cyt .hotel-name,
    #benefit .g_matsuo .hotel-name {
        font-size: 2.6667vw;
    }
    #benefit .subheading + p {
        font-size: 3.7334vw;
        text-align: left;
        line-height: 1.6;
        padding-inline: 5.4%;
    }
    #benefit .swiper-button-next,
    #benefit .swiper-button-prev {
        width: 23.8%;
    }
    #benefit .swiper-button-prev::after,
    #benefit .swiper-button-next::after {
        width: 100%;
    }
    #benefit .swiper-button-prev,
    #benefit .swiper-rtl .swiper-button-next {
        left: 0% !important;
        padding-left: 15.8%;
    }
    #benefit .swiper-button-next,
    #benefit .swiper-rtl .swiper-button-prev {
        right: 0% !important;
        padding-right: 15.8%;
    }
    #benefit .swiper-button-prev,
    #benefit .swiper-button-next,
    #benefit .swiper-rtl .swiper-button-prev,
    #benefit .swiper-rtl .swiper-button-next {
        padding-block: 14.4% 16.6%;
        top: 8%;
    }
    #benefit .swiper-pagination-bullet {
        width: 6px;
        height: 6px;
    }
    #benefit .swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,
    #benefit .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
        margin: 0 6px;
    }
    #benefit .swiper_carousel .swiper-slide {
        transition: none;
    }
    #benefit .swiper_carousel .swiper-slide:hover {
        transform: none;
    }
    #benefit .swiper_carousel .swiper-slide a:hover {
        opacity: .25s;
    }
    #benefit .swiper_carousel .swiper-slide {
        width: 48%;
        height: auto;
        aspect-ratio: 1 / 0.8056;
    }
}
/* /benefit */

/* News */
#news {
    max-width: 1040px;
    padding-inline: 30px;
    margin-inline: auto;
    padding-block: 55px 42px;
}
#news .subheading::before {
    content: "";
    display: block;
    width: 4px;
    aspect-ratio: 1 / 5.5;
    background-color: #A37E39;
    margin-right: 10px;
    flex-shrink: 0;
}
#news .subheading {
    font-size: 20px;
    font-weight: 400;
    display: flex;
    justify-content: left;
    align-items: center;
    padding-bottom: 2px;
    margin-left: 50px;
}
#news ul {
    padding-top: 12px;
    position: relative;
}
#news ul::after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 38px;
    background: linear-gradient(180deg,
                hsla(0, 0%, 100%, 0) 0,
                hsla(0, 0%, 100%, 1) 60%,
                hsla(0, 0%, 100%, 1) 100%,
                #FFF);
}
#news .subheading-wrapper:has(div#close_btn01[style="display: flex;"])  + ul::after {
    content: none;
}
#news ul li {
    background-color: #F8F5F0;
    margin-bottom: 8px;
}
#news ul li a {
    color: #222;
}
#news ul li dl {
    max-width: 940px;
    margin-inline: auto;
    padding-inline: 30px;
    display: flex;
    flex-direction: row;
    justify-content: left;
    align-items: center;
    font-size: 14px;
}
#news ul li dl dt {
    width: 93px;
    white-space: nowrap;
}
#news ul li dl dd {
    width: calc(100% - 93px);
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    line-height: 1.4;
    padding-block: 4px;
}
#news ul li dl dd::after {
    content: "";
    display: block;
    width: 12px;
    height: 10px;
    background-image: url(../../common/img/icon_vector_member-hotel02.svg);
    background-repeat: no-repeat;
    background-size: 100%;
    margin-left: 25px;
}
#news .subheading-wrapper {
    position: relative;
}
#news .btn_more {
    font-size: 14px;
    cursor: pointer;
    opacity: 1;
    transition: opacity .25s ease-in-out;
    position: absolute;
    top: 4px;
    left: 860px;
    display: flex;
    flex-direction: row;
    justify-content: left;
    align-items: center;
}
#news .btn_more:hover {
    opacity: .65;
}
#news .btn_more::before {
    content: "";
    display: block;
    width: 31px;
    aspect-ratio: 1 / 1;
    background-repeat: no-repeat;
    background-size: 100%;
    margin-right: 10px;
}
#news #more_btn01::before { background-image: url(../../common/img/btn_more.webp);}
#news #close_btn01::before { background-image: url(../../common/img/btn_close.webp);}

#news .ofiginal-hp-only {
    display: none;
}

@media screen and (max-width: 980px) {
    #news .btn_more { left: 88%;}
}

@media screen and (max-width: 700px) {
    #news {
        padding-inline: 0;
        padding-block: 9.8% 10.9%;
    }
    #news .subheading {
        font-size: 5.3334vw;
        margin-left: 4.7%;
    }
    #news ul li { margin-bottom: 1.5%;}

    #news ul li dl {
        font-size: 3.4667vw;
        padding-inline: 4.5%;
        align-items: flex-start;
    }
    #news ul li dl dt {
        width: 24%;
        line-height: 1.6;
        padding-block: 1.5%;
    }
    #news ul li dl dd {
        width: calc(100% - 24%);
        line-height: 1.6;
        padding-block: 1.5%;
    }
    #news ul li dl dd::after {
        margin-inline: 3% 2%;
        flex-shrink: 0;
    }
    #news .btn_more {
        font-size: 3.1734vw;
        top: 20%;
        left: 79.7%;
    }
    #news .btn_more::before {
        width: 7.2vw;
        margin-right: 14%;
        flex-shrink: 0;
    }
    #news ul::after {
        height: auto;
        aspect-ratio: 1 / 0.0827;
    }
}
/* /News */

/* Instagram */
#instagram {
    max-width: 900px;
    margin-inline: auto;
}
#instagram .subheading {
    font-size: 20px;
    text-align: center;
    padding-bottom: 6px;
}
#instagram .insta-widget {
    width: 100%;
    clear: both;
    height: auto;
    aspect-ratio: 1 / 0.56;
    overflow-y: hidden;
}
@media screen and (max-width: 900px) {
    #instagram {
        width: 700px;
    }
    #instagram .insta-widget {
        aspect-ratio: 1 / 1.04;
    }
}
@media screen and (max-width: 700px) {
    #instagram {
        width: 500px;
    }
    #instagram .insta-widget {
        aspect-ratio: 1 / 2.35;
    }
    #instagram .subheading {
        font-size: 4.5334vw;
        padding-bottom: 2.3%;
    }
}
@media screen and (max-width: 500px) {
    #instagram {
        width: 375px;
    }
    #instagram .insta-widget {
        aspect-ratio: 1 / 2.15;
    }
}
@media screen and (max-width: 374px) {
    #instagram {
        width: 320px;
    }
    #instagram .insta-widget {
        aspect-ratio: 1 / 2.03;
    }
}
@media screen and (max-width: 319px) {
    #instagram {
        width: 100%;
    }
}
/* /Instagram */