@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 */
:root {
    --sp-fs10: 2.6667vw;
    --sp-fs11: 2.9334vw;
    --sp-fs12: 3.2vw;
    --sp-fs13: 3.4667vw;
    --sp-fs14: 3.7334vw;
    --sp-fs15: 4vw;
    --sp-fs16: 4.2667vw;
    --sp-fs17: 4.5334vw;
    --sp-fs18: 4.8vw;
    --sp-fs19: 5.0667vw;
    --sp-fs20: 5.3334vw;
    --sp-fs21: 5.6vw;
    --sp-fs22: 5.8667vw;
    --sp-fs23: 6.1334vw;
    --sp-fs24: 6.4vw;
}
* { 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;
}
.topic-path {
    position: relative;
    z-index: 2;
}
#hotel-list {
    font-family: yu-gothic-pr6n, sans-serif;
    padding-top: 72px;
}
#hotel-list h1 {
    font-size: 24px;
    text-align: center;
    padding-bottom: 13px;
    position: relative;
    z-index: 2;
}
#hotel-list .contents-lead {
    font-size: 16px;
    text-align: center;
    line-height: 1.9;
    padding-bottom: 20px;
    position: relative;
    z-index: 2;
}
#hotel-list .sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
}
#content .sp-only {
    display: none;
}
@media screen and (max-width: 700px) {
    #hotel-list {
        padding-top: 9.8%;
    }
    #hotel-list h1 {
        font-size: var(--sp-fs20);
        text-align: center;
        padding-bottom: 3.2%;
    }
    #hotel-list .contents-lead {
        font-size: var(--sp-fs14);
        padding-inline: 17%;
        padding-bottom: 4%;
        line-height: 1.6;
    }
    .btn_common {
        font-size: 3.7334vw;
        width: 46.9334vw;
        height: auto;
        padding-block: 0.27%;
    }
    #content .pc-only { display: none;}
    #content .sp-only { display: block;}
}
/* /all */

/* swiper */
/* /swiper */

/* hotel-list */
#hotel-list hgroup {
    text-align: center;
    padding-bottom: 32px;
}
#hotel-list hgroup .subheading {
    font-size: 24px;
    font-weight: 600;
    padding-bottom: 16px;
}
#hotel-list hgroup p {
    font-size: 16px;
    color: #000;
}
@media screen and (max-width: 700px) {
    #hotel-list hgroup {
        padding-bottom: 4.5%;
    }
    #hotel-list hgroup .subheading {
        text-align: left;
        font-size: var(--sp-fs20);
        margin-left: 5.3%;
        padding-bottom: 3.4%;
        display: flex;
        justify-content: left;
        align-items: center;
    }
    #hotel-list hgroup .subheading::before {
        content: "";
        display: block;
        width: .96%;
        aspect-ratio: 1 / 5.5;
        background-color: #A37E39;
        margin-right: 2.5%;
        flex-shrink: 0;
    }
    #hotel-list hgroup p {
        width: 89.3334%;
        margin-inline: auto;
        text-align: left;
        font-size: var(--sp-fs14);
    }
}
/*---------- タブ機能 -----------*/
.tab {
    max-width: 1020px;
    margin: 0 auto;
    padding-inline: 20px;
    position: relative;
}
.tab__menu {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end; /* メニューを下揃え */
    justify-content: left;
    gap: 10px;
    padding: 0;
    margin: 0;
    position: relative;
    z-index: 2;
}

.tab__menu-item {
    width: 188px;
    aspect-ratio: 1 / 0.3192;
    background-color: #F8F5F0;
    font-size: 15px;
    font-weight: 600;
    color: #555555;
    text-align: center;
    cursor: pointer;
    box-sizing: border-box;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .5s;
}
.tab__menu-item:last-of-type {
    margin-right: 0px;
}

/* is-activeがついている時のスタイル */
.tab__menu-item.is-active {
    color: #FFF;
    cursor: auto;
    position: relative;
    z-index: 1;
    background-color: #A48966;
}

/* タブパネル */
.tab__panel {
    width: 100%;
    position: relative;
    z-index: 1;
}
.tab__panel-text {
    padding-bottom: 14px;
}

.tab__panel-box {
    width: 100%;
}

.tab__panel-box001,
.tab__panel-box002,
.tab__panel-box003,
.tab__panel-box004,
.tab__panel-box005,
.tab__panel-box006,
.tab__panel-box007,
.tab__panel-box008,
.tab__panel-box009 {
    display: none;
}

/* is-showがついている時のスタイル */
.tab__panel-box.is-show {
    display: block;
}
.tab__panel-box.is-show .tab__panel-text {
    animation: 1s ease-out tab-fade;
    pointer-events: auto;
}
.tab-btnbox {
    width: 100%;
    margin-inline: auto;
}
.tab__panel section {
    width: 100%;
    margin-inline: auto;
}

@keyframes tab-fade {
    0% { opacity: 0;}
    100% { opacity: 1;}
}
@media screen and (max-width:1020px) {
    .tab {
        max-width: 686px;
        padding-inline: 20px;
    }
    .tab-btnbox {
        width: 584px;
    }
    .tab__panel {
        width: 646px;
        margin-inline: auto;
    }
}
@media screen and (max-width:880px) {
    .tab__panel ul { display: block;}
    .tab__panel li { width: 100%;}
}
@media screen and (max-width:700px) {
    .tab {
        max-width: 89.3334%;
        margin-bottom: 0;
        padding-inline: 0;
    }
    .tab__menu {
        width: 100%;
        margin: 0 auto;
        justify-content: left;
        flex-wrap: wrap;
        gap: 2.9%;
    }
    .tab__menu-item {
        width: 48.515%;
        aspect-ratio: 1 / 0.3068;
        font-size: var(--sp-fs15);
        color: #555555;
        display: flex;
        justify-content: center;
        align-items: center;
        background-color: #F8F5F0;
        border-bottom: none;
        margin-bottom: 3%;
    }
    .tab__menu-item::after {
        border-radius: 11px 11px 0 0;
        width: calc(100% - 10px);
        height: calc(100% - 2%);
    }
    .tab__menu-item.is-active {
        color: #FFF;
        border-bottom: 0px;
        background-color: #A48966;
    }
    .tab__menu-item.is-active::after {
        border-radius: 13px 13px 0 0;
    }
    .tab__panel {
        width: 100%;
        margin-inline: auto;
        background-color: transparent;
    }
    .tab__panel-text {
        padding-bottom: 0;
    }
    .tab-btnbox {
        width: 100%;
        padding-bottom: 0;
    }

}
@media screen and (max-width:500px) {
    .tab__menu-item::after { height: calc(100% - 4%);}
}
/*---------- /タブ機能 -----------*/

/*---------- タブ内コンテンツ -----------*/
.tab__panel ul {
    width: 100%;
    padding-block: 94px 35px;
    margin-top: -50px;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(313px, 1fr));
    gap: 0 20px;
}
.tab__panel li {
    /*width: 31.94%;*/
    width: 313px;
    margin-bottom: 43px;
    color: #222;
    font-size: 17px;
    font-weight: 600;
    display: grid;
    grid-template-rows: subgrid;
    grid-row: span 6;
    place-content: start;
}
.tab__panel li picture {
    width: 100%;
}
.tag-box {
    display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
    padding-block: 4px 5px;
}
.tag-box span {
    display: inline;
    font-size: 13px;
    color: #FFF;
    font-weight: 500;
    line-height: 1.2;
    padding-inline: 8px;
    margin-right: 8px;
    margin-bottom: 4px;
}
.tag-box span.area-name { background-color: #A48966;}
.tag-box span.b-price { background-color: #2C4A3F;}
.tag-box span.m-price { background-color: #A0072B;}

.hotel-name {
    font-size: 17px;
    padding-bottom: 14px;
}
.hotel-caption {
    font-size: 14px;
    font-weight: 500;
    line-height: 1.7;
    padding-block: 17px;
}
.btn_detail {
    width: 100%;
    aspect-ratio: 1 / 0.1406;
    background-color: #333333;
    display: flex;
    align-items: center;
    justify-content: right;
}
.btn_detail span {
    display: block;
    width: 85%;
    text-align: center;
    color: #FFF;
    font-size: 15px;
}
.btn_detail::after {
    content: "";
    display: block;
    width: 5px;
    height: 5px;
    border-top: 1px solid #FFF;
    border-right: 1px solid #FFF;
    margin-right: 17px;
    transform: rotate(45deg);
}

@media screen and (max-width:700px) {
    .tab__panel ul {
        padding-block: 1.55vw 7.7%;
        margin-top: 0;
    }
    .tab__panel li {
        width: 100%;
        display: block;
        font-size: var(--sp-fs15);
        padding: 0 0 5.2% 0;
        margin-bottom: 1.5%;
    }
    .tab__panel li picture {
        width: 100%;
        height: auto;
    }
    .tag-box {
        padding-block: 5.2% 0.5%;
    }
    .tag-box span {
        font-size: var(--sp-fs12);
        line-height: 1.35;
        padding-inline: 2.5%;
        margin-right: 2.5%;
        margin-bottom: 2%;
    }
    .hotel-name {
        font-size: var(--sp-fs17);
        padding-bottom: 3.5%;
    }
    .hotel-caption {
        font-size: var(--sp-fs14);
        padding-block: 3.7%;
    }
    .btn_detail {
        aspect-ratio: 1 / 0.1493;
    }
    .btn_detail span {
        font-size: var(--sp-fs15);
    }
    .btn_detail::after {
        width: 2.2%;
        height: auto;
        aspect-ratio: 1;
        margin-right: 5%;
    }

    #website-footer,
    #website-footer .footer-banners {
        padding-top: 0;
    }
}
/*---------- /タブ内コンテンツ -----------*/
/* /hotel-list */

/* suggest */
#suggestion {
    font-family: yu-gothic-pr6n, sans-serif;
    width: 980px;
    margin-inline: auto;
    padding-bottom: 60px;
}
#suggestion .subheading01 {
    font-size: 24px;
    text-align: center;
    padding-bottom: 23px;
    text-align: center;
}
#suggestion ul {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 20px;
}
#suggestion li {
    width: 480px;
}
#suggestion li a {
    display: flex;
}
#suggestion li picture,
#suggestion li .subheading02 {
    width: 50%;
}
#suggestion .subheading02 {
    text-align: left;
    font-size: 16px;
    color: #222;
    font-weight: 600;
    background-color: #F8F5F0;
    position: relative;
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 0.1667;
    line-height: 1.6;
    display: flex;
    justify-content: center;
    align-items: center;
}
#suggestion .subheading02::after {
    content: "";
    display: block;
    width: 8px;
    height: auto;
    aspect-ratio: 1;
    position: absolute;
    top: 45%;
    right: 5%;
    border-top: #222 solid 1px;
    border-right: #222 solid 1px;
    transform: rotate(45deg);
}
@media screen and (max-width:1020px) {
    #suggestion {
        width: 487px;
    }
    #suggestion ul {
        flex-wrap: wrap;
    }
}
@media screen and (max-width:700px) {
    #suggestion {
        width: 89.3334%;
        padding-bottom: 13%;
    }
    #suggestion .subheading01 {
        font-size: var(--sp-fs20);
        padding-bottom: 5.3%;
    }
    #suggestion ul {
        display: block;
    }
    #suggestion li {
        width: 100%;
        margin-bottom: 4.5%;
    }
    #suggestion .subheading02 {
        font-size: var(--sp-fs13);
        aspect-ratio: 1 / 0.5953;
        justify-content: left;
        padding-inline: 4.3%;
    }
    #suggestion .subheading02::after {
        width: 3.4%;
        right: 7%;
    }
}
/* /suggest */