/******************************
　　　　　　　　共通
******************************/
html {
    font-family: "Zen Kaku Gothic New", sans-serif;
}

.inner {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
}

.inner-1000 {
    width: 100%;
    max-width: 1000px;
    margin: 0 auto;
}

.pc_only {
    display: block !important;
}

.sp_only {
    display: none !important;
}

.btn-resv-yellow a {
    width: 300px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: #E2FF00;
    color: #002E5C;
    padding: .7rem 1.2rem;
    font-weight: 600;
    border-radius: 9999px;
}

.btn-resv-yellow a .icon {
    width: 40px;
    aspect-ratio: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    background: #002E5C;
    border-radius: 50%;
}

.btn-resv-yellow a .icon img {
    object-fit: contain;
    aspect-ratio: auto;
}

/* TOP記事セクションタイトル */
.single-section-ttl {
    text-align: center;
    margin-bottom: 3rem;
}

.single-section-ttl p {
    font-size: 5vw;
    font-weight: 900;
    background: url(../img/yabiji/ttl_bg.png) no-repeat center center;
    background-size: cover;
    background-clip: text;
    color: transparent;
    position: relative;
    letter-spacing: .05em;
}

.single-section-ttl p::before {
    content: attr(data-text);
    position: absolute;
    inset: 0;
    color: transparent;
    -webkit-text-stroke: 7px #002E5C;
    z-index: -1;
    pointer-events: none;
}

.single-section-ttl h2 {
    font-size: 1.5rem;
    font-weight: 600;
}

@media screen and (max-width:767px) {

    /******************************
　　　　　　　　共通
******************************/
    .inner {
        max-width: 390px;
    }

    .pc_only {
        display: none !important;
    }

    .sp_only {
        display: block !important;
    }

    .btn-resv-yellow a {
        width: 300px;
        margin: 0 auto;
        display: flex;
        justify-content: space-between;
        align-items: center;
        background: #E2FF00;
        color: #002E5C;
        padding: .7rem 1.2rem;
        font-weight: 600;
        border-radius: 9999px;
    }

    .btn-resv-yellow a .icon {
        width: 40px;
        aspect-ratio: 1;
        display: flex;
        justify-content: center;
        align-items: center;
        background: #002E5C;
        border-radius: 50%;
    }

    .btn-resv-yellow a .icon img {
        object-fit: contain;
        aspect-ratio: auto;
    }

    /* TOP記事セクションタイトル */
    .single-section-ttl {
        text-align: center;
        margin-bottom: 1.5rem;
    }

    .single-section-ttl p {
        font-size: 15vw;
        line-height: 1;
    }

    .single-section-ttl p::before {
        -webkit-text-stroke: 5px #002E5C;
    }

    .single-section-ttl h2 {
        font-size: 1.1rem;
    }
}

/******************************
　　　　　　　ヘッダー
******************************/
header {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-left: 3rem;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 99;
    background: #fff;
}



header .header-logo {
    width: 10%;
}

header .header-nav {
    width: 80%;
    display: flex !important;
    justify-content: space-between;
    align-items: stretch;
}

header .header-nav-sp {
    display: none;
}

header .hamburger {
    display: none;
}

header .header-nav .main-nav {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 3rem;
    color: #000;
    font-weight: 500;
}

header.kasou-header .header-nav .main-nav {
    color: #484848;
}

header .header-nav .main-nav li {
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

header .header-nav .main-nav li.tour .hover-list {
    display: none;
    width: 100%;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 15px 20px;
    background: #fff;
    padding: 2rem;
    position: absolute;
    left: 50%;
    top: 100px;
    transform: translateX(-50%);
}

header .header-nav .main-nav li.tour:hover .hover-list {
    display: flex;
}

header .header-nav .main-nav li.tour .hover-list .item {
    width: calc((100% - 100px) / 5);
}

header .header-nav .main-nav li.tour .hover-list .item img {
    width: 100%;
    height: auto;
    aspect-ratio: 5 / 3;
    object-fit: cover;
}

header .header-nav .main-nav li.tour .hover-list .item .ttl-area {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
}

header .header-nav .main-nav li.tour .hover-list .item .ttl-area p {
    width: 85%;
    color: #000;
    line-height: 1.3;
    font-weight: 500;
    text-shadow: none;
}

header .header-nav .main-nav li.tour .hover-list .item .ttl-area .icon {
    width: calc(15% - 10px);
    background: #F5F5F5;
    aspect-ratio: 1;
    display: flex;
    justify-content: center;
    border-radius: 50%;
}

header .header-nav .main-nav li.tour .hover-list .item .ttl-area .icon img {
    width: 50%;
    object-fit: none;
}

header .header-nav .label-nav {
    width: 25%;
    display: flex;
    border-radius: 0 0 0 20px;
    overflow: hidden;
}

header .header-nav .label-nav li {
    width: calc(100% / 2);
}

header .header-nav .label-nav li a {
    height: 100px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

header .header-nav .label-nav li a.contact {
    background: #fff;
}

header .header-nav .label-nav li a.resv {
    background: #E2FF00;
}

@media screen and (max-width: 767px) {

    /******************************
　　　　　　　ヘッダー
******************************/
    header {
        padding-left: 0;
        padding: .5rem 1rem;
    }

    header .header-logo {
        width: 45%;
    }

    header .header-nav {
        display: none !important;
    }

    .header-nav-sp {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100vh;
        background-color: #fff;
        /* 背景色はお好みで */
        opacity: 0;
        visibility: hidden;
        transition: all 0.3s ease-in-out;
        z-index: 90;
        overflow-y: auto;
        padding-top: 80px;
        /* ヘッダーの高さ分下げる */
    }

    .header-nav-sp.is-active {
        display: block;
        opacity: 1;
        visibility: visible;
    }

    /* スクロール固定用 */
    body.is-fixed {
        overflow: hidden;
    }

    header .hamburger {
        display: block;
    }

        /* ===================================================
       ハンバーガーアイコン（水滴ぽよんアニメーション）
    =================================================== */
        .hamburger {
            position: relative;
            z-index: 100;
            width: 34px;
            /* 少しだけ横幅にゆとりを持たせる */
            height: 22px;
            cursor: pointer;
        }
    
        /* 3本の線を「水滴」のように丸くぷっくりさせる */
        .hamburger span,
        .hamburger::before,
        .hamburger::after {
            content: '';
            position: absolute;
            left: 0;
            width: 100%;
            height: 3px;
            /* 少し太めにして表面張力感を出す */
            background-color: #000;
            /* 海っぽいブルー（お好みで変更OK） */
            border-radius: 20px;
            /* 角を完全に丸くして水滴感を出す */
        }
    
        /* --- 通常時（3本線に戻る時の動き） --- */
        .hamburger::before {
            top: 0;
            /* 回転が戻ってから、上下に分かれる（時間差） */
            transition: top 0.3s ease 0.3s, transform 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55) 0s;
        }
    
        .hamburger span {
            top: 50%;
            transform: translateY(-50%) scaleX(1);
            /* 真ん中の線がフワッと現れる */
            transition: opacity 0.3s ease 0.3s, transform 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55) 0.3s;
        }
    
        .hamburger::after {
            bottom: 0;
            transition: bottom 0.3s ease 0.3s, transform 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55) 0s;
        }
    
    
        /* --- is-active時（クリックされてバツになる時の動き） --- */
    
        /* 1. 上下の水滴が真ん中に落ちてくる（0秒〜0.3秒） */
        .hamburger.is-active::before {
            top: 50%;
            /* 2. ぽよん！と弾けながらバツになる（0.3秒〜0.6秒） */
            transform: translateY(-50%) rotate(45deg);
            transition: top 0.3s ease 0s, transform 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55) 0.3s;
        }
    
        /* 真ん中の水滴は、上下が落ちてきた瞬間に吸収されるように消える */
        .hamburger.is-active span {
            opacity: 0;
            transform: translateY(-50%) scaleX(0);
            /* 横に潰れながら消える */
            transition: opacity 0.2s ease 0s, transform 0.2s ease 0s;
        }
    
        .hamburger.is-active::after {
            bottom: 50%;
            transform: translateY(50%) rotate(-45deg);
            transition: bottom 0.3s ease 0s, transform 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55) 0.3s;
        }

        /* ===================================================
       スマホメニュー全体のベース
    =================================================== */
        .header-nav-sp {
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100vh;
            background-color: #f7fcff;
            /* 海を感じるごく薄いブルー */
            z-index: 90;
            overflow-y: auto;
            padding: 80px 20px 40px;
            /* ヘッダーの高さに合わせて80px部分は調整してください */
            opacity: 0;
            visibility: hidden;
            transition: all 0.4s ease;
        }
    
        .header-nav-sp.is-active {
            opacity: 1;
            visibility: visible;
        }
    
        /* ===================================================
       各項目のスタイル
    =================================================== */
        .header-nav-sp .item {
            border-bottom: 1px solid #e2eff6;
            /* 爽やかな区切り線 */
        }
    
        /* 一番最後の項目は下線を消す */
        .header-nav-sp .item:last-child {
            border-bottom: none;
        }
    
        /* メインタイトル・大リンク */
        .header-nav-sp .item p,
        .header-nav-sp .item p a {
            display: block;
            width: 100%;
            padding: 18px 0;
            font-size: 16px;
            font-weight: 700;
            color: #333;
            text-decoration: none;
            position: relative;
            margin: 0;
        }
    
        /* リンク付きの親メニューには右側に矢印(>)を付ける */
        .header-nav-sp .item p a::after {
            content: "";
            position: absolute;
            top: 50%;
            right: 10px;
            transform: translateY(-50%) rotate(45deg);
            width: 8px;
            height: 8px;
            border-top: 2px solid #00a0e9;
            /* アクアベースっぽいブルー */
            border-right: 2px solid #00a0e9;
        }
    
        /* ===================================================
       サブメニュー（体験ツアーを選ぶ の中のリスト）
    =================================================== */
        .header-nav-sp .item ul {
            list-style: none;
            padding: 0 0 15px 15px;
            /* インデントを下げる */
            margin: -5px 0 0 0;
        }
    
        .header-nav-sp .item ul li a {
            display: block;
            padding: 12px 0;
            font-size: 14px;
            font-weight: 500;
            color: #555;
            text-decoration: none;
            position: relative;
        }
    
        /* サブメニューの先頭に青い丸ポッチを付ける */
        .header-nav-sp .item ul li a::before {
            content: "";
            display: inline-block;
            width: 6px;
            height: 6px;
            background-color: #00a0e9;
            border-radius: 50%;
            margin-right: 12px;
            vertical-align: middle;
        }
    
        /* ===================================================
       CVボタン（お問い合わせ・ご予約）の特別スタイル
       ※下から1番目と2番目のitemをボタン化
    =================================================== */
        .header-nav-sp .item:nth-last-child(2),
        .header-nav-sp .item:nth-last-child(1) {
            border-bottom: none;
            margin-top: 15px;
        }
    
        .header-nav-sp .item:nth-last-child(2) p a,
        .header-nav-sp .item:nth-last-child(1) p a {
            text-align: center;
            border-radius: 30px;
            padding: 15px 0;
            color: #fff;
        }
    
        /* 矢印を白に変更し、位置を調整 */
        .header-nav-sp .item:nth-last-child(2) p a::after,
        .header-nav-sp .item:nth-last-child(1) p a::after {
            border-color: #fff;
            right: 20px;
        }
    
        /* お問い合わせ（ブルー） */
        .header-nav-sp .item:nth-last-child(2) p a {
            background-color: #00a0e9;
        }
    
        /* ご予約（イエロー/オレンジ系） */
        .header-nav-sp .item:nth-last-child(1) p a {
            background-color: #ffb700;
            margin-top: -10px;
            /* 少し間隔を詰める */
        }
}

/***** メインビジュアル *****/
.mv {
    width: 100%;
    height: 100vh;
    display: flex;
    position: relative;
}

.mv .item {
    width: 50%;
}

.mv .mv-txt {
    width: 80%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(-5deg);
}

.mv .mv-txt h1 {
    font-size: 5vw;
    color: #fff;
    font-weight: 800;
    text-align: center;
}

.mv .mv-txt h1 span.outline {
    position: relative;
    display: inline-block;
    color: #4357D7;
    -webkit-text-stroke: 0;
    font-weight: 800;
}

.mv .mv-txt h1 span.outline::before {
    content: attr(data-text);
    position: absolute;
    inset: 0;
    color: transparent;
    -webkit-text-stroke: 7px #FFF21C;
    z-index: -1;
    pointer-events: none;
}

.mv .item {
    position: relative;
}

.mv .item .mvc-txt {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    height: 50%;
    position: absolute;
    bottom: 0;
    padding: 30px;
    color: #fff;
}

.mv .item .mvc-txt.yabiji-txt {
    left: 0;
    background: url(../img/yabiji/yabiji_tri.png) no-repeat;
    background-size: contain;
    background-position: bottom left;
}

.mv .item .mvc-txt.pumpkin-txt {
    align-items: flex-end;
    right: 0;
    background: url(../img/pumpkin/pump_tri.png) no-repeat;
    background-size: contain;
    background-position: bottom right;
}

.mv .item .mvc-txt span {
    font-size: 1.3rem;
    letter-spacing: .1em;
    font-weight: 600;
}

.mv .item .mvc-txt h2 {
    font-size: 5vw;
    font-weight: 600;
    line-height: 1;
}


.mv .item .mvc-txt.pumpkin-txt h2 {
    text-align: right;
    text-shadow: 0 1px 5px #44444480;
}

.mv .item .mvc-txt p {
    font-weight: normal;
    line-height: 4;
}

.mv .item .mvc-txt .btn.detail a {
    display: block;
    text-align: center;
    width: 250px;
    padding: .2rem;
    border: 1px solid #fff;
    border-radius: 9999px;
}

.mv .item .mv-slider {
    width: 100%;
    height: 100vh;
}

.mv .item .mv-slider img {
    height: 100vh;
    object-fit: cover;
}

@media screen and (max-width: 767px) {

    /***** メインビジュアル *****/
    .mv {
        flex-direction: column;
    }

    .mv .item {
        width: 100%;
        height: 50vh;
    }

    .mv .mv-txt {
        width: 95%;
    }

    .mv .mv-txt h1 {
        font-size: 9vw;
    }

    .mv .item .mvc-txt {
        width: 50%;
        bottom: auto;
        padding: 0;
    }

    .mv .item .mvc-txt.yabiji-txt {
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        background: none;
    }

    .mv .item .mvc-txt.yabiji-txt::before {
        content: '';
        width: 300px;
        aspect-ratio: 4 / 3.5;
        background: url(../img/yabiji/yabiji_tri.png) no-repeat;
        background-size: contain;
        position: absolute;
        top: 100%;
        left: 50%;
        transform: translate(-50%, -50%) rotate(470deg);
        z-index: -1;
    }

    .mv .item .mvc-txt.pumpkin-txt {
        align-items: flex-start;
        right: auto;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        background: none;
    }

    .mv .item .mvc-txt.pumpkin-txt::before {
        content: '';
        width: 300px;
        aspect-ratio: 4 / 3.5;
        background: url(../img/pumpkin/pump_tri.png) no-repeat;
        background-size: contain;
        position: absolute;
        top: 30%;
        left: 50%;
        transform: translate(-50%, -50%) rotate(370deg);
        z-index: -1;
    }

    .mv .item .mvc-txt span {
        font-size: 1rem;
    }

    .mv .item .mvc-txt h2 {
        font-size: 2rem;
    }


    .mv .item .mvc-txt.pumpkin-txt h2 {
        text-align: left;
        text-shadow: 0 1px 5px #44444480;
    }

    .mv .item .mvc-txt p {
        font-size: .95rem;
        line-height: 2;
    }

    .mv .item .mvc-txt .btn.detail a {
        width: 200px;
    }

    .mv .item .mv-slider {
        height: 50vh;
    }

    .mv .item .mv-slider img {
        height: 50vh;
    }
}

/***** ツアーセクション *****/
.tour .tour-item {
    width: 100%;
    position: relative;
}

.tour .tour-item::before {
    content: '';
    background: #00000030;
    position: absolute;
    inset: 0;
}

.tour .tour-item.yabiji {
    background: url(../img/yabiji/yabiji_mv1.png) no-repeat;
    background-size: cover;
}

.tour .tour-item.pumpkin {
    background: url(../img/pumpkin/pumpkin_ttour.jpg) no-repeat;
    background-size: cover;
}

.tour .tour-item.night {
    background: url(../img/night/night01.png) no-repeat;
    background-size: cover;
}

.tour .tour-item.sea-turtle {
    background: url(../img/sea-turtle/umigame1.png) no-repeat;
    background-size: cover;
}

.tour .tour-item .tour-inner {
    width: 80%;
    margin-left: auto;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 3rem;
    padding: 10vh 0;
}

.tour .tour-item .tour-inner .txt {
    width: calc(40% - 3rem);
    color: #fff;
    z-index: 5;
}

.tour .tour-item .tour-inner .txt .ttl {
    margin-bottom: 2rem;
}

.tour .tour-item .tour-inner .txt .ttl span {
    font-size: 2rem;
    font-weight: 600;
}

.tour .tour-item .tour-inner .txt .ttl h2 {
    font-size: 3.5vw;
    font-weight: 600;
}

.tour .tour-item .tour-inner .txt .detail {
    margin-bottom: 2rem;
}

.tour .tour-item .tour-inner .txt .detail p {
    line-height: 2;
}

.tour .tour-item .tour-inner .txt .resv-btn a {
    width: 300px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 2rem;
    border: 1px solid #fff;
    padding: .5rem 0;
    margin-left: auto;
    border-radius: 9999px;
}

.tour .tour-item .tour-inner .tour-content {
    width: 60%;
}

.tour-slider {
    position: relative;
    overflow: hidden;
}

.tour-slider .slick-slide {
    width: 600px;
    margin-right: 2rem;
    background: #fff;
    border-radius: 10px;
    overflow: hidden;
    position: relative;
}

.tour-slider .slick-slide img {
    aspect-ratio: 3 / 1;
    object-fit: cover;
}

.tour-slider .detail {
    padding: 1.5rem;
}

.tour-slider .detail .ttl h3 {
    font-size: 1.2rem;
    font-weight: 600;
}

.tour-slider .detail .label {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 5px 10px;
    margin: 20px 0;
}

.tour-slider .detail .label li {
    padding: 5px 10px;
    background: #E52229;
    border-radius: 3px;
    font-size: .9rem;
    line-height: 1;
    color: #fff;
}

.tour-slider .detail .attract {
    margin-bottom: 10px;
}

.tour-slider .detail .attract p {
    font-size: .9rem;
}

.tour-slider .detail .attract p.head {
    font-weight: 500;
    font-size: 1rem;
}

.tour-slider .detail .price {
    background-color: #FFF7E5;
    padding: 1rem 1.2rem;
    border-radius: 5px;
    margin-bottom: 20px;
    text-align: center;
    position: relative;
}

.tour-slider .detail .price .limited {
    position: relative;
    z-index: 1;
    display: inline-block;
    margin: 0 auto;
    color: #FFF21C;
    -webkit-text-stroke: 0;
    font-size: 1.6rem;
    font-weight: 800;
}

.tour-slider .detail .price .limited::after {
    content: '';
    width: 130px;
    aspect-ratio: 3 / 2;
    background: url(../img/icon/limited_seat.png) no-repeat;
    background-size: contain;
    position: absolute;
    bottom: -50%;
    right: 0;
    transform: translateX(100%);
}

.tour-slider .detail .price .limited::before {
    content: attr(data-text);
    position: absolute;
    inset: 0;
    color: transparent;
    -webkit-text-stroke: 7px #E52229;
    z-index: -1;
    pointer-events: none;
}

.tour-slider .detail .price .term {
    font-weight: 600;
    margin: .5rem 0;
}

.tour-slider .detail .price .price-inner .default {
    font-size: .85rem;
    font-weight: 500;
}

.tour-slider .detail .price .price-inner .default span {
    margin: 0 .3rem;
    font-size: 1rem;
    text-decoration: line-through;
    text-decoration-thickness: 0.1rem;
    text-decoration-color: #E52229;
}

.tour-slider .detail .price .price-inner .new {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 5px;
}

.tour-slider .detail .price .price-inner .new .discount {
    color: #E2FF03;
    font-weight: 500;
    padding: .5rem 2rem;
    line-height: 1;
    background: url(../img/icon/back-arrow-blue.png) no-repeat center;
    background-size: contain;
}

.tour-slider .detail .price .price-inner .new .discount span {
    font-size: .85rem;
}

.tour-slider .detail .price .price-inner .new .new-price {
    font-size: 2.8rem;
    line-height: 1;
    color: #FF3F5F;
    font-weight: 600;
}



@media screen and (max-width: 767px) {

    /***** ツアーセクション *****/
    .tour .tour-item .tour-inner {
        width: 100%;
        flex-direction: column;
        padding: 3rem 1rem;
        gap: 1.9rem;
    }

    .tour .tour-item .tour-inner .txt {
        width: 100%;
        text-shadow: 0 0 5px #44444490;
    }

    .tour .tour-item .tour-inner .txt .ttl {
        margin-bottom: 1.3rem;
    }

    .tour .tour-item .tour-inner .txt .ttl span {
        font-size: 1.3rem;
    }

    .tour .tour-item .tour-inner .txt .ttl h2 {
        font-size: 2.5rem;
    }

    .tour .tour-item .tour-inner .txt .detail {
        margin-bottom: 1.3rem;
    }

    .tour .tour-item .tour-inner .txt .resv-btn a {
        width: fit-content;
        gap: 1.5rem;
        padding: .5rem 2rem;
    }

    .tour .tour-item .tour-inner .tour-content {
        width: 100%;
    }

    .tour-slider .slick-slide {
        width: 100%;
        margin-right: .5rem;
    }

    .tour-slider .slick-slide img {
        aspect-ratio: 2 / 1;
    }

    .tour-slider .detail {
        padding: 1rem .7rem;
    }

    .tour-slider .detail .ttl h3 {
        font-size: 1rem;
    }

    .tour-slider .detail .label {
        gap: 5px;
        margin: 10px 0;
    }

    .tour-slider .detail .label li {
        font-size: .8rem;
    }

    .tour-slider .detail .price {
        padding: 1rem;
        margin-bottom: 10px;
    }

    .tour-slider .sea-camera .detail .price::before {
        width: 35vw;
    }

    .tour-slider .detail .price .limited {
        font-size: 1.1rem;
        font-weight: 600;
    }

    .tour-slider .detail .price .limited::before {
        -webkit-text-stroke: 5px #E52229;
    }

    .tour-slider .detail .price .term {
        margin: .5rem 0;
    }

    .tour-slider .detail .price .price-inner .new .discount {
        padding: .5rem 1.5rem;
    }

    .tour-slider .detail .price .price-inner .new .new-price {
        font-size: 1.5rem;
    }
}

/***** アクアベースが選ばれる理由　*****/
.choosable {
    padding: 35rem 0 6rem;
    background: url(../img/outside.png) no-repeat top;
    background-size: contain;
}

.choosable .ttl-wrap {
    width: 80%;
    padding: 2rem;
    margin-left: auto;
    background: #fff;
    position: relative;
}

.choosable .ttl-wrap h2 {
    font-size: 5vw;
    font-weight: 900;
    color: #fff;
    position: absolute;
    top: 0;
    right: 2%;
    transform: translateY(-80%);
}

.choosable .content {
    background: #fff;
    position: relative;
    padding: 50px 0;
}

.choosable .content::before {
    content: "";
    width: 60%;
    aspect-ratio: 3 / 2;
    position: absolute;
    left: 0;
    top: 20%;
    background:
        linear-gradient(rgba(4, 171, 243, 0.7), rgba(4, 171, 243, 0.7)),
        url(../img/sea-turtle/umigame2.jpeg) left / cover no-repeat;
    pointer-events: none;
}

.choosable .content::after {
    content: "";
    width: 60%;
    aspect-ratio: 3 / 2;
    position: absolute;
    right: 0;
    bottom: 0;
    background: #FF3F5F70;
}

.choosable .content h3 {
    width: 100%;
    text-align: center;
    font-size: 2.5vw;
    color: #FFF21C;
    font-weight: 600;
    position: absolute;
    top: 0;
    left: 0;
    transform: translateY(-70%);
    z-index: 1;
}

.choosable .content h3::before {
    content: attr(data-text);
    position: absolute;
    inset: 0;
    color: transparent;
    -webkit-text-stroke: 7px #4357D7;
    z-index: -1;
    pointer-events: none;
}

.choosable .content .cho-list {
    display: flex;
    flex-direction: column;
    gap: 3rem;
    position: relative;
    z-index: 5;
}

.choosable .content .cho-list .paragraph {
    display: flex;
    gap: 3rem;
}

.choosable .content .cho-list .paragraph:nth-child(odd) {
    padding-right: 3rem;
}

.choosable .content .cho-list .paragraph:nth-child(even) {
    padding-left: 3rem;
}

.choosable .content .cho-list .paragraph .item {
    width: calc((100% - 3rem) / 2);
    aspect-ratio: 3 / 2;
    position: relative;
    background: #fff;
}

.choosable .content .cho-list .paragraph .item .back-img {
    width: 60%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    top: 0;
    left: 0;
}

.choosable .content .cho-list .paragraph .item .label {
    width: 120px;
    aspect-ratio: 1;
    font-size: .9rem;
    line-height: 1.1;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    font-weight: 600;
    position: absolute;
    top: 2%;
    right: 2%;
    z-index: 2;
}

.choosable .content .cho-list .paragraph .item .text {
    width: 70%;
    background: #fff;
    padding: 2rem;
    position: absolute;
    right: 0;
    bottom: 0;
}

.choosable .content .cho-list .paragraph .item .text h4 {
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: 1rem;
}

.choosable .content .cho-list .paragraph .item.blue .label {
    background: url(../img/icon/dia_blue.png) no-repeat center;
    background-size: contain;
}

.choosable .content .cho-list .paragraph .item.blue .text h4,
.choosable .content .cho-list .paragraph .item.blue .text span {
    color: #1169C9;
}


.choosable .content .cho-list .paragraph .item.pink .label {
    background: url(../img/icon/dia_pink.png) no-repeat center;
    background-size: contain;
}

.choosable .content .cho-list .paragraph .item.pink .text h4,
.choosable .content .cho-list .paragraph .item.pink .text span {
    color: #F82592;
}

@media screen and (max-width: 767px) {
    .choosable {
        padding: 9.5rem 0;
    }

    .choosable .ttl-wrap {
        width: 100%;
        padding: 0;
    }

    .choosable .ttl-wrap h2 {
        font-size: 12vw;
        line-height: 1;
        text-align: right;
        transform: translateY(-100%);
    }

    .choosable .content {
        background: #fff;
        position: relative;
        padding: 50px 0;
    }

    .choosable .content::before {
        width: 90%;
        height: 60%;
        aspect-ratio: auto;
    }

    .choosable .content::after {
        width: 90%;
        height: 60%;
        aspect-ratio: auto;
    }

    .choosable .content h3 {
        font-size: 6.5vw;
        position: static;
    }

    .choosable .content .cho-list .paragraph {
        flex-direction: column;
        padding: 0 1rem !important;
        gap: 2rem;
    }

    .choosable .content .cho-list .paragraph:nth-child(odd) {
        padding-right: 0;
    }

    .choosable .content .cho-list .paragraph:nth-child(even) {
        padding-left: 0;
    }

    .choosable .content .cho-list .paragraph .item {
        width: 100%;
        aspect-ratio: auto;
    }

    .choosable .content .cho-list .paragraph .item .back-img {
        width: 100%;
        position: static;
    }

    .choosable .content .cho-list .paragraph .item .text {
        width: 100%;
        padding: 1rem;
        position: static;
    }

    .choosable .content .cho-list .paragraph .item .text h4 {
        font-size: 1rem;
        margin-bottom: .5rem;
    }
}

/***** 手ぶらでGO! *****/
.prepare {
    padding: 23rem 0 0;
    background: url(../img/prepare.png) no-repeat top;
    background-size: 100% auto;
}

.prepare .ttl-wrap {
    width: 80%;
    height: 100px;
    margin-right: auto;
    background: #fff;
    position: relative;
}

.prepare .ttl-wrap h2 {
    font-size: 6vw;
    font-weight: 900;
    color: #fff;
    position: absolute;
    top: 0;
    left: 2%;
    transform: translateY(-80%);
}

.prepare .content .sticky-wrap {
    position: relative;
    height: zuto;
}

.prepare .content .sticky-box {
    position: sticky;
    top: 0;
    height: 120vh;
    padding: 50px 0;
    box-sizing: border-box;
}

.prepare .content .sticky-box.problem {
    background: url(../img/bg_prepare.jpg) center/cover no-repeat;
    isolation: isolate;
}

.prepare .content .sticky-box.problem::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(46, 79, 204, 0.5);
    z-index: 0;
    pointer-events: none;
}

.prepare .content .sticky-box.problem>* {
    position: relative;
    z-index: 1;
}

.prepare .content .sticky-box.problem .problem-inner {
    width: 100%;
    height: calc(100vh - 100px);
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
}

.prepare .content .sticky-box.problem .problem-inner h3 {
    width: 100%;
    text-align: center;
    font-size: 2.5vw;
    color: #FFF21C;
    font-weight: 600;
    position: absolute;
    top: -100px;
    left: 0;
    transform: translateY(-50%);
    z-index: 1;
}

.prepare .content h3::before {
    content: attr(data-text);
    position: absolute;
    inset: 0;
    color: transparent;
    -webkit-text-stroke: 7px #4357D7;
    z-index: -1;
    pointer-events: none;
}

.prepare .content .sticky-box.problem .problem-inner img {
    width: 40%;
    object-fit: contain;
}

.prepare .content .sticky-box.problem .problem-inner .item {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 250px;
    aspect-ratio: 1;
    background: url(../img/icon/hexagon_gray.png) no-repeat center;
    background-size: contain;
    text-align: center;
    position: absolute;
}

.prepare .content .sticky-box.problem .problem-inner .item p {
    font-size: 1.3rem;
    font-weight: 500;
}

.prepare .content .sticky-box.problem .problem-inner .item p span {
    font-size: 1.7rem;
    font-weight: 600;
}

.prepare .content .sticky-box.problem .problem-inner .item.first {
    top: 0;
    left: 0;
}

.prepare .content .sticky-box.problem .problem-inner .item.first p span {
    color: #FF3F5F;
}

.prepare .content .sticky-box.problem .problem-inner .item.second {
    top: 0;
    right: 0;
}

.prepare .content .sticky-box.problem .problem-inner .item.second p span {
    color: #04ABF3;
}

.prepare .content .sticky-box.problem .problem-inner .item.third {
    top: 60%;
    left: 0;
    transform: translateY(-50%);
}

.prepare .content .sticky-box.problem .problem-inner .item.third p span {
    color: #B938FF;
}

.prepare .content .sticky-box.problem .problem-inner .item.forth {
    top: 60%;
    right: 0;
    transform: translateY(-50%);
}

.prepare .content .sticky-box.problem .problem-inner .item.forth p span {
    color: #22CE00;
}

.prepare .content .sticky-box.problem .problem-inner .item.fifth {
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
}

.prepare .content .sticky-box.problem .problem-inner .item.fifth p span {
    color: #FE5B00;
}

.prepare .content .sticky-box.solution {
    background: #fff;
}

.prepare .content .sticky-box.solution .solution-inner {
    width: 100%;
    height: calc(100vh - 100px);
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    position: relative;
}

.prepare .content .sticky-box.solution .solution-inner h3 {
    width: 100%;
    text-align: center;
    font-size: 2.5vw;
    color: #FFF21C;
    font-weight: 600;
    position: relative;
    top: 0;
}

.prepare .content .sticky-box.solution .solution-inner img {
    width: 60%;
    object-fit: contain;
}

.prepare .content .sticky-box.solution .solution-inner .item {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 250px;
    aspect-ratio: 1;
    text-align: center;
    position: absolute;
}

.prepare .content .sticky-box.solution .solution-inner .item p {
    font-size: 1.3rem;
    font-weight: 500;
    color: #fff;
}

.prepare .content .sticky-box.solution .solution-inner .item p span {
    font-size: 1.7rem;
    font-weight: 600;
}

.prepare .content .sticky-box.solution .solution-inner .item.first {
    top: 15%;
    left: 0;
    background: url(../img/icon/hexagon_pink.png) no-repeat center;
    background-size: contain;
}

.prepare .content .sticky-box.solution .solution-inner .item.second {
    top: 15%;
    right: 0;
    background: url(../img/icon/hexagon_blue.png) no-repeat center;
    background-size: contain;
}

.prepare .content .sticky-box.solution .solution-inner .item.third {
    top: 70%;
    left: 0;
    transform: translateY(-50%);
    background: url(../img/icon/hexagon_purple.png) no-repeat center;
    background-size: contain;
}

.prepare .content .sticky-box.solution .solution-inner .item.forth {
    top: 70%;
    right: 0;
    transform: translateY(-50%);
    background: url(../img/icon/hexagon_green.png) no-repeat center;
    background-size: contain;
}

.prepare .content .sticky-box.solution .solution-inner .item.fifth {
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    background: url(../img/icon/hexagon_orange.png) no-repeat center;
    background-size: contain;
}

.prepare .content .sticky-box.clothing {
    background: url(../img/bg_prepare.jpg) center/cover no-repeat;
    isolation: isolate;
}

.prepare .content .sticky-box.clothing::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(49, 147, 244, 0.6);
    z-index: 0;
    pointer-events: none;
}

.prepare .content .sticky-box.clothing .clothing-inner {
    width: 100%;
    height: calc(100vh - 100px);
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    position: relative;
}

.prepare .content .sticky-box.clothing .clothing-inner h3 {
    width: 100%;
    text-align: center;
    font-size: 2.5vw;
    color: #FFF21C;
    font-weight: 600;
    position: relative;
    top: 0;
    transform: none;
}

.prepare .content .sticky-box.clothing .clothing-inner img {
    height: 90%;
}

.prepare .content .sticky-box.clothing .clothing-inner .item {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 250px;
    aspect-ratio: 1;
    background: url(../img/icon/hexagon_red.png) no-repeat center;
    background-size: contain;
    text-align: center;
    position: absolute;
}

.prepare .content .sticky-box.clothing .clothing-inner .item p {
    font-size: 1.3rem;
    font-weight: 600;
    color: #fff;
}

.prepare .content .sticky-box.clothing .clothing-inner .item.first {
    top: 10%;
    left: 2%;
}

.prepare .content .sticky-box.clothing .clothing-inner .item.first::before,
.prepare .content .sticky-box.clothing .clothing-inner .item.third::before {
    content: '';
    width: 370px;
    height: 3px;
    background: #FF3F5F;
    position: absolute;
    top: 60%;
    right: 0;
    transform: translateX(80%) rotate(20deg);
}

.prepare .content .sticky-box.clothing .clothing-inner .item.second::before {
    content: '';
    width: 370px;
    height: 3px;
    background: #FF3F5F;
    position: absolute;
    top: 70%;
    left: 0;
    transform: translateX(-80%);
}

.prepare .content .sticky-box.clothing .clothing-inner .item.second {
    top: 50%;
    right: 2%;
    transform: translateY(-50%);
}

.prepare .content .sticky-box.clothing .clothing-inner .item.third {
    bottom: 0;
    left: 0;
}

@media screen and (max-width: 767px) {

    /***** 手ぶらでGO! *****/
    .prepare {
        padding: 8rem 0 0;
    }

    .prepare .ttl-wrap {
        width: 100%;
        height: 100px;
        margin-right: auto;
        background: #fff;
        position: relative;
    }

    .prepare .ttl-wrap h2 {
        font-size: 13vw;
    }

    .prepare .content .sticky-box {
        padding: 50px 0;
        box-sizing: border-box;
    }

    .prepare .content .sticky-box.problem {
        background: url(../img/bg_prepare.jpg) center/cover no-repeat;
        isolation: isolate;
    }

    .prepare .content .sticky-box.problem::before {
        content: '';
        position: absolute;
        inset: 0;
        background: rgba(46, 79, 204, 0.5);
        z-index: 0;
        pointer-events: none;
    }

    .prepare .content .sticky-box.problem>* {
        position: relative;
        z-index: 1;
    }

    .prepare .content .sticky-box.problem .problem-inner {
        height: 100vh;
        align-items: flex-end;
    }

    .prepare .content .sticky-box.problem .problem-inner h3 {
        font-size: 6.5vw;
    }

    .prepare .content .sticky-box.problem .problem-inner h3.first {
        transform: translateY(-100%);
    }

    .prepare .content .sticky-box.problem .problem-inner h3.second {
        transform: translateY(0);
    }

    .prepare .content .sticky-box.problem .problem-inner img {
        width: 80%;
    }

    .prepare .content .sticky-box.problem .problem-inner .item {
        width: 170px;
    }

    .prepare .content .sticky-box.problem .problem-inner .item p {
        font-size: .9rem;
    }

    .prepare .content .sticky-box.problem .problem-inner .item p span {
        font-size: 1.2rem;
    }

    .prepare .content .sticky-box.problem .problem-inner .item.first {
        top: 10%;
        left: 2%;
    }

    .prepare .content .sticky-box.problem .problem-inner .item.second {
        top: 30%;
        right: 2%;
        transform: translateY(-20%);
    }

    .prepare .content .sticky-box.problem .problem-inner .item.third {
        top: 50%;
        left: 2%;
        transform: translateY(-50%);
    }

    .prepare .content .sticky-box.problem .problem-inner .item.forth {
        top: 70%;
        right: 2%;
        transform: translateY(-70%);
    }

    .prepare .content .sticky-box.problem .problem-inner .item.fifth {
        bottom: 10%;
        left: 2%;
        transform: translate(0, 0);
    }

    .prepare .content .sticky-box.solution .solution-inner {
        height: 100vh;
        padding-top: 10rem;
        align-items: flex-end;
    }

    .prepare .content .sticky-box.solution .solution-inner h3 {
        font-size: 6.5vw;
        position: absolute;
        top: 10%;
    }

    .prepare .content .sticky-box.solution .solution-inner h3.first {
        top: 5%;
    }

    .prepare .content .sticky-box.solution .solution-inner h3.second {
        top: 10%;
    }

    .prepare .content .sticky-box.solution .solution-inner h3.third {
        top: 15%;
    }

    .prepare .content .sticky-box.solution .solution-inner img {
        width: 100%;
    }

    .prepare .content .sticky-box.solution .solution-inner .item {
        width: 170px;
    }

    .prepare .content .sticky-box.solution .solution-inner .item p {
        font-size: .9rem;
    }

    .prepare .content .sticky-box.solution .solution-inner .item p span {
        font-size: 1.2rem;
    }

    .prepare .content .sticky-box.solution .solution-inner .item.first {
        top: 23%;
        left: 50%;
        transform: translate(-100%, 0);
    }

    .prepare .content .sticky-box.solution .solution-inner .item.second {
        top: 33%;
        right: 50%;
        transform: translate(100%, 0);
    }

    .prepare .content .sticky-box.solution .solution-inner .item.third {
        top: 43%;
        left: 50%;
        transform: translate(-100%, 0);
    }

    .prepare .content .sticky-box.solution .solution-inner .item.forth {
        top: 53%;
        right: 50%;
        transform: translate(100%, 0);
    }

    .prepare .content .sticky-box.solution .solution-inner .item.fifth {
        bottom: auto;
        left: 50%;
        transform: translate(-100%, 0);
        top: 63%;
    }

    .prepare .content .sticky-box.clothing .clothing-inner {
        height: 100vh;
    }

    .prepare .content .sticky-box.clothing .clothing-inner img {
        height: 80%;
    }

    .prepare .content .sticky-box.clothing .clothing-inner h3 {
        font-size: 6.5vw;
    }

    .prepare .content .sticky-box.clothing .clothing-inner .item {
        width: 170px;
    }

    .prepare .content .sticky-box.clothing .clothing-inner .item p {
        font-size: .9rem;
    }

    .prepare .content .sticky-box.clothing .clothing-inner .item.first {
        top: 30%;
    }

    .prepare .content .sticky-box.clothing .clothing-inner .item.first::before,
    .prepare .content .sticky-box.clothing .clothing-inner .item.third::before {
        display: none;
    }

    .prepare .content .sticky-box.clothing .clothing-inner .item.second::before {
        display: none;
    }
                .prepare .content .sticky-box.clothing .clothing-inner .item.second {
                    bottom: auto;
                    transform: none;
                    top: 55%;
                }

    .prepare .content .sticky-box.clothing .clothing-inner .item.third {
        bottom: auto;
        top: 80%;
    }
}

/***** スタッフ紹介　*****/
.member {
    padding: 35rem 0 6rem;
    background: url(../img/member.jpeg) no-repeat top;
    background-size: 100% auto;
}

.member .ttl-wrap {
    width: 80%;
    padding: 2rem;
    margin-left: auto;
    background: #fff;
    position: relative;
}

.member .ttl-wrap h2 {
    font-size: 5vw;
    font-weight: 900;
    color: #fff;
    position: absolute;
    top: 0;
    right: 2%;
    transform: translateY(-80%);
}

.member .content {
    background: #fff;
    position: relative;
    padding: 70px 0;
}

.member .content h3 {
    width: 100%;
    text-align: center;
    font-size: 2.5vw;
    color: #FFF21C;
    font-weight: 600;
    position: absolute;
    top: 0;
    left: 0;
    transform: translateY(-70%);
    z-index: 1;
}

.member .content h3::before {
    content: attr(data-text);
    position: absolute;
    inset: 0;
    color: transparent;
    -webkit-text-stroke: 7px #4357D7;
    z-index: -1;
    pointer-events: none;
}

.staff-slider .slick-slide {
    transform: scale(.8);
    aspect-ratio: 2 / 3;
    background-image: linear-gradient(0deg, rgba(85, 250, 235, 1), rgba(255, 255, 255, 1));
    border-radius: 10px;
    overflow: hidden;
    position: relative;
}

/* 中央以外のスライド */
.staff-slider .slick-slide img {
    aspect-ratio: 2 / 3;
    height: 100%;
    object-fit: cover;
    transition: opacity .5s, transform .5s;
    width: 100%;
}

/* 中央のスライド */
.staff-slider .slick-center {
    transform: scale(1);
}

.staff-slider .slick-slide p {
    color: #E2FF03;
    font-size: 3vw;
    font-weight: 500;
    line-height: 1.2;
    position: absolute;
    left: 2%;
    bottom: 2%;
}

.member .btn-resv-yellow {
    margin-top: 3rem;
}

.member .btn-resv-yellow a {
    margin: 0;
    margin-left: auto;
}

@media screen and (max-width: 767px) {

    /***** スタッフ紹介　*****/
    .member {
        padding: 10.5rem 0 2rem;
    }

    .member .ttl-wrap {
        width: 100%;
        padding: 0;
    }

    .member .ttl-wrap h2 {
        font-size: 11vw;
        line-height: 1;
        text-align: right;
        transform: translateY(-100%);
    }

    .member .content {
        padding: 50px 0;
    }

    .member .content h3 {
        font-size: 6.5vw;
        position: static;
        transform: translateY(-70%);
    }

    .staff-slider .slick-slide p {
        font-size: 10vw;
        font-weight: 600;
    }

    .member .btn-resv-yellow {
        margin-top: 2rem;
    }

    .member .btn-resv-yellow a {
        margin: 0 auto;
    }
}

/***** マル優セクション *****/
.maruyu {
    width: 100%;
    height: 100vh;
    background: url(../img/maruyu_bg.png) no-repeat;
    background-size: cover;
    background-position: center;
    position: relative;
}

.maruyu::before {
    content: '';
    background: #002E5C99;
    position: absolute;
    inset: 0;
}

.maruyu .inner {
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.maruyu .txt {
    display: flex;
    flex-direction: column;
    text-align: center;
    color: #fff;
    gap: 1.8rem;
    position: relative;
    z-index: 5;
}

.maruyu .txt h2 {
    font-size: 1.5rem;
    font-weight: 600;
}

.maruyu .txt h2 span {
    font-size: 2.5rem;
}

.maruyu .txt img {
    width: 20%;
    height: auto;
    margin: 0 auto;
}

@media screen and (max-width: 767px) {

    /***** マル優セクション *****/
    .maruyu .inner {
        padding: 0 1rem;
    }

    .maruyu .txt {
        gap: 1rem;
    }

    .maruyu .txt h2 {
        font-size: 1.1rem;
        font-weight: normal;
    }

    .maruyu .txt h2 span {
        font-size: 8vw;
        margin-bottom: .5rem;
        font-weight: 600;
    }

    .maruyu .txt img {
        width: 40%;
    }
}

/***** 今日の八重干瀬 *****/
.today,
.column {
    padding: 50px 0;
}

.today .today-inner {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 40px;
}

.today .today-inner .info {
    width: 50%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    aspect-ratio: 1;
    height: auto;
    background: url(../img/icon/todays_bg.png) no-repeat center;
    background-size: contain;
}

.today .today-inner .info p {
    color: #fff;
    text-align: center;
}

.today .today-inner .info .info-inner {
    width: 50%;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.today .today-inner .info .info-inner .detail {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 2rem;
}

.today .today-inner .info .info-inner .detail .left {
    width: 40%;
    display: flex;
    position: relative;
}

.today .today-inner .info .info-inner .detail .right {
    width: calc(60% - 2rem);
}

.today .today-inner .info .info-inner .detail .left::before {
    content: '';
    width: 80px;
    height: 1px;
    background: #fff;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%) rotate(-45deg);
}

.today .today-inner .info .info-inner .detail .left p {
    width: 50%;
    text-align: center;
    font-size: 2.5rem;
    font-weight: 500;
}

.today .today-inner .info .info-inner .detail .left p.month {
    margin-bottom: 1rem;
}

.today .today-inner .info .info-inner .detail .left p.day {
    margin-top: 1rem;
}

.today .today-inner .info .info-inner .detail .right {
    display: flex;
    flex-direction: column;
    gap: .4rem;
}

.today .today-inner .info .info-inner .detail .right .ttl {
    font-size: 1.3rem;
    font-weight: 500;
}

.today .today-inner .info .info-inner .detail .right .weather {
    font-size: 1.3rem;
    display: flex;
    justify-content: center;
    align-items: center;
    background: #FF7F36;
    padding: .3rem 0;
    border-radius: 10px 10px 10px 0;
}

.today .today-inner .info .info-inner .detail .right .status {
    text-align: center;
}

.today .today-inner .info .info-inner .detail .right .status span {
    font-size: .9rem;
    color: #fff;
}

.today .today-inner .info .info-inner .detail .right .status p {
    font-size: 1.3rem;
}

.today .today-inner .txt-area {
    width: calc(50% - 40px);
    display: flex;
    flex-direction: column;
    gap: 30px;
}

.today .today-inner .txt-area .ttl {
    font-size: 1.3rem;
    font-weight: 600;
}

.today .today-inner .txt-area .btn-area {
    display: flex;
    gap: 1rem;
}

.today .today-inner .txt-area .btn-area .btn-resv-yellow {
    width: calc(50% - .5rem);
}

.today .today-inner .txt-area .btn-area .btn-resv-yellow a {
    width: 100%;
}

/***** コラム *****/
.single-list {
    display: flex;
    flex-wrap: wrap;
    gap: 1.3rem 3rem;
    margin-bottom: 3rem;
}

.single-list .item {
    width: calc((100% - 6rem) / 3);
}

.single-list .item a {
    display: block;
    transition: all .3s ease;
}

.single-list .item a:hover {
    opacity: .7;
    transition: all .3s ease;
}

.single-list .item img {
    width: 100%;
    height: auto;
    aspect-ratio: 3 / 2;
    object-fit: cover;
}

.single-list .item .txt .label {
    width: fit-content;
    font-weight: 500;
    line-height: 1;
    background: #FF3F5F;
    color: #fff;
    padding: 0 .5rem;
    border-radius: 5px;
}

.single-list .item .txt .label.yabiji {
    background: #00A1E6;
}

.single-list .item .txt .label.pumpkin {
    background: #FF7F36;
}

.single-list .item .txt .date {
    display: block;
    font-size: .9rem;
    color: #808080;
}

.single-list .item .txt p {
    font-size: .9rem;
    font-weight: 600;
}

/***** ブログ *****/
.blog {
    padding: 50px 0;
}

@media screen and (max-width: 767px) {

    .today,
    .column {
        padding: 50px 1rem;
    }

    .today .today-inner {
        flex-direction: column;
        gap: 10px;
    }

    .today .today-inner .info {
        width: 100%;
    }

    .today .today-inner .info p {
        font-size: .9rem;
    }

    .today .today-inner .info .info-inner {
        width: 70%;
        gap: .5rem;
    }

    .today .today-inner .info .info-inner .detail {
        gap: 1rem;
    }

    .today .today-inner .info .info-inner .detail .left {
        width: calc(40% - 1rem);
    }

    .today .today-inner .info .info-inner .detail .right {
        width: 60%;
    }

    .today .today-inner .info .info-inner .detail .left::before {
        width: 60px;
        transform: translate(-50%) rotate(-60deg);
    }

    .today .today-inner .info .info-inner .detail .right {
        gap: .2rem;
    }

    .today .today-inner .info .info-inner .detail .right .ttl {
        font-size: 1rem;
    }

    .today .today-inner .info .info-inner .detail .right .weather {
        font-size: 1.1rem;
        padding: .2rem 0;
    }

    .today .today-inner .info .info-inner .detail .right .status p {
        font-size: 1rem;
    }

    .today .today-inner .info .info-inner .btn-resv-yellow {
        transition: all .3s ease;
    }

    .today .today-inner .info .info-inner .btn-resv-yellow:hover {
        opacity: .7;
        transition: all .3s ease;
    }

    .today .today-inner .info .info-inner .btn-resv-yellow a {
        width: 100%;
        padding: .5rem 1rem;
    }

    .today .today-inner .txt-area {
        width: 100%;
        gap: 30px;
    }

    .today .today-inner .txt-area .ttl {
        font-size: 1.1rem;
        text-align: center;
    }

    .today .today-inner .txt-area .ttl p {
        font-size: 1.5rem;
    }

    .today .today-inner .txt-area .btn-area {
        flex-direction: column;
        gap: .5rem;
    }

    .today .today-inner .txt-area .btn-area .btn-resv-yellow {
        width: 100%;
    }

    /***** コラム *****/
    .single-list {
        margin-bottom: 1rem;
    }

    .single-list .item {
        width: 100%;
    }

    /***** ブログ *****/
    .blog {
        padding: 50px 1rem;
    }
}

/******************************
　　　　　　　フッター
******************************/
footer .contact {
    background: #4357D7;
    padding: 100px 0;
}

footer .contact .ttl {
    color: #fff;
    text-align: center;
    margin-bottom: 3rem;
}

footer .contact .ttl h2 {
    font-size: 6rem;
    line-height: 1;
    font-weight: 600;
    letter-spacing: .1em;
    margin-bottom: 1rem;
}

footer .contact .ttl p {
    font-size: 1.5rem;
    font-weight: 500;
}

footer .contact .contact-inner {
    display: flex;
    justify-content: center;
    gap: 5rem;
}

footer .contact .contact-inner .item {
    width: fit-content;
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

footer .contact .contact-inner .item .item-ttl {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1rem;
    font-size: 1.3rem;
    font-weight: 500;
    color: #fff;
}

footer .contact .contact-inner .item .tel-number p {
    font-size: 3rem;
    font-weight: 800;
    line-height: 1;
    letter-spacing: .05em;
    color: #fff;
}

footer .contact .contact-inner .item .tel-number span {
    color: #fff;
}

footer .footer-main {
    background: #002E5C;
    color: #fff;
    padding: 100px 0;
}

footer .footer-main .footer-inner {
    width: 90%;
    margin: 0 auto;
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
}

footer .footer-main .footer-inner .shop-info {
    display: flex;
    flex-direction: column;
    gap: 3rem;
}

footer .footer-main .footer-inner .shop-info th {
    text-align: right;
}

footer .footer-main .footer-inner .link-area {
    display: flex;
    gap: 4vw;
}

footer .footer-main .footer-inner .link-area .category {
    width: fit-content;
}

footer .footer-main .footer-inner .link-area .category .ttl {
    font-size: 1.1rem;
    font-weight: 500;
    position: relative;
    margin-bottom: 1.3rem;
}

footer .footer-main .footer-inner .link-area .category .ttl::before {
    content: '';
    width: 15px;
    aspect-ratio: 1;
    border-radius: 50%;
    background: #55FAEB;
    position: absolute;
    top: 50%;
    left: -5px;
    transform: translate(-100%, -50%);
}

footer .footer-main .footer-inner .link-area .category .parent li {
    font-weight: 500;
    margin-bottom: 1.3rem;
}

footer .footer-main .footer-inner .link-area .category .parent li .child li {
    margin: 0;
    margin-top: .5rem;
    font-weight: 200;
    font-size: .95rem;
}


footer .footer-main .footer-inner .sns .sns-inner {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

footer .footer-main .footer-inner .sns p {
    writing-mode: vertical-rl;
    text-orientation: sideways;
    white-space: nowrap;
    line-height: 1;
}

footer .footer-main .footer-inner .sns .sns-inner ul {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

@media screen and (max-width: 767px) {

    /******************************
　　　　　　　フッター
******************************/
    footer .contact {
        padding: 50px 0;
    }

    footer .contact .ttl {
        margin-bottom: 2rem;
    }

    footer .contact .ttl h2 {
        font-size: 4rem;
        margin-bottom: 1rem;
    }

    footer .contact .ttl p {
        font-size: 1rem;
    }

    footer .contact .contact-inner {
        flex-direction: column;
        align-items: center;
        gap: 2rem;
    }

    footer .contact .contact-inner .item {
        gap: .5rem;
    }

    footer .contact .contact-inner .item .item-ttl {
        font-size: 1rem;
    }

    footer .contact .contact-inner .item .item-ttl svg {
        width: 1.5rem;
    }

    footer .footer-main {
        padding: 50px 1rem;
    }

    footer .footer-main .footer-inner {
        width: 100%;
        flex-direction: column;
        gap: 1rem;
    }

    footer .footer-main .footer-inner .shop-info {
        gap: 1.3rem;
    }

    footer .footer-main .footer-inner .shop-info .concept {
        text-align: center;
    }

    footer .footer-main .footer-inner .link-area {
        flex-direction: column;
        gap: 1.3rem;
        padding: 0 1rem;
    }

    footer .footer-main .footer-inner .link-area .category {
        width: 100%;
    }

    footer .footer-main .footer-inner .link-area .category .ttl {
        font-size: 1rem;
        margin-bottom: 1rem;
    }

    footer .footer-main .footer-inner .link-area .category .ttl::before {
        width: 10px;
    }

    footer .footer-main .footer-inner .link-area .category .parent li {
        margin-bottom: 1rem;
    }

    footer .footer-main .footer-inner .link-area .category .parent li .child li {
        font-size: .9rem;
    }


    footer .footer-main .footer-inner .sns .sns-inner {
        flex-direction: row;
        justify-content: center;
        gap: 1.5rem;
    }

    footer .footer-main .footer-inner .sns p {
        writing-mode: inherit;
    }

    footer .footer-main .footer-inner .sns .sns-inner ul {
        flex-direction: row;
        gap: 1.5rem;
    }
}

/*********************************
　　　　　　　　下層ページ
*********************************/
.kasou {
    overflow: clip;
}

.kasou-mv {
    height: 70vh;
    background: #3193F4;
    display: flex;
    align-items: flex-end;
}

.kasou-mv.pumpkin {
    background: #FE5B00;
}

.kasou-mv-inner {
    width: 90%;
    display: flex;
    align-items: center;
    gap: 2rem;
    margin-left: auto;
}

.kasou-mv-inner .txt {
    width: calc(50% - 1rem);
    color: #fff;
}

.kasou-mv-inner .txt .mv-ttl {
    font-weight: 600;
    margin-bottom: 2.5rem;
}

.kasou-mv-inner .txt .mv-ttl span {
    font-size: 2rem;
}

.kasou-mv-inner .txt .mv-ttl h2 {
    font-size: 3.5vw;
    line-height: 1.2;
}

.kasou-mv-inner .txt p {
    font-size: 1.1rem;
}

.kasou-mv-inner .img {
    display: flex;
    align-items: flex-end;
    width: calc(50% - 1rem);
}

.kasou-mv-inner .img img {
    aspect-ratio: 5 / 3;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/***** ショップ案内 *****/
.shop-detail {
    background: #FAF1E6;
    padding: 100px 0;
}

.shop-detail p.name {
    font-size: 5rem;
    color: #FE5B00;
    font-weight: 600;
}

.shop-detail h2 {
    font-size: 2rem;
    font-weight: 600;
}

.shop-detail ul {
    margin-top: 2rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.shop-detail ul li {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    background: #fff;
    padding: 1rem;
    padding-left: 2.5rem;
    border-left: 10px solid #ff5b00;
    font-size: 1.2rem;
    font-weight: 600;
}

.shop-detail ul li span {
    display: block;
    width: 30%;
    color: #ff5b00;
}

.various-slider {
    background: #FAF1E6;
}

.various-slider img {
    object-fit: cover;
    padding: 0 .7rem;
    aspect-ratio: 5 / 3;
}

/***** アクセスマップ *****/
.access-map {
    padding: 100px 0;
}

.access-map .ttl {
    padding-left: 1.8rem;
    border-left: 10px solid #3193F4;
    font-size: 1.5rem;
    font-weight: 900;
}

.access-map iframe {
    aspect-ratio: 2 / 1;
    margin: 2rem 0;
}

.access-map .txt .label {
    margin-bottom: 10px;
    font-size: 1.3rem;
    font-weight: 600;
    color: #3193F4;
}

.access-map .txt ul {
    display: flex;
    gap: 3rem;
}

.access-map .txt ul li {
    padding-left: 1rem;
    position: relative;
}

.access-map .txt ul li::before {
    content: '';
    width: .5rem;
    height: .5rem;
    background: #484848;
    border-radius: 50%;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}

@media screen and (max-width: 767px) {
    .kasou-mv {
        height: fit-content;
        padding-top: 80px;
    }

    .kasou-mv-inner {
        width: 100%;
        padding: 1rem;
        flex-direction: column;
        gap: 1rem;
    }

    .kasou-mv-inner .txt {
        width: 100%;
    }

    .kasou-mv-inner .txt .mv-ttl {
        margin-bottom: .8rem;
    }

    .kasou-mv-inner .txt .mv-ttl span {
        font-size: .9rem;
    }

    .kasou-mv-inner .txt .mv-ttl h2 {
        font-size: 8vw;
    }

    .kasou-mv-inner .txt p {
        font-size: .9rem;
    }

    .kasou-mv-inner .img {
        width: 100%;
    }

    /***** ショップ案内 *****/
    .shop-detail {
        padding: 50px 1rem;
    }

    .shop-detail p.name {
        font-size: 2rem;
    }

    .shop-detail h2 {
        font-size: 1.1rem;
    }

    .shop-detail ul {
        margin-top: 1.3rem;
        gap: .6rem;
    }

    .shop-detail ul li {
        padding: .6rem;
        padding-left: 1rem;
        border-left: 7px solid #ff5b00;
        font-size: .9rem;
    }

    .shop-detail ul li span {
        width: 40%;
    }

    /***** アクセスマップ *****/
    .access-map {
        padding: 50px 1rem;
    }

    .access-map .ttl {
        padding-left: 1rem;
        border-left: 7px solid #3193F4;
        font-size: 1.3rem;
    }

    .access-map iframe {
        aspect-ratio: 3 / 2;
        margin: .7rem 0;
    }

    .access-map .txt .label {
        font-size: 1.1rem;
    }

    .access-map .txt ul {
        flex-wrap: wrap;
        gap: .5rem;
    }

    .access-map .txt ul li {
        width: 100%;
        padding-left: 1rem;
    }

}

/***********************
　　　　スタッフ紹介
***********************/

.staff-list {
    padding: 100px 0;
    display: flex;
    flex-direction: column;
    gap: 8rem;
}

.staff-list .staff-category p.ttl {
    margin-bottom: 3rem;
    font-size: 8vw;
    color: #e2e2e2;
    font-weight: 900;
    line-height: 1;
    text-align: center;
    position: relative;
}

.staff-list .staff-category p.marine:before {
    content: 'マリンスタッフ';
}

.staff-list .staff-category p.office:before {
    content: '事務スタッフ';
}

.staff-list .staff-category p.ttl:before {
    font-size: 1.1rem;
    color: #FE5B00;
    font-weight: 600;
    position: absolute;
    top: 57%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.staff-list .staff-category ul {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
}

.staff-list .staff-category ul li {
    width: calc((100% - 4rem) / 3);
}

.staff-list .staff-category ul li .img {
    aspect-ratio: 2 / 2.5;
    display: flex;
    align-items: flex-end;
    background: #E2E2E2;
    margin-bottom: 10px;
}

.staff-list .staff-category ul li .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.staff-list .staff-category ul li .txt .en {
    color: #FE5B00;
    font-weight: 600;
}

.staff-list .staff-category ul li .txt p {
    font-size: 2.1rem;
    font-weight: 600;
    line-height: 1;
}

.staff-list .staff-category ul li .txt .post {
    margin-top: 10px;
    display: flex;
    flex-wrap: wrap;
    gap: .8rem;
}

.staff-list .staff-category ul li .txt .post li {
    width: fit-content;
    color: #777;
    font-weight: 600;
}

:root {
    --content-max: 1200px;
}

.staff-detail-mv {
    height: 75vh;
}

.staff-detail-mv .mv-inner {
    width: min(100vw, calc(50vw + calc(var(--content-max) / 2)));
    height: 100%;
    display: flex;
    align-items: flex-end;
    gap: 3rem;
    margin-left: auto;
}

.staff-detail-mv .mv-inner .txt {
    width: 30%;
    padding-bottom: 3rem;
    position: relative;
}

.staff-detail-mv .mv-inner .txt .catch-copy {
    width: 50vw;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    position: absolute;
    left: 0;
    top: -3rem;
    transform: translateY(-100%);
}

.staff-detail-mv .mv-inner .txt .catch-copy p {
    width: fit-content;
    font-size: 2.5rem;
    font-weight: 600;
    color: #fff;
    padding: 0 .3rem;
    background: #3193F4;
}

.staff-detail-mv .mv-inner .txt .post {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}

.staff-detail-mv .mv-inner .txt .post li {
    background: #3193F4;
    padding: .2rem 1rem;
    color: #fff;
    border-radius: 9999px;
    font-weight: 500;
}

.staff-detail-mv .mv-inner .txt h2 {
    font-size: 3rem;
    font-weight: 600;
}

.staff-detail-mv .mv-inner .img {
    width: calc(70% - 3rem);
    height: 100%;
    display: flex;
    align-items: flex-end;
}

.staff-detail-mv .mv-inner .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.staff-qa {
    padding: 100px 0;
    display: flex;
    flex-direction: column;
    gap: 3rem;
}

.staff-qa .item .question {
    background: #3193F4;
    padding: .7rem 1.5rem;
    font-size: 1.5rem;
    font-weight: 600;
    color: #fff;
    border-radius: 10px;
    margin-bottom: 1.5rem;
}

.staff-qa .item .answer {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 2rem;
}

.staff-qa .item:nth-child(even) .answer {
    flex-direction: row-reverse;
}

.staff-qa .item .answer img {
    width: 45%;
    aspect-ratio: 3 / 2;
    border-radius: 10px;
}

.staff-qa .item .answer .txt {
    width: calc(55% - 2rem);
}

.staff-qa .item .answer .txt .head {
    margin-bottom: 1.3rem;
    font-size: 1.5rem;
    font-weight: 600;
    color: #3193F4;
}

@media screen and (max-width: 767px) {
    .staff-list {
        padding: 50px 1rem;
        gap: 3rem;
    }

    .staff-list .staff-category p.ttl {
        margin-bottom: 1.3rem;
        font-size: 5.5rem;
        font-weight: 900;
    }

    .staff-list .staff-category p.ttl:before {
        font-size: 1rem;
    }

    .staff-list .staff-category ul li {
        width: 100%;
    }

    .staff-list .staff-category ul li .img {
        aspect-ratio: 1;
        display: flex;
        align-items: flex-end;
        background: #E2E2E2;
        margin-bottom: 10px;
    }

    .staff-list .staff-category ul li .txt .en {
        font-size: .9rem;
    }

    .staff-list .staff-category ul li .txt .post li {
        font-size: .9rem;
    }

    .staff-detail-mv .mv-inner {
        width: 100%;
        flex-direction: column-reverse;
        gap: 1rem;
    }

    .staff-detail-mv .mv-inner .txt {
        width: 100%;
        padding: 0 1rem;
        padding-bottom: 0;
    }

    .staff-detail-mv .mv-inner .txt .catch-copy {
        width: 100%;
        gap: 5px;
        position: static;
        transform: none;
        margin-bottom: 1rem;
    }

    .staff-detail-mv .mv-inner .txt .catch-copy p {
        font-size: 1.5rem;
    }

    .staff-detail-mv .mv-inner .txt .post {
        gap: .7rem;
    }

    .staff-detail-mv .mv-inner .txt .post li {
        padding: 0 .8rem;
    }

    .staff-detail-mv .mv-inner .txt h2 {
        font-size: 2rem;
    }

    .staff-detail-mv .mv-inner .img {
        width: 90%;
        aspect-ratio: 2 / 3;
    }

    .staff-detail-mv .mv-inner .img img {
        height: 100%;
        object-fit: cover;
    }

    .staff-qa {
        padding: 50px 1rem;
        gap: 1.8rem;
    }

    .staff-qa .item .question {
        padding: .7rem;
        font-size: .9rem;
        border-radius: 5px;
        margin-bottom: 10px;
    }

    .staff-qa .item .answer {
        flex-direction: column-reverse;
        gap: 10px;
    }

    .staff-qa .item:nth-child(even) .answer {
        flex-direction: column-reverse;
    }

    .staff-qa .item .answer img {
        width: 100%;
        border-radius: 5px;
    }

    .staff-qa .item .answer .txt {
        width: 100%;
    }

    .staff-qa .item .answer .txt .head {
        margin-bottom: 10px;
        font-size: 1.1rem;
    }
}

/*******************
　ツアーフローページ
*******************/
.tour-flow-inner {
    padding: 100px 0;
    display: flex;
    flex-direction: column;
    gap: 3rem;
}

.tour-flow-inner .item .head {
    border-bottom: 1.8rem solid #EB612A;
    padding-bottom: .8rem;
    margin-bottom: 2rem;
}

.tour-flow-inner .item .head p {
    font-size: 3rem;
    font-weight: 900;
}

.tour-flow-inner .item .head p span {
    font-size: 5rem;
    color: #EB612A;
    margin-left: 1rem;
}

.tour-flow-inner .item .detail {
    display: flex;
    align-items: flex-start;
    gap: 3rem;
}

.tour-flow-inner .item .detail:nth-child(n+2) {
    margin-top: 2rem;
}

.tour-flow-inner .item .detail:nth-child(even) {
    flex-direction: row-reverse;
}

.tour-flow-inner .item .detail .txt,
.tour-flow-inner .item .detail img {
    width: calc(50% - 1.5rem);
}

.tour-flow-inner .item .detail .txt .ttl {
    font-size: 2.5rem;
    font-weight: 900;
    margin-bottom: 1.8rem;
}

.tour-flow-inner .item .detail img {
    object-fit: cover;
    aspect-ratio: 3 / 2;
    border-radius: 20px;
}

@media screen and (max-width: 767px) {
    .tour-flow-inner {
        padding: 50px 1rem;
        gap: 2rem;
    }

    .tour-flow-inner .item .head {
        border-bottom: .8rem solid #EB612A;
        padding-bottom: .3rem;
        margin-bottom: 0;
    }

    .tour-flow-inner .item .head p {
        font-size: 1.5rem;
    }

    .tour-flow-inner .item .head p span {
        font-size: 1.5rem;
        margin-left: .3rem;
    }

    .tour-flow-inner .item .detail {
        flex-direction: column;
        gap: 1rem;
    }

    .tour-flow-inner .item .detail:nth-child(n+2) {
        margin-top: 1rem;
    }

    .tour-flow-inner .item .detail:nth-child(even) {
        flex-direction: column;
    }

    .tour-flow-inner .item .detail .txt,
    .tour-flow-inner .item .detail img {
        width: 100%;
    }

    .tour-flow-inner .item .detail .txt .ttl {
        font-size: 1.1rem;
        margin-bottom: .5rem;
    }

    .tour-flow-inner .item .detail img {
        border-radius: 10px;
    }
}

/*********************
　　　　　マル優
*********************/
.concept {
    padding-top: 100px;
}

.concept .concept-ttl {
    margin-bottom: 3rem;
}

.concept .concept-ttl p {
    font-size: 1.1rem;
    font-weight: 600;
    color: #FE5B00;
}

.concept .concept-ttl h2 {
    font-size: 2rem;
    font-weight: 600;
}

.concept .concept-inner {
    width: min(100vw, calc(50vw + calc(var(--content-max) / 2)));
    margin-right: auto;
    display: flex;
    gap: 3rem;
}

.concept .concept-inner img {
    width: calc(70% - 3rem);
    aspect-ratio: 3 / 2;
    object-fit: cover;
    display: flex;
    align-items: flex-end;
}

.concept .concept-inner .txt {
    width: 30%;
}

.concept .concept-inner .txt .head {
    font-size: 2rem;
    font-weight: 600;
    margin-bottom: 1rem;
}

.concept .concept-inner .txt .head span {
    color: #FE5B00;
}

.concept .concept-inner .txt .detail {
    line-height: 2;
}

/***** どんな基準で選ばれてるの？ *****/
.howto {
    padding: 100px 0;
    background: #F5F5F5;
    text-align: center;
}

.howto-ttl .en {
    font-size: 1.3rem;
    font-weight: 600;
    color: #FE5B00;
}

.howto-ttl h2 {
    font-size: 2rem;
    font-weight: 600;
    margin-bottom: 1rem;
}

.howto .howto-list {
    display: flex;
    gap: 2.5rem;
    margin: 2.5rem 0;
}

.howto .howto-list .item {
    width: calc((100% - 7.5rem) / 4);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    gap: 1rem;
    font-weight: 600;
    aspect-ratio: 1;
    background: #fff;
    border-radius: 1rem;
}

.howto .howto-list .item img {
    width: 120px;
    aspect-ratio: 1;
    object-fit: contain;
}

/***** マル優を選ぶメリット *****/
.maruyu-merit {
    padding: 100px 0;
}

.merit-ttl {
    width: 100%;
    text-align: center;
    background: #3193F4;
    border-radius: 10px;
    padding: 1rem 0;
    margin-bottom: 3rem;
    position: relative;
}

.merit-ttl h2 {
    font-size: 1.8rem;
    font-weight: 500;
    color: #fff;
}

.merit-ttl h2 span {
    color: #E2FF00;
    font-size: 2rem;
    margin: 0 .7rem;
    font-weight: 600;
}

.merit-ttl::before {
    content: '';
    width: 0;
    height: 0;
    border-style: solid;
    border-right: 15px solid transparent;
    border-left: 15px solid transparent;
    border-top: 25px solid #3193F4;
    border-bottom: 0;
    position: absolute;
    left: 50%;
    bottom: 0;
    z-index: -1;
    transform: translate(-50%, 100%);
}

.maruyu-merit table {
    border-collapse: separate;
    border-spacing: 5rem 3rem;
}

.maruyu-merit th {
    width: 40%;
    font-weight: 600;
}

.maruyu-merit th span {
    font-size: 1.1rem;
}

.maruyu-merit th p {
    font-size: 1.7rem;
}

.maruyu-merit th p span {
    font-size: 1.7rem;
    color: #3193F4;
}

.maruyu-merit td {
    padding-top: 2rem;
}

.maruyu-merit td ul {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.maruyu-merit td ul li span {
    font-size: 1.1rem;
    font-weight: 600;
    color: #FE5B00;
}

/***** お客様の声 *****/
.customer-voice {
    padding: 100px 0;
    background: #FEF9F4;
}

.customer-voice .howto-ttl {
    text-align: center;
}

.customer-voice .cv-list {
    display: flex;
    gap: 1.25rem;
    margin-top: 3rem;
}

.customer-voice .cv-list .item {
    width: calc((100% - 3.75rem) / 4);
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 1.5rem;
    gap: 1rem;
    background: #FFFFFF;
    border-radius: 1rem;
}

.customer-voice .cv-list .item .icon {
    width: 100px;
    aspect-ratio: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    background: #FFC9C9;
    border-radius: 50%;
    overflow: hidden;
}

.customer-voice .cv-list .item:nth-child(even) .icon {
    background: #7ABEE6;
}

.customer-voice .cv-list .item .name {
    font-weight: 600;
}

@media screen and (max-width: 767px) {
    .concept {
        padding-top: 0;
        padding: 50px 1rem;
    }

    .concept .concept-ttl {
        margin-bottom: 1rem;
    }

    .concept .concept-ttl p {
        font-size: .9rem;
    }

    .concept .concept-ttl h2 {
        font-size: 1.1rem;
    }

    .concept .concept-inner {
        width: 100%;
        flex-direction: column;
        gap: 1rem;
    }

    .concept .concept-inner img {
        width: 100%;
    }

    .concept .concept-inner .txt {
        width: 100%;
    }

    .concept .concept-inner .txt .head {
        font-size: 1.5rem;
    }

    .concept .concept-inner .txt .detail {
        line-height: 1.7;
    }

    /***** どんな基準で選ばれてるの？ *****/
    .howto {
        padding: 50px 1rem;
    }

    .howto-ttl h2 {
        font-size: 1.3rem;
    }

    .howto .howto-list {
        gap: 1rem;
        flex-wrap: wrap;
        margin: 2.5rem 0;
    }

    .howto .howto-list .item {
        width: calc((100% - 1rem) / 2);
        gap: .5rem;
        padding: .5rem;
        border-radius: .5rem;
    }

    .howto .howto-list .item img {
        width: 80px;
    }

    .howto .howto-list .item p {
        font-size: .9rem;
    }

    /***** マル優を選ぶメリット *****/
    .maruyu-merit {
        padding: 50px 1rem;
    }

    .merit-ttl {
        border-radius: .5rem;
        padding: .5rem;
        margin-bottom: 1.5rem;
    }

    .merit-ttl h2 {
        font-size: 1.1rem;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .merit-ttl h2 span {
        font-size: 1.3rem;
        margin: 0 .5rem;
    }

    .merit-ttl::before {
        border-right: 10px solid transparent;
        border-left: 10px solid transparent;
        border-top: 20px solid #3193F4;
    }

    .maruyu-merit table {
        border-spacing: 0;
    }

    .maruyu-merit table tr {
        width: 100%;
        display: flex;
        flex-direction: column;
        margin-bottom: 2rem;
    }

    .maruyu-merit th {
        width: 100%;
    }

    .maruyu-merit th span {
        font-size: 1rem;
    }

    .maruyu-merit th p {
        font-size: 1.3rem;
    }

    .maruyu-merit th p span {
        font-size: 1.3rem;
    }

    .maruyu-merit td {
        padding-top: 1rem;
    }

    .maruyu-merit td ul {
        gap: .5rem;
    }

    .maruyu-merit td ul li span {
        font-size: 1rem;
    }

    /***** お客様の声 *****/
    .customer-voice {
        padding: 50px 1rem;
    }

    .customer-voice .cv-list {
        flex-wrap: wrap;
        gap: 1rem;
        margin-top: 1.5rem;
    }

    .customer-voice .cv-list .item {
        width: 100%;
        padding: 1rem;
        gap: .5rem;
        border-radius: .5rem;
    }

    .customer-voice .cv-list .item .icon {
        width: 80px;
    }

}

/*********************************
　　　　　　　アクティビティ
*********************************/
.page-activity {
    padding: 100px 0;
}

.page-activity .activity-item {
    padding: 50px 0;
    padding-top: 150px;
}

.page-activity .activity-item .activity-exp {
    width: min(100vw, calc(50vw + calc(var(--content-max) / 2)));
    margin-right: auto;
    display: flex;
    align-items: flex-start;
    gap: 3rem;
    position: relative;
}

.page-activity .activity-item:nth-child(even) .activity-exp {
    flex-direction: row-reverse;
    margin-right: unset;
    margin-left: auto;
}

.page-activity .activity-item.yabiji .activity-exp::after {
    content: 'YABIJI';
    color: #3193F440;
    text-align: right;
}

.page-activity .activity-item.pumpkin .activity-exp::after {
    content: 'PUMPKIN';
    color: #FF7F3640;
    text-align: left;
}

.page-activity .activity-item.umigame .activity-exp::after {
    content: 'SEA TURTLE';
    color: #3193F440;
    text-align: right;
}

.page-activity .activity-item.night .activity-exp::after {
    content: 'NIGHT HEAL';
    color: #FF7F3640;
    text-align: left;
    line-height: 1.3;
}

.page-activity .activity-item .activity-exp::after {
    width: 100vw;
    font-size: 15vw;
    font-weight: 900;
    line-height: 1.2;
    letter-spacing: .05em;
    position: absolute;
    left: 50%;
    top: 0;
    transform: translate(-50%, -60%);
    z-index: -1;
}

.page-activity .activity-item .activity-exp .img {
    width: 60%;
}

.page-activity .activity-item .activity-exp .img img {
    width: 100%;
    aspect-ratio: 3 / 2;
    object-fit: cover;
}

.page-activity .activity-item .activity-exp .txt {
    width: calc(40% - 3rem);
}

.page-activity .activity-item .activity-exp .txt .ttl p {
    width: fit-content;
    font-size: 3.5vw;
    padding-bottom: 1rem;
    margin-bottom: 1rem;
    font-weight: 600;
    position: relative;
}

.page-activity .activity-item .activity-exp .txt .ttl p.yabiji:before {
    content: 'ヤビジ';
}

.page-activity .activity-item .activity-exp .txt .ttl p:before {
    font-size: 1.2rem;
    font-weight: 600;
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
}

.page-activity .activity-item .activity-exp .txt .exp {
    line-height: 2;
}

.page-activity .activity-item .activity-inner {
    display: flex;
    flex-direction: column;
    gap: 5rem;
    padding: 5rem 0;
}

.page-activity .activity-item .activity-inner .inner-item {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 3rem;
}

.page-activity .activity-item .activity-inner .inner-item.left {
    flex-direction: row-reverse;
}

.page-activity .activity-item .activity-inner .inner-item .txt {
    width: calc(50% - 1.5rem);
}

.page-activity .activity-item .activity-inner .inner-item img {
    width: calc(50% - 1.5rem);
}

.page-activity .activity-item .activity-inner .inner-item .txt .ttl {
    margin-bottom: 1rem;
    font-weight: 900;
}

.page-activity .activity-item .activity-inner .inner-item .txt .ttl h3 {
    color: #3193F4;
    font-size: 1.1rem;
}

.page-activity .activity-item.pumpkin .activity-inner .inner-item .txt .ttl h3,
.page-activity .activity-item.night .activity-inner .inner-item .txt .ttl h3 {
    color: #FF7F36;
}

.page-activity .activity-item .activity-inner .inner-item .txt .ttl span {
    font-size: 2rem;
    line-height: 1;
    letter-spacing: .05em;
}

.page-activity .activity-item .activity-inner .inner-item .txt .exp {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.page-activity .activity-item .activity-inner .inner-item .txt .exp span {
    display: block;
    font-size: 1.1rem;
    font-weight: 600;
}

.page-activity .activity-item .activity-inner .inner-item .txt .exp a {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: .8rem;
    font-size: 1.1rem;
    font-weight: 500;
    color: #fff;
    background: #3193F4;
    padding: 1rem 0;
    border-radius: .8rem;
}

.page-activity .activity-item .activity-inner .inner-item .txt .exp a.pumpkin {
    background: #FF7F36;
}

@media screen and (max-width: 767px) {
    .page-activity {
        padding: 50px 1rem;
    }

    .page-activity .activity-item {
        padding: 0;
        padding-top: 0;
    }

    .page-activity .activity-item .activity-exp {
        width: 100%;
        flex-direction: column;
        gap: 0;
    }

    .page-activity .activity-item:nth-child(even) .activity-exp {
        flex-direction: column;
    }

    .page-activity .activity-item.yabiji .activity-exp::after {
        text-align: center;
    }

    .page-activity .activity-item.pumpkin .activity-exp::after {
        text-align: center;
    }

    .page-activity .activity-item.umigame .activity-exp::after {
        text-align: center;
    }

    .page-activity .activity-item.night .activity-exp::after {
        text-align: center;
        line-height: .8;
    }

    .page-activity .activity-item .activity-exp::after {
        font-size: 20vw;
        left: 50%;
        top: 60%;
        transform: translate(-50%, -50%);
    }

    .page-activity .activity-item .activity-exp .img {
        width: 100%;
    }

    .page-activity .activity-item .activity-exp .txt {
        width: 100%;
    }

    .page-activity .activity-item .activity-exp .txt .ttl p {
        width: 100%;
        font-size: 10vw;
        padding-bottom: 0;
        margin-bottom: 1rem;
        text-align: center;
        margin-bottom: 0;
    }

    .page-activity .activity-item .activity-exp .txt .ttl p.yabiji:before {
        content: '';
    }

    .page-activity .activity-item .activity-exp .txt .exp {
        line-height: 1.5;
        font-size: .9rem;
    }

    .page-activity .activity-item .activity-inner {
        gap: 3rem;
        padding: 3rem 0;
    }

    .page-activity .activity-item .activity-inner .inner-item {
        display: flex;
        flex-direction: column-reverse;
        gap: 1rem;
    }

    .page-activity .activity-item .activity-inner .inner-item.left {
        flex-direction: column-reverse;
    }

    .page-activity .activity-item .activity-inner .inner-item .txt {
        width: 100%;
    }

    .page-activity .activity-item .activity-inner .inner-item img {
        width: 100%;
    }

    .page-activity .activity-item .activity-inner .inner-item .txt .ttl {
        margin-bottom: 1rem;
        font-weight: 900;
    }

    .page-activity .activity-item .activity-inner .inner-item .txt .ttl h3 {
        font-size: .9rem;
    }

    .page-activity .activity-item .activity-inner .inner-item .txt .exp {
        gap: .8rem;
    }

    .page-activity .activity-item .activity-inner .inner-item .txt .exp span {
        font-size: .9rem;
    }

    .page-activity .activity-item .activity-inner .inner-item .txt .exp a {
        font-size: .9rem;
        padding: .8rem 0;
    }

}

/*******************************
八重干瀬110番・パンプキン鍾乳洞の魅力
*******************************/
.what {
    padding: 100px 0;
}

.what-ttl {
    margin-bottom: 4rem;
}

.what-ttl h2 {
    font-size: 2rem;
    padding-left: 2rem;
    position: relative;
}

.what-ttl h2::before {
    content: '';
    width: 1rem;
    height: 1rem;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    border-radius: 50%;
}

.yabiji .what-ttl h2::before {
    background: #3193F4;
}

.pumpkin .what-ttl h2::before {
    background: #FE5B00;
}

.what-ttl p {
    font-size: 6rem;
    font-weight: 900;
    line-height: 1;
}

.what .what-inner {
    display: flex;
    align-items: flex-start;
    gap: 3rem;
}

.what .what-inner .txt {
    width: 65%;
}

.what .what-inner .txt p {
    line-height: 2;
}

.what .what-inner img {
    width: calc(35% - 3rem);
    aspect-ratio: 1;
    object-fit: cover;
    border-radius: 1rem;
}

.page-area_column .various-slider {
    background: none;
}

.enjoy {
    padding: 100px 0;
}

.enjoy-inner {
    display: flex;
    align-items: flex-start;
    gap: 1.8rem;
}

.enjoy-inner .item-list {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
}

.enjoy-inner .item-list:nth-child(2) {
    margin-top: 3rem;
}

.enjoy-inner .item-list:nth-child(3) {
    margin-top: 6rem;
}

.enjoy-inner .item-list:nth-child(4) {
    margin-top: 9rem;
}

.enjoy-inner .item-list .item {
    width: calc((100% - 4.5rem) / 4)
}

.enjoy-inner .item-list .item:nth-child(2) {
    margin-top: 50px;
}

.enjoy-inner .item-list .item:nth-child(3) {
    margin-top: 100px;
}

.enjoy-inner .item-list .item:nth-child(4) {
    margin-top: 150px;
}

.enjoy-inner .item-list .item:nth-child(5) {
    margin-top: -150px;
}

.enjoy-inner .item-list .item:nth-child(6) {
    margin-top: -100px;
}

.enjoy-inner .item-list .item:nth-child(7) {
    margin-top: -50px;
}

.enjoy-inner .item-list .item .img {
    position: relative;
}

.enjoy-inner .item-list .item .img img {
    width: 100%;
    height: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    border-radius: 5rem;
}

.enjoy-inner .item-list .item .img p {
    font-size: 3rem;
    font-weight: 900;
    color: #ff5b00;
    position: absolute;
    bottom: 0;
    left: 0;
}

.enjoy-inner .item-list .item .txt p {
    margin-top: .9rem;
}

.enjoy-inner .item-list .item .txt p span {
    width: fit-content;
    font-size: 1.5rem;
    font-weight: 600;
    margin: 0 5px;
    position: relative;
}

.enjoy-inner .item-list .item .txt p span::before {
    content: '';
    height: 8px;
    background: #FE5B0080;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
}

.discover {
    padding: 100px 0;
    background: #FAF1E6;
}

.discover .discover-list {
    display: flex;
    flex-wrap: wrap;
    gap: 1.8rem;
    margin-bottom: 2rem;
}

.discover .discover-list .item {
    width: calc((100% - 5.4rem) / 4);
}

.discover .discover-list .item .img {
    position: relative;
}

.discover .discover-list .item.tips .img::before {
    content: 'Tips';
    background: #FE5B00;
}

.discover .discover-list .item.special .img::before {
    content: 'Special';
    background: #F82592;
}

.discover .discover-list .item.study .img::before {
    content: 'Study';
    background: #3193F4;
}

.discover .discover-list .item.faq .img::before {
    content: 'FAQ';
    background: #00A23F;
}

.discover .discover-list .item .img::before {
    width: 60px;
    height: 60px;
    font-size: .9rem;
    font-weight: 600;
    color: #fff;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 0;
    left: 0;
    transform: translate(-20%, -20%);
}

.discover .discover-list .item .img img {
    width: 100%;
    height: 100%;
    aspect-ratio: 5 / 4;
    border-radius: 2rem;
    object-fit: cover;
}

.discover .discover-list .item.tips .txt p {
    color: #FE5B00;
}

.discover .discover-list .item.special .txt p {
    color: #F82592;
}

.discover .discover-list .item.study .txt p {
    color: #3193F4;
}

.discover .discover-list .item.faq .txt p {
    color: #00A23F;
}

@media screen and (max-width: 767px) {

    .what {
        padding: 50px 1rem;
    }

    .what-ttl {
        margin-bottom: 2rem;
    }

    .what-ttl h2 {
        font-size: 1rem;
        padding-left: 1.5rem;
    }

    .what-ttl p {
        font-size: 3rem;
        line-height: 1;
    }

    .what .what-inner {
        flex-direction: column-reverse;
        gap: 1rem;
    }

    .what .what-inner .txt {
        width: 100%;
    }

    .what .what-inner .txt p {
        line-height: 1.5;
    }

    .what .what-inner img {
        width: 100%;
        aspect-ratio: 3 / 2;
        border-radius: .5rem;
    }

    .enjoy {
        padding: 50px 1rem;
    }

    .enjoy-inner {
        flex-wrap: wrap;
        gap: 1.2rem;
    }

    .enjoy-inner .item-list {
        display: flex;
        gap: 1rem;
    }

    .enjoy-inner .item-list .item {
        width: calc((100% - 1rem) / 2);
        margin: 0 !important;
    }

    .enjoy-inner .item-list .item .img {
        position: relative;
    }

    .enjoy-inner .item-list .item .img img {
        border-radius: 50%;
    }

    .enjoy-inner .item-list .item .img p {
        font-size: 5rem;
    }

    .enjoy-inner .item-list .item .txt p {
        margin-top: .9rem;
    }

    .enjoy-inner .item-list .item .txt p span {
        font-size: 1.2rem;
        margin: 0 2px;
    }

    .enjoy-inner .item-list .item .txt p span::before {
        content: '';
        height: 8px;
        background: #FE5B0050;
        position: absolute;
        left: 0;
        right: 0;
        bottom: 0;
    }

    .discover {
        padding: 50px 1rem;
    }

    .discover .discover-list {
        gap: 1.2rem;
    }

    .discover .discover-list .item {
        width: calc((100% - 1.2rem) / 2);
    }

    .discover .discover-list .item .img::before {
        width: 45px;
        height: 45px;
        font-size: .7rem;
        transform: translate(-20%, -20%);
    }

    .discover .discover-list .item .img img {
        width: 100%;
        height: 100%;
        aspect-ratio: 1;
        border-radius: 2rem;
        object-fit: cover;
    }

    .discover .discover-list .item .txt p {
        font-size: .9rem;
    }
}

/******************************
　　　　　アーカイブページ
******************************/
.page-archive {
    display: flex;
    gap: 3rem;
    padding: 100px 0;
    position: relative;
}

.page-archive .archive-inner {
    width: 65%;
    display: flex;
    flex-wrap: wrap;
    gap: 1.8rem;
}

.page-archive .archive-inner .item {
    width: calc((100% - 3.6rem) / 3);
}

.page-archive .archive-inner .item .img {
    position: relative;
}

.page-archive .archive-inner .item.toursimg .img::before {
    content: '八重干瀬ツアー';
    background: #3193F4;
}

.page-archive .archive-inner .item.shop .img::before {
    content: 'ショップ情報';
    background: #FE5B00;
}

.page-archive .archive-inner .item .img::before {
    padding: .7rem 1.25rem;
    border-radius: 1.8rem 0 1.8rem 0;
    color: #fff;
    font-weight: 600;
    position: absolute;
    top: 0;
    left: 0;
}

.page-archive .archive-inner .item .img img {
    width: 100%;
    height: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    border-radius: 1.8rem;
}

.page-archive .archive-inner .item .txt span {
    font-size: .8rem;
    color: #424242;
}

.page-archive .archive-inner .item .txt p {
    font-weight: 600;
}

.page-archive .sidebar {
    width: calc(35% - 3rem);
    height: fit-content;
    position: sticky;
    top: 150px;
}

.page-archive .sidebar p.sidebar-ttl {
    font-size: 1.1rem;
    font-weight: 600;
    padding-bottom: .5rem;
    border-bottom: 1px solid #000;
    margin-bottom: 1.8rem;
}

.page-archive .sidebar .single-list {
    display: flex;
    flex-direction: column;
    gap: .9rem;
}

.page-archive .sidebar .single-list li {
    padding-bottom: .9rem;
    border-bottom: 1px solid #000;
}

.page-archive .sidebar .single-list li a {
    display: flex;
    gap: .9rem;
}

.page-archive .sidebar .single-list li a img {
    width: 25%;
    height: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    border-radius: .5rem;
}

.page-archive .sidebar .single-list li a p {
    width: calc(75% - .9rem);
    font-size: .9rem;
}

.pagination {
    width: 100%;
}
.pagination .nav-links {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 15px;
}

.nav-links .page-numbers {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 44px;
    height: 44px;
    padding: 0;
    border-radius: 50%;
    border: 1px solid #333;
    color: #333;
    text-decoration: none;
    background: #fff;
    font-size: 16px;
    box-sizing: border-box;
    transition: all 0.3s;
}

.nav-links .page-numbers.current {
    background: #333;
    color: #fff;
    border-color: #333;
}

.nav-links a.page-numbers:not(.prev):not(.next):hover {
    background: #333;
    color: #fff;
}

.nav-links .page-numbers.dots {
    border: none;
    background: transparent;
    pointer-events: none;
}

.nav-links .page-numbers.prev,
.nav-links .page-numbers.next {
    border: none;
    background: transparent;
    width: auto;
    height: auto;
    font-size: 24px;
}

.nav-links .page-numbers.prev:hover,
.nav-links .page-numbers.next:hover {
    background: transparent;
    opacity: 0.6;
    color: #333;
}

@media screen and (max-width: 767px) {
    .page-archive {
        flex-direction: column;
        gap: 1.8rem;
        padding: 50px 1rem;
    }

    .page-archive .archive-inner {
        width: 100%;
        gap: 1rem;
    }

    .page-archive .archive-inner .item {
        width: calc((100% - 1rem) / 2);
    }

    .page-archive .archive-inner .item .img::before {
        font-size: .9rem;
        padding: .6rem 1.25rem;
        border-radius: .8rem 0 .8rem 0;
    }

    .page-archive .archive-inner .item .img img {
        border-radius: .8rem;
    }

    .page-archive .sidebar {
        width: 100%;
        position: static;
    }

    .page-archive .sidebar p.sidebar-ttl {
        margin-bottom: 1rem;
    }
    .page-archive .pagination .nav-links {
        gap: 8px;
        flex-wrap: wrap;
    }
    .nav-links .page-numbers {
        width: 36px;
        height: 36px;
        font-size: 14px;
        flex-shrink: 0;
    }
    .nav-links .page-numbers.prev,
    .nav-links .page-numbers.next {
        width: auto;
        height: auto;
        font-size: 20px;
    }
}

/*****************************
　　　　　リクルートページ
*****************************/
.recruit-mv {
    width: 100%;
    height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    gap: 1rem;
}

.recruit-mv h2 {
    width: fit-content;
    margin: 0 auto;
    font-size: 4rem;
    font-weight: 900;
    color: #333;
}

.recruit-mv .img-wrap {
    display: flex;
    gap: 3rem;
}

.recruit-mv .img-wrap .item.mini {
    width: 20%;
}

.recruit-mv .img-wrap .item.mini.two {
    display: flex;
    flex-direction: column;
    gap: 3rem;
}

.recruit-mv .img-wrap .item.mini img {
    height: 100%;
    object-fit: cover;
}

.recruit-mv .img-wrap .item.mini.two img {
    height: 100%;
    object-fit: cover;
}

.recruit-mv .img-wrap .item.big {
    width: calc(40% - 9rem);
}

.recruit-mv .img-wrap .item.big img {
    width: 100%;
    height: 100%;
    aspect-ratio: 1;
    object-fit: cover;
}

.recruit-mv .img-wrap .item img {
    border-radius: 1.8rem;
}

.page-recruit .ankerlink {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    padding: 0 3rem;
    position: fixed;
    top: 15%;
    left: 0;
    z-index: 99;
}

.page-recruit .ankerlink li {
    font-size: 1.1rem;
    font-weight: 500;
}

.page-recruit .intro {
    padding: 100px 0;
}

.page-recruit .intro h2 {
    font-size: 2.5vw;
    font-weight: 900;
    margin-bottom: 3rem;
}

.page-recruit .intro p {
    font-size: 1.1rem;
    line-height: 2;
}

.page-recruit .category {
    padding: 100px 0;
    position: relative;
    margin-bottom: 6rem;
}

.page-recruit .category .section-bg {
    width: min(100vw, calc(50vw + calc(var(--content-max) / 2)));
    background: #E9F8FF;
    height: 100%;
    border-radius: 3rem 0 0 3rem;
    position: absolute;
    top: 0;
    right: 0;
    z-index: -1;
}

.page-recruit .category-inner {
    display: flex;
    gap: 3rem;
    position: relative;
}

.page-recruit .category-inner .label {
    width: 10%;
    display: flex;
    height: fit-content;
    position: sticky;
    top: 15%;
}

.page-recruit .category-inner .label p {
    font-size: 1.5rem;
    font-weight: 600;
    color: #3193F4;
    writing-mode: vertical-rl;
    text-orientation: sideways;
}

.page-recruit .category-inner .label h2 {
    writing-mode: vertical-lr;
    font-size: 3.2rem;
    font-weight: 600;
}

.page-recruit .category-inner .category-content {
    display: flex;
    flex-direction: column;
    gap: 5rem;
}

.page-recruit .category-inner .category-content .item {
    position: relative;
}

.page-recruit .category-inner .category-content .item img {
    aspect-ratio: 3 / 2;
    width: 100%;
    object-fit: cover;
    border-radius: 3rem;
}

.page-recruit .category-inner .category-content .item .item-txt {
    width: 50%;
    display: flex;
    flex-direction: column;
    gap: .5rem;
    position: absolute;
    bottom: 5%;
    left: 5%;
}

.page-recruit .category-inner .category-content .item .item-txt h3 {
    font-size: 2.5rem;
    font-weight: 700;
    line-height: 1;
}

.page-recruit .category-inner .category-content .item .item-txt p {
    font-size: 1.1rem;
}

.page-recruit .category-inner .category-content .item .item-txt h3,
.page-recruit .category-inner .category-content .item .item-txt p {
    background: #fff;
    padding: .5rem;
    width: fit-content;
}

.page-recruit .category-inner .category-content.company .item {
    background: #fff;
    padding: 2rem;
    border-radius: 3rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.page-recruit .category-inner .category-content.company .item .main {
    display: flex;
    gap: 1rem;
}

.page-recruit .category-inner .category-content.company .item .main .ttl {
    width: 40%;
}

.page-recruit .category-inner .category-content.company .item .main .ttl p {
    font-size: 2rem;
    font-weight: 600;
    color: #3193F4;
}

.page-recruit .category-inner .category-content.company .item .main .ttl h3 {
    font-weight: 600;
    font-size: 1.5rem;
}

.page-recruit .category-inner .category-content.company .item .main .content {
    width: calc(60% - 1rem);
}

.page-recruit .category-inner .category-content.company .item .table-wrap {
    width: 100%;
    padding: 1rem 2.5rem;
    background: #3193F410;
    border: 1px solid #3193F4;
    border-radius: 1.2rem;
}

.page-recruit .category-inner .category-content.company .item .table-wrap p {
    width: 100%;
    font-weight: 600;
}

.page-recruit .category-inner .category-content.company .item table {
    width: 100%;
    border-collapse: separate;
    margin: .8rem 0;
}

.page-recruit .category-inner .category-content.company .item table th {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .7rem;
    margin-bottom: .5rem;
}

.page-recruit .category-inner .category-content.company .item table th img {
    width: 1.5rem;
    aspect-ratio: 1;
}

.page-recruit .category-inner .category-content.company .item table tr.last th,
.page-recruit .category-inner .category-content.company .item table tr.last td {
    border-top: 1px dashed #000;
}

.page-recruit .guideline {
    padding: 100px 0;
}

.page-recruit .guideline .ttl-wrap {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.page-recruit .guideline .ttl-wrap h2 {
    font-size: 3rem;
    font-weight: 900;
}

.page-recruit .guideline .ttl-wrap a {
    width: 100%;
    max-width: 250px;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    font-size: 1.5rem;
    font-weight: 600;
    background: #3193F4;
    padding: .7rem;
    border-radius: .7rem;
}

.page-recruit .guideline table {
    margin-top: 3rem;
}

.page-recruit .guideline th {
    width: 25%;
    padding: 1rem 0;
    border-top: 1px solid #000;
    font-size: 1.2rem;
    font-weight: 600;
}

.page-recruit .guideline td {
    padding: 1rem 0;
    border-top: 1px solid #000;
}

.page-recruit .recruit-cta {
    padding: 100px 0;
    text-align: center;
}

.page-recruit .recruit-cta .en {
    font-size: 4.5rem;
    font-weight: 900;
    color: #3193F4;
}

.page-recruit .recruit-cta .ja {
    font-size: 1.5rem;
    font-weight: 600;
}

.page-recruit .recruit-cta a {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 1rem;
    width: 100%;
    max-width: 500px;
    border: 1px solid #3193F4;
    color: #3193F4;
    font-size: 1.1rem;
    font-weight: 600;
    margin: 3rem auto 0 auto;
    border-radius: 9999px;
}

@media screen and (max-width: 767px) {
    .sp_none {
        display: none !important;
    }

    .recruit-mv {
        justify-content: flex-end;
        padding: 1rem;
        gap: 0;
    }

    .recruit-mv h2 {
        margin: 0 auto;
        font-size: 1.6rem;
        line-height: 1.3;
    }

    .recruit-mv .img-wrap {
        flex-direction: column;
        gap: 1rem;
    }

    .recruit-mv .img-wrap .item.mini {
        width: 100%;
    }

    .recruit-mv .img-wrap .item.mini.two {
        flex-direction: row;
        gap: 1rem;
    }

    .recruit-mv .img-wrap .item.mini img {
        height: 100%;
        object-fit: cover;
    }

    .recruit-mv .img-wrap .item.mini.two img {
        width: calc(50% - .5rem);
        aspect-ratio: 1;
    }

    .recruit-mv .img-wrap .item.big {
        width: 100%;
    }

    .recruit-mv .img-wrap .item.big img {
        aspect-ratio: 3 / 2;
    }

    .recruit-mv .img-wrap .item img {
        border-radius: .8rem;
    }

    .page-recruit .intro {
        padding: 50px 1rem;
    }

    .page-recruit .intro h2 {
        font-size: 1.5rem;
        margin-bottom: 1.2rem;
    }

    .page-recruit .intro p {
        font-size: .9rem;
        line-height: 1.5;
    }

    .page-recruit .category {
        padding: 50px 0 50px 1.5rem;
        margin-bottom: 3rem;
    }

    .page-recruit .category .section-bg {
        width: 97%;
        border-radius: 1rem 0 0 1rem;
    }

    .page-recruit .category-inner {
        flex-direction: column;
        gap: 1rem;
    }

    .page-recruit .category-inner .label {
        position: static;
        width: 100%;
        display: block;
        top: 10%;
    }

    .page-recruit .category-inner .label p {
        writing-mode: horizontal-tb;
        text-orientation: mixed;
    }

    .page-recruit .category-inner .label h2 {
        writing-mode: horizontal-tb;
        font-size: 2.5rem;
    }

    .page-recruit .category-inner .category-content {
        gap: 1rem;
    }

    .page-recruit .category-inner .category-content .item {
        position: relative;
    }

    .page-recruit .category-inner .category-content .item img {
        border-radius: .8rem 0 0 .8rem;
        aspect-ratio: 1;
    }

    .page-recruit .category-inner .category-content .item .item-txt {
        width: 90%;
        bottom: 7%;
        left: auto;
        right: 0;
    }

    .page-recruit .category-inner .category-content .item .item-txt h3 {
        font-size: 1.1rem;
    }

    .page-recruit .category-inner .category-content .item .item-txt p {
        font-size: .9rem;
    }

    .page-recruit .category-inner .category-content.company .item {
        padding: .9rem;
        border-radius: 1rem 0 0 1rem;
        gap: 1rem;
    }

    .page-recruit .category-inner .category-content.company .item .main {
        flex-direction: column;
        gap: 1rem;
    }

    .page-recruit .category-inner .category-content.company .item .main .ttl {
        width: 100%;
    }

    .page-recruit .category-inner .category-content.company .item .main .ttl h3 {
        font-size: 1.1rem;
    }

    .page-recruit .category-inner .category-content.company .item .main .content {
        width: 100%;
    }

    .page-recruit .category-inner .category-content.company .item .table-wrap {
        padding: .9rem;
        border-radius: .3rem;
    }

    .page-recruit .category-inner .category-content.company .item table {
        margin: .5rem 0;
    }

    .page-recruit .category-inner .category-content.company .item table th {
        flex-wrap: nowrap;
        gap: .5rem;
        margin-bottom: .2rem;
    }

    .page-recruit .category-inner .category-content.company .item table th img {
        width: 1rem;
    }

    .page-recruit .guideline {
        padding: 50px 1rem;
    }

    .page-recruit .guideline .ttl-wrap {
        display: flex;
    }

    .page-recruit .guideline .ttl-wrap h2 {
        font-size: 1.5rem;
    }

    .page-recruit .guideline .ttl-wrap a {
        max-width: fit-content;
        font-size: 1rem;
        padding: .3rem 1rem;
        border-radius: .5rem;
    }

    .page-recruit .guideline table {
        margin-top: 1rem;
    }

    .page-recruit .guideline th,
    .page-recruit .guideline td {
        display: block;
    }

    .page-recruit .guideline th {
        width: 100%;
        padding: 1rem 0 1rem 0;
        font-size: 1.1rem;
    }

    .page-recruit .guideline td {
        padding: 0 0 1rem 0;
        border-top: none;
    }

    .page-recruit .recruit-cta {
        padding: 50px 1rem;
    }

    .page-recruit .recruit-cta .en {
        font-size: 3.5rem;
    }

    .page-recruit .recruit-cta .ja {
        font-size: 1rem;
    }

    .page-recruit .recruit-cta a {
        padding: .8rem;
        font-size: 1rem;
        margin: 1.5rem auto 0 auto;
    }
}

/*****************************
　　　　エントリーフォーム
*****************************/
.page-entry {
    padding: 150px 0 100px 0;
    display: flex;
    flex-direction: column;
    gap: 3rem;
}

.page-entry .entry-flow .ttl {
    margin-bottom: 3rem;
}

.page-entry .entry-flow .ttl p {
    font-size: 1.5rem;
    font-weight: 900;
    color: #3193F4;
}

.page-entry .entry-flow .ttl h2 {
    font-size: 3rem;
    font-weight: 600;
}

.page-entry .entry-flow .flow-inner {
    display: flex;
    flex-direction: column;
    gap: 3rem;
}

.page-entry .entry-flow .flow-inner .item {
    display: flex;
    align-items: center;
    gap: 3rem;
    background: #F9F9F9;
    border-radius: 1rem;
    padding: 3rem 6rem;
    position: relative;
}

.page-entry .entry-flow .flow-inner .item:before {
    content: '▼';
    font-size: .8rem;
    color: #333;
    position: absolute;
    left: 50%;
    bottom: -3rem;
    transform: translate(-50%, -70%);
}

.page-entry .entry-flow .flow-inner .item:last-child::before {
    display: none;
}

.page-entry .entry-flow .flow-inner .item .label span {
    display: block;
    font-size: 1.1rem;
    font-weight: 600;
    margin-bottom: .5rem;
    text-align: center;
}

.page-entry .entry-flow .flow-inner .item .txt h3 {
    font-size: 1.3rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 1rem;
}

.page-entry .entry-flow .flow-inner .item .txt p {
    font-size: 1.1rem;
    line-height: 1.5;
}

.page-entry .entry-form {
    margin-top: 3rem;
}

.page-entry .form-inner {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-bottom: 3rem;
}

.page-entry .form-inner .item {
    display: flex;
    align-items: center;
    gap: 3rem;
    padding-top: 1rem;
    border-top: 1px solid #000;
}

.page-entry .form-inner .item .label {
    width: 30%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
}

.page-entry .form-inner .item .label .label-main {
    width: calc(70% - 10px);
}

.page-entry .form-inner .item .label .label-main p {
    font-weight: 600;
}

.page-entry .form-inner .item .label .label-main span {
    font-size: .8rem;
    color: #333;
}

.page-entry .form-inner .item .label .status {
    width: 20%;
    display: flex;
    justify-content: center;
    align-items: center;
    background: #898989;
    color: #fff;
    font-size: .9rem;
    font-weight: 600;
    line-height: 1;
    padding: .5rem 0;
    border-radius: 5px;
}

.page-entry .form-inner .item .label .status.req {
    background: #ED6862;
}

.page-entry .form-inner .item .item-inner {
    width: calc(70% - 3rem);
}

.page-entry .form-inner .item .item-inner.radio {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem 1.2rem;
}

.page-entry .form-inner .item .item-inner.radio label {
    width: calc((100% - 3.6rem) / 3);
}

.page-entry .form-inner .item .item-inner.radio label:hover,
.page-entry .form-inner .item .item-inner.check label:hover {
    cursor: pointer;
}

.page-entry .form-inner .item .item-inner.text input,
.page-entry .form-inner .item .item-inner.text textarea {
    width: 100%;
    height: 100%;
    display: flex;
    padding: .8rem 1rem;
    background: #F5F5F5;
    border: 1px solid #CBD6E2;
    border-radius: 3px;
}

.page-entry .form-inner .item .item-inner.text p {
    font-weight: 900;
    color: #a3a3a3;
}

.page-entry .form-inner .item .item-inner.check a {
    color: #4357D7;
    border-bottom: 1px solid #4357D7;
}

::placeholder {
    color: #BFBFBF;
}

.entry-form .submit {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    max-width: 500px;
    margin: 0 auto;
    color: #fff;
    background: #3193F4;
    padding: 1rem;
    border-radius: 9999px;
    border: none;
    font-size: 1rem;
    font-weight: 600;
}

.entry-form .submit:hover {
    cursor: pointer;
}

/* =========================================
   お問い合わせフォーム用 selectボックス装飾
   ========================================= */

/* セレクトボックス本体 */
.entry-form select {
    width: 100%;
    padding: 12px 15px;
    padding-right: 40px;
    font-size: 14px;
    color: #bfbfbf;
    background: #F5F5F5;
    border: 1px solid #CBD6E2;
    border-radius: 4px;
    cursor: pointer;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: url('data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22%23007DA5%22%20stroke-width%3D%222%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%3Cpolyline%20points%3D%226%209%2012%2015%2018%209%22%2F%3E%3C%2Fsvg%3E');
    background-repeat: no-repeat;
    background-position: right 15px center;
    background-size: 16px;
    transition: all 0.3s;
}

.entry-form select:focus {
    outline: none;
    border-color: #007DA5;
    box-shadow: 0 0 0 2px rgba(0, 125, 165, 0.2);
}

/* -------------------------------------------
   selectボックスの文字色コントロール
   ------------------------------------------- */

/* ① 初期状態（未選択）はグレー */
.entry-form select {
    color: #bfbfbf;
}

/* ② JSで「.is-active」がついたら黒にする */
.entry-form select.is-active {
    color: #000000;
}

/* ③ ドロップダウンを開いた時の選択肢 */

/* 基本の選択肢は「黒」 */
.entry-form select option {
    color: #000000;
}

/* ただし、valueが空（選択してください）のやつだけ「グレー」 */
.entry-form select option[value=""] {
    color: #bfbfbf;
}

@media screen and (max-width: 768px) {
    .entry-form select {
        font-size: 16px;
        /* 16px未満だとiPhoneで勝手にズームしちゃうので */
    }
}

/* --------------------------------------------------
   MW WP Form 表示切り替え
   -------------------------------------------------- */

/* 完了画面(complete) の時だけ「選考の流れ(.entry-flow)」を非表示 */
/* ※ .mw_wp_form_confirm（確認画面）の記述は消しました */

.mw_wp_form_complete .entry-flow {
    display: none;
}

/* =========================================
   完了画面で注意書き(.notice)を消す
   ========================================= */

/* 「.mw_wp_form_complete（完了画面）」を持っている .page-entry の中の
   .notice を非表示にする */
.page-entry:has(.mw_wp_form_complete) .notice {
    display: none;
}

@media screen and (max-width: 767px) {
    .page-entry {
        padding: 100px 1rem 50px;
    }

    .page-entry .entry-flow .ttl {
        margin-bottom: 20px;
    }

    .page-entry .entry-flow .ttl p {
        font-size: 1rem;
    }

    .page-entry .entry-flow .ttl h2 {
        font-size: 2.1rem;
    }

    .page-entry .entry-flow .flow-inner {
        gap: 2rem;
    }

    .page-entry .entry-flow .flow-inner .item {
        flex-direction: column;
        gap: 1rem;
        padding: 1rem;
    }

    .page-entry .entry-flow .flow-inner .item:before {
        content: '▼';
        font-size: .8rem;
        color: #333;
        position: absolute;
        left: 50%;
        bottom: -2.2rem;
        transform: translate(-50%, -50%);
    }

    .page-entry .entry-flow .flow-inner .item:last-child::before {
        display: none;
    }

    .page-entry .entry-flow .flow-inner .item .txt h3 {
        font-size: 1.1rem;
        margin-bottom: .5rem;
    }

    .page-entry .entry-flow .flow-inner .item .txt p {
        font-size: .9rem;
    }

    .page-entry .form-inner .item {
        flex-direction: column;
        gap: .8rem;
    }

    .page-entry .form-inner .item .label {
        width: 100%;
    }

    .page-entry .form-inner .item .label .label-main {
        width: 100%;
    }

    .page-entry .form-inner .item .item-inner {
        width: 100%;
    }

    .page-entry .form-inner .item .item-inner.radio {
        flex-direction: column;
        gap: .5rem;
    }

    .page-entry .form-inner .item .item-inner.radio label {
        width: 100%;
    }

    .page-entry .form-inner .item .item-inner.text input,
    .page-entry .form-inner .item .item-inner.text textarea {
        width: 100%;
        height: 100%;
        display: flex;
        padding: .8rem 1rem;
        background: #F5F5F5;
        border: 1px solid #CBD6E2;
        border-radius: 3px;
    }

    .page-entry .form-inner .item .item-inner.text p {
        font-weight: 900;
        color: #a3a3a3;
    }

    .page-entry .form-inner .item .item-inner.check a {
        color: #4357D7;
        border-bottom: 1px solid #4357D7;
    }

    ::placeholder {
        color: #BFBFBF;
    }

    .entry-form .submit {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 100%;
        max-width: 500px;
        margin: 0 auto;
        color: #fff;
        background: #3193F4;
        padding: 1rem;
        border-radius: 9999px;
    }
}

/******************************
　　　　　　　完了ページ
******************************/
.complete {
    padding: 100px 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2rem;
    text-align: center;
    color: #333;
}

.complete h2 {
    font-size: 2rem;
    font-weight: 900;
}

.complete p.red {
    color: #ff0000;
}

@media screen and (max-width: 767px) {
    .complete {
        padding: 50px 0;
        gap: 1.2rem;
    }

    .complete h2 {
        font-size: 1.4rem;
    }

    .complete p {
        font-size: .9rem;
    }
}

/****************************
　　　プライバシーポリシー
****************************/

.page-term {
    padding: 100px 0;
    display: flex;
    flex-direction: column;
    gap: 3rem;
}

.page-term .intro {
    font-weight: 600;
}

.page-term .item .ttl {
    font-weight: 600;
    margin-bottom: 1rem;
}

@media screen and (max-width: 767px) {
    .page-term {
        padding: 50px 1rem;
        gap: 2rem;
    }

    .page-term .item .ttl {
        margin-bottom: .5rem;
    }
}

/******************************
　　　　　　　会社案内
******************************/
.comapny-inner {
    width: 90%;
    padding: 100px 0;
    margin: 0 auto;
    display: flex;
    position: relative;
}

.comapny-inner .side-anchor {
    width: 20%;
    height: fit-content;
    display: flex;
    flex-direction: column;
    gap: 2rem;
    position: sticky;
    top: 15%;
}

.comapny-inner .side-anchor li a {
    display: flex;
    align-items: center;
    gap: 1rem;
    font-weight: 500;
}

.comapny-inner .company-content {
    width: 80%;
    display: flex;
    flex-direction: column;
    gap: 100px;
    padding-left: 3rem;
    border-left: 1px solid #000;
}

.comapny-inner .company-content .category-ttl {
    font-size: 2.8rem;
    font-weight: 600;
    color: #3193F4;
    margin-bottom: 1.5rem;
}

.comapny-inner .company-content .item-inner {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.comapny-inner .company-content .item-inner .item-head {
    font-size: 1.8rem;
    font-weight: 600;
    border-bottom: 1px solid #3193F4;
    margin-bottom: 10px;
}

.comapny-inner .company-content .item-inner .item-content h3 {
    font-size: 1.1rem;
    font-weight: 600;
}

.comapny-inner .company-content .item-inner .item-content p {
    line-height: 2;
}

.comapny-inner .company-content .item-inner .item-content ul {
    padding-left: 3rem;
}

.comapny-inner .company-content .item-inner .item-content ul li {
    line-height: 2;
}

.comapny-inner .company-content .item-inner .item-content ul li span {
    font-size: 1.1rem;
    font-weight: 600;
}

.comapny-inner .company-content .company-table {
    width: 100%;
    border-collapse: collapse;
}

.comapny-inner .company-content .company-table th,
.comapny-inner .company-content .company-table td {
    padding: 1.8rem 1.5rem;
    border: 1px solid #E5E4E4;
    font-weight: 500;
}

.comapny-inner .company-content .company-table th {
    background: #F2F1F1;
}

@media screen and (max-width: 767px) {
    .comapny-inner {
        width: 100%;
        padding: 50px 1rem;
    }

    .comapny-inner .side-anchor {
        display: none;
    }

    .comapny-inner .company-content {
        width: 100%;
        gap: 3rem;
        padding-left: 0;
        border-left: none;
    }

    .comapny-inner .company-content .category-ttl {
        font-size: 1.8rem;
        margin-bottom: 1rem;
    }

    .comapny-inner .company-content .item-inner {
        gap: 1rem;
    }

    .comapny-inner .company-content .item-inner .item-head {
        font-size: 1.5rem;
    }

    .comapny-inner .company-content .item-inner .item-content h3 {
        font-size: .9rem;
    }

    .comapny-inner .company-content .item-inner .item-content p {
        font-size: .9rem;
        line-height: 1.5;
    }

    .comapny-inner .company-content .item-inner .item-content ul {
        padding-left: 0;
        padding: 0 5px;
    }

    .comapny-inner .company-content .item-inner .item-content ul li {
        font-size: .9rem;
        line-height: 1.5;
    }

    .comapny-inner .company-content .item-inner .item-content ul li span {
        font-size: .9rem;
        font-weight: 600;
    }

    .comapny-inner .company-content .company-table {
        width: 100%;
        border-collapse: collapse;
    }

    .comapny-inner .company-content .company-table th,
    .comapny-inner .company-content .company-table td {
        display: block;
        padding: 1rem;
    }
}

/**************************
　　　　　プラン詳細
**************************/

.plan-detail {
    padding: 150px 0;
    display: flex;
    flex-direction: column;
    gap: 3rem;
}

.plan-summary .ttl-wrap {
    display: flex;
    flex-direction: column;
    gap: .3rem;
    margin-bottom: 1.4rem;
    font-weight: 600;
}

.plan-summary .ttl-wrap span {
    color: #0060A2;
}

.plan-summary .ttl-wrap h2 {
    font-size: 1.3rem;
}

.plan-summary .ttl-wrap ul {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}

.plan-summary .ttl-wrap ul li {
    width: fit-content;
    padding: .25rem .5rem;
    background: #3193F4;
    color: #fff;
    border-radius: 5px;
    font-weight: normal;
}

.plan-summary .summary-inner {
    display: flex;
    gap: 20px;
}

.plan-summary .summary-inner .img-wrap,
.plan-summary .summary-inner .summary-content {
    width: calc(50% - 10px);
}

.plan-summary .summary-inner .img-wrap {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.plan-summary .summary-inner .img-wrap .tour_slider img,
.plan-summary .summary-inner .img-wrap .tour_thumb img {
    aspect-ratio: 3 / 2;
    object-fit: cover;
}

.plan-summary .summary-inner .img-wrap .slick-slide {
    margin: 0 .5rem;
    transition: all ease-in-out .3s;
    opacity: .2;
}

.plan-summary .summary-inner .img-wrap .slick-active {
    opacity: 1;
}

.plan-summary .summary-inner .img-wrap .slick-current {
    opacity: 1;
}

.plan-summary .summary-inner .summary-content table th {
    width: 30%;
    font-size: .9rem;
    font-weight: 600;
    text-align: center;
    color: #3193F4;
    padding: 10px 0;
    border-bottom: 1px solid #3193F4;
}

.plan-summary .summary-inner .summary-content table td {
    width: 70%;
    font-size: .9rem;
    color: #484848;
    padding: 10px 20px;
    border-bottom: 1px solid #B6B6B6;
}

.plan-summary .summary-inner .summary-content table td p span {
    color: #ff0000;
}

.plan-summary .summary-inner .summary-content table td .col2 {
    display: flex;
}

.plan-summary .summary-inner .summary-content table td .col2 .item {
    width: 50%;
    font-size: .9rem;
}

.plan-summary .summary-inner .summary-content table td .col2 .item .category {
    font-size: .9rem;
    font-weight: 600;
}

.plan-summary .summary-inner .summary-content table td .col2 .item .price span {
    font-size: 1.5rem;
    font-weight: 900;
}

.plan-detail p.head-ttl {
    width: 100%;
    padding: .5rem 1rem;
    border-left: 5px solid #3193F4;
    border-radius: 3px;
    font-weight: 600;
    margin-bottom: 10px;
}

.detail-table table {
    width: 100%;
}

.detail-table table tr:first-child th,
.detail-table table tr:first-child td {
    border-top: 1px solid #000;
}

.detail-table th,
.detail-table td {
    padding: 20px;
    border-bottom: 1px solid #000;
}

.detail-table th {
    width: 20%;
    background-color: #F7F5F2;
    vertical-align: middle;
}

.detail-table td {
    width: 80%;
}

.detail-table td .price-wrap {
    display: flex;
    flex-direction: column;
    gap: 20px;
    font-size: .9rem;
}

.detail-table td .price-wrap p {
    font-weight: 600;
}

.detail-table td .price-wrap .original {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.detail-table td .price-wrap .original span {
    text-decoration: line-through;
}

.detail-table td .price-wrap .original p {
    color: #ff0000;
    border: 1px solid #ff0000;
    padding: .15rem .5rem;
    border-radius: 5px;
}

.detail-table td .price-wrap .discount p {
    font-weight: normal;
}

.detail-table td .price-wrap .discount p span {
    font-size: 1.5rem;
    font-weight: 900;
    color: #ff0000;
    margin-right: 5px;
}

.detail-table td .price-wrap p.terms {
    color: #0060A2;
}

.detail-table td .col2 {
    display: flex;
    flex-wrap: wrap;
    row-gap: 1rem;
}

.detail-table td .col2 .item {
    width: 50%;
}

.detail-table td .col2 .item p {
    margin-bottom: 10px;
}

.detail-table td .col2 .item .ass {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.detail-table td .col2 .item .ass .label {
    padding: 2px 7px;
    color: #fff;
    background: #3193F4;
    border-radius: 5px;
    margin-right: 1rem;
}

.detail-table td .col2 .item .ass .label.pm {
    background: #FF7F36;
}

.detail-table td .status {
    display: flex;
    align-items: center;
    gap: 5px;
    margin-bottom: 1rem;
}

.detail-table td .status p {
    font-weight: 600;
}

.detail-table td p.red {
    color: #ff0000;
}

.detail-table td .policy-table {
    color: #fff;
    margin: 5px 0;
}

.detail-table td .policy-table th {
    text-align: center;
}

.detail-table td .policy-table th,
.detail-table td .policy-table td {
    border: 1px solid #ccc;
    width: calc(100% / 3);
    color: #484848;
}

.detail-table td .policy-table th,
.detail-table td .policy-table td.date {
    background: #002E5C;
    color: #fff;
}

.detail-table .policy-table tr:first-child th,
.detail-table .policy-table tr:first-child td {
    border-top: 1px solid #ccc;
}

.tour-resv .resv-label {
    margin-bottom: 1rem;
}

.tour-resv .resv-label p {
    font-weight: 600;
    text-align: center;
}

.tour-resv .resv-label .flag {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 1rem 0;
    border-radius: 5px;
    background: #FF7F36;
    color: #fff;
    margin-bottom: 1rem;
    position: relative;
}

.tour-resv .resv-label .flag::before {
    content: '';
    width: 0;
    height: 0;
    border-style: solid;
    border-right: .8rem solid transparent;
    border-left: .8rem solid transparent;
    border-top: .8rem solid #ff7f36;
    border-bottom: 0;
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translate(-50%, 100%);
}

.tour-resv .resv-content {
    display: flex;
    align-items: flex-start;
    gap: 30px;
}

.tour-resv .resv-content .txt {
    width: 40%;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.tour-resv .resv-content .txt .head-txt {
    text-align: center;
    font-weight: 600;
}

.tour-resv .resv-content .txt .exp {
    font-size: .9rem;
}

.tour-resv .resv-content .txt .status {
    font-size: .9rem;
    font-weight: 600;
}

.tour-resv .resv-content .txt .tell-label {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-color: #3193F4;
    padding: 1.3rem;
    color: #fff;
    text-align: center;
    border-radius: 10px;
}

.tour-resv .resv-content .txt .tell-label .head {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
}

.tour-resv .resv-content .txt .tell-label .number p {
    font-size: 2.5rem;
    font-weight: 600;
    line-height: 1;
}

.tour-resv .resv-content .txt .tell-label .number span {
    font-size: .9rem;
}

.tour-resv .resv-content .calender {
    width: calc(60% - 30px);
}

/***** カレンダー用スタイル設定 *****/
.calendar-caption {
    font-size: 1rem !important;
    font-weight: 600;
    margin-bottom: 10px;
}

.monthly-prev-next {
    font-size: .9rem;
}

.monthly-prev-next a {
    color: #006EDF;
    border-bottom: 1px solid #006EDF;
}

.monthly-calendar table {
    width: 100% !important;
    border-collapse: separate !important;
    border-spacing: 0;
}

.monthly-calendar td {
    padding: 10px 0;
}

.schedule-note {
    display: none;
}

.calendar-time-mark .calendar-timelink {
    color: #006EDF;
}

.monthly-calendar .header-row th {
    padding: 10px 0;
    background: #3193F4;
    color: #fff;
}

.monthly-calendar .header-row th:first-child {
    border-radius: 10px 0 0 0;
}

.monthly-calendar .header-row th:last-child {
    border-radius: 0 10px 0 0;
}

.monthly-calendar .week-row:last-of-type td:first-child {
    border-radius: 0 0 0 10px;
}

.monthly-calendar .week-row:last-of-type td:last-child {
    border-radius: 0 0 10px 0;
}

.mtssb-timetable-name {
    font-size: 1.1rem;
    font-weight: 600;
}

.mtssb-timetable-date {
    font-size: .9rem;
    color: #4357d7;
}

.mtssb-daily-action {
    margin-bottom: .5rem;
}

.monthly-calendar.day-calendar button {
    display: flex;
    background: #ccc;
    padding: .4rem 2rem;
    border-radius: 5px;
    font-weight: 500;
}

.monthly-calendar.day-calendar button:hover {
    cursor: pointer;
}

.plan-attract {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: .5rem 3rem;
}

.plan-attract .item {
    width: calc((100% - 6rem) / 3);
}

.plan-attract .item img,
.plan-flow .item img {
    width: 100%;
    aspect-ratio: 2 / 1;
    object-fit: cover;
}

.plan-attract .item h3,
.plan-flow .item h3 {
    font-weight: 600;
}

.plan-attract .item p {
    font-size: .9rem;
}

.plan-attract .item p.red {
    color: #ff0000;
}

.plan-flow {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem 3rem;
}

.plan-flow .item {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: calc((100% - 6rem) / 3);
    margin-bottom: 1rem;
    position: relative;
}

.plan-flow .item:before {
    content: '';
    width: 24px;
    aspect-ratio: 1;
    background: url(../img/icon/arrow-right-circle.svg);
    position: absolute;
    top: 50%;
    right: -3rem;
    transform: translateX(-50%);
}

.plan-flow .item:nth-child(4):before,
.plan-flow .item:last-child:before {
    display: none;
}

@media screen and (max-width: 767px) {

    .plan-detail {
        padding: 100px 1rem;
        gap: 2rem;
    }

    .plan-summary .ttl-wrap {
        margin-bottom: 1.2rem;
    }

    .plan-summary .ttl-wrap h2 {
        font-size: 1.1rem;
    }

    .plan-summary .ttl-wrap ul {
        gap: 5px;
    }

    .plan-summary .ttl-wrap ul li {
        font-size: .9rem;
        padding: 5px 7px;
    }

    .plan-summary .summary-inner {
        flex-direction: column;
        gap: 10px;
    }

    .plan-summary .summary-inner .img-wrap,
    .plan-summary .summary-inner .summary-content {
        width: 100%;
    }

    .plan-summary .summary-inner .img-wrap {
        gap: 5px;
    }

    .plan-summary .summary-inner .img-wrap .slick-slide {
        margin: 0 2.5px;
    }

    .plan-summary .summary-inner .summary-content table td {
        padding: 10px;
    }

    .plan-summary .summary-inner .summary-content table td .col2 {
        flex-direction: column;
    }

    .plan-summary .summary-inner .summary-content table td .col2 .item {
        width: 100%;
    }

    .plan-summary .summary-inner .summary-content table td .col2 .item .price span {
        line-height: 1;
    }

    .detail-table th,
    .detail-table td {
        padding: 10px 5px;
        font-size: .85rem;
    }

    .detail-table th {
        width: 30%;
        text-align: center;
    }

    .detail-table td {
        width: 70%;
    }

    .detail-table td .price-wrap .original p {
        font-size: .8rem;
        padding: 2px 7px;
    }

    .detail-table td .price-wrap p.terms {
        font-size: .9rem;
    }

    .detail-table td .col2 {
        flex-direction: column;
    }

    .detail-table td .col2 .item {
        width: 100%;
        margin-bottom: .5rem;
    }

    .detail-table td .col2 .item p {
        margin-bottom: 2px;
    }

    .detail-table td .col2 .item .ass {
        gap: 5px;
    }

    .detail-table td .col2 .item .ass .label {
        padding: 2px 5px;
        margin-right: 5px;
        font-size: .7rem;
    }

    .detail-table td .status {
        gap: 5px;
    }

    .policy-table.sp_only thead th {
        display: block;
        width: 100%;
        padding: 10px;
        text-align: center;
        background-color: #002E5C;
    }

    .detail-table td .policy-table th {
        text-align: center;
    }

    .tour-resv .resv-label .flag {
        padding: .6rem 0;
        margin-bottom: 1.5rem;
    }

    .tour-resv .resv-label .flag::before {
        border-style: solid;
        border-right: .5rem solid transparent;
        border-left: .5rem solid transparent;
        border-top: .8rem solid #ff7f36;
    }

    .tour-resv .resv-content {
        flex-direction: column-reverse;
        gap: 20px;
    }

    .tour-resv .resv-content .txt {
        width: 100%;
    }

    .tour-resv .resv-content .txt .tell-label {
        padding: 1rem;
    }

    .tour-resv .resv-content .txt .tell-label .number p {
        font-size: 2rem;
    }

    .tour-resv .resv-content .calender {
        width: 100%;
    }

    /***** カレンダー用スタイル設定 *****/
    .calendar-caption {
        font-size: 1rem !important;
        font-weight: 600;
        margin-bottom: 10px;
    }
    .monthly-prev-next {
        font-size: .9rem;
    }
    .monthly-prev-next a {
        color: #006EDF;
        border-bottom: 1px solid #006EDF;
    }
    .monthly-calendar table {
        width: 100% !important;
        border-collapse: separate !important;
        border-spacing: 0;
    }
    .monthly-calendar td {
        padding: 10px 0;
    }
    .monthly-calendar .header-row th {
        padding: 10px 0;
        background: #3193F4;
        color: #fff;
    }
    .monthly-calendar .header-row th:first-child {
        border-radius: 10px 0 0 0;
    }
    .monthly-calendar .header-row th:last-child {
        border-radius: 0 10px 0 0;
    }
    .monthly-calendar .week-row:last-of-type td:first-child {
        border-radius: 0 0 0 10px;
    }
    .monthly-calendar .week-row:last-of-type td:last-child {
        border-radius: 0 0 10px 0;
    }

    .plan-attract {
        gap: 0;
    }

    .plan-attract .item {
        width: 100%;
        margin-bottom: 2rem;
    }

    .plan-flow {
        display: flex;
        flex-wrap: wrap;
        gap: 0;
    }

    .plan-flow .item {
        width: 100%;
        margin-bottom: 2rem;
    }

    .plan-flow .item:before {
        content: '';
        width: 24px;
        aspect-ratio: 1;
        background: url(../img/icon/arrow-right-circle.svg);
        position: absolute;
        top: auto;
        bottom: -2rem;
        right: 50%;
        transform: translate(50%, -10%) rotate(90deg);
    }

    .plan-flow .item:nth-child(4):before {
        display: block;
    }
}

/*************************
        予約フロー
*************************/

/* --- フォーム全体 --- */
.content-form {
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
    padding: 100px 0;
    font-family: "Noto Sans JP", sans-serif;
}

/* --- セクション（カード）のデザイン --- */
/* ★ここを影（box-shadow）で表現 */
.content-form fieldset {
    background: #fff;
    border: none !important;
    border-radius: 16px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.25);
    padding: 30px !important;
    margin: 0 0 50px !important;
}

/* --- セクションタイトル（legend） --- */
.content-form legend {
    float: left;
    width: 100%;
    box-sizing: border-box;
    text-align: center;
    display: block;
    width: 100%;
    font-size: 1.4rem;
    font-weight: 700;
    color: #333;
    margin-bottom: 25px;
    padding: 0;
    border: none;
    /* ★タイトルの下線も削除 */
}

/* --- テーブルのレイアウト（縦積みにする） --- */
.content-form table {
    width: 100%;
    border-collapse: separate;
    margin: 0;
}
.content-form table tr {
    display: flex;
    align-items: center;
    margin-bottom: 1rem;
}

.content-form th,
.content-form td {
    display: block;
    width: 100%;
    padding: 0;
    border: none !important;
    text-align: left;
}

/* 項目名（th） */
.content-form th {
    width: 50% !important;
    font-size: 0.85rem !important;
    font-weight: 600;
    color: #333;
    text-align: left !important;
}

.content-form td {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: .5rem;
}

/* 必須マーク */
.content-form .required {
    color: #ff4b4b;
    font-size: 0.8em;
    vertical-align: top;
}

fieldset#booking_client-fieldset table td label {
    display: none;
}

/* --- 予約の表示と注意事項の確認<td>のみflexwrap設定 --- */

fieldset#booking-reservation-fieldset table td {
    flex-wrap: wrap;
    gap: .5rem;
}

span.plan-name {
    display: block;
    width: 100%;
    font-size: 1.2rem;
    font-weight: 600;
}

fieldset#booking-option-fieldset {
    font-size: .85rem;
}

fieldset#booking-option-fieldset table td {
    flex-wrap: wrap;
    gap: .5rem;
}

fieldset#booking-option-fieldset table td span.option-note {
    width: 100%;
    order: -1;
    font-weight: 600;
}

/* --- 入力フィールド（input） --- */
/* ★ここだけ実線（border）を使う */
.content-form input[type="text"],
.content-form input[type="email"],
.content-form input[type="tel"],
.content-form textarea,
.content-form select {
    width: 100%;
    padding: 14px;
    font-size: 16px;
    background: #fff;
    border: 1px solid #ccc;
    /* ★実線の枠 */
    border-radius: 6px;
    box-sizing: border-box;
    appearance: none;
    margin-bottom: 5px;
    /* エラーが出た時などのための予備余白 */
}

/* フォーカス時は枠線をテーマカラーに */
.content-form input:focus,
.content-form textarea:focus,
.content-form select:focus {
    outline: none;
    border-color: #007DA5;
}

/* --- 名前（姓・名）の横並び --- */
.content-form #booking-sei,
.content-form #booking-mei {
    width: calc(50% - 10px);
    display: inline-block;
}

.content-form .booking-seimei {
    display: none;
    /* 「姓」「名」という文字は消す */
}

/* --- 人数選択エリア --- */
.content-form .input-number {
    width: calc((100% - .5rem) / 2);
    display: block;
    align-items: center;
    margin-right: 0 !important;
    text-align: left !important;
}

.content-form .input-number label {
    font-size: .85rem;
    font-weight: 600;
}

.content-form .input-number select {
    width: 100%;
    text-align: left;
    border: 1px solid #B6B6B6;
    padding: 1rem;
    margin: 0;
    margin-top: 5px;
}

fieldset#booking-option-fieldset select {
    padding: 1rem;
}

.content-form select {
    /* ▼ OS標準の矢印を消す（必須） */
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;

    /* ▼ 背景画像として「黒い矢印」を表示 */
    background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23333333' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");

    background-repeat: no-repeat;
    background-position: right 15px center;
    /* 右から15pxの位置 */
    background-size: 12px;
    /* 矢印のサイズ */

    /* 文字が矢印に被らないように右余白を確保 */
    padding-right: 40px !important;

    /* 念のため背景色を指定 */
    background-color: #fff;
    cursor: pointer;
}

/* スマホ(IEなど)対策 */
.content-form select::-ms-expand {
    display: none;
}

/* --- チェックボックス（オプション） --- */
.content-form .field-item {
    display: block;
    margin-bottom: 10px;
    cursor: pointer;
    position: relative;
    padding-left: 30px;
    margin: 0;
}

.content-form .field-item input[type="checkbox"] {
    position: absolute;
    left: 0;
    top: 2px;
    transform: scale(1.3);
}

/* --- 送信ボタン --- */
.content-form #action-button {
    margin-top: 60px;
    text-align: center;
}

.content-form #action-button button {
    display: inline-block;
    width: 100%;
    background: #E2FF00;
    color: #002E5C;
    font-size: 1.1rem;
    font-weight: bold;
    padding: 18px;
    border: none;
    border-radius: 50px;
    cursor: pointer;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.15);
    /* ボタンにも影 */
    transition: transform 0.2s, box-shadow 0.2s;
}

.content-form #action-button button:hover {
    transform: translateY(-2px);
    box-shadow: 0 15px 30px rgba(0, 0, 0, 0.2);
}

/* --- スマホ対応 --- */
@media screen and (max-width: 768px) {
    .content-form {
        padding: 100px 1rem;
    }

    .content-form fieldset {
        width: 100% !important;
        padding: 1rem !important;
        margin-bottom: 2rem !important;
    }

    .content-form table tr {
        flex-direction: column;
        align-items: flex-start;
    }

    .content-form table tr th {
        width: 100% !important;
        font-size: 1.1rem !important;
    }

        span.plan-name {
            font-size: 1rem;
        }

    .content-form legend {
        margin-bottom: 1.5rem !important;
    }

    .content-form #booking-sei,
    .content-form #booking-mei {
        width: calc((100% - .5rem) / 2);
    }

    .content-form textarea {
        width: 100% !important;
    }

    td.option-confirm-value {
        display: flex;
            flex-direction: column;
            align-items: flex-start;
    }

    span.option-confirm-note {
        display: block;
        font-weight: 600;
        order: -1;
    }

    td.option-confirm-header {
        display: none;
    }
}

/* =========================================
   予約完了画面（サンクスページ）スタイル
   ========================================= */

/* --- カード型の大枠 --- */
.thanks_txt {
    max-width: 800px;
    margin: 120px auto;
    /* 上下の余白 */
    padding: 60px 40px;
    background: #fff;
    /* 白背景 */
    border-radius: 16px;
    /* 角丸 */
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.05);
    /* ふんわり影 */
    text-align: center;
    /* 中央寄せ */
    font-family: "Noto Sans JP", sans-serif;
    color: #333;
}

/* --- チェックマークアイコン（青色） --- */
.thanks_txt::before {
    content: '';
    display: block;
    width: 70px;
    height: 70px;
    margin: 0 auto 30px;
    /* 下に余白 */
    background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23007DA5' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 11.08V12a10 10 0 1 1-5.93-9.14'/%3E%3Cpolyline points='22 4 12 14.01 9 11.01'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}

/* --- 見出し --- */
.thanks_txt h2 {
    font-size: 1.6rem;
    color: #007DA5;
    /* テーマカラー */
    font-weight: bold;
    margin-bottom: 30px;
}

/* --- 本文メッセージ --- */
.thanks_txt .message {
    font-size: 1rem;
    line-height: 2;
    /* 行間ゆったり */
    margin-bottom: 20px;
}

/* --- 注意書き（3日以内に...） --- */
.thanks_txt .caution {
    font-size: 0.9rem;
    color: #666;
    background: #f9f9f9;
    /* 薄いグレー背景で囲む */
    padding: 15px;
    border-radius: 8px;
    display: inline-block;
    /* 文字の長さだけ背景をつける */
    margin-bottom: 30px;
}

/* --- 電話番号エリア --- */
.thanks_txt .contact-info {
    margin-bottom: 40px;
    line-height: 1.4;
}

.thanks_txt .contact-info p {
    margin: 0;
}

.thanks_txt .tel-number {
    font-size: 1.4rem;
    font-weight: bold;
    color: #007DA5;
    margin-top: 5px !important;
    letter-spacing: 0.05em;
}

/* --- ボタンエリア --- */
.thanks_txt .btn-area {
    margin-top: 30px;
}

/* --- トップへ戻るボタン --- */
.thanks_txt .btn-back {
    display: inline-block;
    background: #333;
    /* 黒（または #007DA5 でもOK） */
    color: #fff;
    text-decoration: none;
    padding: 18px 60px;
    /* ボタンの大きさ */
    border-radius: 50px;
    /* 丸くする */
    font-weight: bold;
    font-size: 1.1rem;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.15);
    /* 影 */
    transition: all 0.3s;
}

/* ボタンのホバー時 */
.thanks_txt .btn-back:hover {
    background: #007DA5;
    /* カーソルを乗せると青くなる */
    transform: translateY(-3px);
    /* 浮き上がる */
    box-shadow: 0 8px 20px rgba(0, 125, 165, 0.3);
}

/* --- スマホ対応 --- */
@media screen and (max-width: 768px) {
    .thanks_txt {
        width: 90%;
        margin-top: 100px;
        padding: 40px 20px;
    }

    .thanks_txt h2 {
        font-size: 1.3rem;
    }

    .thanks_txt .message {
        font-size: .9rem;
    }

    .thanks_txt .tel-number {
        font-size: 1.2rem;
    }

    .thanks_txt .btn-back {
        width: 100%;
        /* スマホならボタンを横幅いっぱいに */
        box-sizing: border-box;
    }
}

/*************************
　　　ツアー参加ガイド
*************************/

.tour-guide {
    padding: 100px 0;
    display: flex;
    flex-direction: column;
    gap: 5rem;
}

.graph-wrap .ttl {
    text-align: center;
    margin-bottom: 3rem;
}

.graph-wrap .ttl h3 {
    font-size: 1.9rem;
}

.graph-wrap .ttl p {
    font-size: 1.1rem;
}

.graph-wrap .graph-inner {
    display: flex;
    gap: 3rem;
}

.graph-wrap .graph-inner .item {
    width: calc((100% - 3rem) / 2);
    padding: 1.5rem;
    border-radius: 1.8rem;
    box-shadow: 0 2px 10px #00000015;
}

.graph-wrap .graph-inner .item .head {
    display: flex;
    align-items: center;
    gap: 20px;
    font-size: 1.1rem;
}

.graph-wrap .graph-inner .item .head .number {
    width: 40px;
    height: 40px;
    color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    background: #000;
    padding: 10px;
}

.graph-wrap .graph-inner .item .head span {
    font-size: 1.2rem;
    font-weight: 500;
    color: #3193F4;
}

.graph-wrap .graph-inner .item .exp {
    text-align: center;
}

.pie {
    width: 320px;
    aspect-ratio: 1/1;
    position: relative;
    margin: 28px auto;
}

.pie--nest {
    --gap: 20px;
}

/* 半径差：ここを大きくすれば段差が強調される */
.pie:not(.is-ready) {
    opacity: .2;
    filter: blur(4px);
    transition: .25s;
}

.pie.is-ready {
    opacity: 1;
    filter: none;
}

.pie .layer {
    position: absolute;
    inset: calc(var(--gap) * var(--i));
    /* JSが --i を付与して縮める */
    border-radius: 50%;
    background: conic-gradient(#0000 0 360deg);
    /* 初期は空 */
    overflow: visible;
    /* 内側テキストのはみ出し許容したい場合は visible */
}

.pie .label {
    color: #fff;
    font-size: 1.1rem;
    line-height: 1;
}

/* レイヤー内テキストの共通スタイル */
.pie .label span {
    font-size: 3.5rem;
    font-weight: 800;
    line-height: 1;
}

/* “円の上側”にずらしたい場合に */
.pie-3 .label-red {
    position: absolute;
    top: 50%;
    right: 10%;
    transform: translateY(-50%);
}

.pie-4 .label-red {
    position: absolute;
    top: 20%;
    right: 10%;
}

.pie-4 .label-orange {
    position: absolute;
    bottom: 10%;
    left: 50%;
    transform: translateX(-50%);
}

.pie-4 .label-orange span {
    font-size: 2.5rem;
}

.tour-how .head-label {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    color: #fff;
    padding: 1.2rem;
    border-radius: 10px;
    background: #3193F4;
    margin-bottom: 3rem;
    position: relative;
}

.tour-how .head-label p {
    font-size: 1.9rem;
}

.tour-how .head-label p span {
    color: #E2FF00;
    font-weight: 600;
    padding: 0 10px;
}

.tour-how .head-label::before {
    content: '';
    width: 0;
    height: 0;
    border-style: solid;
    border-right: .8rem solid transparent;
    border-left: .8rem solid transparent;
    border-top: .8rem solid #3193F4;
    border-bottom: 0;
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translate(-50%, 100%);
}

.tour-how .how-wrap {
    display: flex;
    flex-direction: column;
    gap: 5rem;
}

.tour-how .how-wrap .item {
    display: flex;
    gap: 3rem;
}

.tour-how .how-wrap .item .label {
    width: calc(40% - 3rem);
    font-weight: 600;
}

.tour-how .how-wrap .item .label .sub {
    font-size: 1.1rem;
}

.tour-how .how-wrap .item .label p {
    font-size: 1.9rem;
}

.tour-how .how-wrap .item .label p span {
    color: #3193F4;
}

.tour-how .how-wrap .item .content {
    width: 60%;
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.how-table thead th {
    width: calc(100% / 4);
    text-align: center;
    vertical-align: middle;
    color: #fff;
    padding: .5rem;
}

.how-table tbody th,
.how-table tbody td {
    width: calc(100% / 4);
    text-align: center;
    vertical-align: middle;
    padding: .5rem;
}

.how-table thead th:nth-child(2) {
    background: #FE5B00;
    border-radius: 12px 0 0 0;
}

.how-table thead th:nth-child(3) {
    background: #FFBB00;
}

.how-table thead th:last-child {
    background: #16C9E5;
    border-radius: 0 12px 0 0;
}

.how-table tbody th.side {
    font-weight: 600;
}

.how-table tbody td:nth-child(n + 2):not(:nth-child(n + 5)) {
    border: 1px solid #ccc;
}

.check-point {
    padding: 1rem 2rem;
    border-radius: 10px;
    background: #FCEBF0;
}

.check-point .label {
    font-size: 1.1rem;
    font-weight: 900;
    color: #FF004B;
    margin-bottom: 10px;
}

.check-point table th {
    width: 20%;
}

@media screen and (max-width:767px) {

    .tour-guide {
        padding: 50px 1rem;
        gap: 3rem;
    }

    .graph-wrap .ttl {
        text-align: center;
        margin-bottom: 1.2rem;
    }

    .graph-wrap .ttl h3 {
        font-size: 1.2rem;
    }

    .graph-wrap .ttl p {
        font-size: .9rem;
    }

    .graph-wrap .graph-inner {
        flex-direction: column;
        gap: 1.5rem;
    }

    .graph-wrap .graph-inner .item {
        width: 100%;
        padding: 1.2rem;
        border-radius: 10px;
    }

    .graph-wrap .graph-inner .item .head {
        gap: 10px;
        font-size: .9rem;
    }

    .graph-wrap .graph-inner .item .head .number {
        width: 35px;
        height: 35px;
        padding: 8px;
    }

    .graph-wrap .graph-inner .item .head span {
        font-size: .9rem;
    }

    .pie--nest {
        --gap: 10px;
    }

    .tour-how .head-label {
        padding: 1rem;
        margin-bottom: 2rem;
    }

    .tour-how .head-label p {
        font-size: 1rem;
    }

    .tour-how .head-label p span {
        padding: 0 7px;
    }

    .tour-how .how-wrap {
        gap: 3rem;
    }

    .tour-how .how-wrap .item {
        flex-direction: column;
        gap: 20px;
    }

    .tour-how .how-wrap .item .label {
        width: 100%;
    }

    .tour-how .how-wrap .item .label .sub {
        font-size: 1.1rem;
    }

    .tour-how .how-wrap .item .label p {
        font-size: 1.9rem;
    }

    .tour-how .how-wrap .item .label p span {
        color: #3193F4;
    }

    .tour-how .how-wrap .item .content {
        width: 100%;
        display: flex;
        flex-direction: column;
        gap: 2rem;
    }

    .how-table thead th {
        font-size: .9rem;
    }

    .how-table tbody th,
    .how-table tbody td {
        font-size: .9rem;
    }

    .how-table thead th:nth-child(2) {
        border-radius: 6px 0 0 0;
    }

    .how-table thead th:last-child {
        border-radius: 0 6px 0 0;
    }

    .check-point {
        padding: .5rem 1rem;
        border-radius: 6px;
    }

    .check-point .label {
        margin-bottom: 8px;
    }

    .check-point table th {
        width: 40%;
    }
}

/* ============================================
   修学旅行・団体ページ (p-group-tour) - 写真マシマシ & 背景全幅Ver
============================================ */
.p-group-tour {
    max-width: 1000px;
    margin: 0 auto;
    padding: 60px 20px;
    color: #333;
    line-height: 1.7;
    position: relative;
    z-index: 0;
}

/* ★背景のドットだけを画面幅いっぱい（100vw）に広げる */
.p-group-tour::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: calc(50% - 50vw);
    right: calc(50% - 50vw);
    background: url('data:image/svg+xml;utf8,<svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"><circle cx="2" cy="2" r="1.5" fill="%23e3f2fd"/></svg>');
    z-index: -1;
}

.p-group-tour img {
    max-width: 100%;
    height: auto;
    display: block;
}

/* ★ 共通：ポラロイド写真風のスタイル ★ */
.p-group-tour .c-photo,
.p-group-tour .c-target-card__img img,
.p-group-tour .c-program-item__img img {
    border: 8px solid #fff;
    border-bottom-width: 24px;
    /* 下だけ太くしてポラロイド風に */
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.15);
    border-radius: 2px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    object-fit: cover;
}

.p-group-tour .c-photo:hover,
.p-group-tour .c-target-card__img img:hover {
    transform: scale(1.05) rotate(0deg) !important;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.25);
    z-index: 10;
    position: relative;
}

/* 共通セクションタイトル */
.p-group-tour .c-section-title {
    font-size: 28px;
    font-weight: 900;
    text-align: center;
    margin-bottom: 50px;
    color: #0056b3;
    position: relative;
    display: inline-block;
    width: 100%;
}

.p-group-tour .c-section-title::after {
    content: "";
    display: block;
    width: 60px;
    height: 4px;
    background: #ff7f50;
    margin: 15px auto 0;
    border-radius: 2px;
}

/* --- 導入セクション（コラージュ） --- */
.p-group-tour__intro {
    margin-bottom: 80px;
    text-align: center;
}

.p-group-tour__collage {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 40px;
    height: 250px;
}

.p-group-tour__collage .c-photo {
    width: 30%;
    max-width: 280px;
    aspect-ratio: 4/3;
}

/* 写真を重ねて散らかす */
.p-group-tour__collage .c-photo--left {
    transform: rotate(-8deg) translateX(20px);
    z-index: 1;
}

.p-group-tour__collage .c-photo--center {
    transform: rotate(3deg) translateY(-10px);
    z-index: 2;
    width: 35%;
    max-width: 320px;
}

.p-group-tour__collage .c-photo--right {
    transform: rotate(-5deg) translateX(-20px);
    z-index: 1;
}

@media (max-width: 768px) {
    .p-group-tour__intro {
        margin-top: 3rem;
    }

    .p-group-tour__collage {
        display: none;
        height: auto;
        flex-direction: column;
        gap: 20px;
    }

    .p-group-tour__collage .c-photo {
        width: 80%;
        transform: none !important;
    }

        .p-group-tour .c-section-title {
            font-size: 6vw;
            margin-bottom: 2rem;
        }
}

.p-group-tour__title {
    font-size: 32px;
    font-weight: 900;
    margin-bottom: 24px;
    line-height: 1.4;
}

/* ターゲットカード */
.p-group-tour__targets {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    justify-content: center;
    margin-top: 50px;
}

.p-group-tour .c-target-card {
    flex: 1;
    min-width: 280px;
    max-width: 320px;
    background: #fff;
    padding: 20px;
    border-radius: 8px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
    border-top: 5px solid #0056b3;
}

.p-group-tour .c-target-card__img {
    margin: -40px auto 20px;
    /* 写真をカードから上に少しはみ出させる */
    width: 90%;
}

.p-group-tour .c-target-card__img img {
    width: 100%;
    aspect-ratio: 4/3;
    transform: rotate(-2deg);
}

.p-group-tour .c-target-card:nth-child(even) .c-target-card__img img {
    transform: rotate(3deg);
}

.p-group-tour .c-target-card__title {
    font-size: 20px;
    font-weight: bold;
    color: #0056b3;
    margin-bottom: 12px;
}

/* --- ギャラリーセクション --- */
.p-group-tour__gallery {
    margin-bottom: 80px;
    background: #eef7ff;
    padding: 50px 20px;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
}

.p-group-tour .c-gallery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 30px;
    max-width: 1000px;
    margin: 0 auto;
}

.p-group-tour .c-gallery-grid .c-photo {
    width: 100%;
    aspect-ratio: 1/1;
}

/* 写真をランダムに傾ける */
.p-group-tour .c-photo--tilt1 {
    transform: rotate(-4deg);
}

.p-group-tour .c-photo--tilt2 {
    transform: rotate(3deg);
}

.p-group-tour .c-photo--tilt3 {
    transform: rotate(-2deg);
}


/* --- 体験内容セクション --- */
.p-group-tour__programs {
    margin-bottom: 80px;
}

.p-group-tour__program-list {
    display: flex;
    flex-direction: column;
    gap: 50px;
}

.p-group-tour .c-program-item {
    display: flex;
    gap: 40px;
    align-items: center;
    background: #fff;
    padding: 30px;
    border-radius: 16px;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
    border: 2px dashed #ccc;
}

@media (max-width: 768px) {
    .p-group-tour__title {
            font-size: 1.5rem;
        }

    .p-group-tour .c-target-card {
        max-width: 100%;
    }

    .p-group-tour .c-program-item {
        flex-direction: column;
        padding: 20px;
        gap: 20px;
    }
}

.p-group-tour .c-program-item__img {
    width: 45%;
    flex-shrink: 0;
}

@media (max-width: 768px) {
    .p-group-tour .c-program-item__img {
        width: 100%;
    }
}

.p-group-tour .c-program-item__img img {
    width: 100%;
    transform: rotate(2deg);
}

.p-group-tour .c-program-item__body {
    width: 55%;
}

@media (max-width: 768px) {
    .p-group-tour .c-program-item__body {
        width: 100%;
    }
}

.p-group-tour .c-program-item__num {
    display: inline-block;
    font-size: 14px;
    font-weight: bold;
    color: #fff;
    background: #ff7f50;
    padding: 6px 16px;
    border-radius: 30px;
    margin-bottom: 15px;
}

.p-group-tour .c-program-item__title {
    font-size: 24px;
    font-weight: bold;
    color: #0056b3;
    margin-bottom: 10px;
}

.p-group-tour .c-program-item__time {
    font-size: 14px;
    background: #f0f0f0;
    display: inline-block;
    padding: 4px 12px;
    border-radius: 4px;
    margin-bottom: 15px;
}


/* --- 特徴（掲示板風） --- */
.p-group-tour__features {
    margin-bottom: 80px;
    text-align: center;
}

.p-group-tour .c-feature-box {
    background: #fff9c4;
    /* 付箋っぽい色 */
    padding: 40px;
    display: inline-block;
    box-shadow: 3px 3px 10px rgba(0, 0, 0, 0.1);
    transform: rotate(-1deg);
    position: relative;
}

/* テープ装飾 */
.p-group-tour .c-feature-box::before {
    content: "";
    position: absolute;
    top: -10px;
    left: 50%;
    transform: translateX(-50%) rotate(-2deg);
    width: 120px;
    height: 30px;
    background: rgba(255, 255, 255, 0.6);
    border: 1px solid #ddd;
}

.p-group-tour .c-feature-box__num {
    color: #ff7f50;
    font-size: 40px;
    font-weight: 900;
    margin-right: 8px;
}

/* ===================================================
   団体ページ：アクアベースの特徴セクション (PC First - 2カラム版)
=================================================== */
.p-group-tour__features {
    padding: 80px 20px;
    background-color: #f7fcff;
    /* 海を連想させるごく薄いブルー */
}

/* 全体のラッパー (PC: 2列のグリッド) */
.c-feature-list {
    max-width: 1000px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 40px;
    row-gap: 50px;
}

/* 各アイテム (縦積みのカード型) */
.c-feature-item {
    display: flex;
    flex-direction: column;
    background: #fff;
    border-radius: 8px;
    /* 丸みを抑えてスタイリッシュに */
    overflow: hidden;
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.04);
    /* 影は極限まで薄く上品に */
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

/* ホバー時に少し浮かす（リッチな演出） */
.c-feature-item:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.08);
}

/* 以前のジグザグ用クラスが無効化されるようリセット */
.c-feature-item.c-feature-item--reverse {
    flex-direction: column;
}

/* 画像エリア */
.c-feature-item__img {
    margin: 0;
    width: 100%;
    overflow: hidden;
}

.c-feature-item__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    aspect-ratio: 16 / 10;
    /* 少し横長にして今っぽく */
    transition: transform 0.6s ease;
}

/* ホバーで画像がゆっくり拡大 */
.c-feature-item:hover .c-feature-item__img img {
    transform: scale(1.05);
}

/* テキストエリア */
.c-feature-item__body {
    padding: 30px;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

/* タイトル */
.c-feature-item__title {
    font-size: 20px;
    font-weight: 700;
    color: #333;
    margin-bottom: 15px;
    display: flex;
    align-items: center;
    gap: 15px;
    line-height: 1.4;
}

/* ナンバリング（野暮ったい丸を廃止し、スタイリッシュなアクセントに） */
.c-feature-item__num {
    color: #00a0e9;
    font-size: 32px;
    font-weight: 900;
    line-height: 1;
    padding-right: 15px;
    border-right: 2px solid #e5f3fa;
    /* 薄いブルーの縦線で区切る */
}

/* 説明文 */
.c-feature-item__text {
    font-size: 15px;
    line-height: 1.8;
    color: #555;
}

/* 注意書き（※部分） */
.c-feature-item__text small {
    display: block;
    font-size: 13px;
    color: #888;
    margin-top: 12px;
    line-height: 1.6;
}

/* ===================================================
   スマホ版のレイアウト（max-width: 768px）
=================================================== */
@media screen and (max-width: 768px) {

    .p-group-tour .c-program-item__title {
        font-size: 1.1rem;
    }
    .p-group-tour__features {
        padding: 50px 20px;
        margin-bottom: 2rem;
    }

    /* スマホは1列にする */
    .c-feature-list {
        grid-template-columns: 1fr;
        row-gap: 30px;
    }

    .c-feature-item__body {
        padding: 20px;
    }

    .c-feature-item__title {
        font-size: 1rem;
        gap: 12px;
    }

    .c-feature-item__num {
        font-size: 26px;
        padding-right: 12px;
    }

    .c-feature-item__text {
        font-size: 14px;
        text-align: left;
    }
}
/* ===================================================
   団体ページ：変更・キャンセル・注意事項まとめ (PC First)
=================================================== */
.p-group-tour__cancel {
    padding: 80px 0;
}

/* 全体を囲むひとつの箱 */
.c-cancel-box {
    max-width: 1200px;
    margin: 0 auto;
    background-color: #fafafa;
    border: 1px solid #eaeaea;
    padding: 50px;
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    gap: 40px;
    /* 各項目の間の余白 */
}

/* 各項目の小見出し（h3） */
.c-cancel-block__title {
    font-size: 18px;
    font-weight: 700;
    color: #333;
    margin-bottom: 20px;
    padding-left: 12px;
    border-left: 4px solid #00a0e9;
    /* 左に青いアクセントライン */
    line-height: 1.4;
}

/* ▼ 1. 注意事項 ▼ */
.c-attention-list {
    margin: 0;
    padding: 0 0 0 1.2em;
}

.c-attention-list li {
    font-size: 15px;
    color: #444;
    line-height: 1.8;
    margin-bottom: 10px;
}

.c-attention-list li:last-child {
    margin-bottom: 0;
}

/* ▼ 2. キャンセル料金 ▼ */
.c-cancel-block__lead {
    font-size: 15px;
    line-height: 1.8;
    color: #444;
    margin-bottom: 20px;
}

.c-cancel-table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 20px;
    background-color: #fff;
}

.c-cancel-table th,
.c-cancel-table td {
    border: 1px solid #ddd;
    padding: 15px;
    font-size: 15px;
    text-align: center;
    vertical-align: middle;
}

.c-cancel-table th {
    background-color: #f7fcff;
    color: #00a0e9;
    font-weight: 700;
    width: 50%;
}

.c-cancel-table td {
    color: #444;
    font-weight: 500;
}

.c-attention-notes {
    list-style: none;
    padding: 0;
    margin: 0;
}

.c-attention-notes li {
    font-size: 13px;
    color: #e53935;
    line-height: 1.6;
    margin-bottom: 5px;
}

/* ▼ 3. コース変更・中止について ▼ */
.c-attention-text {
    font-size: 15px;
    color: #444;
    line-height: 1.8;
    margin: 0;
}

/* ===================================================
   スマホ版のレイアウト（max-width: 768px）
=================================================== */
@media screen and (max-width: 768px) {
    .p-group-tour__cancel {
        padding: 50px 20px;
    }

    .c-cancel-box {
        padding: 30px 20px;
        gap: 30px;
    }

    .c-cancel-block__title {
        font-size: 16px;
        margin-bottom: 15px;
        padding-left: 10px;
    }

    /* テーブルを縦積みにする */
    .c-cancel-table th,
    .c-cancel-table td {
        display: block;
        width: 100%;
        text-align: left;
    }

    .c-cancel-table th {
        border-bottom: none;
    }

    .c-cancel-table td {
        border-top: none;
        margin-bottom: 10px;
    }

    .c-cancel-table tr:last-child td {
        margin-bottom: 0;
    }

    .c-attention-list li,
    .c-cancel-block__lead,
    .c-attention-text {
        font-size: 14px;
    }
}

/* ===================================================
   団体ページ：お申し込み・お問い合わせ (PC First)
=================================================== */
.p-group-tour__contact {
    padding: 80px 20px;
    background-color: #f7fcff;
    /* キャンセル規定(白)と差をつけるブルー背景 */
}

/* PCは2カラム（横並び） */
.p-group-tour__contact-inner {
    max-width: 1000px;
    margin: 0 auto;
    display: flex;
    gap: 2rem;
}

/* 共通の白いボックス */
.c-contact-block {
    flex: 1;
    background-color: #fff;
    border-radius: 8px;
    padding: 2rem 1rem;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
    display: flex;
    flex-direction: column;
}

/* ボックス内のタイトル */
.c-contact-block__title {
    font-size: 20px;
    font-weight: 700;
    color: #333;
    text-align: center;
    margin-bottom: 25px;
    padding-bottom: 15px;
    border-bottom: 2px dashed #e2eff6;
}

/* ▼ 申し込みの流れ ▼ */
.c-contact-flow {
    list-style: none;
    padding: 0;
    margin: 0 0 30px 0;
    flex-grow: 1;
    /* ボタンを下に押しやる */
}

.c-contact-flow li {
    font-size: 15px;
    color: #444;
    line-height: 1.8;
    margin-bottom: 15px;
    padding-left: 1.5em;
    position: relative;
}

.c-contact-flow li::before {
    content: "✓";
    position: absolute;
    left: 0;
    color: #00a0e9;
    font-weight: bold;
}

/* ▼ お問い合わせ先 ▼ */
.c-contact-info {
    text-align: center;
    margin-bottom: 25px;
}

.c-contact-name {
    font-size: 18px;
    font-weight: 700;
    color: #00a0e9;
    margin-bottom: 5px;
}

.c-contact-rep {
    font-size: 15px;
    color: #444;
}

/* 電話・FAX番号エリア */
.c-contact-telbox {
    background-color: #fafafa;
    border-radius: 6px;
    padding: 20px;
    margin-bottom: 25px;
}

.c-contact-telbox__item {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 15px;
    margin-bottom: 10px;
}

.c-contact-telbox__item:last-child {
    margin-bottom: 0;
}

.c-contact-telbox__item .label {
    display: inline-block;
    background-color: #333;
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    padding: 4px 8px;
    border-radius: 3px;
    letter-spacing: 1px;
}

.c-contact-telbox__item .number {
    font-size: 28px;
    font-weight: 900;
    color: #333;
    text-decoration: none;
    line-height: 1;
}

/* ▼ SNS案内 ▼ */
.c-contact-sns {
    font-size: 14px;
    color: #666;
    text-align: center;
    margin-top: 20px;
}

/* ▼ ボタン共通 ▼ */
.c-contact-btns {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.c-btn {
    display: block;
    width: 100%;
    text-align: center;
    padding: 16px;
    font-size: 15px;
    font-weight: 700;
    border-radius: 30px;
    text-decoration: none;
    transition: opacity 0.3s, transform 0.3s;
}

.c-btn:hover {
    opacity: 0.8;
    transform: translateY(-2px);
}

.c-btn--pdf {
    background-color: #f15a24;
    /* PDFは目立つオレンジ系 */
    color: #fff;
}

.c-btn--mail {
    background-color: #00a0e9;
    /* WEB問い合わせはブルー */
    color: #fff;
}

/* ===================================================
   スマホ版のレイアウト（max-width: 768px）
=================================================== */
@media screen and (max-width: 768px) {
    .p-group-tour__contact {
        padding: 50px 20px;
    }

    .p-group-tour__contact-inner {
        flex-direction: column;
        /* スマホは縦積み */
        gap: 30px;
    }

    .c-contact-block {
        padding: 30px 20px;
    }

    .c-contact-block__title {
        font-size: 18px;
    }

    .c-contact-flow li,
    .c-contact-rep,
    .c-btn {
        font-size: 14px;
    }

    .c-contact-telbox {
        padding: 15px;
    }

    .c-contact-telbox__item {
        gap: 10px;
    }

    .c-contact-telbox__item .number {
        font-size: 24px;
    }

    .c-contact-sns {
        font-size: 13px;
    }
}

/* =========================================
   ツアースケジュール（カレンダー）ページ
========================================= */
.page-calendar {
    padding: 100px 0;
}

.page-calendar .cal-ttl {
    text-align: center;
    margin-bottom: 3rem;
}

.page-calendar .cal-ttl h2 {
    font-size: 1.5rem;
    font-weight: bold;
    color: #333;
    line-height: 1.6;
}

.page-calendar .sp-only {
    display: none;
}

/* カレンダーを囲む枠 */
.cal-iframe-wrap {
    width: 100%;
    max-width: 1000px;
    margin: 0 auto;
    background-color: #fff;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
    /* 少しフワッと浮かせる */
    border-radius: 8px;
    overflow: hidden;
}

/* iframe自体の設定 */
.cal-iframe-wrap iframe {
    width: 100%;
    height: 800px;
    display: block;
}

/* =========================================
   スマホ表示 (767px以下)
========================================= */
@media screen and (max-width: 767px) {
    .page-calendar {
        padding: 60px 1rem;
    }

    .page-calendar .cal-ttl h2 {
        font-size: 1.1rem;
    }

    .page-calendar .sp-only {
        display: block;
    }

    /* スマホの時はカレンダーの縦幅を少し縮める */
    .cal-iframe-wrap iframe {
        height: 600px;
    }
}


/* =========================================
   アクアベースのおもてなし（選ばれる理由 /strong/）
========================================= */
.strong-content {
    padding: 80px 0 120px;
}

.strong-content section {
    margin-bottom: 100px;
}

.st-ttl {
    text-align: center;
    margin-bottom: 3rem;
}

.st-ttl h2 {
    font-size: 1.8rem;
    font-weight: bold;
    color: #0080bc;
    line-height: 1.5;
    margin-bottom: 0.5rem;
}

.st-ttl span {
    display: inline-block;
    font-size: 1.1rem;
    font-weight: bold;
    color: #fff;
    background-color: #f09300;
    padding: 0.3rem 1.5rem;
    border-radius: 30px;
}

.desc-center {
    text-align: center;
    line-height: 1.8;
    margin-bottom: 3rem;
}

/* イントロ */
.st-intro {
    text-align: center;
    line-height: 2;
    font-size: 1.05rem;
    background: #f4fbfe;
    padding: 3rem;
    border-radius: 10px;
}

/* 6つのお約束 */
.promise-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
}

.promise-list .item {
    background: #fff;
    border: 1px solid #e5e5e5;
    padding: 2rem;
    border-radius: 8px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.03);
    position: relative;
    padding-top: 3rem;
}

.promise-list .item .num {
    position: absolute;
    top: -20px;
    left: 20px;
    font-size: 3rem;
    font-weight: 900;
    color: #e5f5fc;
    line-height: 1;
    z-index: 1;
}

.promise-list .item h3 {
    font-size: 1.1rem;
    font-weight: bold;
    color: #333;
    margin-bottom: 1rem;
    position: relative;
    z-index: 2;
    border-bottom: 2px solid #f09300;
    padding-bottom: 0.5rem;
}

.promise-list .item p {
    font-size: 0.95rem;
    line-height: 1.6;
    color: #555;
    position: relative;
    z-index: 2;
}

/* 施設について（アメニティタグ） */
.amenity-tags {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    margin-bottom: 4rem;
}

.amenity-tags li {
    background: #00a0e9;
    color: #fff;
    padding: 0.5rem 1rem;
    border-radius: 20px;
    font-size: 0.9rem;
    font-weight: bold;
}

/* 施設について（画像とテキスト交互） */
.feature-rows .row {
    display: flex;
    align-items: center;
    gap: 4rem;
    margin-bottom: 4rem;
}

.feature-rows .row.reverse {
    flex-direction: row-reverse;
}

.feature-rows .row .img {
    width: 50%;
}

.feature-rows .row .img img {
    border-radius: 8px;
    width: 100%;
    height: auto;
}

.feature-rows .row .txt {
    width: 50%;
}

.feature-rows .row .txt h3 {
    font-size: 1.3rem;
    font-weight: bold;
    color: #0080bc;
    margin-bottom: 1rem;
}

.feature-rows .row .txt p {
    line-height: 1.8;
}

/* 器材について（グリッド） */
.equip-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    margin-bottom: 4rem;
}

.equip-grid .item .img img {
    width: 100%;
    border-radius: 8px;
    margin-bottom: 1rem;
}

.equip-grid .item h4 {
    font-weight: bold;
    color: #333;
    margin-bottom: 0.5rem;
}

.equip-grid .item p {
    font-size: 0.9rem;
    line-height: 1.6;
}

.equip-wide-boxes {
    display: flex;
    gap: 2rem;
}

.equip-wide-boxes .wide-box {
    background: #eef8fb;
    padding: 2rem;
    border-radius: 8px;
    width: 50%;
}

.equip-wide-boxes .wide-box h3 {
    font-weight: bold;
    color: #0080bc;
    margin-bottom: 1rem;
    font-size: 1.1rem;
}

.equip-wide-boxes .wide-box p {
    font-size: 0.95rem;
    line-height: 1.6;
}

/* ガイドについて */
.guide-inner {
    display: flex;
    gap: 4rem;
    align-items: center;
    background: #fff;
    border: 1px solid #e5e5e5;
    border-radius: 10px;
    padding: 3rem;
}

.guide-inner .img {
    width: 40%;
    height: auto;
    aspect-ratio: 3 / 2;
}

.guide-inner .img img {
    width: 100%;
    height: 100%;
    border-radius: 8px;
    object-fit: cover;
}

.guide-inner .txt {
    width: 60%;
}

.guide-inner .txt p {
    line-height: 1.8;
}

.sp_only {
    display: none;
}

/* =========================================
   スマホ用レスポンシブ (767px以下)
========================================= */
@media screen and (max-width: 767px) {
    .strong-content {
        padding: 40px 1rem 80px;
    }

    .strong-content section {
        margin-bottom: 60px;
        font-size: .9rem;
    }

    .st-ttl h2 {
        font-size: 1.3rem;
    }

    .desc-center {
        text-align: left;
    }

    .st-intro {
        padding: 1.5rem;
        text-align: left;
    }

    .pc_only {
        display: none;
    }

    .sp_only {
        display: block;
    }

    .promise-list {
        grid-template-columns: 1fr;
    }

    .amenity-tags li {
        font-size: 0.8rem;
        padding: 0.4rem 0.8rem;
    }

    .feature-rows .row,
    .feature-rows .row.reverse {
        flex-direction: column;
        gap: 1.5rem;
        margin-bottom: 3rem;
    }

    .feature-rows .row .img,
    .feature-rows .row .txt {
        width: 100%;
    }

    .equip-grid {
        grid-template-columns: 1fr;
    }

    .equip-wide-boxes {
        flex-direction: column;
    }

    .equip-wide-boxes .wide-box {
        width: 100%;
    }

    .guide-inner {
        flex-direction: column;
        padding: 1.5rem;
        gap: 1.5rem;
    }

    .guide-inner .img,
    .guide-inner .txt {
        width: 100%;
    }
}

/* =========================================================
   FAQ アコーディオン
========================================================= */
.faq .accordion {
    border-top: 1px solid #ccc;
    margin-bottom: 40px;
}

.faq .accordion-item {
    border-bottom: 1px solid #ccc;
}

.faq .accordion-item button {
    position: relative;
    display: block;
    width: 100%;
    text-align: left;
    padding: 25px 50px 25px 0;
    font-size: 16px;
    font-weight: bold;
    color: #333;
    background: transparent;
    border: none;
    cursor: pointer;
    line-height: 1.5;
}

/* ＋アイコンの作成 */
.faq .icon {
    position: absolute;
    top: 50%;
    right: 15px;
    transform: translateY(-50%);
    width: 14px;
    height: 14px;
}

.faq .icon::before,
.faq .icon::after {
    content: "";
    position: absolute;
    background-color: #333;
    transition: transform 0.3s ease;
}

.faq .icon::before {
    top: 6px;
    left: 0;
    width: 14px;
    height: 2px;
}

.faq .icon::after {
    top: 0;
    left: 6px;
    width: 2px;
    height: 14px;
}

/* アコーディオンが開いた時（マイナスにする） */
.faq .accordion-item.is-open .icon::after {
    transform: scaleY(0);
}

/* 回答コンテンツ部分（初期状態は隠す） */
.faq .accordion-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease, padding 0.3s ease, opacity 0.3s ease;
    padding: 0 50px 0 0;
    opacity: 0;
}

.faq .accordion-content p {
    font-size: 15px;
    line-height: 1.8;
    color: #444;
    margin: 0;
}

/* アコーディオンが開いた時（ぬるっと表示） */
.faq .accordion-item.is-open .accordion-content {
    max-height: 500px;
    padding-bottom: 25px;
    opacity: 1;
}

/* スマホ用の微調整 */
@media screen and (max-width: 768px) {
    .faq {
        padding: 50px 1rem;
    }
    .faq .accordion-item button {
        font-size: 15px;
        padding: 20px 40px 20px 0;
    }

    .faq .accordion-content p {
        font-size: 14px;
    }
}