@charset "UTF-8";

/* =========================================================
   館内ページ固有スタイル (css/kannai.css)
   foundation.css の変数・ルールに完全準拠
   他ページ（foundation / cuisine / onsen）の CSS は一切変更しない
   ========================================================= */

/* =========================================================
   ヒーローセクション（全セクション共通：高さ 650px）
   ========================================================= */
.p-kannai-hero {
    position: relative;
    width: 100%;
    height: 650px;
    overflow: hidden;
}

.p-kannai-hero__img {
    width: 100%;
    height: 650px;
    object-fit: cover;
    object-position: center;
    display: block;
}

.p-kannai-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background-color: #000;
    mix-blend-mode: multiply;
    opacity: 0.25;
    pointer-events: none;
}

/* =========================================================
   館内イントロセクション
   ========================================================= */
.p-kannai-intro {
    padding: 0 0 var(--space-xl);
}

/* hero → h2「館内」の間隔を50pxに */
.p-kannai-intro h2 {
    margin-top: 50px;
}

.p-kannai-intro__inner {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 40px;
    text-align: center;
}

.p-kannai-intro__desc {
    font-size: var(--base-fs);
    line-height: var(--base-lh);
    letter-spacing: var(--base-ls);
    margin-bottom: 0;
}

/* =========================================================
   アンカーナビゲーション
   ========================================================= */
.p-kannai-nav {
    margin-top: var(--space-l);
}

.p-kannai-nav__list {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    list-style: none;
    padding: 0;
    margin: 0;
    gap: 0 3em;
}

.p-kannai-nav__list a {
    font-size: 20px;
    letter-spacing: 0.1em;
    color: var(--text-color);
    text-decoration: underline;
    text-underline-offset: 4px;
    line-height: 1.8;
    transition: opacity 0.3s;
}

.p-kannai-nav__list a:hover {
    opacity: 0.6;
}

/* =========================================================
   施設セクション共通
   ========================================================= */

/* ① ヒーロー写真（各施設セクション先頭：高さ 650px） */
.p-kannai-facility__photo-wrap {
    width: 100%;
    height: 650px;
    overflow: hidden;
    line-height: 0;
}

.p-kannai-facility__photo {
    width: 100%;
    height: 650px;
    object-fit: cover;
    object-position: center;
    display: block;
}

/* ② テキストエリア（左：タイトル ／ 右：本文） */
.p-kannai-facility__content {
    padding: 60px 0;
}

.p-kannai-facility__inner {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 40px;
    display: flex;
    align-items: flex-start;
    gap: 60px;
}

.p-kannai-facility__title {
    flex-shrink: 0;
    width: 280px;
    font-size: 30px;
    font-weight: 600;
    letter-spacing: 0.1em;
    line-height: 1.4;
    margin: 0;
}

.p-kannai-facility__body {
    flex: 1;
}

.p-kannai-facility__text {
    font-size: var(--base-fs);
    line-height: var(--base-lh);
    letter-spacing: var(--base-ls);
    margin: 0 0 8px;
}

.p-kannai-facility__streetview {
    display: inline-block;
    font-size: var(--base-fs);
    letter-spacing: var(--base-ls);
    color: var(--text-color);
    text-decoration: underline;
    text-underline-offset: 3px;
    transition: opacity 0.3s;
}

.p-kannai-facility__streetview:hover {
    opacity: 0.6;
}

/* =========================================================
   ③ フォトグリッド
   実寸（デザインカンプ値）：
     左カラム幅 489px  右カラム幅 489px  列間ギャップ 22px → 合計 1000px
     A（左上）  : 489 × 222
     B（左下左）: 230 × 222   B+C ギャップ 29px → 合計 489px
     C（左下右）: 230 × 222
     D（右縦長）: 489 × 474
   ========================================================= */

/* ラウンジ・売店 → 次のHero間：100px */
#lounge + #hiroma {
    margin-top: 100px;
}

/* ミニギャラリー → 次のHero間：160px */
#gallery + #kumiko {
    margin-top: 160px;
}

/* 大広間「平安」 → 次のHero間：110px */
#hiroma + #gallery {
    margin-top: 110px;
}

/* 組子細工 → 次のHero間：160px */
#kumiko + #overview {
    margin-top: 160px;
}

/* gallery-wrap：1000px 幅・水平パディングなし（ギャラリーをフル幅に） */
.p-kannai-facility__gallery-wrap {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 40px 60px;
}

/* 外側：左右2カラム flex、ギャップ 22px */
.p-kannai-facility__gallery {
    display: flex;
    gap: 22px;
}

/* 左カラム：縦に A → サブ行(B+C)、カンプ値474px */
.p-kannai-facility__gallery-left {
    width: 489px;
    display: flex;
    flex-direction: column;
    gap: 30px;
    height: 474px;
}

/* A：左上 大きい横長写真（カンプ値：474px） */
.p-kannai-facility__gallery-photo--a {
    overflow: hidden;
    line-height: 0;
    height: 474px;
}

.p-kannai-facility__gallery-photo--a img {
    width: 100%;
    height: 474px;
    object-fit: cover;
    object-position: center top;
    display: block;
}

/* サブ行：B + C を横並び、ギャップ 30px */
.p-kannai-facility__gallery-sub {
    display: flex;
    gap: 30px;
}

/* B・C：各 flex:1、カンプ値：222px */
.p-kannai-facility__gallery-photo--b,
.p-kannai-facility__gallery-photo--c {
    flex: 1;
    overflow: hidden;
    line-height: 0;
    height: 222px;
}

.p-kannai-facility__gallery-photo--b img,
.p-kannai-facility__gallery-photo--c img {
    width: 100%;
    height: 222px;
    object-fit: cover;
    object-position: center top;
    display: block;
}

/* 右カラム：縦長写真（カンプ値：474px） */
.p-kannai-facility__gallery-right {
    width: 489px;
    overflow: hidden;
    line-height: 0;
    display: flex;
    height: 474px;
}

.p-kannai-facility__gallery-right img {
    width: 100%;
    height: 474px;
    object-fit: cover;
    object-position: center top;
    display: block;
}

/* =========================================================
   写真2枚横並び（大広間など）
   ========================================================= */
.p-kannai-facility__twin-wrap {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 40px 60px;
}

/* 水平パディングなし（写真が 490×2 + gap = 1000px のとき） */
.p-kannai-facility__twin-wrap--fullwidth {
    padding-left: 0;
    padding-right: 0;
}

.p-kannai-facility__twin {
    display: flex;
    gap: 22px;
}

/* 組子細工：gap 20px（490+20+490=1000px） */
.p-kannai-facility__twin--kumiko {
    gap: 20px;
}

.p-kannai-facility__twin-photo {
    flex: 1;
    overflow: hidden;
    line-height: 0;
}

.p-kannai-facility__twin-photo img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    display: block;
}

/* 組子細工：490×330 */
.p-kannai-facility__twin-photo--kumiko img {
    aspect-ratio: 490 / 330;
}

/* =========================================================
   ④ お取り寄せバナー
   ========================================================= */
.p-kannai-facility__banner {
    margin-top: 60px;
    text-align: center;
}

.p-kannai-facility__banner a {
    display: inline-block;
    transition: opacity 0.3s;
}

.p-kannai-facility__banner a:hover {
    opacity: 0.85;
}

.p-kannai-facility__banner img {
    width: 490px;
    height: 120px;
    max-width: 100%;
    object-fit: cover;
    display: block;
    margin: 0 auto;
}

.p-kannai-facility__banner-text {
    font-size: var(--base-fs);
    letter-spacing: var(--base-ls);
    line-height: var(--base-lh);
    margin-top: var(--space-s);
}

/* =========================================================
   施設概要（定義リスト形式）
   ========================================================= */
.p-kannai-overview {
    padding: 0 0 270px;
}

.p-kannai-overview__inner {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0;
}

/* h2 は foundation.css の自動ルールをそのまま適用 */

.p-kannai-overview__list {
    margin-top: var(--space-m);
}

/* 各行：dt + dd を横並びに */
.p-kannai-overview__row {
    display: flex;
    align-items: flex-start;
    padding: 22px 0;
    border-bottom: 1px solid var(--text-color);
}

.p-kannai-overview__row:first-child {
    border-top: 1px solid var(--text-color);
}

.p-kannai-overview__row dt {
    flex: 0 0 200px;
    white-space: nowrap;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: 0.1em;
    line-height: 25px;
    padding-left: 20px;
}

.p-kannai-overview__row dd {
    flex: 1;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: 0.1em;
    line-height: 25px;
    margin: 0;
}

/* =========================================================
   スマホ版（768px以下 / 650pxカンプ基準）
   ========================================================= */
@media screen and (max-width: 768px) {

    /* ページヒーロー */
    .p-kannai-hero {
        height: 61.54vw;
    }

    /* イントロ */
    .p-kannai-intro {
        padding: 0 0 10vw;
    }

    .p-kannai-intro h2 {
        margin-top: 6vw;
        font-size: 6.15vw;
    }

    .p-kannai-intro__inner {
        padding: 0 var(--sp-side-padding);
    }

    .p-kannai-intro__desc {
        font-size: var(--sp-base-fs);
        line-height: var(--sp-base-lh);
    }

    /* アンカーナビ：SP 2段・中央揃え */
    .p-kannai-nav {
        margin-top: var(--sp-h2-mt);
    }

    .p-kannai-nav__list {
        gap: 0 2em;
    }

    .p-kannai-nav__list a {
        font-size: var(--sp-base-fs);
        line-height: 2.2;
    }

    /* 施設セクション：ヒーロー写真 */
    .p-kannai-facility__photo-wrap {
        height: 61.54vw;
    }

    /* テキストエリア：2カラム → 縦積み */
    .p-kannai-facility__content {
        padding: 8vw 0;
    }

    .p-kannai-facility__inner {
        flex-direction: column;
        gap: 5.38vw;
        padding: 0 7.69vw;
    }

    .p-kannai-facility__title {
        width: 100%;
        font-size: 4.62vw;
        line-height: 1.5;
        text-align: center;
    }

    .p-kannai-facility__text,
    .p-kannai-facility__streetview {
        font-size: var(--sp-base-fs);
        line-height: var(--sp-base-lh);
    }

    /* フォトグリッド：SP は左右カラムを縦積み */
    .p-kannai-facility__gallery-wrap {
        padding: 0 7.69vw 12vw;
    }

    .p-kannai-facility__gallery {
        flex-direction: column;
        gap: 4.62vw;
    }

    .p-kannai-facility__gallery-left,
    .p-kannai-facility__gallery-right {
        width: 100%;
        height: auto;
        min-width: 0;
    }

    .p-kannai-facility__gallery-left {
        gap: 4.62vw;
    }

    .p-kannai-facility__gallery-photo--a,
    .p-kannai-facility__gallery-photo--b,
    .p-kannai-facility__gallery-photo--c {
        height: auto;
    }

    .p-kannai-facility__gallery-photo--a img,
    .p-kannai-facility__gallery-photo--b img,
    .p-kannai-facility__gallery-photo--c img,
    .p-kannai-facility__gallery-right img {
        width: 100%;
        height: auto;
        max-width: 100%;
        display: block;
        object-fit: cover;
    }

    .p-kannai-facility__gallery-photo--a img {
        aspect-ratio: 489 / 222;
    }

    .p-kannai-facility__gallery-photo--b img,
    .p-kannai-facility__gallery-photo--c img {
        aspect-ratio: 230 / 222;
    }

    .p-kannai-facility__gallery-right img {
        aspect-ratio: 489 / 474;
    }

    .p-kannai-facility__gallery-sub {
        gap: 4.62vw;
    }

    /* セクション間マージン：SP */
    .p-kannai-facility + .p-kannai-facility {
        margin-top: 16vw;
    }

    /* 写真2枚横並び：SP */
    .p-kannai-facility__twin-wrap {
        padding: 0 7.69vw 10vw;
    }

    .p-kannai-facility__banner img {
        width: 75.38vw;
        height: 18.46vw;
        max-width: 490px;
    }

    /* fullwidth も SP では 50px 余白を付ける */
    .p-kannai-facility__twin-wrap--fullwidth {
        padding-left: 7.69vw;
        padding-right: 7.69vw;
    }

    .p-kannai-facility__twin {
        gap: 4.62vw;
    }

    .p-kannai-facility__twin--kumiko {
        gap: 4.62vw;
    }

    /* 施設概要 */
    .p-kannai-overview {
        padding-bottom: var(--sp-space-l);
    }

    .p-kannai-overview__inner {
        padding: 0 var(--sp-side-padding);
    }

    .p-kannai-overview h2 {
        font-size: 6.15vw;
    }

    .p-kannai-overview__row {
        flex-direction: column;
        gap: 4px;
        padding: 4vw 0;
    }

    .p-kannai-overview__row dt {
        flex: none;
        font-size: var(--sp-base-fs);
        line-height: var(--sp-base-lh);
    }

    .p-kannai-overview__row dd {
        padding-left: 6.15vw;
        font-size: var(--sp-base-fs);
        line-height: var(--sp-base-lh);
    }

    /* お取り寄せバナー */
    .p-kannai-facility__banner {
        margin-top: 8vw;
        padding: 0 var(--sp-side-padding);
    }

    .p-kannai-facility__banner img {
        width: 70vw;
    }

    .p-kannai-facility__banner-text {
        font-size: var(--sp-base-fs);
        line-height: var(--sp-base-lh);
    }
}
