@charset "UTF-8";

/* CSS Document */

html, body {
    margin: 0;
    padding: 0;
}

html.lenis-preload,
body.lenis-preload {
    overflow: hidden;
    height: 100%;
}

html {
    font-size: 62.5%;
    overflow: auto;
}

body {
    font-family: YakuHanJP, "Noto Sans JP", serif;
    font-optical-sizing: auto;
    font-weight: 500;
    font-style: normal;
    min-height: 100vh;
    margin: 0;
    background-color: #FFFFFF;
}

h1, h2, h3, h4, h5, h6 {
    /*display: none;*/
    text-align: justify;
    word-break: break-all;
    text-justify: inter-ideograph;
    text-justify: inter-character;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

img {
    width: 100%;
    height: auto;
    display: block;
}

ul {
    padding: 0;
    margin: 0;
    list-style: none;
}

p {
    margin: 0;
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 1.8;
    text-align: justify;
    word-break: break-all;
    text-justify: inter-ideograph;
    text-justify: inter-character;
    word-wrap: break-word;
    overflow-wrap: break-word;
    font-weight: 500;
}

li {
    color: #000000;
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 1.8;
    text-align: justify;
    word-break: break-all;
    text-justify: inter-ideograph;
    text-justify: inter-character;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

p,
li,
table, figcaption, time {
    letter-spacing: 0.05rem;
    color: #27597e;
}

a,
a:hover {
    text-decoration: none;
    transition: 0.3s;
}

article {
    overflow: hidden;
}

/* スマホ時にアニメーションを無効化 */
@media (max-width: 767px) {
    a {
        transition: none !important;
        animation: none !important;
    }

    a:hover {
        transform: none !important;
    }
}

figure {
    margin: 0;
}

table {
    width: 100%;
    border-collapse: collapse;
}

section {
    overflow: hidden;
}

*,
*::after,
*::before {
    box-sizing: border-box;
}

@media screen and (min-width: 1200px) {
    .display-none.min-1200 {
        display: none !important;
    }
}

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

@media screen and (min-width: 992px) {
    .display-none.min-992 {
        display: none !important;
    }
}

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

@media screen and (min-width: 768px) {
    .display-none.min-768 {
        display: none !important;
    }
}

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

.display-none.heading {
    display: none;
}

.effect-fade {
    opacity: 0;
}

.fade-01 {
    transform: translate(0, 45px);
    transition: 1s;
}

.fade-02 {
    transform: translate(0, 45px);
    transition: 1.5s;
}

.fade-03 {
    transform: translate(0, 45px);
    transition: 2s;
}

.fade-04 {
    transform: translate(0, 45px);
    transition: 2.5s;
}

.fade-05 {
    transform: translate(0, 45px);
    transition: 3s;
}

.fade-06 {
    transform: translate(0, 45px);
    transition: 3.5s;
}

.fade-07 {
    transform: translate(0, 45px);
    transition: 4s;
}

.effect-fade.effect-scroll {
    opacity: 1;
    transform: translate(0, 0);
}

/*-------管理画面用_マージン-------*/
@media (min-width: 783px) {

    .modal-menu-box.margin-top-32 .modal-btn {
        top: 32px;
    }

    .slide-text-wrap.wpadminbar-32 {
        height: calc(100vh - 32px);
    }

    .hero-news .hero-news-bar .left-tag.wpadminbar-32 {
        bottom: 32px;
    }

    .swiper-container.wpadminbar-32 {
        height: calc(100vh - 32px);
    }

    .floating-menu.margin-top-32 {
        margin-top: 32px;
    }

    .header-box.margin-top-32 {
        margin-top: 32px;
    }
}

@media (max-width: 782px) {
    .margin-top-46 {
        /* margin-top: 46px; */
    }

    .modal-menu-box.margin-top-46 {
        /* margin-top: 0; */
    }

    #header.margin-top-46 {
        /* position: absolute; */
    }

    #wpadminbar {
        position: fixed !important;
        top: 0;
        left: 0;
    }

    .header-box.margin-top-46 {
        margin-top: 46px;
    }
}

/*-------管理画面用_マージン-------*/

.container-fluid {
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
    margin-right: auto;
    margin-left: auto;
}

.container {
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
    margin-right: auto;
    margin-left: auto;
    position: relative;
}

@media screen and (min-width: 576px) {
    .container {
        max-width: 540px;
    }
}

@media screen and (min-width: 768px) {
    .container {
        max-width: 720px;
    }
}

@media screen and (min-width: 992px) {
    .container {
        max-width: 820px;
    }
}

@media screen and (min-width: 1200px) {
    .container {
        max-width: 1000px;
    }
}

@media screen and (min-width: 1400px) {
    .container {
        max-width: 1120px;
    }
}

.row {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-right: -15px;
    margin-left: -15px;
}

.wrap-col {
    position: relative;
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
}

@media screen and (min-width: 992px) {
    .wrap-col {
        -ms-flex: 0 0 100%;
        flex: 0 0 100%;
        max-width: 100%;
    }
}

.img-liquid {
    width: 100%;
}

/* フォント */

.work-sans {
    font-family: "Work Sans", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
}

.zen-old-mincho {
    font-family: "Zen Old Mincho", serif;
    font-style: normal;
}

.geologica {
    font-family: "Geologica", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-variation-settings:
        "slnt"0,
        "CRSV"0,
        "SHRP"0;
}

.roboto {
    font-family: "Roboto", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
}

h2 {
    display: none;
}

/*------------- ヘッダー -------------*/
#header {
    /* position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
    transition: .3s; */

    padding-top: 15px;
    padding-bottom: 15px;
}

.header-row {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    padding: 0 30px;
}

.main-logo .title {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    font-size: 20px;
    line-height: 1.5;
    transition: .3s;
}

@media screen and (max-width: 1199px) {
    .main-logo .title {
        font-size: 18px;
    }
}

.main-logo .title span {
    font-size: 14px;
}

.global-menu ul {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: nowrap;
    gap: 25px;
}

@media screen and (max-width: 1199px) {
    .global-menu ul {
        gap: 20px;
    }
}

.global-menu li {
    font-size: 14px;
    font-weight: 600;
    transition: .3s;
}

@media screen and (max-width: 1199px) {
    .global-menu li {
        font-size: 12px;
    }
}

@media screen and (min-width: 992px) and (max-width: 1099px) {
    .global-menu li {
        font-size: 11px;
    }
}

.global-menu li a {
    color: #333333;
    transition: .3s;
}

.global-menu li a:hover {
    color: #0068B5;
}


/*------------- ヘッダー -------------*/
.section-box {
    /* padding: 100px 0; */
    scroll-margin-top: 100px;
}

.section-box {
    padding-top: 100px;
    padding-bottom: 100px;
    position: relative;
}

@media screen and (max-width: 991px) {
    .section-box {
        padding-top: 0;
        padding-bottom: 50px;
    }

}

.section-box::before {
    content: "";
    display: block;
    height: 100px;
    margin-top: -100px;
}

.not-top .section-box::before {
    display: none;
}

.section-title-box {
    display: inline-block;
    position: relative;
    z-index: 2;
}

.section-title .en {
    text-transform: uppercase;
    font-family: "Geologica", sans-serif;
    font-weight: 200;
    font-size: 40px;
    line-height: 1.1;
    margin-bottom: 10px;
    letter-spacing: 0.7rem;
}

.section-title {
    /* display: flex;
    flex-direction: column;
    border-left: 5px solid #227EA5;
    padding-left: 15px; */
}

.section-box h3 {
    display: none;
}

/* .section-box.news {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}

.section-box.news .section-title-box {
    width: 25%;
}

.section-box.news .contents-box {
    width: 75%;
}

.news-list a {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 30px;
}

.section-box.news time {
    white-space: nowrap;
    font-weight: 600;
    color: #6D7682;
}

.news-list {
    padding: 30px 0;
    border-bottom: 1px solid #ddd;
}

.news-list .title {
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
    font-weight: 600;
    text-decoration: none;
    background: linear-gradient(#0068B5, #0068B5) no-repeat 0 100%;
    background-size: 0 1px;
    transition: background-size .3s;
} */

/* .news-list a:hover .title {
    color: #0068B5;
    background-size: 100% 1px;
} */

/* .news-list:first-of-type {
    padding-top: 0;
} */

.section-box.news .link-box {
    /* margin-top: 80px; */
}

/* .section-box.news .link-box a {
    color: #333333;
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

.section-box.news .link-box a .title {
    color: #333333;
    font-size: 14px;
    line-height: 1;
    margin-left: 15px;
}

.section-box.news .link-box a:hover .title {
    color: #0068B5;
}

.section-box.news .link-box .arrow i {
    font-size: 24px;
    background-color: #429de2;
    color: #FFF;
    padding: 20px;
    border-radius: 50%;
    transition: .3s;
}

.section-box.news .link-box a:hover .arrow i {
    background-color: #0068B5;
    transform: scale(1.1);
} */

.slide-section .row {
    flex-direction: column;
}

.section-title-box {
    display: flex;
    justify-content: space-between;
    margin-bottom: 50px;
    align-items: flex-end;
    width: 100%;
}

.slide-section .section-title {
    /* margin-bottom: 50px; */
}

.slide-section .contents-box {
    width: 100%;
}

.swiper {
    max-width: 100%;
    width: 100%;
    overflow: hidden;
    position: relative;
}

.swiper-slide {
    width: auto;
}

.swiper-slide img {
    width: 100%;
    height: auto;
}

.swiper .slide-content {
    margin-top: 10px;
}

.swiper .spot {
    font-size: 12px;
    color: #0068B5;
}

.swiper .slide-title {
    font-size: 16px;
    font-weight: 600;
}

.swiper .artist {
    font-size: 14px;
}

.swiper-controller {
    display: flex;
    gap: 1.6rem;
    align-items: center;
    justify-content: flex-end;
    margin-top: 3.2rem;
}

.swiper-pagination {
    margin-right: auto;
}

.swiper-button-box {
    position: relative;
    display: flex;
    justify-content: space-between;
    gap: 15px;
    flex-direction: row-reverse;
}

/* Swiperナビゲーションボタン */
.swiper-button-prev,
.swiper-button-next {
    position: relative;
    z-index: 10;
    width: 100%;
    margin: 0;
    top: auto;
    /* width: 60px;
    height: 60px;
    background: #FFF;
    border: 1px solid #333;
    color: #333;
    border-radius: 50%;
    display: flex;
    font-size: 24px; */
}

.swiper-button-prev i,
.swiper-button-next i {
    font-size: 24px;
    background-color: #fff;
    color: #333;
    border: 1px solid #333;
    padding: 20px;
    border-radius: 50%;
    transition: .3s;
}

.swiper-button-prev i:hover,
.swiper-button-next i:hover {
    background-color: #0068B5;
    color: #fff;
    border: 1px solid #0068B5;
    /* transform: scale(1.1); */
}

/* 左右ボタンの位置調整 */
.swiper-button-prev {
    left: 0;
}

.swiper-button-next {
    right: 0;
}

.swiper-button-prev:after, .swiper-rtl .swiper-button-next:after {
    content: '';
}

.swiper-button-next:after, .swiper-rtl .swiper-button-prev:after {
    content: '';
}

.section-title-box .link-box-wrap {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
}

.section-title-box .link-box {
    /* margin-left: 20px; */
}

/* セレクタを汎用化 */
.link-box a {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    background-color: #F5F7F8;
    color: #fff;
    flex-direction: row-reverse;
    padding: 10px 10px 10px 20px;
    border-radius: 50px;
}

.link-box.prev-post a {
    padding: 10px 20px 10px 10px;
}

.link-box a:hover {
    background-color: #429de2;
}

.link-box a .title {
    line-height: 1;
    margin: 0 15px;
    color: #0066B1;
    font-size: clamp(1.2rem, 0.714rem + 0.49vw, 1.4rem);
}

.link-box a:hover .title {
    color: #FFF;
}

.link-box .arrow i {
    font-size: 18px;
    color: #FFF;
    padding: 15px;
    transition: .3s;
    background-color: #0066B1;
    border-radius: 50%;
}

.link-box a:hover .arrow i {
    color: #0066B1;
    background-color: #FFF;
}

.swiper-slide figure img {
    transition: .7s;
}

.swiper-slide:hover figure img {
    transform: scale(1.1);
}

.swiper figure {
    position: relative;
    overflow: hidden;
}

.swiper1 figure::before {
    content: "";
    display: block;
    padding-top: 66.7%;
}

.swiper2 figure::before {
    content: "";
    display: block;
    padding-top: 100%;
}

.swiper figure::after {
    content: "";
    position: absolute;
    inset: 0px;
    transition: background-color 0.3s ease 0s;
}

.swiper figure img {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    object-fit: cover;
    border-radius: 3px;
}


/* コンテンツのスタイル */
.content {
    position: relative;
    width: 100%;
}

/* 背景の波 */
.wave-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    z-index: 1;
}

.wave-container svg {
    width: 200%;
    /* 2倍の幅を確保 */
    height: 100%;
    animation: wave 8s linear infinite;
}

/* 波のアニメーション */
@keyframes wave {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(-50%);
    }
}

.section-box.artists .wave-container svg path {
    fill: #E9F2FC;
}

/* コンテンツ内のテキスト */
.inner-content {
    position: relative;
    z-index: 1;
    max-width: 800px;
    margin: 0 auto;
}

.section-box.map {
    background-color: #e9f2fc;
    margin-top: -1px;
}

.section-box.map .wave-container svg path {
    fill: #a4d1f4;
}

.contents-box {
    position: relative;
    z-index: 2;
    width: 100%;
}

.recommend .section-title-box {
    display: flex;
    justify-content: space-between;
    margin-bottom: 50px;
    align-items: flex-end;
    width: 100%;
}

@media screen and (max-width: 991px) {
    .recommend .section-title-box {
        margin-bottom: 30px;
        justify-content: center;
    }

}

.recommend .list-content {
    display: flex;
    flex-wrap: wrap;
    /* gap: 50px 30px; */
    justify-content: space-between;
}

@media screen and (max-width: 991px) {
    .recommend .list-content {
        flex-direction: column;
    }

}

.recommend .list-content li {
    flex: 1 1 calc(33.333% - 30px);
    text-align: center;
    font-size: 14px;
    /* transition: 0.3s; */
}

@media screen and (max-width: 991px) {
    .recommend .list-content li {
        margin-bottom: 30px;
    }
}

.recommend .list-content li:nth-child(odd) {
    background-color: #0068B5;
    /* transition: 1s; */
}

@media screen and (min-width: 992px) {
    .recommend .list-content li:nth-child(odd):hover {
        background-color: #014f89;
    }
}

.recommend .list-content li:nth-child(even) {
    background-color: #227EA5;
}

@media screen and (min-width: 992px) {
    .recommend .list-content li:nth-child(even):hover {
        background-color: #166789;
    }
}

.recommend.gourmet .list-content li:nth-child(odd) {
    background-color: #227EA5;
    /* transition: 1s; */
}

@media screen and (min-width: 992px) {
    .recommend.gourmet .list-content li:nth-child(odd):hover {
        background-color: #166789;
    }
}

.recommend.gourmet .list-content li:nth-child(even) {
    background-color: #0068B5;
}

@media screen and (min-width: 992px) {
    .recommend.gourmet .list-content li:nth-child(even):hover {
        background-color: #014f89;
    }
}

.recommend .list-content li figure {
    position: relative;
    /* 基準位置とする */
}

.recommend .list-content li figure::before {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
}

.recommend .list-content li:nth-child(odd) figure::before {
    background: linear-gradient(rgba(255, 255, 255, 0) 0, rgba(255, 255, 255, 0) 80%, rgba(0, 104, 181, 0.8) 90%, rgba(0, 104, 181, 1) 95%, #0068B5 100%);
    transition: 0.3s;
}

@media screen and (min-width: 992px) {
    .recommend .list-content li:nth-child(odd):hover figure::before {
        background: linear-gradient(rgba(255, 255, 255, 0) 0, rgba(255, 255, 255, 0) 80%, rgba(1, 79, 137, 0.8) 90%, rgba(1, 79, 137, 1) 95%, #014f89 100%);
    }
}

.recommend .list-content li:nth-child(even) figure::before {
    background: linear-gradient(rgba(255, 255, 255, 0) 0, rgba(255, 255, 255, 0) 80%, rgba(34, 126, 165, 0.8) 90%, rgba(34, 126, 165, 1) 95%, #227EA5 100%);
}

@media screen and (min-width: 992px) {
    .recommend .list-content li:nth-child(even):hover figure::before {
        background: linear-gradient(rgba(255, 255, 255, 0) 0, rgba(255, 255, 255, 0) 80%, rgba(22, 103, 137, 0.8) 90%, rgba(22, 103, 137, 1) 95%, #166789 100%);
    }
}





.recommend.gourmet .list-content li:nth-child(odd) figure::before {
    background: linear-gradient(rgba(255, 255, 255, 0) 0, rgba(255, 255, 255, 0) 80%, rgba(34, 126, 165, 0.8) 90%, rgba(34, 126, 165, 1) 95%, #227EA5 100%);
}

@media screen and (min-width: 992px) {
    .recommend.gourmet .list-content li:nth-child(odd):hover figure::before {
        background: linear-gradient(rgba(255, 255, 255, 0) 0, rgba(255, 255, 255, 0) 80%, rgba(22, 103, 137, 0.8) 90%, rgba(22, 103, 137, 1) 95%, #166789 100%);
    }
}

.recommend.gourmet .list-content li:nth-child(even) figure::before {
    background: linear-gradient(rgba(255, 255, 255, 0) 0, rgba(255, 255, 255, 0) 80%, rgba(0, 104, 181, 0.8) 90%, rgba(0, 104, 181, 1) 95%, #0068B5 100%);
    transition: 0.3s;
}

@media screen and (min-width: 992px) {
    .recommend.gourmet .list-content li:nth-child(even):hover figure::before {
        background: linear-gradient(rgba(255, 255, 255, 0) 0, rgba(255, 255, 255, 0) 80%, rgba(1, 79, 137, 0.8) 90%, rgba(1, 79, 137, 1) 95%, #014f89 100%);
    }
}

.recommend .list-content figure {
    position: relative;
    overflow: hidden;
    aspect-ratio: 9 / 7;
    /* 比率だけ指定 */
    width: 100%;
    /* または max-width, % など */
}

.recommend .list-content figure::before {
    content: "";
    display: block;
    padding-top: 66.7%;
}

.recommend .list-content figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 1s ease;
}

@media screen and (min-width: 992px) {
    .recommend .list-content li:hover figure img {
        transform: scale(1.1);
    }
}

.recommend .list-content figure::after {
    content: "";
    position: absolute;
    inset: 0px;
    transition: background-color 0.3sease 0s;
}

.recommend .list-content .text-box {
    padding: 20px;
    padding-top: 10px;
    position: relative;
}

.recommend .spot {
    font-size: 12px;
    color: #0068B5;
}

.recommend .list-content .title {
    position: absolute;
    top: -35px;
    z-index: 3;
    color: #FFF;
    font-weight: 500;
}

@media screen and (min-width: 992px) {
    .recommend .list-content .title {
        font-size: clamp(1.6rem, 1.481rem + 0.37vw, 2rem);
    }

}

.recommend .list-content .text {
    color: #FFF;
    font-weight: 400;
}

@media screen and (min-width: 992px) {
    .recommend .list-content .text {
        font-size: clamp(1.2rem, 0.714rem + 0.49vw, 1.4rem);
    }

}

@media screen and (max-width: 991px) {
    .recommend .list-content .text {
        font-size: 14px;
    }

}

footer {
    background-color: #103652;
    position: relative;
    overflow: hidden;
    padding-top: 50px;
    padding-bottom: 50px;
}

footer .wave-container svg path {
    fill: #1d79df;
}

footer .contents-box {
    display: flex;
    justify-content: center;
    width: 100%;
    flex-direction: column;
    align-items: center;
}

footer .footer-title {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    font-size: 16px;
    line-height: 1.5;
    transition: .3s;
    color: #FFF;
    margin-bottom: 50px;
    font-weight: 300;
}

footer .footer-title span {
    font-size: 12px;
}

footer .policy {
    margin-top: 50px;
    font-size: 12px;
    font-weight: 300;
}

footer .policy a {
    color: #FFF;
}

footer .copyright {
    margin-top: 15px;
    font-size: 12px;
    font-weight: 300;
    color: #FFF;
}

.main-visual {
    position: relative;
    display: inline-block;
    /* 必要に応じて */
}

.main-visual {
    position: relative;
    top: 0;
    margin: 0;
    padding: 0;
}

.main-visual img {
    width: 100%;
    height: auto;
    display: block;
}

#countdown-box {
    position: absolute;
    bottom: 30px;
    right: 30px;
    pointer-events: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    border: 1px solid #fff;
    padding: 15px;
    background-color: rgb(255 255 255 / 10%);
    aspect-ratio: 1 / 1;
}

#countdown-box .countdown-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

#countdown-box p {
    color: #FFF;
}

@media screen and (min-width: 992px) {
    #countdown-box p {
        font-size: clamp(1.6rem, 0.627rem + 0.98vw, 2rem);
    }

}

#countdown-box .countdown {
    line-height: 1;
    font-weight: 700;
}

@media screen and (min-width: 992px) {
    #countdown-box .countdown {
        font-size: clamp(10rem, 5.137rem + 4.902vw, 12rem);
    }

}

#countdown-box .days {
    line-height: 1;
    font-weight: 600;
    margin-bottom: 15px;
}

@media screen and (min-width: 992px) {
    #countdown-box .days {
        font-size: clamp(2.4rem, 0.455rem + 1.961vw, 3.2rem);
    }

}


/* 修正デザイン */
body {
    position: relative;
}

#header {
    /* position: absolute;
    top: 0;
    left: 0; */
    width: 100%;
    /* z-index: 1000; */
    padding: 0;
    position: relative;
    top: 0;
    left: 0;
}


/* 初期状態（相対配置、フロー内） */
#header {
    position: relative;
    top: 0;
    left: 0;
    width: 100%;
    /* padding: 0;
    z-index: 10; */
    /* background: transparent; */
    transition: all 0.4s ease;
}

.main-logo {
    /* width: 35%;
    height: 100vh;
    background-color: #11567B; */
}

.header-row {
    padding: 0;
    align-items: flex-start;
}

@media screen and (min-width: 992px) {
    .main-logo {
        /* padding: clamp(2rem, -2.326rem + 4.36vw, 5rem);
        padding-top: 15px; */
    }
}

.main-logo .header-title-box {
    position: relative;
    z-index: 30;
}

.main-logo .header-title-box a {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.main-logo .header-title-box .title {
    color: #FFF;
    display: block;
}

.main-logo .header-title-box .sub-title {
    color: #FFF;
    font-weight: 300;
    display: block;
    font-size: 14px;
    line-height: 1;
}

/* 背景画像 */
.main-visual {
    position: relative;
    z-index: 0;
}

.main-visual img {
    width: 100%;
    display: block;
}

.header-left-box {
    width: 35%;
    height: 100vh;
    position: relative;
}

@media screen and (max-width: 991px) {
    .header-left-box {
        width: 100%;
        display: block;
    }
}

.not-top .header-left-box {
    height: 100%;
}

.fixed .header-left-box {
    display: none;
}

/* ロゴエリア（背景色を透かして画像を見せる） */
.main-logo {
    display: flex;
    align-items: center;
    width: 35%;
    height: 80px;
    position: relative;
    padding: 0;
    padding-left: 30px;
}

.main-logo::after {
    content: '';
    display: block;
    width: 100%;
    height: 80px;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 22;
    /* background-color: #2a8ea3;
    mix-blend-mode: multiply; */
}

/* .main-logo::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background-image: url(../images/setouchi-map.svg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: right center;
    z-index: 11;
    pointer-events: none;
    opacity: 0.8;
} */

/* .main-logo::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background-color: #2a8ea3;
    mix-blend-mode: multiply;
    display: flex;
    align-items: center;
    z-index: 10;
} */

.visual-title-box-wrap::after {
    content: '';
    position: absolute;
    top: 80px;
    left: 0;
    width: 100%;
    height: calc(100vh - 80px);
    background-color: #2a8ea3;
    mix-blend-mode: multiply;
    display: flex;
    align-items: center;
    z-index: 10;
}

@media screen and (max-width: 991px) {
    .visual-title-box-wrap::after {
        display: none;
    }
}

/* テキスト部分はそのまま白で表示 */
.main-logo .header-title-box .title {
    color: #ffffff;
    line-height: 1.5;
    position: relative;
    z-index: 11;
    font-weight: 400;
    line-height: 1;
}

@media screen and (min-width: 992px) {
    .main-logo .header-title-box .title {
        font-size: clamp(1.8rem, 1.314rem + 0.49vw, 2rem)
    }
}

.main-logo .header-title-box .title span {
    display: block;
}

@media screen and (min-width: 992px) {
    .main-logo .header-title-box .title span {
        font-size: clamp(1.4rem, 0.914rem + 0.49vw, 1.6rem);
    }
}

.main-visual img {
    /* width: 100%;
    height: 100vh;
    object-fit: cover; */
}

.main-visual {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    /* overflow: hidden; */
}

@media screen and (max-width: 991px) {
    .main-visual {
        padding-top: 60px;
    }
}

.zoom-container {
    width: 100%;
    height: 100%;
    /* overflow: hidden; */
}

.zoom-container img {
    width: 100%;
    height: 700px;
    object-fit: cover;
    animation: zoomIn 10s ease-in-out forwards;
}

@keyframes zoomIn {
    0% {
        transform: scale(1);
    }

    100% {
        transform: scale(1.1);
    }
}

.parallax-wrapper {
    position: relative;
    overflow: hidden;
    height: 100vh;
    /* ビューポートの高さに合わせる */
}

.zoom-container img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    object-fit: cover;
    /* 必要に応じて追加 */
}

.visual-title-box-wrap {
    padding: 100px 30px;
    padding-bottom: 0;
    height: calc(100% - 80px);
}

@media screen and (max-width: 991px) {
    .visual-title-box-wrap {
        position: absolute;
        top: 0;
        padding: 0;
        padding-top: 90px;
        width: 100%;
    }
}

.visual-title-box {
    position: relative;
    z-index: 11;
    /* margin-top: 70px; */
    overflow: hidden;
}

.visual-title-box .head-title {
    color: #FFF;
    align-items: flex-start;
    font-weight: 600;
    opacity: 1;
}

@media screen and (min-width: 992px) {
    .visual-title-box .head-title {
        font-size: clamp(1.4rem, 0.427rem + 0.98vw, 1.8rem);
    }

}

.visual-title-box .title {
    opacity: 1;
    transform: translateY(0);
}

.visual-title-box .sub-title {
    opacity: 1;
    transform: translateY(0);
}

.main-logo .title, .main-logo .sub-title {
    color: #FFF;
    align-items: flex-start;
    display: inline-block;
}

.visual-title-box .title {
    line-height: 1;
    font-weight: 200;
    color: #FFF;
}

@media screen and (min-width: 992px) {
    .visual-title-box .title {
        font-size: clamp(8rem, -1.725rem + 9.804vw, 12rem);
    }
}

.visual-title-box .sub-title {
    line-height: 1;
    font-weight: 700;
    color: #FFF;
    align-items: flex-start;
    display: inline-block;
}

@media screen and (min-width: 992px) {
    .visual-title-box .sub-title {
        font-size: clamp(6.4rem, 1.537rem + 4.902vw, 8.4rem);
    }
}

.visual-title-box .sub-title span {
    line-height: 1;
    font-weight: 200;
    margin-top: -10px;
    display: block;
    text-align: right;
}

@media screen and (min-width: 992px) {
    .visual-title-box .sub-title span {
        font-size: clamp(2.8rem, -0.118rem + 2.941vw, 4rem);
    }
}

#header {
    display: flex;
    align-items: flex-start;
}

.not-top #header {
    height: 80px;
}

@media screen and (max-width: 991px) {
    #header {
        /* height: 60px; */
    }

    .not-top #header {
        height: 60px;
    }
}

#header .global-menu {
    position: relative;
    z-index: 1;
    padding: 20px 50px;
}

.header-box {
    width: 100%;
    background-color: #103653;
    position: relative;
    z-index: 999;
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 80px;
    position: fixed;
    top: 0;
    left: 0;
}

@media screen and (min-width: 992px) {
    .header-box .main-logo {
        /* display: none; */
    }

}

.header-box .news-box {
    width: 45%;
    height: 100%;
    padding: 0 20px;
    display: flex;
    align-items: center;
}

.header-box .news-box-title-wrap {
    padding-left: 15px;
    background-color: #07293b;
    height: 40px;
    display: flex;
    align-items: center;
    border-top-left-radius: 5px;
    border-bottom-left-radius: 5px;
}

.header-box .news-box-title {
    color: #FFF;
    white-space: nowrap;
    font-size: 12px;
    padding-right: 15px;
    margin-right: 15px;
    border-right: 1px solid #74838f;
}

#header .menu-box {
    /* width: 180px;
    height: 80px; */
    /* background-color: #103653; */
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 30px;
    position: relative;
    /* top: 0;
    right: 0; */
    z-index: 11111;
}

#header .menu-box img {
    width: 24px;
    height: 24px;
}

.news-ticker {
    width: 100%;
    height: 40px;
    overflow: hidden;
    background-color: #07293b;
    display: flex;
    align-items: center;
    color: white;
    font-size: 1.4rem;
    position: relative;
    padding: 5px;
    padding-left: 0;
    border-top-right-radius: 5px;
    border-bottom-right-radius: 5px;
}

.ticker-track {
    display: flex;
    transition: transform 0.8s ease-in-out;
}

.ticker-item {
    flex: 0 0 100%;
    padding-left: 0;
    box-sizing: border-box;
    white-space: nowrap;
}


.ticker-list li a {
    color: #fff;
}

.news-ticker:hover .ticker-track {
    animation-play-state: paused;
}

.ticker-item time {
    color: #94c9f1;
    margin-right: 15px;
    font-size: 12px;
}

.ticker-item time i {
    margin-right: 5px;
}

.ticker-item p {
    color: #FFF;
    font-size: 14px;
}

/* .c-hamburger span {
    height: 3px;
    background: #ed0000;
} */

/* nav-icon */
.nav-icon {
    width: 30px;
    height: 30px;
    position: relative;
    transition: .1s;
    margin-left: 15px;
    cursor: pointer;
    display: inline-block;
}

.nav-icon span {
    width: 5px;
    height: 5px;
    background-color: #fff;
    display: block;
    border-radius: 0;
    position: absolute;

}

.nav-icon:hover span {
    transform: scale(1.2);
    transition: 350ms cubic-bezier(.8, .5, .2, 1.4);
}

.nav-icon span:nth-child(1) {
    left: 0;
    top: 0;
}

.nav-icon span:nth-child(2) {
    left: 12px;
    top: 0;
}

.nav-icon span:nth-child(3) {
    right: 0;
    top: 0;
}

.nav-icon span:nth-child(4) {
    left: 0;
    top: 12px;
}

.nav-icon span:nth-child(5) {
    position: absolute;
    left: 12px;
    top: 12px;
}

.nav-icon span:nth-child(6) {
    right: 0px;
    top: 12px;
}

.nav-icon span:nth-child(7) {
    left: 0px;
    bottom: 0px;
}

.nav-icon span:nth-child(8) {
    position: absolute;
    left: 12px;
    bottom: 0px;
}

.nav-icon span:nth-child(9) {
    right: 0px;
    bottom: 0px;
}

.nav-icon.open {
    /* transform: rotate(180deg); */
    cursor: pointer;
    transition: .2s cubic-bezier(.8, .5, .2, 1.4);
}

.nav-icon.open span {
    border-radius: 50%;
    transition-delay: 200ms;
    transition: .5s cubic-bezier(.8, .5, .2, 1.4);
}

.nav-icon.open span:nth-child(2) {
    left: 6px;
    top: 6px;
}

.nav-icon.open span:nth-child(4) {
    left: 6px;
    top: 18px;
}

.nav-icon.open span:nth-child(6) {
    right: 6px;
    top: 6px;
}

.nav-icon.open span:nth-child(8) {
    left: 18px;
    bottom: 6px;
}

.nav-icon span:nth-child(1) {
    left: 0;
    top: 0;
}

.nav-icon span:nth-child(9) {
    display: none;
}

.nav-icon.open span:nth-child(9) {
    display: block;
}

.section-box.welcome {
    /* background-color: #0066B1; */
    position: relative;
    z-index: 12;
}

@media screen and (max-width: 767px) {
    .section-box.welcome {
        padding-bottom: 20px;
    }

}

.welcome .contents-title p {
    color: #fff;
    font-weight: 400;
    margin-bottom: 20px;
}

@media screen and (min-width: 992px) {
    .welcome .contents-title p {
        font-size: clamp(3rem, 1.541rem + 1.471vw, 3.6rem);
    }

}

@media screen and (max-width: 991px) {
    .welcome .contents-title p {
        font-size: clamp(2rem, 1.857rem + 0.447vw, 2.2rem);
    }

}

.welcome .contents-box-inner {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 50px;
}

@media screen and (max-width: 991px) {
    .welcome .contents-box-inner {
        flex-direction: column;
    }

}

.welcome .contents-box-inner .box {
    flex: 1;
}

.welcome .contents-box-inner .box.left .copy {
    font-weight: 400;
    color: #fff;
    margin-bottom: 30px;
}

@media screen and (min-width: 992px) {
    .welcome .contents-box-inner .box.left .copy {
        font-size: clamp(1.8rem, -0.145rem + 1.961vw, 2.6rem);
    }

}

@media screen and (max-width: 991px) {
    .welcome .contents-box-inner .box.left .copy {
        font-size: clamp(1.7rem, 1.628rem + 0.224vw, 1.8rem);
    }

}

.welcome .contents-box-inner .box.left .text {
    color: #fff;
    font-weight: 300;
}

@media screen and (min-width: 992px) {
    .welcome .contents-box-inner .box.left .text {
        font-size: clamp(1.4rem, 0.914rem + 0.49vw, 1.6rem);
    }

}

.parallax {
    position: relative;
    overflow: hidden;
}

.parallax img {
    width: 100%;
    height: auto;
    transform: translateY(0);
    transition: transform 0.2s ease-out;
}

#gotsugotsu-canvas {
    /* position: fixed; */
    position: absolute;
    top: 0;
    left: 0;
    width: 100vw;
    /* height: 100vh; */
    height: 100%;
    background: #0066b1;
    z-index: -1;
}


.contents-box-inner {
    display: flex;
    align-items: stretch;
}

.box.right {
    display: flex;
    align-items: stretch;
}

.box.right img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    /* 画像をコンテナに合わせてトリミング */
}

.box.right {
    overflow: hidden;
    display: block;
    line-height: 0;
    position: relative;
}

.box.right img {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    object-fit: cover;
}

.box.right .splide__slide::before {
    content: "";
    display: block;
    padding-top: 100%;
}

.box.right .splide__slide::after {
    content: "";
    position: absolute;
    inset: 0px;
    transition: background-color 0.3s ease 0s;
}

.section-box.artworks {
    background-color: #FFF
}

@media screen and (max-width: 991px) {
    .section-title-box {
        margin-bottom: 30px;
        justify-content: center;
    }

}

.section-title.en {
    color: #0066B1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    margin-bottom: 30px;
}

@media screen and (max-width: 991px) {
    .section-title.en {
        margin-bottom: 15px;
        align-items: center;
    }

}

.section-title.en .big {
    font-weight: 700;
    line-height: 1;
    text-transform: uppercase;
    position: relative;
    top: 3px;
}

@media screen and (min-width: 992px) {
    .section-title.en .big {
        font-size: clamp(4.8rem, 1.882rem + 2.941vw, 6rem);
    }

}

@media screen and (max-width: 991px) {
    .section-title.en .big {
        font-size: 30px;
    }

}

.section-title.en .small {
    font-weight: 100;
    line-height: 1;
}

@media screen and (min-width: 992px) {
    .section-title.en .small {
        font-size: clamp(3.2rem, 1.255rem + 1.961vw, 4rem);
    }

}

@media screen and (max-width: 991px) {
    .section-title.en .small {
        font-size: 24px;
        font-weight: 300;
        margin-right: 10px !important;
    }

}

.section-title-box-inner {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

@media screen and (max-width: 991px) {
    .section-title-box-inner {
        align-items: center;
    }

}

.section-title.jp {
    font-size: 26px;
    font-weight: 500;
    line-height: 1;
    color: #27597e;
    margin-bottom: 0;
}

@media screen and (min-width: 992px) {
    .section-title.jp {
        font-size: clamp(2.2rem, 1.227rem + 0.98vw, 2.6rem);
    }

}

.section-box.artworks .description {
    margin-bottom: 50px;
}

@media screen and (min-width: 992px) {
    .section-box.artworks .description .text {
        font-size: clamp(1.4rem, 0.914rem + 0.49vw, 1.6rem);
    }

}

.section-box.artworks .number {
    font-size: 16px;
    font-weight: 700;
    color: #8AB9DB;
}

@media screen and (min-width: 992px) {
    .section-box.artworks .number {
        font-size: clamp(1.2rem, 0.227rem + 0.98vw, 1.6rem);
    }

}

.section-box.artworks .works-title {
    font-weight: 600;
    color: #27597e;
}

@media screen and (min-width: 992px) {
    .section-box.artworks .works-title {
        font-size: clamp(1.8rem, 0.827rem + 0.98vw, 2.2rem);
    }

}

.section-box.artworks .works .artist {
    font-weight: 600;
    color: #27597e;
}

@media screen and (min-width: 992px) {
    .section-box.artworks .works .artist {
        font-size: clamp(1.5rem, 0.771rem + 0.735vw, 1.8rem);
    }

}

.section-box.artworks .works .location {
    font-weight: 600;
    color: #0068B5;
}

@media screen and (min-width: 992px) {
    .section-box.artworks .works .location {
        font-size: clamp(1.5rem, 0.771rem + 0.735vw, 1.8rem);
    }

}

.section-box.artworks .works .works-title-box {
    margin-bottom: 30px;
}

.section-box.artworks .works .works-box .contents {
    margin-bottom: 30px;
}

.section-box.artworks .works .text-box .text {
    margin-bottom: 30px;
}

@media screen and (min-width: 992px) {
    .section-box.artworks .works .text-box .text {
        font-size: clamp(1.4rem, 0.914rem + 0.49vw, 1.6rem);
    }

}

.section-box.artworks .profile {
    display: flex;
    align-items: flex-start;
    gap: 30px;
    background-color: #E9F2FC;
    padding: 20px;
}

@media screen and (max-width: 991px) {
    .section-box.artworks .profile {
        flex-direction: column;
    }

}

.section-box.artworks .profile .img-box {
    flex: 2;
}

.section-box.artworks .profile .profile-box {
    flex: 8;
}

.profile-title-box {
    border-bottom: 1px solid #C7C7C7;
    margin-bottom: 10px;
    padding-bottom: 10px;
}

.section-box.artworks .profile .profile-text-box .info {
    color: #103652;
    font-size: 14px;
    font-weight: 500;
}

@media screen and (min-width: 992px) {
    .section-box.artworks .profile .profile-text-box .info {
        font-size: clamp(1.2rem, 0.471rem + 0.735vw, 1.5rem);
    }

}

@media screen and (min-width: 992px) {
    .section-box.artworks .profile .profile-text-box .text {
        font-size: clamp(1.2rem, 0.714rem + 0.49vw, 1.4rem);
    }

}

.section-box.artworks .profile .artist {
    font-weight: 600;
    color: #27597e;
}

@media screen and (min-width: 992px) {
    .section-box.artworks .profile .artist {
        font-size: clamp(1.4rem, 0.671rem + 0.735vw, 1.7rem);
    }

}

.section-box.artworks .profile .country {
    font-size: 13px;
    color: #0068B5;
}

@media screen and (min-width: 992px) {
    .section-box.artworks .profile .country {
        font-size: clamp(1.2rem, 0.471rem + 0.735vw, 1.5rem);
    }

}

.section-box.recommend {
    background-color: #FFF;
}

.section-box.recommend .section-title.en {
    flex-direction: row;
    align-items: flex-end;
}

.section-box.recommend .section-title.en .small {
    margin-right: 15px;
}

.section-box.news {
    background-color: #FFF;
}

.section-box.news .section-title.en {
    flex-direction: row;
    align-items: flex-end;
}

.section-box.news .section-title-box {
    display: flex;
    justify-content: space-between;
    margin-bottom: 50px;
    align-items: flex-end;
    width: 100%;
}

@media screen and (max-width: 991px) {
    .section-box.news .section-title-box {
        flex-direction: column;
        align-items: center;
        margin-bottom: 30px;
    }

}

.section-box.news .section-title.en .small {
    margin-right: 15px;
}

.section-box.news .news-list-content {
    border-top: 2px solid #0066B1;
    border-bottom: 2px solid #0066B1;
    /* padding-top: 30px;
    padding-bottom: 30px; */
}

@media screen and (max-width: 991px) {
    .section-box.news .news-list-content {
        display: flex;
        flex-wrap: wrap;
    }

}

.section-box.news .news-list {
    border-bottom: 1px solid #71ADD9;
    /* margin-bottom: 30px;
    padding-bottom: 30px; */
}

@media screen and (max-width: 991px) {
    .section-box.news .news-list {
        width: 100%;
        padding: 0;
        margin-bottom: 0;
        /* border-bottom: none; */
    }

}

.section-box.news .news-list:last-of-type {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.section-box.news .news-list a {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 20px;
    transition: .3s;
    padding: 30px 15px;
}

@media screen and (min-width: 992px) {
    .section-box.news .news-list a:hover {
        background-color: #e3f3ff;
    }
}

@media screen and (max-width: 991px) {
    .section-box.news .news-list a {
        /* flex-direction: column;
        align-items: flex-start;
        justify-content: flex-start; */
        gap: 15px;
    }

}

.section-box.news .news-list .img-box {
    /* flex: 1.2; */
    width: 15%
}

.section-box.news .news-list .img-box img {
    display: block;
}

.section-box.news .news-list .text-box {
    /* flex: 8.8; */
    line-height: 1;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: space-evenly;
    gap: 20px;
}

@media screen and (max-width: 991px) {
    .section-box.news .news-list .text-box {
        display: block;
    }

}

.section-box.news .news-list time {
    color: #429DE2;
}

@media screen and (min-width: 992px) {
    .section-box.news .news-list time {
        font-size: clamp(1.2rem, 0.714rem + 0.49vw, 1.4rem);
    }

}

@media screen and (max-width: 991px) {
    .section-box.news .news-list time {
        font-size: 14px;
    }

}

.section-box.news .news-list .title {
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: #27597e;
    transition: .3s;
}

@media screen and (min-width: 992px) {
    .section-box.news .news-list .title {
        font-size: clamp(1.5rem, 0.771rem + 0.735vw, 1.8rem);
    }

}

@media screen and (max-width: 991px) {
    .section-box.news .news-list .title {
        white-space: unset;
        line-height: 1.8;
        font-size: 16px;
        margin-top: 15px;
    }

}

@media screen and (min-width: 992px) {
    .section-box.news .news-list a:hover .title {
        color: #429de2;
    }
}

.section-box.news .news-list a::after .title {
    position: absolute;
    left: 0;
    content: '';
    width: 100%;
    height: 2px;
    background: #000000;
    bottom: -1px;
    transform: scale(0, 1);
    transform-origin: right top;
    /*変形（アンダーラインの伸長）の原点がaタグ（各メニュー）の右端*/
    transition: transform 0.3s;
    /*変形の時間*/
}

.section-box.news .news-list a:hover::after .title {
    transform: scale(1, 1);
    /*ホバー後、x軸方向に1（相対値）伸長*/
    transform-origin: left top;
    /*左から右に向かう*/
}

.section-box.news .news-list .excerpt {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1;
    transition: .3s;
}

@media screen and (min-width: 992px) {
    .section-box.news .news-list .excerpt {
        font-size: clamp(1.3rem, 1.057rem + 0.245vw, 1.4rem);
    }

}

@media screen and (max-width: 991px) {
    .section-box.news .news-list .excerpt {
        display: none;
    }

}

.section-box.news .news-list a:hover .excerpt {
    color: #429de2;
}

.section-box.news .news-list .img-box figure {
    position: relative;
    overflow: hidden;
    /* aspect-ratio: 10 / 7; */
    aspect-ratio: 16 / 9;
    width: 100%;
}

.section-box.news .news-list .img-box img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .3s ease;
}

@media screen and (min-width: 992px) {
    .section-box.news .news-list a:hover .img-box img {
        transform: scale(1.1);
    }
}

.section-box.access {
    background-color: #0066B1;
}

.section-box.access .section-title.en .big {
    color: #fff;
}

.section-box.access .section-title.en .small {
    color: #fff;
}

.section-box.access .section-title.jp {
    color: #FFF;
}

.section-box.access .section-title-box .link-box a {
    background-color: #2488d4;
}

.section-box.access .section-title-box .link-box a:hover {
    background-color: #d2e3ef;
}

.section-box.access .section-title-box .link-box a .title {
    color: #FFF;
}

.section-box.access .section-title-box .link-box a:hover .title {
    color: #0066B1;
}

.section-box.access .section-title-box .link-box a:hover .arrow i {
    color: #FFF;
    background-color: #0066B1;
}

.section-box.access .section-title-box .link-box a .arrow i {
    color: #0066B1;
    background-color: #FFF;
}

.section-box.faq {
    background-color: #FFF;
}

.section-box.faq .faq-list {
    border-bottom: 1px solid #71ADD9;
    padding-top: 30px;
    padding-bottom: 30px;
}

.section-box.faq .faq-list-content {
    border-top: 2px solid #0066B1;
    border-bottom: 2px solid #0066B1;
}

.section-box.faq .faq-content {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 30px;
    padding: 0 15px;
}

.section-box.faq .faq-content .q-number-box {
    flex: 1;
}

.section-box.faq .faq-content .text-box {
    flex: 9;
}

.section-box.faq .faq-content .q-number-box p {
    color: #0068B5;
    line-height: 1;
}

@media screen and (min-width: 992px) {
    .section-box.faq .faq-content .q-number-box p {
        font-size: clamp(2.4rem, 0.941rem + 1.471vw, 3rem);
    }

}

.section-box.faq .faq-content .text-box .title {
    font-size: 20px;
    font-weight: 500;
    margin-bottom: 20px;
    line-height: 1;
}

.section-box.faq .faq-content .text-box .text {
    font-size: 14px;
    margin-bottom: 0;
}

.section-box.faq .faq-content .text-box img {
    border: 1px solid #71ADD9;
    margin-top: 30px;
}

.section-box.faq .faq-content .text-box .text a {
    color: #0068B5;
    text-decoration: underline;
    display: block;
}

footer .link-box-wrap {
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 30px;
}

@media screen and (max-width: 991px) {
    footer .link-box-wrap {
        flex-direction: column;
    }

}

footer .link-box-wrap .link-box {
    width: 300px;
    text-align: center;
}

footer .link-box-wrap .link-box a {
    display: block;
    font-size: 14px;
    padding: 30px 0;
    letter-spacing: 0.1rem;
}

@media screen and (max-width: 991px) {
    footer .link-box-wrap .link-box a {
        font-size: 12px;
    }
}

footer .link-box-wrap .left a {
    background-color: #0068B5;
    color: #fff;
    transition: 0.3s;
}

@media screen and (min-width: 992px) {
    footer .link-box-wrap .left a:hover {
        background-color: #0b4978;
    }
}

footer .link-box-wrap .right a {
    background-color: #429DE2;
    color: #fff;
    transition: 0.3s;
}

@media screen and (min-width: 992px) {
    footer .link-box-wrap .right a:hover {
        background-color: #2f77ad;
    }
}

.transport .heading-title {
    text-align: left;
    margin-bottom: 15px;
    color: #FFF;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    line-height: 1;
}

@media screen and (min-width: 992px) {
    .transport .heading-title {
        font-size: clamp(1.6rem, 1.114rem + 0.49vw, 1.8rem);
    }

}

.transport .heading-title span {
    margin-top: -4px;
}

.transport .heading-title::before {
    font-size: 18px;
    margin-right: 10px;
    color: #FFF;
    background-color: #0366b1;
    border-radius: 50%;
    width: 37px;
    height: 37px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.transport.train .heading-title::before {
    content: '\f238';
    font-family: 'font awesome 6 Pro';
}

.transport.car .heading-title::before {
    content: '\f1b9';
    font-family: 'font awesome 6 Pro';
}

.transport ul {
    margin: 0 auto;
    padding: 0;
    display: flex;
    display: -webkit-flex;
    align-items: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    margin-top: 30px;
}

.transport ul li {
    position: relative;
    display: table;
    width: 20%;
    margin: 0 0 25px;
}

@media screen and (max-width: 991px) {
    .transport ul li {
        width: 100%;
        margin: 0 0 20px;
    }

}

.transport ul li:first-child, .transport ul li:last-child {
    color: #0468b7;
    /* border: #0468b7 2px solid; */
    background-color: #FFF;
    width: 20%;
}

@media screen and (max-width: 991px) {
    .transport ul li:first-child, .transport ul li:last-child {
        width: 100%;
        height: auto;
    }

}

.transport ul li:nth-child(odd) {
    margin: 0 0 20px;
    padding: 0;
    /* min-height: 50px; */
    font-size: 16px;
    /* border: #0468b7 2px solid; */
    margin-bottom: 0;
    border-radius: 0 0 5px 5px;
    background-color: #FFF;
    position: relative;
    z-index: 2;
}

.transport ul li:nth-child(even) {
    width: 60%;
    margin-bottom: 0;
}

.transport ul li p {
    text-align: center;
    margin-bottom: 0;
}

.transport ul li:nth-child(odd) p {
    display: table-cell;
    vertical-align: middle;
    padding: 10px 0;
    letter-spacing: 0.5rem;
    color: #0366b1;
    font-weight: 500;
}

@media screen and (min-width: 992px) {
    .transport ul li:nth-child(odd) p {
        font-size: clamp(1.3rem, 1.057rem + 0.245vw, 1.4rem);
    }

}

.transport ul li:nth-child(even) {
    width: 59.5%;
    margin-right: 0.5%;
    margin-bottom: 0;
}

.transport.train ul li:nth-child(even) {
    width: 60%;
    margin-right: 0;
    margin-bottom: 0;
    top: -10px;
}

@media screen and (max-width: 991px) {
    .transport.train ul li:nth-child(even) {
        width: 100%;
        padding: 0;
        width: 100%;
        height: 150px;
        margin: 0 auto;
        display: flex;
        align-items: center;
        justify-content: center;
        position: relative;
        z-index: 1;
    }

}

.transport ul li:nth-child(even) p {
    margin: 0;
    padding: 0;
    letter-spacing: 0.1rem;
    color: #ffffff;
    width: auto;
    font-weight: 300;
}

@media screen and (min-width: 992px) {
    .transport ul li:nth-child(even) p {
        font-size: clamp(1.2rem, 0.957rem + 0.245vw, 1.3rem);
    }

}

@media screen and (max-width: 991px) {
    .transport ul li:nth-child(even) p {
        font-size: 12px;
        flex: 4;
    }

}

.transport ul li figure {
    position: relative;
    height: 2px;
    margin: 5px 0;
    background-color: #FFF;
}

@media screen and (max-width: 991px) {
    .transport.triple ul li figure {
        transform: rotate(90deg);
        position: relative;
        height: 3px;
        margin: 0;
        width: 100px;
    }

}

.transport.train ul li figure {
    position: relative;
    margin: 5px 0;
    height: 4px;
    width: 100%;
    background-image: repeating-linear-gradient(to right, #0366b1 0 10px, white 10px 20px);
}

@media screen and (max-width: 991px) {
    .transport.train ul li figure {
        position: relative;
        margin: 5px 0;
        width: 4px;
        height: 100%;
        background-image: repeating-linear-gradient(to bottom, #0366b1 0 10px, white 10px 20px);
    }

}

.transport.car ul li figure:after {
    content: "";
    display: inline-block;
    width: 10px;
    height: 10px;
    border-top: 2px solid #ffffff;
    border-right: 2px solid #ffffff;
    transform: rotate(45deg);
    margin-left: 5px;
    position: absolute;
    top: -4px;
    right: 1px;
}

.transport-wrap {
    position: relative;
    overflow: hidden;
    background-color: #2488d4;
    padding: 50px;
    border-radius: 15px;
}

@media screen and (max-width: 991px) {
    .transport-wrap {
        padding: 15px;
    }

}

.transport {
    margin-bottom: 30px;
}

.transport:last-of-type {
    margin-bottom: 0;
}

.transport.triple ul li:nth-child(odd) {
    width: 20%;
}

@media screen and (max-width: 991px) {
    .transport.triple ul li:nth-child(odd) {
        width: 100%;
    }

}

.transport.triple ul li:nth-child(even) {
    width: 19.5%;
    margin-right: 0.5%;
}

@media screen and (max-width: 991px) {
    .transport.triple ul li:nth-child(even) {
        height: 100px;
        width: 100%;
        margin: 0 auto;
        display: flex;
        align-items: center;
        justify-content: space-evenly;
    }

}

.transport ul li:first-of-type::before {
    font-size: 10px;
    position: absolute;
    top: -20px;
    left: 0;
    height: 20px;
    padding: 5px;
    content: 'START';
    color: #fff;
    border-radius: 5px 5px 0 0;
    background: #0366b1;
    width: 100%;
    text-align: center;
    line-height: 1;
}

.transport ul li:last-of-type::before {
    font-size: 10px;
    position: absolute;
    top: -20px;
    left: 0;
    height: 20px;
    padding: 5px;
    content: 'GOAL';
    color: #fff;
    border-radius: 5px 5px 0 0;
    background: #0366b1;
    width: 100%;
    text-align: center;
    line-height: 1;
}

.transport-title p {
    position: relative;
    color: #FFF;
    margin-bottom: 30px;
    font-weight: 500;
    border: 1px solid #FFF;
    line-height: 1;
    padding: 15px;
    background-color: rgb(29 111 176 / 30%);
}

@media screen and (min-width: 992px) {
    .transport-title p {
        font-size: clamp(2rem, 1.514rem + 0.49vw, 2.2rem);
    }

}

.transport-box {
    margin-bottom: 50px;
}

.transport-box:last-of-type {
    margin-bottom: 0;
}

.transport-box-inner {
    padding: 0 15px;
}

@media screen and (max-width: 991px) {
    .transport-box-inner {
        padding: 0 5px;
    }

}

.transport.car ul li:nth-of-type(3) {
    position: relative;
}

@media screen and (max-width: 991px) {
    .transport.car ul li:nth-of-type(3) {
        margin-top: 25px;
    }

    .transport.car ul li:nth-of-type(5) {
        margin-top: 25px;
    }

}

.transport.car ul li:nth-of-type(3)::before {
    font-size: 10px;
    position: absolute;
    top: -20px;
    left: 0;
    height: 20px;
    padding: 5px;
    content: 'EXIT';
    color: #fff;
    border-radius: 5px 5px 0 0;
    background: #0366b1;
    width: 100%;
    text-align: center;
    line-height: 1;
}

.section-box.access .section-title.en {
    flex-direction: row;
    align-items: flex-end;
}

.section-box.access .section-title.en .small {
    margin-right: 15px;
}

.section-box.recommend {
    padding: 0;
    padding-bottom: 100px;
}

@media screen and (max-width: 991px) {
    .section-box.recommend {
        padding-top: 0;
        padding-bottom: 50px;
    }

}

.section-box.cycling {
    background-color: #FFF;
}

.section-box.cycling .header-contents {
    display: flex;
    align-items: flex-start;
    gap: 30px;
    background-color: #E9F2FC;
    padding: 20px;
    margin-bottom: 50px;
    position: relative;
}

@media screen and (max-width: 991px) {
    .section-box.cycling .header-contents {
        flex-direction: column;
    }

}

.section-box.cycling .header-contents .img-box {
    flex: 2;
}

.section-box.cycling .header-contents .description-box {
    flex: 8;
}

.section-box.cycling .header-contents .img-box figure {
    position: relative;
    overflow: hidden;
    aspect-ratio: 1 / 1;
    width: 100%;
}

.section-box.cycling .header-contents .img-box figure::before {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
}

.section-box.cycling .header-contents .img-box figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.description-title-box .title {
    line-height: 2;
    font-weight: 500;
}

@media screen and (min-width: 992px) {
    .description-title-box .title {
        font-size: clamp(1.8rem, 1.314rem + 0.49vw, 2rem);
    }
}

.description-title-box .en {
    font-weight: 500;
    color: #0068B5;
    line-height: 1;
}

@media screen and (min-width: 992px) {
    .description-title-box .en {
        font-size: clamp(1.2rem, 0.471rem + 0.735vw, 1.5rem);
    }

}

@media screen and (min-width: 992px) {
    .description-text-box .text {
        font-size: clamp(1.2rem, 0.714rem + 0.49vw, 1.4rem);
    }
}

.cycling-time p {
    font-size: 14px;
    background-color: #227EA5;
    color: #FFF;
    padding: 5px 10px;
    position: absolute;
    top: 0;
    right: 0;
    font-weight: 300;
}

@media screen and (min-width: 992px) {
    .cycling-time p {
        font-size: clamp(1.2rem, 0.714rem + 0.49vw, 1.4rem);
    }

}

@media screen and (max-width: 991px) {
    .cycling-time p {
        top: auto;
        bottom: 0;
    }

}

.cycling-time p::before {
    content: '\e29e';
    color: #FFF;
    font-size: 14px;
    font-family: 'font awesome 6 Pro';
    margin-right: 5px;
}

/* タイムライン */
.timeline {
    font-size: 14px;
    padding: 0;
}


.timeline>li {
    position: relative;
    margin: 0 0 0 2em;
    padding: 0 0 1em 2em;
}

.timeline .start {
    margin: 0;
    padding: 0;
    padding-bottom: 50px;
}

.timeline>li:before, .timeline>li:after {
    content: "";
    display: block;
    position: absolute;
}

.timeline>li:before {
    top: 0.1em;
    left: 0;
    width: 2px;
    height: 100%;
    background: #0068B5;
}

.timeline .start:before {
    position: absolute;
    left: 2em;
    top: 52px;
}

@media screen and (max-width: 991px) {
    .timeline .start:before {
        left: 15px;
    }

}

.timeline .header {
    line-height: 1;
    letter-spacing: 1px;
    margin-bottom: 0.5em;
}

.timeline .start .header {
    display: block;
    margin: 0;
    padding: 15px;
    background: #0068B5;
    border-radius: 0;
    border: 2px solid #0068B5;
}

.timeline .start .header p {
    display: inline-block;
    line-height: 1;
    font-size: 18px;
    font-weight: 700;
    color: #FFF;
    letter-spacing: 0.2rem;
}

.timeline .start .header p.point::before, .timeline .goal .header p.point::before {
    font-family: 'Font Awesome 6 pro';
    font-weight: 900;
    width: 13px;
    display: inline-block;
    text-align: center;
    margin-right: 15px;
    content: '\f3c5';
    color: #FFF;
}

.timeline .start .header p.point-info, .timeline .goal .header p.point-info {
    margin-left: 20px;
}

.timeline li {
    list-style: none;
}

.timeline .spot {
    padding-bottom: 50px;
}

@media screen and (max-width: 991px) {
    .timeline .spot {
        margin-left: 15px;
        padding-left: 20px;
    }

}

.timeline>li:not(:first-child) {
    padding-top: 1em;
}

.timeline>li:before, .timeline>li:after {
    content: "";
    display: block;
    position: absolute;
}

.timeline>li:before {
    top: 0.1em;
    left: 0;
    width: 2px;
    height: 100%;
    background: #0068B5;
}

.timeline>li:not(:first-child):before {
    top: 0;
}

.timeline .title-wrap {
    display: flex;
    align-items: center;
    margin-bottom: 5px;
}

.timeline .spot .header {
    /* border: 2px solid #0468b7; */
    background-color: #0068B5;
    display: inline-block;
    /* padding: 10px 13px; */
    position: relative;
    left: -36px;
    margin: 0;
    width: 10px;
    height: 10px;
    border-radius: 50%;
}

@media screen and (max-width: 991px) {
    .timeline .spot .header {
        left: -24px;
    }

}

.timeline .spot .header p {
    line-height: 1;
    color: #ffffff;
    font-size: 26px;
    font-weight: 700;
}

/* .timeline li:nth-of-type(2) .header p::before {
    content: 'A';
}

.timeline li:nth-of-type(4) .header p::before {
    content: 'B';
}

.timeline li:nth-of-type(6) .header p::before {
    content: 'C';
}

.timeline li:nth-of-type(8) .header p::before {
    content: 'D';
}

.timeline li:nth-of-type(10) .header p::before {
    content: 'E';
}

.timeline li:nth-of-type(12) .header p::before {
    content: 'F';
}

.timeline li:nth-of-type(14) .header p::before {
    content: 'G';
} */

.timeline .spot .title {
    position: relative;
    left: -10px;
    padding: 0;
}

.timeline .spot .title p {
    line-height: 1.4;
    font-weight: 500;
    color: #0068B5;
}

@media screen and (min-width: 992px) {
    .timeline .spot .title p {
        font-size: clamp(2rem, 1.514rem + 0.49vw, 2.2rem);
    }

}

@media screen and (max-width: 991px) {
    .timeline .spot .title p {
        font-size: 20px;
    }

}

.timeline .sub-title-wrap {
    margin-bottom: 15px;
}

.timeline .sub-title-wrap .sub-title {
    font-weight: 500;
    line-height: 1.4;
    color: #103652;
}

@media screen and (min-width: 992px) {
    .timeline .sub-title-wrap .sub-title {
        font-size: clamp(2rem, 1.027rem + 0.98vw, 2.4rem);
    }

}

@media screen and (max-width: 991px) {
    .timeline .sub-title-wrap .sub-title {
        font-size: 22px;
    }

}

.timeline .contents-wrap {
    display: flex;
    align-items: stretch;
    gap: 30px;
}

@media screen and (max-width: 991px) {
    .timeline .contents-wrap {
        flex-direction: column;
    }

}

/* .timeline .contents-wrap .left-box {
    width: 55%;
} */

.timeline .contents-wrap .left-box img {
    /* margin-bottom: 15px; */
}

.timeline .contents-wrap .left-box p {
    text-align: justify;
    color: #393232;
    font-size: 12px;
}

/* .timeline .contents-wrap .right-box {
    width: 45%;
} */

.timeline .contents-wrap .table-box .basic {
    padding: 10px;
    background-color: #0068B5;
    color: #fff;
    letter-spacing: 0.3rem;
    /* font-weight: bold; */
    font-size: 13px;
    text-align: center;
    line-height: 1;
}

.single-section table {
    border-collapse: collapse;
    width: 100%;
    font-size: 14px;
}

tbody, td, tfoot, th, thead, tr {
    border-color: inherit;
    border-style: solid;
    border-width: 0;
}

.timeline .contents-wrap .table-box th, .timeline .contents-wrap .table-box td {
    padding: 10px;
    border: 1px solid #e9e9e9;
    text-align: left;
    box-sizing: border-box;
}

.timeline .contents-wrap .table-box th {
    color: #27597e;
    border-left: none;
    border-right: none;
    font-size: 13px;
    white-space: nowrap;
    font-weight: 500;
    width: 25%;
}

.timeline .contents-wrap .table-box th:first-of-type {
    border-top: none;
}

.timeline .contents-wrap .table-box td {
    color: #27597e;
    border-left: none;
    border-right: none;
    font-size: 13px;
    width: 75%;
}

.timeline .contents-wrap .table-box td:first-of-type {
    border-top: none;
}

.timeline .contents-wrap .table-box td a {
    color: #429de2;
    text-decoration: underline;
    transition: .3s;
}

.timeline .contents-wrap .table-box td a:hover {
    color: #276da2;
    text-decoration: none;
}

/* .timeline .contents-wrap .table-box a {
    padding: 10px;
    background-color: #fff;
    border: 2px solid #0068B5;
    color: #0068B5;
    display: block;
    font-size: 16px;
    line-height: 1.8;
    border-radius: 5px;
    text-align: center;
    transition: .3s;
}

.timeline .contents-wrap .table-box a p {
    color: #0068B5;
    letter-spacing: 0.3rem;
    display: inline-block;
    font-size: 16px;
    line-height: 1;
    border-radius: 5px;
    text-align: center;
}

.timeline .contents-wrap .table-box a i {
    font-family: 'Font Awesome 6 pro';
    font-weight: 900;
    font-style: normal;
    position: relative;
    right: 0;
    margin-left: 8px;
    font-size: 16px;
    color: #0068B5;
} */

.fa-angle-right:before {
    font-family: 'Font Awesome 6 pro';
    font-weight: 900;
    font-style: normal;
    content: "\f105";
}

.timeline .time {
    padding-bottom: 50px;
}

.timeline>li:not(:first-child) {
    padding-top: 1em;
}

.timeline>li:not(:first-child):before {
    top: 0;
}

.timeline .time .header {
    border: 2px solid #0068B5;
    background-color: #fff;
    display: inline-block;
    padding: 10px;
    position: relative;
    left: -45px;
    margin-bottom: 0;
}

.timeline .time .header p {
    font-size: 14px;
    color: #0068B5;
    line-height: 1;
}

.timeline .goal {
    margin: 0;
    padding: 0;
    padding-top: 50px;
}

.timeline .goal:before {
    position: absolute;
    left: 2em;
    top: -52px !important;
}

@media screen and (max-width: 991px) {
    .timeline .goal:before {
        left: 15px;
    }

}

.timeline .goal .header {
    display: block;
    margin: 0;
    padding: 15px;
    background: #0068B5;
    border-radius: 0;
    border: 2px solid #0068B5;
}

.timeline .goal .header p {
    font-size: 18px;
    font-weight: 700;
    color: #FFF;
    letter-spacing: 0.2rem;
    line-height: 1;
    display: inline-block;
}

.timeline .contents-wrap .left-box,
.timeline .contents-wrap .right-box {
    flex: 1;
}

.timeline .contents-wrap .left-box {
    overflow: hidden;
}

.timeline .contents-wrap .left-box figure {
    margin: 0;
}

@media screen and (min-width: 1200px) {
    .timeline .contents-wrap .left-box figure {
        aspect-ratio: 9 / 8;
    }

}

@media screen and (min-width: 992px) and (max-width: 1199px) {
    .timeline .contents-wrap .left-box figure {
        aspect-ratio: 9 / 8;
    }

}

.timeline .contents-wrap .left-box img {
    height: 100%;
    width: 100%;
    object-fit: cover;
    display: block;
}

.timeline .contents-wrap .right-box .text {
    margin-bottom: 15px;
}

@media screen and (min-width: 992px) {
    .timeline .contents-wrap .right-box .text {
        font-size: clamp(1.3rem, 1.057rem + 0.245vw, 1.4rem);
    }

}

.modern-accordion {
    max-width: 800px;
    margin: 0 auto;
    --primary-color: #2563eb;
    --text-color: #1f2937;
    --border-color: #e5e7eb;
}

.accordion-item {
    border: 1px solid var(--border-color);
    /* border-radius: 12px; */
    margin-bottom: 5px;
    overflow: hidden;
    background: white;
}

.accordion-header {
    width: 100%;
    padding: 15px;
    display: flex;
    justify-content: center;
    position: relative;
    align-items: center;
    background: #0068B5;
    border: none;
    cursor: pointer;
    transition: background-color 0.2s;
}

.accordion-header:hover {
    background-color: #014f89;
}

.header-content {
    text-align: left;
}

.label {
    font-size: 14px;
    color: var(--primary-color);
    margin-bottom: 4px;
    display: block;
}

.title {
    font-size: 18px;
    color: var(--text-color);
    margin: 0;
    font-weight: 500;
}

.icon-wrap {
    position: absolute;
    width: 14px;
    height: 14px;
    top: 50%;
    right: 10px;
    transform: translate(-50%, -50%);
}

.line {
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #FFF;
    transition: transform 0.3s ease;
}

.line:first-child {
    transform: translateY(-50%);
}

.line:last-child {
    transform: translateY(-50%) rotate(90deg);
}

.accordion-header.active .line:last-child {
    transform: translateY(-50%) rotate(0);
}

.accordion-body {
    height: 0;
    overflow: hidden;
    transition: height 0.3s ease-out;
}

.body-content {
    padding: 0;
}

.timeline .spot .accordion-item .title {
    position: relative;
    left: 0;
    padding: 0;
    color: #fff;
    font-size: 14px;
    font-weight: 400;
}

.timeline .contents-wrap .table-box .button-box {
    display: flex;
    justify-content: center;
    width: 100%;
    display: flex;
    justify-content: center;
    position: relative;
    align-items: center;
    border: none;
    cursor: pointer;
    transition: background-color 0.3s;
}

.timeline .contents-wrap .table-box .button-box a {
    padding: 15px;
    background-color: #227EA5;
    border: none;
    color: #FFF;
    display: block;
    font-size: 14px;
    line-height: 1.8;
    border-radius: 0;
    text-align: center;
    transition: .3s;
    width: 100%;
}

.timeline .contents-wrap .table-box .button-box a:hover {
    background-color: #165e7d;
}

.timeline .contents-wrap .table-box .button-box p {
    display: inline-block;
    color: #FFF;
    font-size: 14px;
}

.timeline .contents-wrap .table-box .button-box i {
    position: absolute;
    width: 14px;
    height: 14px;
    top: 50%;
    right: 10px;
    transform: translate(-50%, -50%);
    color: #FFF;
    text-align: center;
}

.bg-center .parallax-img {
    height: 55vw;
    overflow: hidden;
    width: 100%;
}

.bg-center {
    margin-top: 0;
    background-color: #0066B1;
}

.ph {
    --clip-1: 50%;
    --clip-2: 50%;
    -webkit-clip-path: polygon(var(--clip-1) var(--clip-1), var(--clip-2) var(--clip-1), var(--clip-2) var(--clip-2), var(--clip-1) var(--clip-2));
    clip-path: polygon(var(--clip-1) var(--clip-1), var(--clip-2) var(--clip-1), var(--clip-2) var(--clip-2), var(--clip-1) var(--clip-2));
    width: 100%;
    height: auto;
    display: block;
    overflow: hidden;
}

.ph img {
    width: 100%;
    height: auto;
    /* ← 高さを画像の比率にあわせて */
    object-fit: cover;
    display: block;
}

.modal-nav {
    background: #103652;
    background-size: 600% 600%;
    /* animation: AnimationName 18s ease infinite; */
}

.modal-open .main-logo::before {
    background-image: none;
}

.modal-open .main-logo::after {
    /* background-color: transparent; */
}

.modal-open .main-logo .header-title-box {
    /* display: none; */
}

.modal-open .visual-title-box {
    display: none;
}

.modal-open #countdown-box {
    display: none;
}

.modal-open .news-ticker {
    /* display: none; */
}

.modal-open .header-box {
    /* background-color: transparent; */
}

.modal-open .header-box .menu-box {
    background-color: transparent;
}

.modal-open .header-box .menu-box img {
    /* opacity: 0; */
}

.modal-open .main-visual {
    mix-blend-mode: difference;
}

.modal-open .scroll {
    display: none;
}

body.modal-open.overflow {
    /* overflow: hidden;
    position: fixed;
    width: 100%; */
}

.modal-nav .phone-modal-menu.main {
    height: 50vh;
}

@media screen and (max-width: 991px) {
    .modal-nav .phone-modal-menu.main {
        height: auto;
    }
}

html.lenis-loading {
    /* overflow: hidden; */
}

.svg-box {
    position: absolute;
    top: 80px;
    left: 0;
    width: 100%;
    height: calc(100vh - 80px);
    z-index: 11;
    overflow: hidden;
}

.svg-box svg {
    position: absolute;
    top: -100px;
    right: 0;
    width: 120%;
    height: 100vh;
    z-index: 11;
}

#blink-target {
    animation: blinkZoom 2.5s ease-in-out infinite;
    transform-origin: center;
    transform-box: fill-box;
    /* SVG内のg要素に正しく中心拡大を効かせる */
}

@keyframes blinkZoom {
    0%, 100% {
        opacity: 1;
        transform: scale(1);
    }

    50% {
        opacity: 0.3;
        transform: scale(1.1);
    }
}

.contents-box-inner {
    display: flex;
    align-items: stretch;
    gap: 50px;
}

.box.left,
.box.right {
    flex: 1;
}

.box.right {
    overflow: hidden;
    display: flex;
    align-items: stretch;
}

/* .box.right video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
} */

.video-wrapper {
    width: 100%;
    overflow: hidden;
    position: relative;
}

@media screen and (min-width: 1200px) {
    .video-wrapper {
        aspect-ratio: 1 / 1;
    }

}

@media screen and (min-width: 992px) and (max-width: 1199px) {
    .video-wrapper {
        aspect-ratio: 2 / 3;
    }

}

.video-wrapper video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    /* はみ出し部分をトリミング */
    display: block;
}

/* スクロールダウンの位置 */
.scroll {
    position: absolute;
    left: 0;
    bottom: 160px;
    writing-mode: vertical-rl;
    z-index: 20;
    padding: clamp(2rem, -2.326rem + 4.36vw, 5rem);
    padding-top: 0;
    padding-bottom: 0;
    z-index: 22;
}

@media screen and (max-width: 991px) {
    .scroll {
        display: none;
    }

}

/* 線のアニメーション部分 */
.scroll::before {
    animation: scroll 2s infinite;
    background-color: #FFF;
    bottom: -115px;
    content: "";
    height: 100px;
    left: 0;
    margin: auto;
    position: absolute;
    right: 0;
    width: 1px;
    z-index: 11;
}

.scroll::after {
    background-color: #0f3553;
    content: "";
    height: 210px;
    top: -10px;
    left: 0;
    margin: auto;
    position: absolute;
    right: 0;
    width: 30px;
    z-index: 1;
}

/* 線のアニメーション */
@keyframes scroll {
    0% {
        transform: scale(1, 0);
        transform-origin: 0 0;
    }

    50% {
        transform: scale(1, 1);
        transform-origin: 0 0;
    }

    51% {
        transform: scale(1, 1);
        transform-origin: 0 100%;
    }

    100% {
        transform: scale(1, 0);
        transform-origin: 0 100%;
    }
}

.scroll span {
    font-size: 10px;
    color: #fff;
    text-align: center;
    line-height: 1.2;
    position: relative;
    z-index: 11;
}

.bg-center {
    position: relative;
    overflow: hidden;
    background-color: #0066B1;
}

.bg-text-wrap {
    position: relative;
    width: 100%;
    overflow: hidden;
    background: #0066B1;
    padding: 2vw 0;
}

.bg-text-track {
    position: absolute;
    top: -6vw;
    display: inline-block;
    white-space: nowrap;
    min-width: 200%;
    animation: scrollTextLoop 60s linear infinite;
}

@media screen and (max-width: 1199px) {
    .bg-text-track {
        top: -4vw;
    }
}

.bg-text {
    display: inline-block;
    font-size: 30vw;
    font-weight: 600;
    line-height: 1;
    color: rgba(255, 255, 255, 1);
    padding-right: 2vw;
}

@keyframes scrollTextLoop {
    0% {
        transform: translateX(0%);
    }

    100% {
        transform: translateX(-50%);
    }
}

.taxi-table {
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
    font-weight: 300;
}

.taxi-table th,
.taxi-table td {
    border: none;
    text-align: left;
    font-size: 16px;
    color: #FFF;
}

@media screen and (min-width: 992px) {

    .taxi-table th,
    .taxi-table td {
        padding: clamp(0.5rem, -0.716rem + 1.225vw, 1rem);
        font-size: clamp(1.3rem, 0.571rem + 0.735vw, 1.6rem);
    }

}

.taxi-table th {
    background-color: #f5f5f5;
}

.taxi-table td:first-child {
    width: 30%;
}

@media screen and (max-width: 991px) {
    .taxi-table td:first-child {
        width: 50%;
    }

}

.taxi-table td:last-child {
    width: 40%;
}

@media screen and (max-width: 991px) {
    .taxi-table td:last-child {
        width: 50%;
    }

}

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

    .taxi-table td,
    .taxi-table th {
        font-size: 15px;
        padding: 10px 5px;
    }
}

.taxi-rental-car-wrap .transport-box-inner {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
}

@media screen and (max-width: 991px) {
    .taxi-rental-car-wrap .transport-box-inner {
        flex-direction: column;
    }

}

.taxi-rental-car-wrap .transport {
    flex: 1;
}

.transport.taxi .heading-title::before {
    content: '\f1ba';
    font-family: 'font awesome 6 Pro';
}

.transport.rental .heading-title::before {
    content: '\f5e4';
    font-family: 'font awesome 6 Pro';
}

.transport.bus .heading-title::before {
    content: '\f207';
    font-family: 'font awesome 6 Pro';
}

.bus-wrap .text-box p, .ship-wrap .text-box p, .bicycle-wrap .text-box p {
    color: #FFF;
    font-weight: 300;
}

@media screen and (min-width: 992px) {
    .bus-wrap .text-box p, .ship-wrap .text-box p, .bicycle-wrap .text-box p {
        font-size: clamp(1.4rem, 0.914rem + 0.49vw, 1.6rem);
    }

}

.transport .text-box p i {
    margin-right: 5px;
}

.transport.ship .heading-title::before {
    content: '\f21a';
    font-family: 'font awesome 6 Pro';
}

.transport.bicycle .heading-title::before {
    content: '\f206';
    font-family: 'font awesome 6 Pro';
}

.transport .heading-title::before {
    font-weight: 300;
}

.modal-nav {
    /* background-image: url(../images/visual/slide/01.jpg);
    background-size: cover;
    background-position: center; */
}

.floating-menu {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background: #fff;
    padding: 20px clamp(2rem, -2.326rem + 4.36vw, 5rem);
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    z-index: 999;
    transform: translateY(-100%);
    transition: transform 0.3s ease;
}

.floating-menu.show {
    transform: translateY(0);
}

.floating-menu ul {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    gap: 20px;
}

.floating-menu ul li {
    font-size: clamp(1.1rem, 0.371rem + 0.735vw, 1.4rem);
}

.floating-menu ul li a {
    color: #27597e;
    font-weight: 500;
    transition: .3s;
}

.floating-menu ul li a:hover {
    opacity: 0.6;
}

@media screen and (max-width: 991px) {
    .main-logo .header-title-box {
        background-color: transparent;
        position: relative;
        width: 100%;
        z-index: 21;
    }

    .main-logo .header-title-box .title {
        font-size: 14px;
    }

    .main-logo .header-title-box .sub-title {
        font-size: 12px;
    }

    .header-box {
        /* display: none; */
        position: fixed;
        left: 0;
        top: 0;
        width: 100%;
        z-index: 2001;
        /* background-color: #dc2c0a; */
        height: 60px;
    }

    .header-box .news-box {
        display: none;
    }

    .header-box .menu-box {
        width: auto;
        height: auto;
        padding: 0;
    }

    /* .header-box .menu-box a {
        display: none;
    } */

    .main-logo {
        /* display: block;
        width: auto;
        height: auto; */
        padding-left: 15px;
        height: 60px;
        width: auto;
        z-index: 1111111;
    }

    .main-logo::after {
        display: none;
    }

    .main-logo .title, .main-logo .sub-title {
        color: #FFF;
        align-items: flex-start;
        display: inline-block;
    }

    .visual-title-box .title {
        font-size: clamp(10rem, 8.568rem + 4.474vw, 12rem);
        display: block;
    }

    .visual-title-box .sub-title {
        font-size: clamp(8rem, 7.284rem + 2.237vw, 9rem);
    }

    .visual-title-box .sub-title span {
        font-size: clamp(2.8rem, -0.118rem + 2.941vw, 4rem);
    }

    .visual-title-box {
        padding: 0 15px;
        /* margin-top: 90px; */
    }

    .svg-box {
        display: none;
    }

    #countdown-box p {
        font-size: 17px;
    }

    #countdown-box .countdown {
        font-size: 100px;
    }

    #countdown-box .days {
        font-size: 36px;
    }

    #countdown-box .countdown-inner {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }

    .modal-btn {
        /* position: fixed;
        top: 12.5px;
        right: 15px;
        width: auto; */
        background-color: transparent;
    }

    .modal-nav {
        background-position: center !important;
    }

    .modal-nav-inner {
        width: 100%;
        height: 100%;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        /* display: flex;
        align-items: center;
        justify-content: center; */
        padding: 0;
        /* flex-direction: column; */
        position: fixed;
        top: 60px;
        padding: 30px;
        padding-bottom: 150px;
    }
}

@media screen and (min-width: 768px) and (max-width: 991px) {
    #countdown-box {
        position: absolute;
        bottom: 50px;
        left: 50%;
        transform: translateX(-50%);
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        padding: 15px 20px;
        background-color: rgba(255, 255, 255, 0.1);
        border: 1px solid #fff;
        box-sizing: border-box;
        text-align: center;
        pointer-events: none;
        width: 30%;
    }
}

@media screen and (max-width: 767px) {
    #countdown-box {
        position: absolute;
        bottom: 50px;
        left: 50%;
        transform: translateX(-50%);
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        padding: 15px 20px;
        background-color: rgba(255, 255, 255, 0.1);
        border: 1px solid #fff;
        box-sizing: border-box;
        text-align: center;
        pointer-events: none;
        width: 70%;
    }
}


/* .news-ticker {
    display: none;
}

.section-box.news {
    display: none;
} */

.sp.link-box-wrap {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    justify-content: center;
    margin-top: 30px;
}

.sp.link-box-wrap .link-box {
    /* margin-left: 20px; */
}

.sp.link-box-wrap .link-box a {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    background-color: #F5F7F8;
    color: #fff;
    flex-direction: row-reverse;
    padding-left: 20px;
    border-radius: 50px;
    /* border: 1px solid #429de2; */
    padding-right: 10px;
    padding-top: 10px;
    padding-bottom: 10px;
}

.sp.link-box-wrap .link-box a .title {
    line-height: 1;
    margin-right: 15px;
    margin-left: 15px;
    margin-bottom: 0;
    color: #0066B1;
    font-size: 14px;
}

@media screen and (min-width: 992px) {
    .sp.link-box-wrap .link-box a .title {
        font-size: clamp(1.2rem, 0.714rem + 0.49vw, 1.4rem);
    }

}

.sp.link-box-wrap .link-box .arrow i {
    font-size: 18px;
    color: #FFF;
    padding: 15px;
    transition: .3s;
    background-color: #0066B1;
    border-radius: 50%;
}

@media screen and (max-width: 991px) {
    .section-box.cycling {
        padding-bottom: 50px;
    }

}

.page .scroll {
    display: none;
}

/* .page .main-logo::after {
    display: none;
} */

/* .page .main-logo {
    padding: clamp(2rem, -2.326rem + 4.36vw, 5rem);
    padding-right: 0;
    padding-top: 0;
    padding-bottom: 0;
    height: auto;
} */

/* @media screen and (max-width: 991px) {
    .page .main-logo {
        padding: 0;
        height: auto;
    }

} */

/* .page #header {
    display: flex;
    align-items: flex-start;
    background-color: #103552;
    display: flex;
    align-items: center;
    height: 70px;
    justify-content: space-between;
} */

/* @media screen and (max-width: 991px) {
    .page #header {
        height: 60px;
        padding: 0;
    }

} */

/* .page #header .menu-box {
    width: 16.25%;
    height: 100%;
    background-color: #429DE2;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px;
} */

/* @media screen and (max-width: 991px) {
    .page #header .menu-box {
        padding: 0;
        padding-right: 15px;
        width: auto;
    }

} */

/* .page #header .menu-box img {
    width: 24px;
    height: 24px;
} */

/* @media screen and (max-width: 991px) {
    .page #header .menu-box a {
        display: none;
    }

    .page.modal-open #header .menu-box a {
        display: block;
    }

    .page.modal-open #header .menu-box a.sns {
        display: none;
    }
} */

/* .page #header .menu-box img {
    width: 24px;
    height: 24px;
} */

.page .section-box.news {
    padding-top: 50px;
}

.page.single .section-box.news {
    padding-top: 0;
}

@media screen and (max-width: 991px) {
    .page .section-box.news {
        padding-top: 50px;
    }

}

.news-single .title {
    font-size: 26px;
    font-weight: 700;
    color: #27597e;
    margin-bottom: 0;
}

@media screen and (max-width: 991px) {
    .news-single .title {
        font-size: 22px;
    }

}

.news-single .news-list-header {
    margin-bottom: 0;
}

.news-single .container {
    max-width: 820px;
}

.news-single p {
    margin-bottom: 30px;
}

.single .section-box h3 {
    display: block;
    font-size: 18px;
    margin: 10px 0;
    color: #27597e;
}

.single .title-box {
    border-left: 2px solid #0066B1;
    padding-left: 30px;
    margin-left: 30px;
    padding-bottom: 15px;
    padding-top: 10px;
}

@media screen and (max-width: 991px) {
    .single .news-single .post-list-header-wrap .title-box {
        border: none;
        font-size: 20px;
        margin-left: 0;
        padding-left: 0;
        padding-bottom: 10px;
        padding-top: 5px;
    }

}

.single figure {
    margin-top: 50px;
    margin-bottom: 30px;
}

.page .bg-center {
    position: relative;
    overflow: hidden;
    background-color: #0066B1;
    height: 300px;
}

@media screen and (max-width: 1199px) {
    .page .bg-center {
        height: 250px;
    }
}

@media screen and (max-width: 991px) {
    .page .bg-center {
        display: none;

    }
}

/*------------- 2025年06月_追加 -------------*/
.section-box.news .news-list time {
    color: #28597e;
    margin-bottom: 0;
    display: flex;
    width: 17%;
    margin-right: 0;
    transition: .3s;
}

@media screen and (min-width: 992px) {
    .section-box.news .news-list a:hover time {
        color: #429de2;
    }
}

.section-box.news .news-list .inner-text-box {
    width: 68%;
}

@media screen and (min-width: 992px) and (max-width: 1199px) {
    .section-box.news .news-list time {
        width: 24%;
    }

    .section-box.news .news-list .img-box {
        width: 23%;
    }

    .section-box.news .news-list .inner-text-box {
        width: 53%;
    }
}

@media screen and (max-width: 991px) {
    .section-box.news .news-list time {
        float: left;
        width: 50%;
    }

    .section-box.news .news-list .img-box {
        float: left;
        clear: right;
        width: 50%;
    }

    .section-box.news .news-list .inner-text-box {
        width: 100%;
        float: left;
    }
}

.single-line-text {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 14px;
    line-height: 1;
    margin-top: 15px;
    transition: .3s;
}

@media screen and (max-width: 991px) {
    .single-line-text {
        display: none;
    }
}

.news-list a:hover .single-line-text {
    color: #429de2;
}

.breadcrumb-box {
    background-color: #0066B1;
    padding: 10px 0;
}

.breadcrumb-box li {
    display: inline;
    color: #FFF;
    font-size: 12px;
}

@media screen and (max-width: 991px) {
    .breadcrumb-box li {
        font-size: 10px;
    }
}

.breadcrumb-box li a {
    color: #FFF;
    text-decoration: underline;
    transition: 0.3s
}

.breadcrumb-box li a:hover {
    opacity: 0.6;
    text-decoration: none;
}

.breadcrumb li+li::before {
    content: "＞";
    margin: 0 8px;
    color: #FFF;
}

.page .section-box.blog {
    padding-top: 50px;
}

.section-box.blog .section-title.en {
    flex-direction: row;
    align-items: flex-end;
}

.section-box.blog .section-title.en .small {
    margin-right: 15px;
}

.blog-list-content {
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
    list-style: none;
    padding: 0;
    margin: 0;
}

@media screen and (max-width: 991px) {
    .blog-list-content {
        gap: 15px;
    }

}

.blog-list {
    width: calc((100% - 60px) / 3);
    overflow: hidden;
    background: #fff;
    transition: transform 0.3s;
    box-sizing: border-box;
}

@media screen and (max-width: 991px) {
    .blog-list {
        width: calc((100% - 15px) / 2);
    }
}

@media screen and (max-width: 767px) {
    .blog-list-content {
        flex-wrap: wrap;
    }

    .blog-list {
        width: 100%;
    }

    .blog-list.half {
        width: calc(50% - 15px);
    }

    /* 最初の1件目だけ1カラム表示 */
    .blog-list:nth-child(1) {
        width: 100%;
    }

    /* 2件目・3件目は2カラム並び */
    .blog-list:nth-child(2),
    .blog-list:nth-child(3),
    .blog-list:nth-child(4),
    .blog-list:nth-child(5) {
        width: calc(50% - 7.5px);
    }
}

.blog-list a {
    transition: .3s;
    display: block;
    height: 100%;
}

@media screen and (min-width: 992px) {
    .blog-list a:hover {
        background-color: #429de2;
        display: block;
    }
}

.blog-list .img-box img {
    width: 100%;
    height: auto;
    display: block;
}

.blog-list .text-box {
    padding: 15px;
}

.blog-list .posted-on {
    font-size: 13px;
    display: block;
}

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

    .blog-list:nth-child(2) .posted-on,
    .blog-list:nth-child(3) .posted-on,
    .blog-list:nth-child(4) .posted-on,
    .blog-list:nth-child(5) .posted-on {
        font-size: 11px;
        line-height: 1;
    }
}

.blog-list .title {
    font-weight: 600;
    line-height: 1.5;
    color: #27597e;
    transition: .3s;
}

@media screen and (min-width: 992px) {
    .blog-list a:hover .title {
        color: #FFF;
        transition-delay: 0.4s;
    }
}

@media screen and (min-width: 992px) {
    .blog-list .title {
        font-size: clamp(1.5rem, 1.47rem + 0.093vw, 1.6rem);
    }
}

@media screen and (max-width: 991px) {
    .blog-list .title {
        font-size: 16px;
    }

    .blog-list:nth-child(2) .title,
    .blog-list:nth-child(3) .title,
    .blog-list:nth-child(4) .title,
    .blog-list:nth-child(5) .title {
        font-size: 14px;
    }
}

.blog-list time {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    margin-top: 5px;
    transition: .3s;
}

@media screen and (min-width: 992px) {
    .blog-list a:hover time {
        color: #FFF;
        transition-delay: 0.4s;
    }
}

.blog-list time i {
    margin-right: 5px;
}

.date-wrapper {
    font-size: 22px;
    color: #28597e;
    display: flex;
    align-items: center;
    margin-left: -10px;
}

@media screen and (min-width: 992px) {
    .date-wrapper.sp {
        display: none;
    }
}

@media screen and (max-width: 991px) {
    .date-wrapper.pc {
        display: none;
    }

    .date-wrapper.sp {
        margin-left: 0;
        font-size: 14px;
    }

    .date-wrapper.sp i {
        margin-right: 5px;
    }
}

.date-month-day {
    font-size: 50px;
    margin-left: -8px;
    line-height: 1;
    letter-spacing: -0.4rem;
    font-weight: 500;
}

.date-year {
    font-size: 16px;
    transform: rotate(90deg);
    font-weight: 500;
}

/* @media screen and (max-width: 991px) {

    .date-month-day {
        font-size: clamp(2.5rem, 2.47rem + 0.093vw, 2.6rem);
    }

    .date-year {
        font-size: clamp(1.2rem, 0.714rem + 0.49vw, 1.4rem);
    }
} */

.date-weekday {
    font-size: 14px;
    color: #FFF;
    background-color: #28597e;
    padding: 2px;
    margin-top: 15px;
    margin-left: 8px;
    transition: .3s;
}

@media screen and (min-width: 992px) {
    .news-list a:hover .date-weekday {
        background-color: #429DE2;
    }
}

.section-box.blog figure {
    position: relative;
    overflow: hidden;
    aspect-ratio: 16 / 9;
    width: 100%;
}

.section-box.blog .blog-list .img-box img {
    width: 100%;
    height: 100%;
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .3s ease;
}

@media screen and (min-width: 992px) {
    .section-box.blog .blog-list a:hover .img-box img {
        transform: scale(1.1);
        transition-delay: 0.4s;
    }
}

.post-thumbnail {
    margin-bottom: 30px;
}

.post-list-header-wrap {
    display: flex;
    align-items: center;
}

.news-single .post-list-header-wrap {
    margin-bottom: 30px;
    border-bottom: 2px solid #0066B1;
}

@media screen and (max-width: 991px) {
    .news-single .post-list-header-wrap {
        flex-direction: column;
        align-items: flex-start;
        margin-bottom: 15px;
    }

}

.blog .post-list-header-wrap {
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
    margin-bottom: 50px;
}

.section-box.blog {
    background-color: #e9f2fc;
}

/* ------------------------ */

/* button style from here */
.btn {
    position: relative;
    display: inline-block;
    line-height: 3;
    text-align: center;
    text-decoration: none;
    font-weight: bold;
    transition: all 0.3s;
    cursor: pointer;
    user-select: none;
}

.btn:hover {
    letter-spacing: 2px;
    box-shadow: none;
}

/* btn2 */
.btn2 span::after, .btn2 span::before, .btn2::after, .btn2::before {
    content: "";
    position: absolute;
    transition: all 0.3s;
    background-color: #429DE2;
}

.btn2::before {
    height: 2px;
    width: 0;
    top: 0;
    left: 0;
    transition-delay: 0.4s;
    z-index: 1;
}

.btn2::after {
    width: 2px;
    height: 0;
    top: 0;
    right: 0;
    transition-delay: 0.2s;
}

.btn2 span::before {
    height: 2px;
    width: 0;
    bottom: 0;
    right: 0;
    transition-delay: 0.4s;
}

.btn2 span::after {
    width: 2px;
    height: 0;
    bottom: 0;
    left: 0;
    transition-delay: 0.2s;
}

@media screen and (min-width: 992px) {
    .btn2:hover span::before, .btn2:hover::before {
        width: 100%;
        transition: all 0.2s;
    }

    .btn2:hover span::after, .btn2:hover::after {
        height: 100%;
        transition: all 0.2s;
    }

    .btn2:hover::after {
        transition-delay: 0.2s;
    }

    .btn2:hover span::after {
        transition-delay: 0.2s;
    }

    .btn2:hover {
        transition-delay: 0.4s;
    }
}

/* ------------------------ */

.blog .section-title-box .link-box a {
    background-color: #FFF;
}

.blog .section-title-box .link-box a:hover {
    background-color: #429de2;
}

.post-navigation {
    margin-top: 40px;
    padding-top: 40px;
    border-top: 1px solid #0566b1;
    text-align: center;
}

.post-nav-links {
    display: flex;
    justify-content: center;
    gap: 20px;
    list-style: none;
    padding: 0;
    margin: 0;
}

@media screen and (max-width: 991px) {
    .post-nav-links {
        flex-direction: column;
        align-items: center;
    }

}

.post-nav-links li a {
    display: inline-block;
    padding: 10px 16px;
    background-color: #f5f5f5;
    color: #333;
    text-decoration: none;
    border-radius: 4px;
    transition: background-color 0.3s;
}

.post-nav-links li a:hover {
    background-color: #ddd;
}

.section-title.en .page-not-found {
    text-transform: initial;
}

.section-box.news .news-list-none {
    padding: 50px 30px !important;
}

main.blog {
    background-color: #e9f2fc;
}

/* ------------------------ */

.two-column-layout {
    display: flex;
    flex-wrap: wrap;
    gap: 80px;
    /* padding: 0; */
    padding-top: 50px;
    padding-bottom: 100px;
}

@media screen and (max-width: 991px) {
    .blog .two-column-layout {
        flex-direction: column;
        gap: 30px;
        padding-top: 30px;
        padding-bottom: 50px;
    }

}

.main-content {
    width: calc(70% - 40px);
    min-width: 0;
}

@media screen and (max-width: 991px) {
    .main-content {
        width: 100%;
    }

}

.news-single.main-content {
    width: 100%;
}

.sidebar {
    width: calc(30% - 40px);
    position: sticky;
    top: 50px;
    align-self: flex-start;
}

@media screen and (max-width: 991px) {
    .sidebar {
        width: 100%;
        position: static;
        top: auto;
    }
}

.latest-posts {
    list-style: none;
    padding: 0;
    margin: 0;
}

.latest-post-item {
    display: flex;
    gap: 10px;
    margin-bottom: 15px;
    border-bottom: 1px solid #71ADD9;
    padding-bottom: 15px;
}

.latest-post-item:last-child {
    border-bottom: none;
}

.latest-post-item .thumb img {
    width: 80px;
    height: 80px;
    object-fit: cover;
}

.latest-post-item .text .post-title {
    font-size: 13px;
    font-weight: 600;
    line-height: 1.6;
}

.latest-post-item .text .post-date {
    font-size: 12px;
    color: #668196;
}

.sidebar .post-link {
    display: flex;
    transition: background-color 0.3s;
    align-items: center;
}

.sidebar .text {
    padding-left: 15px;
    display: flex;
    flex-direction: column;
    gap: 7px;
}

.widget-title {
    font-size: 20px;
    font-weight: 600;
    color: #27597e;
    margin-top: 0;
    margin-bottom: 15px;
    padding-top: 10px;
    border-top: 3px solid #0066B1;
    text-transform: uppercase;
}

.widget-title::first-letter {
    text-transform: uppercase;
    font-weight: 600;
    font-size: 36px;
    color: #429de2;
}

.single .single-post-thumbnail {
    margin-top: 0;
}

.blog-bg-text {
    color: rgb(233 242 252);
}

.breadcrumb-box .container {
    /* padding: 0; */
}

.latest-post-item .text .post-date i {
    margin-right: 5px;
}

.blog-single .contents-box p {
    margin-bottom: 20px;
    font-size: 16px;
    line-height: 1.8;
}

.blog-single .title-box {
    border-left: none;
    padding-left: 0;
    margin-left: 0;
    padding-bottom: 0;
    padding-top: 0;
}

.blog-single .title {
    color: #27597e;
    font-size: 30px;
    font-weight: 700;
    line-height: 1.5;
}

@media screen and (max-width: 991px) {
    .blog-single .title {
        font-size: 22px;
    }

}

.blog.blog-single .post-list-header-wrap time {
    font-size: 14px;
}

.list-tags {
    margin-top: 20px;
    display: flex;
    gap: 10px;
    justify-content: flex-start;
    align-items: center;
    flex-wrap: wrap;
}

.list-tags li a {
    background-color: #d8e5ef;
    color: #28597e;
    padding: 5px 10px;
    font-weight: 500;
    font-size: 16px;
    border-radius: 5px;
    display: block;
}

.list-tags li a:hover {
    background-color: #28597e;
    color: #8dc6f1;
    text-decoration: none;
}

.blog-single .single-post-thumbnail {
    position: relative;
    overflow: hidden;
    aspect-ratio: 16 / 9;
    width: 100%;
}

.blog-single .single-post-thumbnail img {
    width: 100%;
    height: 100%;
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .3s ease;
}

.list-tags.archive-tag {
    gap: 5px;
    margin-top: 5px;
}

.list-tags.archive-tag li {
    background-color: #d8e5ef;
    color: #28597e;
    padding: 5px 10px;
    font-weight: 500;
    font-size: 10px;
    border-radius: 5px;
    display: block;
}

.single article h2 {
    display: block !important;
    color: #27597e;
    font-size: 24px;
    font-weight: 600;
    line-height: 1.6;
}

@media screen and (max-width: 991px) {
    .single article h2 {
        font-size: 20px;
    }

}

.single article h3 {
    color: #27597e;
    font-size: 20px;
    padding: 15px 0;
    display: block;
    background-image: linear-gradient(transparent 95%, #0366b1 50%);
    line-height: 1.6;
}

@media screen and (max-width: 991px) {
    .single article h3 {
        font-size: 18px;
    }

}

.single article h4 {
    color: #27597e;
    font-size: 18px;
    display: block;
    position: relative;
    padding-bottom: 0;
    padding-left: 35px;
    line-height: 1.6;
}

@media screen and (max-width: 991px) {
    .single article h4 {
        font-size: 16px;
    }

}

.single article h4:before {
    font-family: FontAwesome;
    font-weight: 900;
    font-size: 30px;
    color: #429de2;
    left: 0;
    top: 0;
    content: "\f00c";
    position: absolute;
}

.custom-tag-cloud {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.custom-tag-cloud a,
.custom-tag-cloud a:link,
.custom-tag-cloud a:visited {
    padding: 5px 10px;
    font-weight: 400;
    border-radius: 5px;
    display: inline-block;
    text-decoration: none;
    line-height: 1.8;
    transition: background-color 0.3s, color 0.3s;
}

/* ホバー時のスタイル */
.custom-tag-cloud a:hover,
.custom-tag-cloud a:focus {
    background-color: #28597e;
    color: #8dc6f1;
    text-decoration: none;
}

.custom-tag-cloud a.size-1 {
    font-size: 12px;
}

.custom-tag-cloud a.size-2 {
    font-size: 14px;
}

.custom-tag-cloud a.size-3 {
    font-size: 16px;
}

.custom-tag-cloud a.size-4 {
    font-size: 18px;
}

.custom-tag-cloud a.size-5 {
    font-size: 20px;
}

/* 背景色段階（tag-bg-1 ～ tag-bg-5） */
.tag-bg-1 {
    background-color: #d8e7f7;
    color: #28597e;
}

.tag-bg-2 {
    background-color: #79aee6;
    color: #ffffff;
}

.tag-bg-3 {
    background-color: #429de2;
    color: #ffffff;
}

.tag-bg-4 {
    background-color: #1d79df;
    color: #ffffff;
}

.tag-bg-5 {
    background-color: #0368b5;
    color: #ffffff;
}

.sidebar-content {
    margin-bottom: 30px;
}

.sidebar-content:last-of-type {
    margin-bottom: 0;
}

@media screen and (min-width: 992px) {
    #visual-blog {
        position: absolute;
        top: 110px;
        right: 30px;
        z-index: 22;
        width: 450px;
    }
}

@media screen and (max-width: 991px) {
    #visual-blog {
        display: none;
    }

}

#visual-blog a {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: rgb(0 102 177 / 70%);
    color: #fff;
    border-radius: 10px;
    font-size: 16px;
    text-decoration: none;
    padding: 20px;
    gap: 20px;
    transition: .3s;
}

#visual-blog a:hover {
    background-color: #103452;
}

#visual-blog h2 {
    display: block;
    font-size: 14px;
    font-weight: 500;
    margin: 0;
}

.visual-blog-thumb {
    flex: 1;
}

.visual-blog-meta {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.visual-blog-meta .tag-title {
    color: #FFF;
    font-weight: 700;
    font-size: 20px;
    line-height: 1;
}

.visual-blog-meta time {
    color: #FFF;
    font-size: 14px;
}

.visual-blog-meta time i {
    margin-right: 5px;
}

.visual-blog-thumb {
    position: relative;
    overflow: hidden;
    aspect-ratio: 16 / 9;
    width: 100%;
}

.visual-blog-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .3s ease;
}

#visual-blog:hover .visual-blog-thumb img {
    transform: scale(1.1);
}

.visual-blog-title {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.6;
    max-height: calc(1.6em * 2);
}

.instagram-box {
    margin-top: 100px;
}

.instagram-box .section-title.en {
    color: #FFF;
    align-items: center;
    margin-bottom: 15px;
    flex-direction: row;
}

.instagram-box .section-title.en i {
    font-size: clamp(3.6rem, 3.304rem + 0.926vw, 4.6rem);
    margin-right: 10px;
    position: relative;
    top: 3px;
}

/* 見出し_ハイライト */
h2.is-current {
    color: #007bff;
    font-weight: bold;
    border-left: 4px solid #007bff;
    padding-left: 8px;
}

#toc {
    position: fixed;
    bottom: 30px;
    right: 30px;
    z-index: 500;
    background: rgba(255, 255, 255, 0.8);
    padding: 15px;
    border: 1px solid #0366b1;
    display: none;
    /* width: 220px; */
    opacity: 0;
    transition: opacity 0.3s ease;
}

@media screen and (max-width: 1199px) {
    #toc {
        display: none !important;
    }
}

#toc.show {
    display: block;
    opacity: 1;
}

#toc ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

#toc li+li {
    margin-top: 5px;
}

#toc a {
    text-decoration: none;
    color: #2488d4;
}

#toc li.is-active-li a {
    font-weight: bold;
    color: #0566b1;
}

section h2 {
    display: block;
    color: transparent
}

.toc-list-item {
    font-size: 13px;
}

/* TOC項目の基本レイアウト */
#toc .toc-list-item {
    position: relative;
    padding-left: 1.5em;
    /* アイコン分の余白を確保 */
    list-style: none;
}

/* アクティブ時のみアイコン表示 */
#toc .toc-list-item.is-active-li a::before {
    content: "\f192";
    /* fa-diamonds-4 の Unicode */
    font-family: "Font Awesome 6 Pro";
    font-weight: 900;
    position: absolute;
    left: 0;
    top: 55%;
    transform: translateY(-50%);
    color: #0566b1;
    font-size: 1em;
}

#header .menu-box {
    transition: .3s;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background-color: #429DE2;
    height: 100%;
}

@media screen and (max-width: 767px) {
    #header .menu-box {
        padding: 0;
        padding-right: 15px;
        background-color: transparent;
        justify-content: flex-end;
    }
}

#header .menu-box a.sns {
    transition: .3s;
}

@media screen and (max-width: 767px) {
    #header .menu-box a.sns {
        display: none;
    }
}

#header .menu-box a.sns:hover {
    opacity: 0.6;
}

.modal-open #header .menu-box {
    background-color: #103652;
}

.modal-nav .section-title.en .big {
    font-size: 24px;
}

.modal-nav .section-title.en .small {
    font-size: 18px;
}

.modal-nav .section-title.en {
    color: #98c4f6;
    margin-bottom: 20px;
}

@media screen and (max-width: 767px) {
    .modal-nav .section-title.en {
        align-items: flex-start;
    }
}

/* スクロールで固定された状態 */
#header.fixed {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    background: #103653;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    transition: top 0.5s ease;
    z-index: 122;
    height: 80px;
}

/* スクロールで固定された状態 */
#header.fixed.active {
    top: 0;
}

#fixed-menu .main-logo::after {
    background-color: transparent;
}

#fixed-menu .main-logo {
    top: 100px;
}

#fixed-menu .menu-box {
    width: 180px;
    height: 80px;
    background-color: #103653;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px;
    position: absolute;
    top: 100px;
    right: 0;
    z-index: 11111;
}

#fixed-menu .menu-box img {
    width: 24px;
    height: 24px;
}

@media screen and (min-width: 992px) {
    .section-box.news .news-list-content .sp {
        display: none;
    }
}

@media screen and (max-width: 991px) {
    .news-list-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
    }

    .blog .news-list-header {
        align-items: flex-start;
        justify-content: flex-start;
        flex-direction: column;
    }

    .section-box.news .news-list-content .pc {
        display: none;
    }
}

@media screen and (max-width: 767px) {
    .breadcrumb {
        max-width: 100%;
    }

    .breadcrumb {
        overflow: hidden;
        /* text-overflow: ellipsis;
        white-space: nowrap; */
    }

    .breadcrumb ul {
        /* display: flex;
        flex-wrap: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap; */
    }

    .breadcrumb ul li {
        /* flex-shrink: 0;
        margin-right: 0.5em; */
    }

    .breadcrumb ul li:last-child {
        /* overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap; */
    }

}

.menu-box-wrap {
    width: 15%;
    height: 100%;
}

@media screen and (max-width: 1199px) {
    .menu-box-wrap {
        width: 20%;
    }
}

.sp-button {
    background-color: #103652;
    width: 100%;
    /* height: 100%; */
    position: fixed;
    bottom: 0;
    left: 0;
    z-index: 111;
}

@media screen and (min-width: 768px) {
    .sp-button {
        display: none;
    }
}

@media screen and (max-width: 767px) {
    /* .sp-button.hidden {
        display: none !important;
    } */
}

@media screen and (max-width: 767px) {
    .sp-button {
        opacity: 1;
        transform: translateY(0);
        transition: opacity 0.3s ease, transform 0.3s ease;
        pointer-events: auto;
    }

    .sp-button.hidden {
        opacity: 0;
        transform: translateY(100%);
        pointer-events: none;
    }
}

.sp-button-inner {
    display: flex;
    justify-content: space-between;
    /* 左右の余白調整したい場合 */
    align-items: center;
    gap: 10px;
    /* 要素間の隙間（任意） */
    padding: 0;
    margin: 0;
    list-style: none;
}

.sp-button-inner li {
    flex: 1;
    /* 均等幅にする */
    text-align: center;
}

.sp-button-inner li a {
    display: inline-block;
    width: 100%;
    padding: 10px 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border-right: 1px solid #2b5575;
}

.sp-button-inner li img {
    max-width: 40px;
    /* アイコンサイズを統一 */
    height: auto;
    display: inline-block;
}

@media screen and (max-width: 767px) {
    main {
        padding-bottom: 60px;
    }

    .main-visual {
        padding-bottom: 60px;
    }

    .zoom-container img {
        height: calc(100vh - 60px);
    }

    footer {
        margin-bottom: 60px;
    }
}

@media screen and (max-width: 991px) {
    .link-box-wrap {
        margin-top: 50px;
    }

    .section-box.news .link-box {
        text-align: center;
    }

    .section-box.blog .link-box {
        text-align: center;
    }

    .link-box a {
        display: inline-block;
    }
}

.addtoany_content {
    text-align: center;
    margin-top: 50px !important;
}

.addtoany_header {
    font-size: 14px;
    color: #27597e;
}