:root {
    --font-mincho: "Shippori Mincho", serif;
    --font-cursive: "Alex Brush", cursive;
    --font-sans: "Noto Sans JP", sans-serif;
    --font-en: "Gotu", sans-serif;
    --font-accent: "Open Sans", sans-serif;
    --font-mincho-zen: "Zen Old Mincho", serif;
    --color-light-beige: #faf5f0;
    --color-mid-beige: #eee8dc;
    --color-black: #252525;
    --color-gray: #454545;
    --color-light-gray: #bababa;
    --color-white: #fff;
    --color-beige: #aa9670;
    --color-dark-beige: #937b4e;
    --color-yellow: #d1af6e;
    --color-blue: #5786b1
}

html {
    -webkit-font-smoothing: antialiased
}

body {
    background-color: var(--color-light-beige);
    color: var(--color-black);
    container-type: inline-size;
    cursor: auto;
    display: flex;
    flex-direction: column;
    font-family: var(--font-mincho);
    font-weight: 400;
    line-height: 1.4;
    min-height: 100vh;
    overflow-x: hidden;
    position: relative
}

body.is-fixed,
main {
    overflow: hidden
}

main {
    flex: 1;
    position: relative;
    z-index: 1
}

main.top:before {
    top: 93svh
}

@media (min-width:52.1875em) {
    main.top:before {
        top: 46.25vw
    }
}

main:before {
    background-image: url(../img/common/bg-deco-sp_2x.png);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: cover;
    content: "";
    height: 2023.2vw;
    left: calc(50% - 65.06667vw);
    position: absolute;
    top: 163.4666666667vw;
    width: 130.1333333333vw;
    z-index: -1
}

@media (min-width:52.1875em) {
    main:before {
        background-image: url(../img/common/bg-deco_2x.png);
        height: 511.4583333333vw;
        left: calc(50% - 59.30556vw);
        top: 0;
        width: 118.6111111111vw
    }
}

@media (min-width:90em) {
    main:before {
        height: 7365px;
        left: calc(50% - 854px);
        width: 1708px
    }
}

.kv .kv__inner {
    height: 100svh;
    padding: 0;
    position: relative
}

@media (min-width:52.1875em) {
    .kv .kv__inner {
        height: auto;
        padding: 1.1111111111vw
    }
}

@media (min-width:90em) {
    .kv .kv__inner {
        padding: 16px
    }
}

.kv .kv__carousel {
    height: 100%;
    overflow: hidden;
    position: relative;
    z-index: 1
}

@media (min-width:52.1875em) {
    .kv .kv__carousel {
        border-radius: .3472222222vw;
        height: auto
    }
}

@media (min-width:90em) {
    .kv .kv__carousel {
        border-radius: 5px
    }
}

.kv .kv__carousel * {
    height: 100%
}

@media (min-width:52.1875em) {
    .kv .kv__carousel * {
        height: auto
    }
}

.kv .kv__img {
    height: 100%
}

@media (min-width:52.1875em) {
    .kv .kv__img {
        height: auto
    }
}

.kv .kv__img img {
    height: 100%;
    object-fit: cover;
    width: 100%
}

@media (min-width:52.1875em) {
    .kv .kv__img img {
        height: auto
    }
}

.kv .kv__over {
    bottom: 10.6666666667vw;
    left: 6.6666666667vw;
    position: absolute;
    z-index: 2
}

@media (min-width:52.1875em) {
    .kv .kv__over {
        bottom: 2.5694444444vw;
        left: 5.3472222222vw;
        padding: 5.9027777778vw 5.7638888889vw
    }
}

@media (min-width:90em) {
    .kv .kv__over {
        bottom: 37px;
        left: 77px;
        padding: 85px 83px
    }
}

.kv .kv__over:before {
    background-image: url(../img/top/kv-blur_2x.png);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 210%;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 130%;
    z-index: -1
}

@media (min-width:52.1875em) {
    .kv .kv__over:before {
        height: 100%;
        left: 0;
        top: 0;
        transform: none;
        width: 100%
    }
}

.kv .kv__title {
    font-size: 7.4666666667vw;
    line-height: 1.5
}

@media (min-width:52.1875em) {
    .kv .kv__title {
        font-size: 3.3333333333vw
    }
}

@media (min-width:90em) {
    .kv .kv__title {
        font-size: 48px
    }
}

@keyframes zoomUp {
    0% {
        transform: scale(1)
    }

    to {
        transform: scale(1.08)
    }
}

.add-animation {
    animation: zoomUp 7s linear 0s normal both
}

.intro {
    margin-top: 20.2666666667vw
}

@media (min-width:52.1875em) {
    .intro {
        margin-top: 5.2777777778vw
    }
}

@media (min-width:90em) {
    .intro {
        margin-top: 76px
    }
}

.intro .intro__inner {
    max-width: 93.0666666667vw;
    text-align: center
}

@media (min-width:52.1875em) {
    .intro .intro__inner {
        max-width: 77.7777777778vw
    }
}

@media (min-width:90em) {
    .intro .intro__inner {
        max-width: 1120px
    }
}

.intro .intro__title {
    font-size: 6.4vw;
    line-height: 1.6
}

@media (min-width:52.1875em) {
    .intro .intro__title {
        font-size: 2.2222222222vw
    }
}

@media (min-width:90em) {
    .intro .intro__title {
        font-size: 32px
    }
}

.intro .intro__text {
    font-family: var(--font-sans);
    font-size: 3.7333333333vw;
    line-height: 1.6;
    margin-top: 6.4vw;
    position: relative;
    z-index: 1
}

@media (min-width:52.1875em) {
    .intro .intro__text {
        font-size: .9722222222vw;
        margin-top: 2.7777777778vw
    }
}

@media (min-width:90em) {
    .intro .intro__text {
        font-size: 14px;
        margin-top: 40px
    }
}

.intro .intro__text+.intro__text {
    margin-top: 1lh
}

.intro .intro__img {
    margin-inline: calc(50% - 50cqi);
    margin-top: 9.8666666667vw
}

@media (min-width:52.1875em) {
    .intro .intro__img {
        margin-top: -2.9166666667vw
    }
}

@media (min-width:90em) {
    .intro .intro__img {
        margin-top: -42px
    }
}

.intro .intro__img img {
    height: auto;
    width: 100%
}

.hall {
    margin-top: 10.6666666667vw
}

@media (min-width:52.1875em) {
    .hall {
        margin-top: 8.1944444444vw
    }
}

@media (min-width:90em) {
    .hall {
        margin-top: 118px
    }
}

.hall .hall__cont {
    margin-top: 6.4vw
}

@media (min-width:52.1875em) {
    .hall .hall__cont {
        margin-top: 2.7777777778vw
    }
}

@media (min-width:90em) {
    .hall .hall__cont {
        margin-top: 40px
    }
}

.faq {
    margin-top: 10.6666666667vw
}

@media (min-width:52.1875em) {
    .faq {
        margin-top: 8.6111111111vw
    }
}

@media (min-width:90em) {
    .faq {
        margin-top: 124px
    }
}

.faq .faq__title {
    margin-top: 10.6666666667vw
}

@media (min-width:52.1875em) {
    .faq .faq__title {
        margin-top: 5.5555555556vw
    }
}

@media (min-width:90em) {
    .faq .faq__title {
        margin-top: 80px
    }
}

.faq .faq__cont {
    margin-top: 9.6vw
}

@media (min-width:52.1875em) {
    .faq .faq__cont {
        margin-top: 2.7777777778vw
    }
}

@media (min-width:90em) {
    .faq .faq__cont {
        margin-top: 40px
    }
}

.faq .faq__items {
    margin-inline: auto;
    margin-bottom: 10.6666666667vw
}

@media (min-width:52.1875em) {
    .faq .faq__items {
        margin-bottom: 5.5555555556vw;
        max-width: 50vw
    }
}

@media (min-width:90em) {
    .faq .faq__items {
        margin-bottom: 80px;
        max-width: 720px
    }
}

.faq .faq__item:not(:first-child) {
    margin-top: 9.6vw
}

@media (min-width:52.1875em) {
    .faq .faq__item:not(:first-child) {
        margin-top: 1.6666666667vw
    }
}

@media (min-width:90em) {
    .faq .faq__item:not(:first-child) {
        margin-top: 24px
    }
}

.faq .faq__item-head {
    align-items: flex-start;
    background: var(--color-beige);
    border-radius: 1.3333333333vw;
    color: var(--color-white);
    cursor: pointer;
    display: flex;
    padding: 2.1333333333vw 4.2666666667vw 3.2vw
}

@media (min-width:52.1875em) {
    .faq .faq__item-head {
        border-radius: .3472222222vw;
        padding: .5555555556vw 2.2222222222vw .8333333333vw
    }
}

@media (min-width:90em) {
    .faq .faq__item-head {
        border-radius: 5px;
        padding: 8px 32px 12px
    }
}

.faq .faq__item-head.is-show .faq__item-toggle:before {
    transform: translate(-50%, -50%) rotate(90deg)
}

.faq .faq__item-q {
    font-family: var(--font-en);
    font-size: 6.4vw;
    line-height: 1;
    margin-right: 4.2666666667vw
}

@media (min-width:52.1875em) {
    .faq .faq__item-q {
        font-size: 2.2222222222vw;
        margin-right: .9027777778vw
    }
}

@media (min-width:90em) {
    .faq .faq__item-q {
        font-size: 32px;
        margin-right: 13px
    }
}

.faq .faq__item-question {
    font-size: 4.8vw;
    line-height: 1.5;
    margin-right: 5.3333333333vw
}

@media (min-width:52.1875em) {
    .faq .faq__item-question {
        font-size: 1.25vw;
        margin-right: 0;
        padding-top: .4166666667vw
    }
}

@media (min-width:90em) {
    .faq .faq__item-question {
        font-size: 18px;
        padding-top: 6px
    }
}

.faq .faq__item-toggle {
    aspect-ratio: 1/1;
    background: var(--color-white);
    border-radius: 50%;
    flex-shrink: 0;
    margin-left: auto;
    margin-top: 1.6vw;
    position: relative;
    width: 5.8666666667vw
}

@media (min-width:52.1875em) {
    .faq .faq__item-toggle {
        margin-top: .625vw;
        width: 1.5277777778vw
    }
}

@media (min-width:90em) {
    .faq .faq__item-toggle {
        margin-top: 9px;
        width: 22px
    }
}

.faq .faq__item-toggle:after,
.faq .faq__item-toggle:before {
    background: var(--color-beige);
    border-radius: 100vmax;
    content: "";
    height: 3.2vw;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    transition: transform .3s;
    width: .5333333333vw
}

@media (min-width:52.1875em) {

    .faq .faq__item-toggle:after,
    .faq .faq__item-toggle:before {
        height: .8333333333vw;
        width: .1388888889vw
    }
}

@media (min-width:90em) {

    .faq .faq__item-toggle:after,
    .faq .faq__item-toggle:before {
        height: 12px;
        width: 2px
    }
}

.faq .faq__item-toggle:after {
    transform: translate(-50%, -50%) rotate(90deg)
}

.faq .faq__item-body {
    padding-top: 2.1333333333vw
}

@media (min-width:52.1875em) {
    .faq .faq__item-body {
        padding-top: .5555555556vw
    }
}

@media (min-width:90em) {
    .faq .faq__item-body {
        padding-top: 8px
    }
}

.faq .faq__item-inner {
    align-items: flex-start;
    background: var(--color-white);
    border: .2666666667vw solid var(--color-beige);
    border-radius: 1.3333333333vw;
    color: var(--color-beige);
    display: flex;
    padding: 6.4vw 5.3333333333vw 6.4vw 4vw
}

@media (min-width:52.1875em) {
    .faq .faq__item-inner {
        border: .0694444444vw solid var(--color-beige);
        border-radius: .3472222222vw;
        padding: 1.6666666667vw 4.8611111111vw 1.6666666667vw 2.2222222222vw
    }
}

@media (min-width:90em) {
    .faq .faq__item-inner {
        border: 1px solid var(--color-beige);
        border-radius: 5px;
        padding: 24px 70px 24px 32px
    }
}

.faq .faq__item-a {
    font-family: var(--font-en);
    font-size: 6.4vw;
    line-height: 1;
    margin-right: 4.2666666667vw
}

@media (min-width:52.1875em) {
    .faq .faq__item-a {
        font-size: 2.2222222222vw;
        margin-right: 1.1111111111vw
    }
}

@media (min-width:90em) {
    .faq .faq__item-a {
        font-size: 32px;
        margin-right: 16px
    }
}

.faq .faq__item-answer {
    font-family: var(--font-sans);
    font-size: 4.2666666667vw;
    line-height: 1.5
}

@media (min-width:52.1875em) {
    .faq .faq__item-answer {
        font-size: 1.1111111111vw
    }
}

@media (min-width:90em) {
    .faq .faq__item-answer {
        font-size: 16px
    }
}

.faq .faq__sec.is-bg-white {
    background: var(--color-white);
    margin-inline: auto;
    padding: 10.6666666667vw 2.6666666667vw;
    width: -webkit-fit-content;
    width: fit-content
}

@media (min-width:52.1875em) {
    .faq .faq__sec.is-bg-white {
        border-radius: .3472222222vw;
        padding: 4.8611111111vw
    }
}

@media (min-width:90em) {
    .faq .faq__sec.is-bg-white {
        border-radius: 5px;
        padding: 70px
    }
}

.faq .faq__cols {
    display: flex;
    flex-wrap: wrap;
    gap: 6.9333333333vw;
    justify-content: center;
    margin-top: 4.2666666667vw
}

@media (min-width:52.1875em) {
    .faq .faq__cols {
        gap: .5555555556vw;
        justify-content: flex-start;
        margin-top: 2.2222222222vw
    }
}

@media (min-width:90em) {
    .faq .faq__cols {
        gap: 8px;
        margin-top: 32px
    }
}

.faq .faq__col {
    align-items: center;
    display: flex;
    flex-direction: column;
    flex-shrink: 0;
    gap: 1.0666666667vw;
    width: calc(33.3% - 4.62222vw)
}

@media (min-width:52.1875em) {
    .faq .faq__col {
        flex: 1;
        gap: .2777777778vw
    }
}

@media (min-width:90em) {
    .faq .faq__col {
        gap: 4px
    }
}

.faq .faq__col-picto {
    align-items: center;
    aspect-ratio: 1/1;
    background: var(--color-yellow);
    display: flex;
    justify-content: center;
    padding: 1.8666666667vw;
    width: 100%
}

@media (min-width:52.1875em) {
    .faq .faq__col-picto {
        padding: .4861111111vw
    }
}

@media (min-width:90em) {
    .faq .faq__col-picto {
        padding: 7px
    }
}

.faq .faq__col-picto img {
    height: auto;
    width: 100%
}

.faq .faq__col-text {
    font-family: var(--font-sans);
    font-size: 4.2666666667vw;
    text-align: center;
    white-space: nowrap
}

@media (min-width:52.1875em) {
    .faq .faq__col-text {
        font-size: 1.1111111111vw
    }
}

@media (min-width:90em) {
    .faq .faq__col-text {
        font-size: 16px
    }
}

.faq .faq__figure {
    margin: 2.4vw auto 0
}

@media (min-width:52.1875em) {
    .faq .faq__figure {
        margin: 1.6666666667vw auto 0;
        width: 48.1944444444vw
    }
}

@media (min-width:90em) {
    .faq .faq__figure {
        margin: 24px auto 0;
        width: 694px
    }
}

.faq .faq__figure img {
    height: auto;
    width: 100%
}

.column {
    margin-top: 14.9333333333vw
}

@media (min-width:52.1875em) {
    .column {
        margin-top: 8.3333333333vw
    }
}

@media (min-width:90em) {
    .column {
        margin-top: 120px
    }
}

.column .column__cont {
    align-items: center;
    display: flex;
    flex-direction: column;
    gap: 10.6666666667vw;
    margin-right: calc(50% - 50cqi);
    margin-top: 6.4vw
}

@media (min-width:52.1875em) {
    .column .column__cont {
        gap: 3.8888888889vw;
        margin-right: 0;
        margin-top: 2.7777777778vw
    }
}

@media (min-width:90em) {
    .column .column__cont {
        gap: 56px;
        margin-top: 40px
    }
}

.column .column__cont .column__text {
    font-size: 4.2666666667vw;
    text-align: center
}

@media (min-width:52.1875em) {
    .column .column__cont .column__text {
        font-size: 1.3888888889vw;
        margin-top: 1.3888888889vw
    }
}

@media (min-width:90em) {
    .column .column__cont .column__text {
        font-size: 20px;
        margin-top: 20px
    }
}

.news {
    margin-top: 21.3333333333vw
}

@media (min-width:52.1875em) {
    .news {
        margin-top: 13.8888888889vw
    }
}

@media (min-width:90em) {
    .news {
        margin-top: 200px
    }
}

.news .news__cont {
    align-items: center;
    display: flex;
    flex-direction: column;
    gap: 10.6666666667vw;
    margin-right: calc(50% - 50cqi);
    margin-top: 6.4vw
}

@media (min-width:52.1875em) {
    .news .news__cont {
        gap: 3.8888888889vw;
        margin-right: 0;
        margin-top: 2.7777777778vw
    }
}

@media (min-width:90em) {
    .news .news__cont {
        gap: 56px;
        margin-top: 40px
    }
}

.news .news__cont .news__text {
    font-size: 4.2666666667vw;
    text-align: center
}

@media (min-width:52.1875em) {
    .news .news__cont .news__text {
        font-size: 1.3888888889vw;
        margin-top: 1.3888888889vw
    }
}

@media (min-width:90em) {
    .news .news__cont .news__text {
        font-size: 20px;
        margin-top: 20px
    }
}