/* --------------------
 Front
-------------------- */
.hero {
    margin: 0;
    padding: 32.2222222222vw 0 22.2222222222vw;
    position: relative;
}

@media (min-width: 768px) {
    .hero {
        padding: 50px 0 160px;
    }
}

@media (min-width: 1400px) {
    .hero {
        padding-bottom: 11.4285714286vw;
    }
}

.hero:before {
    background-image: url(../images/pages/front/front-hero-bg-mb.webp);
    background-position: center top;
    background-repeat: no-repeat;
    background-size: 100% auto;
    bottom: 0;
    content: "";
    display: block;
    left: 0;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 1;
}

@media (min-width: 768px) {
    .hero:before {
        background-image: url(../images/pages/front/front-hero-bg.webp);
        background-size: cover;
        bottom: -5vw;
    }
}

.hero:after {
    background-color: #1e7fb7;
    bottom: -5vw;
    content: "";
    display: block;
    left: 0;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 0;
}

.hero__deco {
    background-image: url(../images/pages/front/front-hero-deco-01-mb.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    display: block;
    height: 136.1111111111vw;
    left: 0;
    margin: 0 auto;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 61.1111111111vw;
    width: 94.4444444444vw;
    z-index: 2;
}

@media (min-width: 768px) {
    .hero__deco {
        background-image: url(../images/pages/front/front-hero-deco-01.svg);
        height: 350px;
        top: 460px;
        transform: translateX(-20px);
        width: 740px;
    }
}

.hero-container {
    margin: 0;
    padding: 0;
    position: relative;
    width: 100%;
    z-index: 3;
}

@media (min-width: 768px) {
    .hero-container {
        padding: 0 var(--c-pad);
    }
}

.hero__logo {
    font-size: 10px;
    margin: 0 0 8.3333333333vw;
    text-align: center;
}

@media (min-width: 768px) {
    .hero__logo {
        margin: 0 0 20px;
    }
}

.hero__logo img {
    vertical-align: middle;
    width: 79.4444444444vw;
}

@media (min-width: 768px) {
    .hero__logo img {
        width: 412px;
    }
}

.hero__schedule {
    font-size: 10px;
    margin: 0 auto;
    position: relative;
    text-align: center;
    width: 100%;
}

@media (min-width: 768px) {
    .hero__schedule {
        width: 490px;
    }
}

.hero__schedule picture {
    display: block;
    width: 100%;
}

.hero__schedule img {
    vertical-align: middle;
    width: 100%;
}

.hero__schedule__access {
    bottom: 2%;
    display: block;
    height: 16.6666666667vw;
    left: 25%;
    opacity: 0.2;
    position: absolute;
    right: 22%;
    width: auto;
}

@media (min-width: 768px) {
    .hero__schedule__access {
        height: 65px;
    }
}

.news {
    margin: 0 0 -42.7777777778vw;
    padding: 0 0 18.6111111111vw;
    position: relative;
    z-index: auto;
}

@media (min-width: 768px) {
    .news {
        margin: 0 0 -154px;
        padding: 0 0 67px;
    }
}

.news:before {
    background-image: url(../images/pages/front/front-news-bg.svg);
    background-position: center top;
    background-repeat: no-repeat;
    background-size: 194.4444444444vw 52.7777777778vw;
    content: "";
    display: block;
    height: 105.5555555556vw;
    left: 0;
    margin: 0 auto;
    position: absolute;
    right: 0;
    top: -22.2222222222vw;
    z-index: 1;
}

@media (min-width: 768px) {
    .news:before {
        background-size: 1400px 380px;
        height: 380px;
        top: -160px;
    }
}

@media (min-width: 1400px) {
    .news:before {
        aspect-ratio: 1400/380;
        background-size: cover;
        height: auto;
        top: -11.4285714286vw;
    }
}

.news:after {
    background-color: #e2af5e;
    bottom: 0;
    content: "";
    display: block;
    left: 0;
    position: absolute;
    right: 0;
    top: 5vw;
    z-index: 0;
}

.news-container {
    margin: 0 auto;
    max-width: calc(876px + var(--c-pad)*2);
    padding: 0 var(--c-pad);
    position: relative;
    width: 100%;
    z-index: 2;
}

.news__title {
    color: var(--color-white);
    font-size: var(--fs24);
    font-weight: 900;
    line-height: 1.2;
    margin: 0 0 8.3333333333vw;
    text-align: center;
}

@media (min-width: 768px) {
    .news__title {
        font-size: 2.5625rem;
        margin: 0 0 65px;
    }
}

.news__list {
    background-color: #1e7fb7;
    border-radius: 2.7777777778vw;
    color: var(--color-white);
    margin: 0 auto;
    padding: 6.9444444444vw 9.7222222222vw 6.9444444444vw;
}

@media (min-width: 768px) {
    .news__list {
        border-radius: 10px;
        padding: 50px 50px 50px;
    }
}

.news__list__item {
    align-items: stretch;
    color: var(--color-white);
    display: flex;
    flex-flow: column nowrap;
    gap: 0;
    justify-content: stretch;
    margin: 0 0 4.4444444444vw;
    padding: 0;
    position: relative;
    text-decoration: none;
    width: 100%;
}

@media (min-width: 768px) {
    .news__list__item {
        align-items: flex-start;
        flex-direction: row;
        justify-content: flex-start;
        margin: 0 0 16px auto;
        padding: 2px 0 0;
        width: calc(100% - 115px);
    }
}

.news__list__item:last-child {
    margin-bottom: 0;
}

.news__list__item time {
    display: block;
    font-size: var(--fs10);
    line-height: 1.4;
    margin: 0 0 1.6666666667vw;
}

@media (min-width: 768px) {
    .news__list__item time {
        flex: 0 0 130px;
        font-size: var(--fs16);
        margin: 0;
    }
}

.news__list__item span {
    display: block;
    font-size: var(--fs14);
    line-height: 1.4;
    margin: 0;
}

@media (min-width: 768px) {
    .news__list__item span {
        flex: 0 1 auto;
        font-size: var(--fs16);
    }
}

.news__list__item--new:before {
    align-items: center;
    background-color: #e2af5e;
    border-radius: 2.7777777778vw;
    content: "NEW";
    display: flex;
    font-size: var(--fs12);
    font-weight: 700;
    height: 6.6666666667vw;
    justify-content: center;
    line-height: 1.05;
    margin: 0 0 2.2222222222vw;
    text-align: center;
    transform: translateZ(0);
    width: 18.8888888889vw;
}

@media (min-width: 768px) {
    .news__list__item--new:before {
        border-radius: 10px;
        font-size: var(--fs12);
        height: 24px;
        left: -115px;
        margin: 0;
        position: absolute;
        top: -2px;
        width: 68px;
    }
}

@media (min-width: 768px) {
    _::-webkit-full-page-media, _:future, :root .news__list__item--new:before {
        top: 2px;
    }
}

a.news__list__item {
    transition: opacity var(--duration) var(--cubic) 0s;
}

a.news__list__item:focus {
    opacity: 0.6;
}

@media (hover: hover) and (pointer: fine) {
    a.news__list__item:hover {
        opacity: 0.6;
    }
}

.about {
    padding: 44.4444444444vw 0 16.6666666667vw;
    position: relative;
    z-index: 1;
}

@media (min-width: 768px) {
    .about {
        padding: 160px 0 120px;
    }
}

@media (min-width: 1400px) {
    .about {
        padding-bottom: 8.5714285714vw;
    }
}

.about:before {
    background-image: url(../images/pages/front/front-about-bg.svg);
    background-position: center top;
    background-repeat: no-repeat;
    background-size: cover;
    bottom: 0;
    content: "";
    display: block;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 0;
}

@media (min-width: 768px) {
    .about:before {
        bottom: -120px;
    }
}

@media (min-width: 1400px) {
    .about:before {
        bottom: -8.5714285714vw;
    }
}

.about-container {
    margin: 0 auto;
    max-width: calc(860px + var(--c-pad)*2);
    padding: 0 var(--c-pad);
    position: relative;
    width: 100%;
    z-index: 1;
}

.about__logo {
    font-size: 10px;
    margin: 0 0 10vw;
    text-align: center;
}

@media (min-width: 768px) {
    .about__logo {
        margin: 0 0 36px;
    }
}

.about__logo img {
    width: 63.8888888889vw;
}

@media (min-width: 768px) {
    .about__logo img {
        width: 312px;
    }
}

.about__title {
    color: var(--color-white);
    font-size: var(--fs24);
    line-height: 1.2;
    margin: 0 0 5.5555555556vw;
    text-align: center;
}

@media (min-width: 768px) {
    .about__title {
        font-size: var(--fs30);
        margin: 0 0 30px;
    }
}

.about__fig {
    align-items: flex-start;
    display: flex;
    flex-flow: row nowrap;
    gap: 1.1111111111vw;
    justify-content: center;
    margin: 0 auto 4.4444444444vw;
    width: 100%;
}

@media (min-width: 768px) {
    .about__fig {
        gap: 17px;
        margin: 0 auto 38px;
        max-width: 780px;
    }
}

.about__fig__item {
    flex: 0 0 calc(20% - 0.88889vw);
}

@media (min-width: 768px) {
    .about__fig__item {
        flex: 0 0 calc(20% - 13.6px);
    }
}

.about__fig__item:nth-child(2n-1) {
    padding: 5.5555555556vw 0 0;
}

@media (min-width: 768px) {
    .about__fig__item:nth-child(2n-1) {
        padding: 54px 0 0;
    }
}

.about__fig__item img {
    aspect-ratio: 1/1;
    border-radius: 50%;
    display: block;
    height: auto;
    object-fit: cover;
    object-position: center;
    width: 100%;
}

.about__lead {
    background-image: url(../images/pages/front/front-about-line.svg);
    background-position: center bottom;
    background-repeat: no-repeat;
    background-size: 215.5555555556vw 2.2222222222vw;
    margin: 0 -2.7777777778vw 4.4444444444vw;
    padding: 0 0 6.6666666667vw;
}

@media (min-width: 768px) {
    .about__lead {
        background-size: 776px 8px;
        margin: 0 auto 8px;
        padding: 0 0 24px;
        width: -webkit-fit-content;
        width: fit-content;
    }
}

.about__lead p {
    color: var(--color-white);
    font-size: var(--fs15);
    line-height: 1.2;
    margin: 0;
    text-align: center;
}

@media (min-width: 768px) {
    .about__lead p {
        font-size: var(--fs24);
    }
}

.about__main {
    padding: 0 0 5.5555555556vw;
}

@media (min-width: 768px) {
    .about__main {
        padding: 0 0 20px;
    }
}

.about__main__title {
    color: var(--color-white);
    font-size: var(--fs24);
    line-height: 1.4;
    margin: 0 0 8.3333333333vw;
    text-align: center;
}

@media (min-width: 768px) {
    .about__main__title {
        font-size: var(--fs30);
        margin: 0 0 30px;
    }
}

.about__main__content {
    text-align: center;
}

.about__main__content p {
    color: var(--color-white);
    display: inline;
    font-size: var(--fs14);
    line-height: 1.88;
    margin: 0;
    text-align: center;
}

@media (min-width: 768px) {
    .about__main__content p {
        display: block;
        font-size: var(--fs18);
        margin: 0 0 1.75em;
    }
}

.about__main__content p:last-child {
    margin-bottom: 0;
}

.detail {
    margin: 0 0 -0.2777777778vw;
    padding: 0 0 30.5555555556vw;
    position: relative;
    text-align: center;
    z-index: 1;
}

@media (min-width: 768px) {
    .detail {
        margin: 0 0 -1px;
        padding: 0 0 110px;
    }
}

.detail:before {
    background-image: url(../images/pages/front/front-detail-bg.svg);
    background-position: center top;
    background-repeat: no-repeat;
    background-size: 194.4444444444vw 47.2222222222vw;
    content: "";
    display: block;
    height: 94.4444444444vw;
    left: 0;
    margin: 0 auto;
    position: absolute;
    right: 0;
    top: -16.6666666667vw;
}

@media (min-width: 768px) {
    .detail:before {
        background-size: 1400px 340px;
        height: 340px;
        top: -120px;
    }
}

@media (min-width: 1400px) {
    .detail:before {
        aspect-ratio: 1400/340;
        background-size: cover;
        height: auto;
        top: -8.5714285714vw;
    }
}

.detail:after {
    background-color: #f7f7f7;
    bottom: 0;
    content: "";
    display: block;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 0;
}

@media (min-width: 768px) {
    .detail:after {
        top: 200px;
    }
}

@media (min-width: 1400px) {
    .detail:after {
        top: 14.2857142857vw;
    }
}

.detail-container {
    position: relative;
    z-index: 1;
}

.detail__title {
    background-color: var(--color-white);
    color: #153368;
    display: block;
    font-size: var(--fs24);
    line-height: 1.2;
    margin: 0 auto 10vw;
    padding: 0.05em 0.2em 0;
    width: -webkit-fit-content;
    width: fit-content;
}

@media (min-width: 768px) {
    .detail__title {
        font-size: var(--fs30);
        margin: 0 auto 36px;
    }
}

_::-webkit-full-page-media, _:future, :root .detail__title {
    padding-block: 0 0.05em;
}

.detail__item-wrapper {
    align-items: stretch;
    display: flex;
    flex-flow: row nowrap;
    gap: 3.3333333333vw;
    justify-content: center;
    margin: 0 0 13.3333333333vw;
    padding: 0 2.7777777778vw;
}

@media (min-width: 768px) {
    .detail__item-wrapper {
        gap: 38px;
        margin: 0 auto 48px;
        max-width: 680px;
        padding: 0;
        width: 100%;
    }
}

.detail__item {
    background-color: var(--color-white);
    border: 1.1111111111vw solid #eaeaea;
    border-radius: 2.7777777778vw;
    flex: 0 0 calc(50% - 6px);
    padding: 10vw 3.3333333333vw 7.7777777778vw;
}

@media (min-width: 768px) {
    .detail__item {
        border-radius: 10px;
        border-width: 11px;
        flex: 0 0 calc(50% - 19px);
        padding: 36px 20px 28px;
    }
}

.detail__item__title {
    background-image: url(../images/pages/front/front-detail-title-line.svg);
    background-position: center bottom;
    background-repeat: no-repeat;
    background-size: 60vw 2.2222222222vw;
    color: #153368;
    display: block;
    font-size: var(--fs40);
    letter-spacing: -0.01em;
    line-height: 1.05;
    margin: 0 0 4.4444444444vw;
    padding: 0 0 5.5555555556vw;
    text-align: center;
    white-space: nowrap;
}

@media (min-width: 768px) {
    .detail__item__title {
        background-size: 216px 8px;
        font-size: 5.625rem;
        margin: 0 0 22px;
        padding: 0 0 26px;
    }
}

.detail__item__title .--ls-1 {
    letter-spacing: -0.15em;
}

.detail__item__title .--ls-2 {
    letter-spacing: -0.175em;
}

.detail__item__contents h4 {
    color: #153368;
    font-size: var(--fs14);
    line-height: 1.29;
    margin: 0 0 3.3333333333vw;
}

@media (min-width: 768px) {
    .detail__item__contents h4 {
        font-size: var(--fs17);
        margin: 0 0 12px;
    }
}

.detail__item__contents p {
    font-size: var(--fs12);
    line-height: 1.23;
    margin: 0;
}

@media (min-width: 768px) {
    .detail__item__contents p {
        font-size: var(--fs13);
    }
}

.detail__gallery {
    margin: 0 0 11.1111111111vw;
}

@media (min-width: 768px) {
    .detail__gallery {
        margin: 0 0 40px;
    }
}

.detail__gallery .splide__slide {
    width: 38.8888888889vw;
}

@media (min-width: 768px) {
    .detail__gallery .splide__slide {
        width: 220px;
    }
}

.detail__ticket {
    margin: 0 0 16.6666666667vw;
    padding: 0 var(--c-pad);
}

@media (min-width: 768px) {
    .detail__ticket {
        margin: 0 0 90px;
    }
}

.detail__ticket-container {
    background-color: var(--color-white);
    border-radius: 2.7777777778vw;
    margin: 0 auto;
    padding: 8.3333333333vw var(--c-pad);
    width: 100%;
}

@media (min-width: 768px) {
    .detail__ticket-container {
        border-radius: 10px;
        max-width: 1154px;
        padding: 56px var(--c-pad);
    }
}

.detail__ticket__title {
    background-color: #eaeaea;
    color: #153368;
    display: block;
    font-size: var(--fs24);
    line-height: 1.05;
    margin: 0 auto 6.9444444444vw;
    padding: 0.1em 0.1em 0.05em;
    width: -webkit-fit-content;
    width: fit-content;
}

@media (min-width: 768px) {
    .detail__ticket__title {
        font-size: var(--fs30);
        margin: 0 auto 25px;
    }
}

_::-webkit-full-page-media, _:future, :root .detail__ticket__title {
    padding-block: 0.05em 0.1em;
}

.detail__ticket__item-wrapper {
    align-items: stretch;
    display: flex;
    flex-flow: column nowrap;
    gap: 16.6666666667vw;
    justify-content: center;
    margin: 0 auto 6.1111111111vw;
    padding: 6.6666666667vw 0 0;
    width: 100%;
}

@media (min-width: 768px) {
    .detail__ticket__item-wrapper {
        flex-direction: row;
        gap: 40px;
        margin: 0 auto 22px;
        max-width: 680px;
        padding: 24px 0 0;
    }
}

.detail__ticket__item {
    background-color: #f7f7f7;
    border-radius: 2.7777777778vw;
    padding: 15.2777777778vw 11.6666666667vw 6.6666666667vw;
    position: relative;
}

@media (min-width: 768px) {
    .detail__ticket__item {
        border-radius: 10px;
        flex: 0 0 calc(50% - 20px);
        padding: 70px 42px 24px;
    }
}

.detail__ticket__item__title {
    align-items: center;
    background-image: url(../images/pages/front/front-detail-ticket-bg.svg);
    color: var(--color-white);
    display: flex;
    flex-flow: row nowrap;
    font-size: var(--fs24);
    height: 12.2222222222vw;
    justify-content: center;
    left: 0;
    line-height: 1.2;
    margin: 0 auto 6.3888888889vw;
    padding: 0.1em 0 0.05em 4.4444444444vw;
    position: absolute;
    right: 0;
    top: -5.5555555556vw;
    width: 42.7777777778vw;
    z-index: 1;
}

@media (min-width: 768px) {
    .detail__ticket__item__title {
        font-size: var(--fs30);
        height: 54px;
        margin: 0 auto 23px;
        padding: 0.1em 0 0.05em 16px;
        top: -20px;
        width: 192px;
    }
}

_::-webkit-full-page-media, _:future, :root .detail__ticket__item__title {
    padding-block: 0.05em 0.1em;
}

.detail__ticket__item__schedule {
    left: -8.3333333333vw;
    position: absolute;
    top: 10vw;
    z-index: 1;
}

@media (min-width: 768px) {
    .detail__ticket__item__schedule {
        left: -36px;
        top: 36px;
    }
}

.detail__ticket__item__schedule img {
    width: 27.7777777778vw;
}

@media (min-width: 768px) {
    .detail__ticket__item__schedule img {
        width: 128px;
    }
}

.detail__ticket__item__type {
    margin: 0 0 6.6666666667vw;
}

@media (min-width: 768px) {
    .detail__ticket__item__type {
        margin: 0 0 24px;
    }
}

.detail__ticket__item__type:last-child {
    margin-bottom: 0;
}

.detail__ticket__item__type__item {
    background-color: var(--color-white);
    border-radius: 3.3333333333vw;
    margin: 0 0 6.1111111111vw;
    padding: 3.3333333333vw 0 3.8888888889vw;
}

@media (min-width: 768px) {
    .detail__ticket__item__type__item {
        border-radius: 12px;
        margin: 0 0 22px;
        padding: 12px 0 14px;
    }
}

.detail__ticket__item__type__item:last-child {
    margin-bottom: 0;
}

.detail__ticket__item__type__item__number {
    color: #153368;
    font-size: var(--fs14);
    font-weight: 700;
    line-height: 1.05;
    margin: 0;
    text-align: center;
}

@media (min-width: 768px) {
    .detail__ticket__item__type__item__number {
        font-size: var(--fs18);
    }
}

.detail__ticket__item__type__item__number em {
    font-size: 3.75rem;
    font-style: normal;
    font-weight: 400;
    letter-spacing: -0.05em;
}

@media (min-width: 768px) {
    .detail__ticket__item__type__item__number em {
        font-size: 4.625rem;
    }
}

.detail__ticket__item__type__item__number span.--t-1 {
    margin-left: 0.5em;
    margin-right: -0.5em;
}

.detail__ticket__item__type__item__note {
    background-color: #eaeaea;
    font-size: 10px;
    margin: 0 auto 3.3333333333vw;
    max-width: 47.2222222222vw;
    padding: 0.5555555556vw 2.2222222222vw 0;
    width: 100%;
}

@media (min-width: 768px) {
    .detail__ticket__item__type__item__note {
        margin: 0 auto 12px;
        max-width: 170px;
        padding: 2px 8px 0;
    }
}

_::-webkit-full-page-media, _:future, :root .detail__ticket__item__type__item__note {
    padding-block: 0 0.5555555556vw;
}

@media (min-width: 768px) {
    _::-webkit-full-page-media, _:future, :root .detail__ticket__item__type__item__note {
        padding-block: 0 2px;
    }
}

.detail__ticket__item__type__item__note p {
    color: #153368;
    font-size: var(--fs12);
    line-height: 1.2;
    margin: 0;
}

.detail__ticket__item__type__item__price {
    color: #153368;
    font-size: var(--fs16);
    font-weight: 700;
    line-height: 1.05;
    padding: 0 0 0 4.4444444444vw;
    text-align: center;
}

@media (min-width: 768px) {
    .detail__ticket__item__type__item__price {
        font-size: var(--fs18);
        padding: 0 0 0 16px;
    }
}

.detail__ticket__item__type__item__price em {
    font-size: 2.625rem;
    font-style: normal;
    font-weight: 700;
    letter-spacing: -0.06em;
    margin: 0 0.8333333333vw 0 0;
}

@media (min-width: 768px) {
    .detail__ticket__item__type__item__price em {
        font-size: 3.3125rem;
        margin: 0 3px 0 0;
    }
}

.detail__ticket__item__type__item__price .--ls-1 {
    letter-spacing: -0.2em;
}

.detail__ticket__item__note {
    margin: 0 auto 6.1111111111vw;
    max-width: 47.2222222222vw;
    width: 100%;
}

@media (min-width: 768px) {
    .detail__ticket__item__note {
        margin: 0 auto 22px;
        max-width: 170px;
    }
}

.detail__ticket__item__note p {
    font-size: var(--fs12);
    line-height: 1.2;
    margin: 0;
    text-align: center;
}

@media (min-width: 768px) {
    .detail__ticket__item__note p {
        font-size: var(--fs14);
    }
}

.detail__ticket__item__banner__item {
    margin: 0 auto 5.5555555556vw;
    text-align: center;
    width: 38.8888888889vw;
}

@media (min-width: 768px) {
    .detail__ticket__item__banner__item {
        margin: 0 auto 20px;
        width: 140px;
    }
}

.detail__ticket__item__banner__item a {
    text-decoration: none;
    transition: opacity var(--duration) var(--cubic) 0s;
}

.detail__ticket__item__banner__item a:focus {
    opacity: 0.65;
}

@media (hover: hover) and (pointer: fine) {
    .detail__ticket__item__banner__item a:hover {
        opacity: 0.65;
    }
}

.detail__ticket__item__banner__item img {
    width: 100%;
}

.detail__ticket__item__banner__item:last-child {
    margin-bottom: 0;
}

.detail__ticket__note {
    margin: 0 auto 11.1111111111vw;
    width: 100%;
}

@media (min-width: 768px) {
    .detail__ticket__note {
        margin: 0 auto 40px;
        max-width: 480px;
    }
}

.detail__ticket__note p {
    font-size: var(--fs13);
    line-height: 1.23;
    margin: 0;
    text-align: center;
}

@media (min-width: 768px) {
    .detail__ticket__note p {
        font-size: var(--fs14);
    }
}

.detail__ticket__flow {
    margin: 14.4444444444vw 0 0;
}

@media (min-width: 768px) {
    .detail__ticket__flow {
        margin: 52px 0 0;
    }
}

.detail__ticket__flow__title {
    color: #153368;
    font-size: var(--fs16);
    font-weight: 700;
    line-height: 1.2;
    margin: 0 0 1.1111111111vw;
    text-align: center;
}

@media (min-width: 768px) {
    .detail__ticket__flow__title {
        font-size: var(--fs18);
        margin: 0 0 4px;
    }
}

.detail__ticket__flow__note {
    margin: 0 0 1.1111111111vw;
}

@media (min-width: 768px) {
    .detail__ticket__flow__note {
        margin: 0 0 4px;
    }
}

.detail__ticket__flow__note p {
    color: #b84240;
    font-size: var(--fs12);
    line-height: 1.2;
    margin: 0;
    text-align: center;
}

@media (min-width: 768px) {
    .detail__ticket__flow__note p {
        font-size: var(--fs14);
    }
}

.detail__ticket__flow__step {
    margin: 0 auto;
    padding: 0 0 5.5555555556vw;
    width: 100%;
}

@media (min-width: 768px) {
    .detail__ticket__flow__step {
        display: grid;
        gap: 0;
        grid-gap: 0;
        grid-template-columns: repeat(4, 1fr);
        height: 140px;
        max-width: 845px;
        padding: 0 34px 0 0;
    }
}

@media (min-width: 992px) {
    .detail__ticket__flow__step {
        padding: 0 34px 0 20px;
    }
}

.detail__ticket__flow__step__item {
    background-color: #2384b6;
    color: var(--color-white);
    font-size: var(--fs12);
    padding: 11.1111111111vw 0 2.7777777778vw;
    position: relative;
}

@media (min-width: 768px) {
    .detail__ticket__flow__step__item {
        display: grid;
        gap: 0;
        grid-gap: 0;
        grid-row: span 2;
        grid-template-rows: subgrid;
        height: 100%;
        padding: 38px 0 0 48px;
    }
}

@media (min-width: 992px) {
    .detail__ticket__flow__step__item {
        font-size: var(--fs14);
    }
}

.detail__ticket__flow__step__item:after {
    bottom: -5.2777777778vw;
    -webkit-clip-path: polygon(0 0, 100% 0%, 50% 100%);
    clip-path: polygon(0 0, 100% 0%, 50% 100%);
    content: "";
    display: block;
    height: 5.5555555556vw;
    left: 0;
    position: absolute;
    right: 0;
    top: auto;
    width: auto;
    z-index: 1;
}

@media (min-width: 768px) {
    .detail__ticket__flow__step__item:after {
        bottom: 0;
        -webkit-clip-path: polygon(0 0, 100% 50%, 0 100%);
        clip-path: polygon(0 0, 100% 50%, 0 100%);
        height: auto;
        left: auto;
        right: -33px;
        top: 0;
        width: 34px;
    }
}

.detail__ticket__flow__step__item:nth-child(1) {
    background-color: #3eaacc;
}

@media (max-width: 767px) {
    .detail__ticket__flow__step__item:nth-child(1) {
        padding-top: 5.5555555556vw;
    }
}

@media (min-width: 768px) {
    .detail__ticket__flow__step__item:nth-child(1) {
        padding-left: 0;
    }
}

.detail__ticket__flow__step__item:nth-child(1):after {
    background-color: #3eaacc;
}

.detail__ticket__flow__step__item:nth-child(2) {
    background-color: #319ac4;
}

.detail__ticket__flow__step__item:nth-child(2):after {
    background-color: #319ac4;
}

.detail__ticket__flow__step__item:nth-child(3) {
    background-color: #268abc;
}

.detail__ticket__flow__step__item:nth-child(3):after {
    background-color: #268abc;
}

.detail__ticket__flow__step__item:nth-child(4) {
    background-color: #1e7fb7;
}

.detail__ticket__flow__step__item:nth-child(4):after {
    background-color: #1e7fb7;
}

.detail__ticket__flow__step__item em {
    align-content: center;
    display: block;
    font-size: var(--fs24);
    font-style: normal;
    font-weight: 700;
    grid-row: 1/2;
    line-height: 1.15;
    margin: 0;
}

@media (min-width: 768px) {
    .detail__ticket__flow__step__item em {
        font-size: var(--fs21);
        margin: 0 0 -0.1em;
    }
}

@media (min-width: 992px) {
    .detail__ticket__flow__step__item em {
        font-size: var(--fs32);
    }
}

.detail__ticket__flow__step__item span {
    display: block;
    grid-row: 2/3;
}

@media (min-width: 768px) {
    .detail__ticket__flow__step__item span:before {
        content: ".";
        overflow: hidden;
        visibility: hidden;
        width: 0px;
    }
}

.detail__map {
    margin: 0 0 16.6666666667vw;
    padding: 0 var(--c-pad);
}

@media (min-width: 768px) {
    .detail__map {
        margin: 0 0 80px;
    }
}

.detail__map-container {
    background-color: var(--color-white);
    border-radius: 2.7777777778vw;
    margin: 0 auto;
    padding: 8.3333333333vw var(--c-pad);
    width: 100%;
}

@media (min-width: 768px) {
    .detail__map-container {
        border-radius: 10px;
        max-width: 1154px;
        padding: 36px var(--c-pad) 20px;
    }
}

.detail__map__title {
    background-color: #eaeaea;
    color: #153368;
    display: block;
    font-size: var(--fs24);
    line-height: 1.05;
    margin: 0 auto 5.5555555556vw;
    padding: 0.1em 0.1em 0.05em;
    width: -webkit-fit-content;
    width: fit-content;
}

@media (min-width: 768px) {
    .detail__map__title {
        font-size: var(--fs30);
        margin: 0 auto 20px;
    }
}

_::-webkit-full-page-media, _:future, :root .detail__map__title {
    padding-block: 0.05em 0.1em;
}

.detail__map__cs {
    color: #b84240;
    font-size: var(--fs24);
    font-weight: 700;
    line-height: 1.4;
    margin: 0;
    text-align: center;
}

@media (min-width: 768px) {
    .detail__map__cs {
        font-size: var(--fs30);
    }
}

.detail__brewery {
    margin: 0 0 16.6666666667vw;
    padding: 0 var(--c-pad);
}

@media (min-width: 768px) {
    .detail__brewery {
        margin: 0 0 124px;
    }
}

.detail__brewery-container {
    margin: 0 auto;
    max-width: 1300px;
    width: 100%;
}

.detail__brewery__title {
    background-color: #eaeaea;
    color: #153368;
    display: block;
    font-size: var(--fs24);
    line-height: 1.05;
    margin: 0 auto 5.5555555556vw;
    padding: 0.1em 0.1em 0.05em;
    width: -webkit-fit-content;
    width: fit-content;
}

@media (min-width: 768px) {
    .detail__brewery__title {
        font-size: var(--fs30);
        margin: 0 auto 20px;
    }
}

_::-webkit-full-page-media, _:future, :root .detail__brewery__title {
    padding-block: 0.05em 0.1em;
}

.detail__brewery__subtitle {
    font-size: var(--fs20);
    font-weight: 400;
    line-height: 1.4;
    margin: 0 0 2.7777777778vw;
    text-align: center;
}

@media (min-width: 768px) {
    .detail__brewery__subtitle {
        font-size: var(--fs24);
        margin: 0 0 10px;
    }
}

.detail__brewery__content {
    margin: 0 0 7.7777777778vw;
}

@media (min-width: 768px) {
    .detail__brewery__content {
        margin: 0 0 28px;
    }
}

.detail__brewery__content p {
    font-size: var(--fs13);
    line-height: 1.21;
    margin: 0;
    text-align: center;
}

@media (min-width: 768px) {
    .detail__brewery__content p {
        font-size: var(--fs14);
    }
}

.detail__brewery__sake {
    margin: 0 0 11.1111111111vw;
}

@media (min-width: 768px) {
    .detail__brewery__sake {
        margin: 0 0 40px;
    }
}

.detail__brewery__sake__title {
    background-color: var(--color-black);
    color: var(--color-white);
    font-size: var(--fs20);
    font-weight: 400;
    line-height: 1.2;
    margin: 0 0 5.5555555556vw;
    padding: 2.2222222222vw 2.2222222222vw;
    text-align: center;
}

@media (min-width: 768px) {
    .detail__brewery__sake__title {
        font-size: var(--fs24);
        margin: 0 0 36px;
        padding: 14px 8px;
    }
}

.detail__brewery__sake__item-wrapper {
    display: grid;
    gap: 6.6666666667vw 8.3333333333vw;
    grid-gap: 6.6666666667vw 8.3333333333vw;
    grid-template-columns: repeat(2, 1fr);
    padding: 0;
    width: 100%;
}

@media (min-width: 768px) {
    .detail__brewery__sake__item-wrapper {
        gap: 28px 32px;
        grid-template-columns: repeat(4, 1fr);
        padding: 0 45px;
    }
}

@media (min-width: 992px) {
    .detail__brewery__sake__item-wrapper {
        grid-template-columns: repeat(6, 1fr);
    }
}

.detail__brewery__sake__item {
    color: inherit;
    display: block;
    position: relative;
    text-decoration: none;
}

.detail__brewery__sake__item__fig {
    align-items: center;
    background-color: var(--color-white);
    border-radius: 2.7777777778vw;
    display: flex;
    flex-flow: row nowrap;
    height: 50vw;
    justify-content: center;
    margin: 0 0 1.1111111111vw;
    padding: 4.4444444444vw;
    position: relative;
}

@media (min-width: 768px) {
    .detail__brewery__sake__item__fig {
        border-radius: 10px;
        height: 200px;
        margin: 0 0 4px;
        padding: 8px;
    }
}

@media (max-width: 767px) {
    .detail__brewery__sake__item__fig img {
        height: 100%;
        object-fit: contain;
        object-position: center;
        width: 100%;
    }
}

.detail__brewery__sake__item__name {
    font-size: var(--fs15);
    line-height: 1.4;
    margin: 0 0 0.5555555556vw;
    text-align: center;
}

@media (min-width: 768px) {
    .detail__brewery__sake__item__name {
        font-size: var(--fs18);
        margin: 0 0 2px;
    }
}

.detail__brewery__sake__item__area {
    font-size: var(--fs11);
    line-height: 1.4;
    text-align: center;
}

@media (min-width: 768px) {
    .detail__brewery__sake__item__area {
        font-size: var(--fs12);
    }
}

.detail__brewery__beer__title {
    background-color: var(--color-black);
    color: var(--color-white);
    font-size: var(--fs20);
    font-weight: 400;
    line-height: 1.2;
    margin: 0 0 5.5555555556vw;
    padding: 2.2222222222vw 2.2222222222vw;
    text-align: center;
}

@media (min-width: 768px) {
    .detail__brewery__beer__title {
        font-size: var(--fs24);
        margin: 0 0 20px;
        padding: 14px 8px;
    }
}

.detail__brewery__beer__cs {
    color: #b84240;
    font-size: var(--fs24);
    font-weight: 700;
    line-height: 1.4;
    margin: 0;
    text-align: center;
}

@media (min-width: 768px) {
    .detail__brewery__beer__cs {
        font-size: var(--fs30);
    }
}

.detail__shop {
    margin: 0 0 16.6666666667vw;
    padding: 0 var(--c-pad);
}

@media (min-width: 768px) {
    .detail__shop {
        margin: 0 0 50px;
        padding: 0 var(--c-pad);
    }
}

.detail__shop-container {
    background-color: var(--color-white);
    border-radius: 2.7777777778vw;
    margin: 0 auto;
    max-width: 1154px;
    padding: 8.3333333333vw var(--c-pad);
    width: 100%;
}

@media (min-width: 768px) {
    .detail__shop-container {
        border-radius: 10px;
        padding: 36px var(--c-pad) 20px;
    }
}

.detail__shop__title {
    background-color: #eaeaea;
    color: #153368;
    display: block;
    font-size: var(--fs24);
    line-height: 1.05;
    margin: 0 auto 5.5555555556vw;
    padding: 0.1em 0.1em 0.05em;
    width: -webkit-fit-content;
    width: fit-content;
}

@media (min-width: 768px) {
    .detail__shop__title {
        font-size: var(--fs30);
        margin: 0 auto 20px;
    }
}

_::-webkit-full-page-media, _:future, :root .detail__shop__title {
    padding-block: 0.05em 0.1em;
}

.detail__shop__cs {
    color: #b84240;
    font-size: var(--fs24);
    font-weight: 700;
    line-height: 1.4;
    margin: 0;
    text-align: center;
}

@media (min-width: 768px) {
    .detail__shop__cs {
        font-size: var(--fs30);
    }
}

.detail__sp {
    margin: 0;
    padding: 0 var(--c-pad);
}

@media (min-width: 768px) {
    .detail__sp {
        padding: 0 var(--c-pad);
    }
}

.detail__sp-container {
    background-color: var(--color-white);
    border-radius: 2.7777777778vw;
    margin: 0 auto;
    max-width: 1154px;
    padding: 8.3333333333vw var(--c-pad) 5.5555555556vw;
    width: 100%;
}

@media (min-width: 768px) {
    .detail__sp-container {
        border-radius: 10px;
        padding: 36px var(--c-pad) 20px;
    }
}

.detail__sp__title {
    background-color: #eaeaea;
    color: #153368;
    display: block;
    font-size: var(--fs24);
    line-height: 1.05;
    margin: 0 auto 6.9444444444vw;
    padding: 0.1em 0.1em 0.05em;
    width: -webkit-fit-content;
    width: fit-content;
}

@media (min-width: 768px) {
    .detail__sp__title {
        font-size: var(--fs30);
        margin: 0 auto 25px;
    }
}

_::-webkit-full-page-media, _:future, :root .detail__sp__title {
    padding-block: 0.05em 0.1em;
}

.detail__sp__cs {
    color: #b84240;
    font-size: var(--fs24);
    font-weight: 700;
    line-height: 1.4;
    margin: 0;
    text-align: center;
}

@media (min-width: 768px) {
    .detail__sp__cs {
        font-size: var(--fs30);
    }
}

.faq {
    background-color: #f7f7f7;
    padding: 0 0 16.6666666667vw;
}

@media (min-width: 768px) {
    .faq {
        padding: 0 0 100px;
    }
}

.faq-container {
    margin: 0 auto;
    max-width: calc(1120px + var(--c-pad)*2);
    padding: 0 var(--c-pad);
    width: 100%;
}

.faq__title {
    color: #365684;
    font-size: var(--fs38);
    font-weight: 700;
    line-height: 1.4;
    margin: 0 0 11.1111111111vw;
    text-align: center;
}

@media (min-width: 768px) {
    .faq__title {
        font-size: 3rem;
        margin: 0 0 56px;
    }
}

.faq__item {
    background-color: var(--color-white);
    border: 0.2777777778vw solid #eaeaea;
    border-radius: 3.3333333333vw;
    margin: 0 0 4.4444444444vw;
    padding: 0 2.7777777778vw;
}

@media (min-width: 768px) {
    .faq__item {
        border-radius: 12px;
        border-width: 1px;
        margin: 0 0 26px;
        padding: 0 40px;
    }
}

.faq__item:last-child {
    margin-bottom: 0;
}

.faq__item__head {
    cursor: pointer;
    padding: 3.3333333333vw 0 3.3333333333vw 8.3333333333vw;
    position: relative;
}

@media (min-width: 768px) {
    .faq__item__head {
        padding: 44px 0 44px 64px;
    }
}

.faq__item__head:before {
    background-image: url(../images/pages/front/front-faq-icon-q.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    bottom: 0;
    content: "";
    display: block;
    height: 5vw;
    left: 0;
    margin: auto 0;
    position: absolute;
    top: 0;
    width: 5vw;
}

@media (min-width: 768px) {
    .faq__item__head:before {
        height: 18px;
        left: 4px;
        width: 18px;
    }
}

.faq__item__head__title {
    font-size: var(--fs16);
    font-weight: 400;
    letter-spacing: 0.05em;
    line-height: 1.4;
    margin: 0;
    padding: 0 6.9444444444vw 0 0;
    position: relative;
}

@media (min-width: 768px) {
    .faq__item__head__title {
        font-size: var(--fs20);
        letter-spacing: 0.14em;
        padding: 0 53px 0 0;
    }
}

.faq__item__head__title:after {
    background-image: url(../images/pages/front/front-faq-icon-plus.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    bottom: 0;
    content: "";
    display: block;
    height: 4.7222222222vw;
    margin: auto 0;
    position: absolute;
    right: 0;
    top: 0;
    transition: transform var(--duration) var(--cubic) 0s;
    width: 4.7222222222vw;
}

@media (min-width: 768px) {
    .faq__item__head__title:after {
        height: 17px;
        right: 24px;
        width: 17px;
    }
}

.faq__item__contents {
    border-top: 0.2777777778vw solid #eaeaea;
    display: none;
    padding: 3.3333333333vw 0;
    position: relative;
}

@media (min-width: 768px) {
    .faq__item__contents {
        border-top-width: 1px;
        padding: 44px 0;
    }
}

.faq__item__contents__content {
    padding: 0 0 0 8.3333333333vw;
    position: relative;
}

@media (min-width: 768px) {
    .faq__item__contents__content {
        padding: 0 0 0 64px;
    }
}

.faq__item__contents__content:before {
    background-image: url(../images/pages/front/front-faq-icon-a.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    bottom: 0;
    content: "";
    display: block;
    height: 5vw;
    left: 0;
    position: absolute;
    top: 0;
    width: 5vw;
}

@media (min-width: 768px) {
    .faq__item__contents__content:before {
        height: 18px;
        left: 4px;
        width: 18px;
    }
}

.faq__item__contents__content p {
    font-size: var(--fs14);
    font-weight: 400;
    letter-spacing: 0.14em;
    line-height: 1.6;
    margin: 0 0 1.5em;
}

@media (min-width: 768px) {
    .faq__item__contents__content p {
        font-size: var(--fs16);
    }
}

.faq__item__contents__content p:last-child {
    margin-bottom: 0;
}

.faq__item__contents__content p a {
    color: #153368;
    text-decoration: underline;
}

.faq__item__contents__content p a:focus {
    text-decoration: none;
}

@media (hover: hover) and (pointer: fine) {
    .faq__item__contents__content p a:hover {
        text-decoration: none;
    }
}

.faq__item.-active .faq__item__head__title:after {
    transform: rotate(45deg);
}

.caution {
    background-color: #2384b6;
    background-image: url(../images/pages/front/front-caution-bg.webp);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    padding: 11.1111111111vw 0;
}

@media (min-width: 768px) {
    .caution {
        padding: 52px 0;
    }
}

.caution-container {
    margin: 0 auto;
    max-width: calc(860px + var(--c-pad)*2);
    padding: 0 var(--c-pad);
    width: 100%;
}

.caution__title {
    color: var(--color-white);
    font-size: var(--fs20);
    line-height: 1.4;
    margin: 0 0 2.2222222222vw;
    text-align: center;
}

@media (min-width: 768px) {
    .caution__title {
        font-size: var(--fs24);
        margin: 0 0 8px;
    }
}

.caution__icon {
    margin: 0 0 8.8888888889vw;
    text-align: center;
}

@media (min-width: 768px) {
    .caution__icon {
        margin: 0 0 32px;
    }
}

.caution__content p {
    color: var(--color-white);
    font-size: var(--fs13);
    line-height: 1.8;
    margin: 0 0 1.5em;
    text-align: center;
}

@media (min-width: 768px) {
    .caution__content p {
        font-size: var(--fs14);
    }
}

.caution__content p:last-child {
    margin-bottom: 0;
}

.access {
    background-color: #eaeaea;
    padding: 16.6666666667vw var(--c-pad) 0;
    text-align: center;
}

@media (min-width: 768px) {
    .access {
        padding: 60px var(--c-pad) 0;
    }
}

.access__title {
    color: #153368;
    font-size: var(--fs24);
    line-height: 1.4;
    margin: 0 0 4.4444444444vw;
    text-align: center;
}

@media (min-width: 768px) {
    .access__title {
        font-size: var(--fs30);
        margin: 0 0 16px;
    }
}

.access__address {
    display: block;
    font-size: var(--fs14);
    line-height: 1.2;
    margin: 0 0 10vw;
}

@media (min-width: 768px) {
    .access__address {
        font-size: var(--fs18);
        margin: 0 0 36px;
    }
}

.access__address a {
    display: inline-block;
    margin-left: 0.5em;
    text-decoration: none;
    transform: translateY(-0.1em);
}

@media (min-width: 768px) {
    .access__address a {
        margin-right: -24px;
    }
}

.access__address a img {
    width: 3.8888888889vw;
}

@media (min-width: 768px) {
    .access__address a img {
        width: 16px;
    }
}

.access__list {
    display: grid;
    gap: 5.5555555556vw;
    grid-gap: 5.5555555556vw;
    grid-template-columns: repeat(2, 1fr);
    margin: 0 auto 13.8888888889vw;
    position: relative;
    width: 100%;
    z-index: 1;
}

@media (min-width: 768px) {
    .access__list {
        gap: 0;
        margin: 0 auto 50px;
        max-width: 700px;
    }
}

.access__list:before {
    background-image: url(../images/pages/front/front-access-line.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    bottom: 0;
    content: "";
    display: block;
    height: 30.5555555556vw;
    left: 0;
    margin: auto;
    position: absolute;
    right: 0;
    top: 0;
    width: 0.8333333333vw;
}

@media (min-width: 768px) {
    .access__list:before {
        height: 110px;
        width: 3px;
    }
}

.access__list__walk {
    display: grid;
    gap: 0;
    grid-gap: 0;
    grid-row: span 4;
    grid-template-rows: subgrid;
    padding: 0;
    position: relative;
}

.access__list__walk:before {
    background-image: url(../images/pages/front/front-access-bg-01.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    bottom: auto;
    content: "";
    display: block;
    height: 33.6666666667vw;
    left: 0;
    margin: auto;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 39vw;
    z-index: -1;
}

@media (min-width: 768px) {
    .access__list__walk:before {
        height: 202px;
        width: 234px;
    }
}

.access__list__walk__title {
    color: #153368;
    font-size: var(--fs24);
    font-weight: 700;
    grid-row: 1/2;
    line-height: 1.4;
    margin: 0 0 3.3333333333vw;
    text-align: center;
}

@media (min-width: 768px) {
    .access__list__walk__title {
        font-size: var(--fs30);
        margin: 0 0 12px;
    }
}

.access__list__walk__icon {
    grid-row: 2/3;
    margin: 0 0 3.3333333333vw;
    text-align: center;
}

@media (min-width: 768px) {
    .access__list__walk__icon {
        margin: 0 0 12px;
    }
}

.access__list__walk__content {
    grid-row: 3/4;
}

.access__list__walk__content p {
    font-size: var(--fs14);
    margin: 0;
    text-align: center;
}

@media (min-width: 768px) {
    .access__list__walk__content p {
        font-size: var(--fs18);
    }
}

.access__list__bus {
    display: grid;
    gap: 0;
    grid-gap: 0;
    grid-row: span 4;
    grid-template-rows: subgrid;
    padding: 0;
    position: relative;
}

.access__list__bus:before {
    background-image: url(../images/pages/front/front-access-bg-02.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    bottom: auto;
    content: "";
    display: block;
    height: 33.6666666667vw;
    left: 0;
    margin: auto;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 39vw;
    z-index: -1;
}

@media (min-width: 768px) {
    .access__list__bus:before {
        height: 202px;
        width: 234px;
    }
}

.access__list__bus__title {
    color: #153368;
    font-size: var(--fs24);
    font-weight: 700;
    grid-row: 1/2;
    line-height: 1.4;
    margin: 0 0 3.3333333333vw;
    text-align: center;
}

@media (min-width: 768px) {
    .access__list__bus__title {
        font-size: var(--fs30);
        margin: 0 0 12px;
    }
}

.access__list__bus__icon {
    grid-row: 2/3;
    margin: 0 0 3.3333333333vw;
    text-align: center;
}

@media (min-width: 768px) {
    .access__list__bus__icon {
        margin: 0 0 12px;
    }
}

.access__list__bus__content {
    grid-row: 3/4;
}

.access__list__bus__content p {
    font-size: var(--fs14);
    margin: 0;
    text-align: center;
}

@media (min-width: 768px) {
    .access__list__bus__content p {
        font-size: var(--fs18);
    }
}

.access__msg {
    background-color: #e2af5e;
    color: var(--color-white);
    margin: 0 auto 4.4444444444vw;
    padding: 0.5555555556vw 4.4444444444vw 0;
    width: -webkit-fit-content;
    width: fit-content;
}

@media (min-width: 768px) {
    .access__msg {
        margin: 0 auto 16px;
        padding: 2px 8px 0;
    }
}

_::-webkit-full-page-media, _:future, :root .access__msg {
    padding-block: 0px 0.5555555556vw;
}

@media (min-width: 768px) {
    _::-webkit-full-page-media, _:future, :root .access__msg {
        padding-block: 0px 2px;
    }
}

.access__msg p {
    font-size: var(--fs20);
    font-weight: 700;
    line-height: 1.4;
    margin: 0;
}

@media (min-width: 768px) {
    .access__msg p {
        font-size: var(--fs24);
    }
}

.access__map {
    margin: 0 calc(var(--c-pad)*-1);
}

.access__map iframe {
    border: none;
    border-radius: 0;
    display: block;
    height: 88.8888888889vw;
    width: 100%;
}

@media (min-width: 768px) {
    .access__map iframe {
        height: 500px;
    }
}