@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 */
#page { color: #222222;}

#page a {
    opacity: 1;
	transition: opacity .25s ease-in-out;
    text-decoration: none;
}
#page a:hover {
    opacity: .65;
    text-decoration: none;
}

#news-summer * { box-sizing: border-box;}

#news-summer {
    font-family: toppan-bunkyu-mincho-pr6n, serif;
    padding-block: 80px 150px;
}

#news-summer img { width: 100%;}

#news-summer figure,
#news-summer picture {
    display: block;
}

#news-summer .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;
}
#news-summer .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%;
}
#news-summer .btn_common span {
    display: block;
    width: 70%;
    text-align: center;
}
#news-summer .subheading {
    font-size: 26px;
    font-weight: 400;
    text-align: left;
    padding-block: 14px;
    position: relative;
    z-index: 2;
}
#news-summer .contents-lead {
    font-size: 16px;
    text-align: center;
    line-height: 1.9;
    padding-bottom: 20px;
    position: relative;
    z-index: 2;
}
#news-summer .sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
}
#news-summer .sp-only {
    display: none;
}
@media screen and (max-width:1139px) {
    #news-summer {
        padding-block: 80px 0;
    }
}
@media screen and (max-width: 700px) {
    #news-summer {
        padding-block: 15.9% 0;
    }
    #news-summer .subheading {
        font-size: var(--sp-fs24);
        text-align: center;
        padding-bottom: 5.8%;
    }
    #news-summer .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%;
    }
    #news-summer .pc-only { display: none;}
    #news-summer .sp-only { display: block;}
}
/* /all */

/* KV */
.kv {
    max-width: 1440px;
    height: 1080px;
    background-image: url(../img/bg_kv_pc.webp);
    background-image: image-set(url(../img/bg_kv_pc.webp) 1x, url(../img/bg_kv_pc@2x.webp) 2x);
    background-image: -webkit-image-set(url(../img/bg_kv_pc.webp) 1x, url(../img/bg_kv_pc@2x.webp) 2x);
    background-size: 1440px 1080px;
    background-position: center;
    background-repeat: no-repeat;
    padding-top: 124px;
    margin-bottom: -148px;
    margin-inline: auto;
    position: relative;
}
.kv h1 {
    width: 491px;
    margin-inline: auto;
    padding-bottom: 58px;
}
.kv .lead {
    max-width: 826px;
    margin-inline: auto;
    padding-inline: 30px;
}
.kv .lead p {
    max-width: 766px;
    margin-inline: auto;
    font-size: 18px;
    font-weight: 400;
    line-height: 2.2;
    text-align: center;
    background-image: url(../img/bg_lead.webp);
    background-size: 100% 100%;
    background-repeat: no-repeat;
    padding: 27px;
}
@media screen and (max-width: 700px) {
    .kv {
        height: auto;
        aspect-ratio: 1 / 1.795;
        background-image: url(../img/bg_kv_sp.webp);
        background-image: image-set(url(../img/bg_kv_sp.webp) 1x, url(../img/bg_kv_sp.webp) 2x);
        background-image: -webkit-image-set(url(../img/bg_kv_sp.webp) 1x, url(../img/bg_kv_sp.webp) 2x);
        background-size: 100%;
        background-position: top;
        background-color: #FCFBE8;
        padding-top: 18.5%;
        margin-bottom: 0;
    }
    .kv h1 {
        width: 89.2%;
        padding-bottom: 9.3%;
    }
    .kv .lead p {
        font-size: var(--sp-fs15);
        line-height: 2;
        padding: 9.3% 10%;
    }
}
/* KV */

/* swiper */
.swiper-pagination-bullet {
    background: #FFF;
    opacity: .5;
}
.swiper-pagination-bullet-active {
    opacity: 1;
    background: #FFF;
}
.swiper-horizontal>.swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-pagination-custom,
.swiper-pagination-fraction {
    bottom: 0;
}
/* /swiper */

/* hotel-list */
#news-summer hgroup {
    text-align: center;
    padding-bottom: 32px;
}
#news-summer hgroup p {
    font-size: 16px;
    color: #000;
}
@media screen and (max-width: 700px) {
    #news-summer hgroup {
        padding-bottom: 4.5%;
    }
    #news-summer hgroup p {
        width: 89.3334%;
        margin-inline: auto;
        text-align: left;
        font-size: var(--sp-fs14);
    }
}
/*---------- タブ機能 -----------*/
.tab {
    max-width: 1140px;
    margin-inline: auto;
    padding-top: 65px;
    padding-inline: 80px;
    position: relative;
    background-color: #FCFBE8;
}
.tab__menu {
    width: fit-content;
    margin-inline: auto;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end; /* メニューを下揃え */
    justify-content: left;
    gap: 10px;
    padding: 0;
    position: relative;
    z-index: 2;
}
.tab__menu-item {
    width: 221px;
    aspect-ratio: 1 / 0.2381;
    background-color: transparent;
    border: 1px solid #222222;
    font-size: 16px;
    font-weight: 400;
    color: #222;
    text-align: center;
    cursor: pointer;
    box-sizing: border-box;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .5s;
    opacity: 1;
}
.tab__menu-item:hover {
    opacity: .65;
}
.tab__menu-item.is-active:hover,
.tab__menu-item.is-active02:hover {
    opacity: 1;
}
#area .tab__menu-item {
    width: 130px;
    height: 36px;
    aspect-ratio: unset;
    font-size: 17px;
    border: 1px solid #6A9792;
}

.tab__menu-item:last-of-type {
    margin-right: 0px;
}

/* is-activeがついている時のスタイル */
.tab__menu-item.is-active,
.tab__menu-item.is-active02 {
    color: #FFF;
    cursor: auto;
    position: relative;
    z-index: 1;
    background-color: #AEA94A;
    border: 1px solid #AEA94A;
}
.tab__menu-item.is-active02 {
    background-color: #6A9792;
    border: 1px solid #6A9792;
}


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

.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,
.tab__panel-box.is-show02 {
    display: block;
}
.tab__panel-box.is-show .tab__panel-text,
.tab__panel-box.is-show02 .tab__panel-text {
    animation: 1s ease-out tab-fade;
    pointer-events: auto;
}
.tab-btnbox,
.tab-btnbox02 {
    max-width: 980px;
    margin-inline: auto;
    background-color: #FFF;
    padding-inline: 32px;
    padding-bottom: 32px;
}
.tab-btnbox02 {
    width: 335px;
    margin-inline: 0 auto;
}
.tab__panel section {
    max-width: 980px;
    margin-inline: auto;
}

@keyframes tab-fade {
    0% { opacity: 0;}
    100% { opacity: 1;}
}
@media screen and (max-width:1139px) {
    .tab-btnbox,
    .tab-btnbox02 {
        max-width: 516px;
        margin-inline: unset;
    }
}
@media screen and (max-width:880px) {
    .tab {
        padding-inline: 50px;
    }
}
@media screen and (max-width:700px) {
    .tab {
        max-width: 100%;
        margin-bottom: 0;
        padding-top: 7%;
        padding-inline: 0;
    }
    .tab-btnbox,
    .tab-btnbox02 {
        max-width: 100%;
        background-color: unset;
        padding-inline: 3.3334%;
        line-height: 1.3;
    }
    #categories .tab__menu {
        width: 100%;
        gap: 2.9%;
    }
    #area .tab__menu {
        width: 83%;
        gap: 3.6%;
    }
    .tab__menu-item {
        width: 48.515%;
        aspect-ratio: 1 / 0.3068;
        font-size: var(--sp-fs15);
        display: flex;
        justify-content: center;
        align-items: center;
        background-color: #FFF;
        margin-bottom: 3.5%;
    }
    .tab__menu-item::after {
        border-radius: 11px 11px 0 0;
        width: calc(100% - 10px);
        height: calc(100% - 2%);
    }
    .tab__menu-item.is-active::after,
    .tab__menu-item.is-active02::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,
    .tab-btnbox02 {
        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 22px;
    margin-top: -62px;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
    gap: 0 20px;
}
.tab__panel li {
    width: 230px;
    margin-bottom: 43px;
    color: #222;
    font-size: 17px;
    font-weight: 600;
    display: grid;
    grid-template-rows: subgrid;
    grid-row: span 6;
    place-content: start;
}
#area .tab__panel li {
    grid-row: span 4;
}
.tab__panel li picture {
    width: 100%;
}
.tab__panel li .img-box {
    width: 230px;
}
.tag-box {
    display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
    padding-block: 4px;
}
.tag-box span {
    display: inline-block;
    background-color: #FFF;
    opacity: .8;
    padding: 4px 9px 1px;
    font-family: "toppan-bunkyu-gothic-pr6n", serif;
    color: #1E285E;
    font-size: 14px;
    font-weight: 400;
}
.tag-box span.area-name { background-color: #FFF;}
.tag-box span.b-price { background-color: #2C4A3F;}
.tag-box span.m-price { background-color: #A0072B;}

.hotel-name {
    font-size: 17px;
    padding-bottom: 6px;
    font-weight: 400;
}
.hotel-caption {
    font-family: "toppan-bunkyu-gothic-pr6n", serif;
    font-size: 14px;
    line-height: 1.7;
    padding-block: 14px 13px;
    font-weight: 400;
}
.btn-box {
    padding-top: 12px;
}
.btn-box .btn_detail:nth-of-type(n+2) {
    margin-top: 11px;
}
.btn-box .btn_detail span:has(br) {
    line-height: 1.3;
}
.btn_detail {
    display: flex;
    justify-content: right;
    align-items: center;
    aspect-ratio: 1 / 0.1914;
}
#categories .btn_detail {
    border: solid 1px #AEA94A;
    background-color: #AEA94A;
}
#area .btn_detail {
    border: solid 1px #6A9792;
    background-color: #6A9792;
}
.btn_detail span {
    width: 81%;
    display: block;
    font-size: 15px;
    font-weight: 400;
    color: #FFF;
    font-family: "toppan-bunkyu-gothic-pr6n", serif;
    text-align: center;
}
#area .btn_detail:nth-of-type(n+3) span {
    font-size: 14px;
    color: #222222;
}
#area .btn_detail:nth-of-type(n+3) {
    background-color: #FFF;
}
.btn_detail small {
    font-size: 12px;
}
.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);
}
#categories {
    margin-bottom: 30px;
}

#area.tab {
    background-color: #E5F5F3;
}

@media screen and (max-width:1139px) {
    .tab__panel li,
    .tab__panel li .img-box {
        width: 100%;
    }
    #categories {
        margin-bottom: 0;
    }
}
@media screen and (max-width:700px) {
    .tab__panel ul {
        display: block;
        padding-block: 0 7.7%;
        margin-top: 0;
    }
    .tab__panel li {
        width: 93.3334%;
        margin-inline: auto;
        display: block;
        font-size: var(--sp-fs15);
        padding: 0 0 3% 0;
        margin-bottom: 0;
    }
    .tab__panel li picture {
        width: 100%;
        height: auto;
    }
    .tag-box {
        padding-block: 5.2% 0.5%;
    }
    .tag-box span {
        font-size: var(--sp-fs11);
        line-height: 1.35;
        padding-inline: 2.5%;
        margin-right: 2.5%;
        margin-bottom: 1%;
    }
    .hotel-name {
        font-size: var(--sp-fs16);
        padding-bottom: 1.8%;
    }
    .hotel-caption {
        font-size: var(--sp-fs13);
        padding-block: 3.3% 0%;
    }
    .btn_detail {
        aspect-ratio: 1 / 0.1143;
    }
    .btn_detail span {
        width: 91%;
        font-size: var(--sp-fs14);
    }
    #area .btn_detail:nth-of-type(n+3) span {
        font-size: var(--sp-fs14);
    }
    .btn_detail small {
        font-size: var(--sp-fs12);
    }
    .btn_detail::after {
        width: 1.6%;
        height: auto;
        aspect-ratio: 1;
        margin-right: 2.5%;
    }
    .btn-box {
        padding-top: 3%;
    }
    .btn-box .btn_detail:nth-of-type(n+2) {
        margin-top: 3%;
    }
    #area .tab__menu-item {
        width: 48.195%;
        height: auto;
        aspect-ratio: 1 / 0.2858;
        font-size: var(--sp-fs15);
    }
    #categories {
        padding-bottom: 2%;
    }
    #area {
        padding-bottom: 5%;
    }
    #website-footer,
    #website-footer .footer-banners {
        padding-top: 0;
    }
}
/*---------- /タブ内コンテンツ -----------*/
/* /hotel-list */