@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Shippori+Mincho&display=swap");
@font-face {
  font-family: "SoDoSans";
  font-style: normal;
  font-weight: 400;
  src: url("/common/fonts/SoDoSans/SoDoSans-Regular.woff") format("woff2");
}
@font-face {
  font-family: "SoDoSans";
  font-style: normal;
  font-weight: 700;
  src: url("/common/fonts/SoDoSans/SoDoSans-Bold.woff") format("woff2");
}
.u-en {
  font-family: "SoDoSans";
}

.u-min {
  font-family: "Shippori Mincho", serif;
}

article {
  color: #000;
}
article a {
  color: #000;
}
article img {
  width: 100%;
}
article a {
  display: block;
}
article h2, article h3 {
  margin: 0;
}

@media print, screen and (min-width: 1024px) {
  :root {
    --card-width: 430px;
    --card-pos1: 0;
    --card-pos2: calc(-1 * var(--card-width));
    --card-pos3: calc(-2 * var(--card-width));
    --card-pos4: calc(-3 * var(--card-width));
    --card-pos5: calc(-4 * var(--card-width));
  }
  .c-prlx-main-section {
    position: relative;
    height: 120vh;
    height: calc(100vh - 160px);
  }
  .c-prlx-main-view {
    position: sticky;
    top: 0;
    left: 0;
    right: 0;
    height: calc(100vh - 160px);
  }
  .c-prlx-year-card-section {
    position: relative;
    height: 500vh;
  }
  .c-prlx-year-card-view {
    position: sticky;
    top: 0;
    left: 0;
    right: 0;
    height: 100vh;
  }
  .c-prlx-main-bg {
    transform: translate(0, calc(var(--scroll-progress) * -100px + 45px));
  }
  .c-prlx-year-card-content {
    position: relative;
  }
  .block-wrap {
    position: relative;
  }
  .block-wrap h2, .block-wrap h3, .block-wrap h4, .block-wrap p {
    margin: 0;
  }
  .block-wrap sup {
    font-size: 70%;
  }
  .block-wrap img {
    width: 100%;
  }
  .block-wrap {
    -webkit-font-smoothing: antialiased;
    --w:1440;
    --tc:rgba(0, 0, 0, 0.87);
  }
  .block-stage {
    background: #fff;
    width: 430px;
    margin: 0 auto;
    overflow: clip;
  }
  .block-stage-bg {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    height: 100vh;
    z-index: -1;
    background: linear-gradient(180deg, #256E53 0%, #00372F 100%);
  }
  .block-main {
    position: relative;
    height: 802.67px;
  }
  .block-main ._bg {
    width: 430px;
    position: absolute;
    top: 0;
    left: 0;
  }
  .block-main ._logo {
    width: 231.63px;
    position: absolute;
    top: 28.67px;
    left: 105.49px;
  }
  .block-main ._copy {
    width: 430px;
    position: absolute;
    top: 236.21px;
    left: 0;
  }
  .block-main ._title {
    width: 268.32px;
    position: absolute;
    top: 384.13px;
    left: 73.39px;
  }
  .block-main p._lead {
    font-size: 13.76px;
    line-height: 2.17;
    letter-spacing: 0.3333em;
    font-weight: bold;
    text-align: center;
    color: #000;
    position: absolute;
    top: 673.09px;
    left: 36.69px;
  }
  .block-main svg {
    width: 100%;
    height: auto;
  }
  .block-stage-pc {
    position: absolute;
    top: 0;
    left: 0;
    width: calc(50vw - 229.33px);
    height: 0;
    position: sticky;
    visibility: visible;
    opacity: 1;
  }
  .block-stage-pc ._inner {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    height: 90vh;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .block-stage-pc ._logo-pc {
    width: 194.93px;
    margin-top: -57.33px;
    margin-left: 22.93px;
  }
  body.is-stage-last .block-stage-pc {
    visibility: hidden;
    opacity: 0;
    transition-duration: 0.2s;
  }
  /* -------------------------------------------------- */
  .block-menu {
    width: 430px;
    padding: 5.73px 0 0 0;
    position: relative;
  }
  .block-menu ._btns {
    display: flex;
    gap: 25.23px;
    width: 371.52px;
    margin: 0 auto;
  }
  .block-menu ._btn-special1 {
    width: 172px;
  }
  .block-menu ._btn-special2 {
    width: 172px;
  }
  .block-menu a {
    display: block;
  }
  .mod-btn-menu-special1 {
    width: 172px;
    height: 157.09px;
    position: relative;
    display: block;
    width: 172px;
    height: 157.09px;
    background-image: url("/30th/images/menu/btn-special1.webp");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    cursor: pointer;
    transition-duration: 0.2s;
  }
  .mod-btn-menu-special1:hover {
    opacity: 0.8;
  }
  .mod-btn-menu-special1::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    opacity: 0;
    transition-duration: 0.2s;
    background-image: url("/30th/images/menu/btn-special1-on.webp");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  .mod-btn-menu-special1.is-active::after {
    opacity: 1;
  }
  .mod-btn-menu-special2 {
    width: 172px;
    height: 157.09px;
    background-image: url("/30th/images/menu/btn-special2-coming.webp");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  /* -------------------------------------------------- */
  .block-history {
    width: 430px;
    height: 2073.17px;
    position: relative;
    background-image: url("/30th/images/history/bg.webp?");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  .block-history ._p1 {
    width: 137.6px;
    position: absolute;
    top: 282.08px;
    left: 73.39px;
  }
  .block-history ._p2 {
    width: 222.45px;
    position: absolute;
    top: 379.55px;
    left: 227.04px;
  }
  .block-history ._p3 {
    width: 111.23px;
    position: absolute;
    top: 595.12px;
    left: 68.8px;
  }
  .block-history ._p4 {
    width: 114.67px;
    position: absolute;
    top: 790.05px;
    left: 235.07px;
  }
  .block-history ._p5 {
    width: 267.17px;
    position: absolute;
    top: 929.95px;
    left: -53.89px;
  }
  .block-history ._p6 {
    width: 181.17px;
    position: absolute;
    top: 1217.76px;
    left: 230.48px;
  }
  .block-history ._p7 {
    width: 183.47px;
    position: absolute;
    top: 113.52px;
    left: 235.07px;
  }
  .block-history ._p8 {
    width: 258px;
    position: absolute;
    top: 1293.44px;
    left: 9.17px;
  }
  .block-history p {
    color: #006241;
  }
  .block-history p._t1 {
    font-size: 11.47px;
    line-height: 1.4;
    text-align: right;
    position: absolute;
    top: 210.99px;
    left: 103.2px;
  }
  .block-history p._t2 {
    font-size: 11.47px;
    line-height: 1.4;
    text-align: right;
    position: absolute;
    top: 535.49px;
    left: 82.56px;
    text-align: right;
  }
  .block-history p._t3 {
    font-size: 11.47px;
    line-height: 1.4;
    text-align: right;
    position: absolute;
    top: 882.93px;
    left: 114.67px;
  }
  .block-history p._t4 {
    font-size: 11.47px;
    line-height: 1.4;
    text-align: right;
    position: absolute;
    top: 1276.24px;
    left: 64.21px;
  }
  .block-history p._t5 {
    font-size: 11.47px;
    line-height: 1.4;
    position: absolute;
    top: 1441.36px;
    left: 245.39px;
  }
  .block-history p._t6 {
    font-size: 11.47px;
    line-height: 1.4;
    position: absolute;
    top: 372.67px;
    left: 245.39px;
  }
  .block-history p._t7 {
    font-size: 11.47px;
    line-height: 1.4;
    position: absolute;
    top: 712.08px;
    left: 245.39px;
  }
  .block-history p._t8 {
    font-size: 11.47px;
    line-height: 1.4;
    position: absolute;
    top: 1096.21px;
    left: 245.39px;
  }
  .block-history p._t9 {
    font-size: 13.76px;
    line-height: 1.4;
    text-align: center;
    position: absolute;
    top: 1692.48px;
    left: 82.56px;
  }
  /* -------------------------------------------------- */
  .block-special1-bg {
    position: relative;
    margin-top: -91.73px;
    background-image: url("/30th/images/special1-1/bg.webp?");
    background-size: 100% auto;
    background-position: top center;
    background-repeat: no-repeat;
  }
  /* -------------------------------------------------- */
  .block-special1-1 {
    position: relative;
    width: 430px;
    height: 1169.6px;
  }
  .block-special1-1 ._logo-30th {
    width: 303.87px;
    position: absolute;
    top: 67.65px;
    left: 66.51px;
  }
  .block-special1-1 ._copy {
    width: 430px;
    position: absolute;
    top: 181.17px;
    left: 0;
  }
  .block-special1-1 ._cafe {
    width: 399.04px;
    position: absolute;
    top: 439.17px;
    left: 33.25px;
  }
  .block-special1-1 ._deco {
    width: 391.01px;
    position: absolute;
    top: 591.68px;
    left: 13.76px;
  }
  .block-special1-1 ._number {
    width: 321.07px;
    position: absolute;
    top: 921.92px;
    left: 57.33px;
  }
  .block-special1-1 p._note {
    position: absolute;
    top: 858.85px;
    left: 68.8px;
  }
  .block-special1-1 p._doc {
    position: absolute;
    top: 987.28px;
    left: 75.68px;
  }
  .block-special1-1 p._note {
    font-size: 11.47px;
    line-height: 1.4;
    text-align: center;
    color: #fff;
  }
  .block-special1-1 p._doc {
    font-size: 14.91px;
    line-height: 2.15;
    letter-spacing: 0.18em;
    font-weight: bold;
    text-align: center;
    color: #fbf7ce;
  }
  /* -------------------------------------------------- */
  .block-special1-2 {
    position: relative;
    width: 431.15px;
    height: 1240.69px;
  }
  .block-special1-2 ._copy {
    width: 430px;
    position: absolute;
    top: 12.61px;
    left: 0;
  }
  .block-special1-2 ._title {
    width: 301.57px;
    position: absolute;
    top: 443.76px;
    left: 63.07px;
  }
  .block-special1-2 ._star {
    width: 392.16px;
    position: absolute;
    top: 524.03px;
    left: 26.37px;
    z-index: 2;
  }
  .block-special1-2 ._covers1 {
    position: absolute;
    top: 782.03px;
    right: 0;
    left: 0;
  }
  .block-special1-2 ._covers2 {
    position: absolute;
    top: 1011.36px;
    right: 0;
    left: 0;
  }
  .mod-special1-2-covers1 {
    width: 430px;
    height: 229.33px;
    background-image: url("/30th/images/special1-2/covers1.webp?");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-position: left top;
    background-size: 825.6px auto;
    background-repeat: repeat;
  }
  .mod-special1-2-covers2 {
    width: 430px;
    height: 229.33px;
    background-image: url("/30th/images/special1-2/covers2.webp?");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-position: left top;
    background-size: 825.6px auto;
    background-repeat: repeat;
  }
  /* -------------------------------------------------- */
  .block-special1-3 {
    position: relative;
    width: 430px;
    height: 1058.37px;
  }
  .block-special1-3 ._deco {
    width: 420.83px;
    position: absolute;
    top: 6.88px;
    left: 5.73px;
  }
  .block-special1-3 p._doc {
    position: absolute;
    top: 26.37px;
    left: 68.8px;
  }
  .block-special1-3 p._doc {
    font-size: 14.91px;
    line-height: 2.15;
    letter-spacing: 0.18em;
    font-weight: bold;
    text-align: center;
    color: #fbf7ce;
  }
  .block-special1-3 ._trophy {
    width: 227.04px;
    position: absolute;
    top: 283.23px;
    left: 119.25px;
  }
  .block-special1-3 ._mask {
    width: 183.47px;
    height: 315.33px;
    position: absolute;
    top: 284.37px;
    left: 123.84px;
  }
  .block-special1-3 ._kira {
    width: 43.57px;
    position: absolute;
    top: 282.08px;
    left: 162.83px;
  }
  .block-special1-3 ._covers1 {
    position: absolute;
    top: 599.71px;
    right: 0;
    left: 0;
  }
  .block-special1-3 ._covers2 {
    position: absolute;
    top: 829.04px;
    right: 0;
    left: 0;
  }
  .mod-special1-3-covers1 {
    width: 430px;
    height: 229.33px;
    background-image: url("/30th/images/special1-3/covers1.webp?2");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-position: left top;
    background-size: 825.6px auto;
    background-repeat: repeat;
  }
  .mod-special1-3-covers2 {
    width: 430px;
    height: 229.33px;
    background-image: url("/30th/images/special1-3/covers2.webp?2");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-position: left top;
    background-size: 825.6px auto;
    background-repeat: repeat;
  }
  /* -------------------------------------------------- */
  .block-special1-4 {
    position: relative;
    width: 430px;
    background: #000;
  }
  .block-special1-4 ._navi-prev {
    position: absolute;
    top: 344px;
    left: 2.29px;
    z-index: 10;
    opacity: 0;
  }
  .block-special1-4 ._navi-next {
    position: absolute;
    top: 344px;
    right: 2.29px;
    z-index: 10;
    opacity: 0;
  }
  .block-special1-4 ._pagers {
    position: absolute;
    top: 710.93px;
    right: 0;
    left: 0;
    z-index: 10;
  }
  .mod-card-navi-prev {
    width: 41.28px;
    height: 82.56px;
    transition-duration: 0.2s;
  }
  .mod-card-navi-prev span {
    display: block;
    width: 41.28px;
    height: 82.56px;
    background-image: url("/30th/images/common/icon-prev.webp");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    cursor: pointer;
    transition-duration: 0.2s;
  }
  .mod-card-navi-prev span:hover {
    opacity: 0.8;
  }
  .mod-card-navi-next {
    width: 41.28px;
    height: 82.56px;
    transition-duration: 0.2s;
  }
  .mod-card-navi-next span {
    display: block;
    width: 41.28px;
    height: 82.56px;
    background-image: url("/30th/images/common/icon-next.webp");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    cursor: pointer;
    transition-duration: 0.2s;
  }
  .mod-card-navi-next span:hover {
    opacity: 0.8;
  }
  body.is-card-slide2 .block-special1-4 ._navi-prev {
    opacity: 1;
  }
  body.is-card-slide3 .block-special1-4 ._navi-prev {
    opacity: 1;
  }
  body.is-card-slide4 .block-special1-4 ._navi-prev {
    opacity: 1;
  }
  body.is-card-slide5 .block-special1-4 ._navi-prev {
    opacity: 1;
  }
  body.is-card-slide1 .block-special1-4 ._navi-next {
    opacity: 1;
  }
  body.is-card-slide2 .block-special1-4 ._navi-next {
    opacity: 1;
  }
  body.is-card-slide3 .block-special1-4 ._navi-next {
    opacity: 1;
  }
  body.is-card-slide4 .block-special1-4 ._navi-next {
    opacity: 1;
  }
  body.is-card-slide5 .block-special1-4 ._navi-next {
    opacity: 0;
  }
  .mod-card-pagers {
    display: flex;
    gap: 4.59px;
    justify-content: center;
  }
  .mod-card-pagers ._pager {
    width: 18.35px;
    height: 18.35px;
    background-image: url("/30th/images/common/icon-pager.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide1 .block-special1-4 ._pager.is-1 {
    background-image: url("/30th/images/common/icon-pager-on.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide2 .block-special1-4 ._pager.is-2 {
    background-image: url("/30th/images/common/icon-pager-on.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide3 .block-special1-4 ._pager.is-3 {
    background-image: url("/30th/images/common/icon-pager-on.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide4 .block-special1-4 ._pager.is-4 {
    background-image: url("/30th/images/common/icon-pager-on.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide5 .block-special1-4 ._pager.is-5 {
    background-image: url("/30th/images/common/icon-pager-on.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide2 .block-special1-4 ._pager.is-1 {
    background-image: url("/30th/images/common/icon-pager.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide3 .block-special1-4 ._pager.is-2 {
    background-image: url("/30th/images/common/icon-pager.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide4 .block-special1-4 ._pager.is-3 {
    background-image: url("/30th/images/common/icon-pager.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide5 .block-special1-4 ._pager.is-4 {
    background-image: url("/30th/images/common/icon-pager.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide2 .block-special1-4 ._cards {
    transform: translateX(var(--card-pos2));
  }
  body.is-card-slide3 .block-special1-4 ._cards {
    transform: translateX(var(--card-pos3));
  }
  body.is-card-slide4 .block-special1-4 ._cards {
    transform: translateX(var(--card-pos4));
  }
  body.is-card-slide5 .block-special1-4 ._cards {
    transform: translateX(var(--card-pos5));
  }
  .mod-year-card {
    height: 779.73px;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .mod-year-card.is-1 {
    background-image: url("/30th/images/special1-4/bg1.webp?14");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  .mod-year-card.is-2 {
    background-image: url("/30th/images/special1-4/bg2.webp?14");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  .mod-year-card.is-3 {
    background-image: url("/30th/images/special1-4/bg3.webp?14");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  .mod-year-card.is-4 {
    background-image: url("/30th/images/special1-4/bg4.webp?14");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  .mod-year-card.is-5 {
    background-image: url("/30th/images/special1-4/bg5.webp?14");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  .mod-year-card.is-1 ._deco {
    width: 90.59px;
    position: absolute;
    top: 29.81px;
    left: 26.37px;
  }
  .mod-year-card.is-1 ._year {
    width: 76.83px;
    position: absolute;
    top: 16.05px;
    left: 176.59px;
  }
  .mod-year-card.is-1 ._copy {
    width: 124.99px;
    position: absolute;
    top: 91.73px;
    left: 276.35px;
  }
  .mod-year-card.is-1 ._name {
    width: 206.4px;
    position: absolute;
    top: 421.97px;
    left: 112.37px;
  }
  .mod-year-card.is-1 ._texts {
    width: 374.96px;
    position: absolute;
    top: 533.2px;
    left: 27.52px;
  }
  .mod-year-card.is-1 ._texts {
    color: #e8c689;
  }
  .mod-year-card.is-1 .c-card-btn {
    border-color: #e8c689;
    color: #e8c689;
  }
  .mod-year-card.is-2 ._deco {
    width: 90.59px;
    position: absolute;
    top: 29.81px;
    left: 310.75px;
  }
  .mod-year-card.is-2 ._year {
    width: 76.83px;
    position: absolute;
    top: 16.05px;
    left: 176.59px;
  }
  .mod-year-card.is-2 ._copy {
    width: 124.99px;
    position: absolute;
    top: 91.73px;
    left: 30.96px;
  }
  .mod-year-card.is-2 ._name {
    width: 215.57px;
    position: absolute;
    top: 421.97px;
    left: 107.79px;
  }
  .mod-year-card.is-2 ._texts {
    width: 374.96px;
    position: absolute;
    top: 533.2px;
    left: 27.52px;
  }
  .mod-year-card.is-2 ._texts {
    color: #e8c689;
  }
  .mod-year-card.is-2 .c-card-btn {
    border-color: #e8c689;
    color: #e8c689;
  }
  .mod-year-card.is-3 ._deco {
    width: 90.59px;
    position: absolute;
    top: 29.81px;
    left: 26.37px;
  }
  .mod-year-card.is-3 ._year {
    width: 76.83px;
    position: absolute;
    top: 16.05px;
    left: 176.59px;
  }
  .mod-year-card.is-3 ._copy {
    width: 124.99px;
    position: absolute;
    top: 91.73px;
    left: 276.35px;
  }
  .mod-year-card.is-3 ._name {
    width: 206.4px;
    position: absolute;
    top: 421.97px;
    left: 112.37px;
  }
  .mod-year-card.is-3 ._texts {
    width: 374.96px;
    position: absolute;
    top: 533.2px;
    left: 27.52px;
  }
  .mod-year-card.is-3 ._texts {
    color: #f9d1cb;
  }
  .mod-year-card.is-3 .c-card-btn {
    border-color: #f9d1cb;
    color: #f9d1cb;
  }
  .mod-year-card.is-4 ._deco {
    width: 90.59px;
    position: absolute;
    top: 29.81px;
    left: 310.75px;
  }
  .mod-year-card.is-4 ._year {
    width: 76.83px;
    position: absolute;
    top: 16.05px;
    left: 176.59px;
  }
  .mod-year-card.is-4 ._copy {
    width: 124.99px;
    position: absolute;
    top: 91.73px;
    left: 30.96px;
  }
  .mod-year-card.is-4 ._name {
    width: 215.57px;
    position: absolute;
    top: 421.97px;
    left: 107.79px;
  }
  .mod-year-card.is-4 ._texts {
    width: 374.96px;
    position: absolute;
    top: 533.2px;
    left: 27.52px;
  }
  .mod-year-card.is-4 ._texts {
    color: #ebd56c;
  }
  .mod-year-card.is-4 .c-card-btn {
    border-color: #ebd56c;
    color: #ebd56c;
  }
  .mod-year-card.is-5 ._deco {
    width: 90.59px;
    position: absolute;
    top: 29.81px;
    left: 26.37px;
  }
  .mod-year-card.is-5 ._year {
    width: 76.83px;
    position: absolute;
    top: 16.05px;
    left: 176.59px;
  }
  .mod-year-card.is-5 ._copy {
    width: 124.99px;
    position: absolute;
    top: 91.73px;
    left: 276.35px;
  }
  .mod-year-card.is-5 ._name {
    width: 206.4px;
    position: absolute;
    top: 421.97px;
    left: 112.37px;
  }
  .mod-year-card.is-5 ._texts {
    width: 374.96px;
    position: absolute;
    top: 533.2px;
    left: 27.52px;
  }
  .mod-year-card.is-5 ._texts {
    color: #efed72;
  }
  .mod-year-card.is-5 .c-card-btn {
    border-color: #efed72;
    color: #efed72;
  }
  .mod-year-card ._card-inner {
    width: 430px;
    height: 745.33px;
    position: relative;
  }
  .mod-year-card ._card-inner ._star {
    width: 364.64px;
    position: absolute;
    top: 75.68px;
    left: 33.25px;
  }
  .mod-year-card ._card-inner ._cafe {
    width: 253.41px;
    position: absolute;
    top: 91.73px;
    left: 98.61px;
    cursor: pointer;
    transition: filter 0.2s;
  }
  .mod-year-card ._card-inner ._cafe:hover {
    filter: brightness(1.05);
  }
  .mod-year-card ._card-inner ._title {
    font-size: 18.35px;
    line-height: 1.4;
    font-weight: bold;
    text-align: center;
  }
  .mod-year-card ._card-inner ._title small {
    font-size: 11.47px;
  }
  .mod-year-card ._card-inner p._lead {
    font-size: 13.76px;
    line-height: 1.5;
    text-align: center;
  }
  .mod-year-card ._card-inner ._btn {
    margin-top: 13.76px;
    display: flex;
    gap: 0;
    justify-content: center;
  }
  ._controllers {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  ._controllers ._controllers-inner {
    position: relative;
    width: 430px;
    height: 756.8px;
  }
  .c-card-btn {
    width: 206.4px;
    height: 49.31px;
    border: 1.15px solid #000;
    border-radius: 114.67px;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .c-card-btn span {
    font-size: 18.35px;
    line-height: 1;
    font-weight: bold;
    text-align: center;
  }
  .c-card-btn {
    cursor: pointer;
    transition-duration: 0.2s;
  }
  .c-card-btn:hover {
    opacity: 0.8;
  }
  /* -------------------------------------------------- */
  .block-special1-5 {
    position: relative;
    width: 430px;
    height: 1410.4px;
    background-image: url("/30th/images/special1-5/bg.webp?4");
    background-size: 100% auto;
    background-position: top center;
    background-repeat: no-repeat;
  }
  .block-special1-5 ._copy {
    width: 430px;
    position: absolute;
    top: 59.63px;
    left: 0;
  }
  .block-special1-5 ._title {
    width: 308.45px;
    position: absolute;
    top: 511.41px;
    left: 61.92px;
  }
  .block-special1-5 p._doc {
    position: absolute;
    top: 615.76px;
    left: 73.39px;
  }
  .block-special1-5 p._doc {
    font-size: 14.91px;
    line-height: 2.15;
    letter-spacing: 0.2em;
    font-weight: bold;
    text-align: center;
    color: #fbf7ce;
  }
  .block-special1-5 ._cafe {
    width: 236.21px;
    position: absolute;
    top: 801.52px;
    left: 189.2px;
  }
  .block-special1-5 ._photo {
    width: 332.53px;
    position: absolute;
    top: 873.76px;
    left: 48.16px;
  }
  .block-special1-5 ._logo {
    width: 217.87px;
    position: absolute;
    top: 1140.93px;
    left: 111.23px;
  }
  /* -------------------------------------------------- */
  /* -------------------------------------------------- */
  /* -------------------------------------------------- */
  .block-special2-coming {
    width: 431.15px;
    height: 668.51px;
    position: relative;
    margin-top: -106.64px;
    background-image: url("/30th/images/special2-coming/bg.webp?2");
    background-size: 100% auto;
    background-position: top center;
    background-repeat: no-repeat;
  }
  .block-special2-coming ._title {
    width: 299.28px;
    position: absolute;
    top: 75.68px;
    left: 65.36px;
  }
  .block-special2-coming ._copy {
    width: 430px;
    position: absolute;
    top: 202.96px;
    left: 0;
  }
  .mod-deco {
    pointer-events: none;
  }
  .mod-hover {
    display: block;
    cursor: pointer;
  }
  .mod-hover:hover {
    opacity: 0.8;
  }
  .mod-link-image {
    display: block;
    cursor: pointer;
    transition-duration: 0.2s;
  }
  .mod-link-image:hover {
    filter: brightness(1.1);
  }
  .mod-link-image-hover {
    opacity: 0;
    transition-duration: 0.2s;
  }
  .mod-link-image-hover:hover {
    opacity: 1;
  }
  .mod-swiper {
    position: relative;
    width: 100%;
    margin: 0 auto;
    --swiper-navigation-color: #007aff;
    --swiper-navigation-size: 44px;
    --swiper-navigation-sides-offset: 10px;
    --swiper-pagination-bottom: 25px;
  }
  .mod-swiper .swiper-button-prev:after {
    content: "";
  }
  .mod-swiper .swiper-button-prev {
    width: 36px;
    height: 72px;
    background-image: url("/30th/images/common/icon-prev.webp");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    top: calc(50% - 20px);
  }
  .mod-swiper .swiper-button-next:after {
    content: "";
  }
  .mod-swiper .swiper-button-next {
    width: 36px;
    height: 72px;
    background-image: url("/30th/images/common/icon-next.webp");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    top: calc(50% - 20px);
  }
  .mod-swiper .swiper-button-prev.swiper-button-disabled {
    opacity: 0;
  }
  .mod-swiper .swiper-button-next.swiper-button-disabled {
    opacity: 0;
  }
  .mod-swiper .swiper-pagination-bullet {
    width: 16px;
    height: 16px;
    background: none;
    background-image: url("/30th/images/common/icon-pager.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 1;
  }
  .mod-swiper .swiper-pagination-bullet-active {
    background-image: url("/30th/images/common/icon-pager-on.svg");
  }
  .u-sp {
    display: none;
  }
}
@media screen and (max-width: 1023px) {
  :root {
    --card-width: 100vw;
    --card-pos1: 0;
    --card-pos2: calc(-1 * var(--card-width));
    --card-pos3: calc(-2 * var(--card-width));
    --card-pos4: calc(-3 * var(--card-width));
    --card-pos5: calc(-4 * var(--card-width));
  }
  .c-prlx-main-section {
    position: relative;
  }
  .c-prlx-main-bg {
    transform: translate(0, calc(var(--scroll-progress) * -100px + 85px));
  }
  .block-wrap {
    position: relative;
  }
  .block-wrap h2, .block-wrap h3, .block-wrap h4, .block-wrap p {
    margin: 0;
  }
  .block-wrap sup {
    font-size: 70%;
  }
  .block-wrap img {
    width: 100%;
  }
  .block-wrap {
    overflow: clip;
    -webkit-font-smoothing: antialiased;
    --w:375;
    --tc:rgba(0, 0, 0, 0.87);
  }
  .block-stage-pc {
    display: none;
  }
  .block-main {
    position: relative;
    height: calc(710 / var(--w) * 100vw);
  }
  .block-main ._bg {
    width: calc(375 / var(--w) * 100vw);
    position: absolute;
    top: 0;
    left: 0;
  }
  .block-main ._logo {
    width: calc(202 / var(--w) * 100vw);
    position: absolute;
    top: calc(25 / var(--w) * 100vw);
    left: calc(92 / var(--w) * 100vw);
  }
  .block-main ._copy {
    width: calc(375 / var(--w) * 100vw);
    position: absolute;
    top: calc(206 / var(--w) * 100vw);
    left: 0;
  }
  .block-main ._title {
    width: calc(234 / var(--w) * 100vw);
    position: absolute;
    top: calc(335 / var(--w) * 100vw);
    left: calc(64 / var(--w) * 100vw);
  }
  .block-main p._lead {
    font-size: calc(12 / var(--w) * 100vw);
    line-height: 2.17;
    letter-spacing: 0.3333em;
    font-weight: bold;
    text-align: center;
    color: #000;
    position: absolute;
    top: calc(587 / var(--w) * 100vw);
    left: calc(32 / var(--w) * 100vw);
  }
  .block-main svg {
    width: 100%;
    height: auto;
  }
  /* -------------------------------------------------- */
  .block-menu {
    width: calc(375 / var(--w) * 100vw);
    padding: calc(5 / var(--w) * 100vw) 0 0 0;
    position: relative;
  }
  .block-menu ._btns {
    display: flex;
    gap: calc(22 / var(--w) * 100vw);
    width: calc(324 / var(--w) * 100vw);
    margin: 0 auto;
  }
  .block-menu ._btn-special1 {
    width: calc(150 / var(--w) * 100vw);
  }
  .block-menu ._btn-special2 {
    width: calc(150 / var(--w) * 100vw);
  }
  .block-menu a {
    display: block;
  }
  .mod-btn-menu-special1 {
    width: calc(150 / var(--w) * 100vw);
    height: calc(137 / var(--w) * 100vw);
    position: relative;
    display: block;
    width: calc(150 / var(--w) * 100vw);
    height: calc(137 / var(--w) * 100vw);
    background-image: url("/30th/images/menu/btn-special1.webp");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    cursor: pointer;
    transition-duration: 0.2s;
  }
  .mod-btn-menu-special1:hover {
    opacity: 0.8;
  }
  .mod-btn-menu-special1::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    opacity: 0;
    transition-duration: 0.2s;
    background-image: url("/30th/images/menu/btn-special1-on.webp");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  .mod-btn-menu-special1.is-active::after {
    opacity: 1;
  }
  .mod-btn-menu-special2 {
    width: calc(150 / var(--w) * 100vw);
    height: calc(137 / var(--w) * 100vw);
    background-image: url("/30th/images/menu/btn-special2-coming.webp");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  /* -------------------------------------------------- */
  .block-history {
    width: calc(375 / var(--w) * 100vw);
    height: calc(1808 / var(--w) * 100vw);
    position: relative;
    background-image: url("/30th/images/history/bg.webp?");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  .block-history ._p1 {
    width: calc(120 / var(--w) * 100vw);
    position: absolute;
    top: calc(246 / var(--w) * 100vw);
    left: calc(64 / var(--w) * 100vw);
  }
  .block-history ._p2 {
    width: calc(194 / var(--w) * 100vw);
    position: absolute;
    top: calc(331 / var(--w) * 100vw);
    left: calc(198 / var(--w) * 100vw);
  }
  .block-history ._p3 {
    width: calc(97 / var(--w) * 100vw);
    position: absolute;
    top: calc(519 / var(--w) * 100vw);
    left: calc(60 / var(--w) * 100vw);
  }
  .block-history ._p4 {
    width: calc(100 / var(--w) * 100vw);
    position: absolute;
    top: calc(689 / var(--w) * 100vw);
    left: calc(205 / var(--w) * 100vw);
  }
  .block-history ._p5 {
    width: calc(233 / var(--w) * 100vw);
    position: absolute;
    top: calc(811 / var(--w) * 100vw);
    left: calc(-47 / var(--w) * 100vw);
  }
  .block-history ._p6 {
    width: calc(158 / var(--w) * 100vw);
    position: absolute;
    top: calc(1062 / var(--w) * 100vw);
    left: calc(201 / var(--w) * 100vw);
  }
  .block-history ._p7 {
    width: calc(160 / var(--w) * 100vw);
    position: absolute;
    top: calc(99 / var(--w) * 100vw);
    left: calc(205 / var(--w) * 100vw);
  }
  .block-history ._p8 {
    width: calc(225 / var(--w) * 100vw);
    position: absolute;
    top: calc(1128 / var(--w) * 100vw);
    left: calc(8 / var(--w) * 100vw);
  }
  .block-history p {
    color: #006241;
  }
  .block-history p._t1 {
    font-size: calc(10 / var(--w) * 100vw);
    line-height: 1.4;
    text-align: right;
    position: absolute;
    top: calc(184 / var(--w) * 100vw);
    left: calc(90 / var(--w) * 100vw);
  }
  .block-history p._t2 {
    font-size: calc(10 / var(--w) * 100vw);
    line-height: 1.4;
    text-align: right;
    position: absolute;
    top: calc(467 / var(--w) * 100vw);
    left: calc(72 / var(--w) * 100vw);
    text-align: right;
  }
  .block-history p._t3 {
    font-size: calc(10 / var(--w) * 100vw);
    line-height: 1.4;
    text-align: right;
    position: absolute;
    top: calc(770 / var(--w) * 100vw);
    left: calc(100 / var(--w) * 100vw);
  }
  .block-history p._t4 {
    font-size: calc(10 / var(--w) * 100vw);
    line-height: 1.4;
    text-align: right;
    position: absolute;
    top: calc(1113 / var(--w) * 100vw);
    left: calc(56 / var(--w) * 100vw);
  }
  .block-history p._t5 {
    font-size: calc(10 / var(--w) * 100vw);
    line-height: 1.4;
    position: absolute;
    top: calc(1257 / var(--w) * 100vw);
    left: calc(214 / var(--w) * 100vw);
  }
  .block-history p._t6 {
    font-size: calc(10 / var(--w) * 100vw);
    line-height: 1.4;
    position: absolute;
    top: calc(325 / var(--w) * 100vw);
    left: calc(214 / var(--w) * 100vw);
  }
  .block-history p._t7 {
    font-size: calc(10 / var(--w) * 100vw);
    line-height: 1.4;
    position: absolute;
    top: calc(621 / var(--w) * 100vw);
    left: calc(214 / var(--w) * 100vw);
  }
  .block-history p._t8 {
    font-size: calc(10 / var(--w) * 100vw);
    line-height: 1.4;
    position: absolute;
    top: calc(956 / var(--w) * 100vw);
    left: calc(214 / var(--w) * 100vw);
  }
  .block-history p._t9 {
    font-size: calc(12 / var(--w) * 100vw);
    line-height: 1.4;
    text-align: center;
    position: absolute;
    top: calc(1476 / var(--w) * 100vw);
    left: calc(72 / var(--w) * 100vw);
  }
  /* -------------------------------------------------- */
  .block-special1-bg {
    position: relative;
    margin-top: calc(-80 / var(--w) * 100vw);
    background-image: url("/30th/images/special1-1/bg.webp?");
    background-size: 100% auto;
    background-position: top center;
    background-repeat: no-repeat;
  }
  /* -------------------------------------------------- */
  .block-special1-1 {
    position: relative;
    width: calc(375 / var(--w) * 100vw);
    height: calc(1020 / var(--w) * 100vw);
  }
  .block-special1-1 ._logo-30th {
    width: calc(265 / var(--w) * 100vw);
    position: absolute;
    top: calc(59 / var(--w) * 100vw);
    left: calc(58 / var(--w) * 100vw);
  }
  .block-special1-1 ._copy {
    width: calc(375 / var(--w) * 100vw);
    position: absolute;
    top: calc(158 / var(--w) * 100vw);
    left: 0;
  }
  .block-special1-1 ._cafe {
    width: calc(348 / var(--w) * 100vw);
    position: absolute;
    top: calc(383 / var(--w) * 100vw);
    left: calc(29 / var(--w) * 100vw);
  }
  .block-special1-1 ._deco {
    width: calc(341 / var(--w) * 100vw);
    position: absolute;
    top: calc(516 / var(--w) * 100vw);
    left: calc(12 / var(--w) * 100vw);
  }
  .block-special1-1 ._number {
    width: calc(280 / var(--w) * 100vw);
    position: absolute;
    top: calc(804 / var(--w) * 100vw);
    left: calc(50 / var(--w) * 100vw);
  }
  .block-special1-1 p._note {
    position: absolute;
    top: calc(749 / var(--w) * 100vw);
    left: calc(60 / var(--w) * 100vw);
  }
  .block-special1-1 p._doc {
    position: absolute;
    top: calc(861 / var(--w) * 100vw);
    left: calc(66 / var(--w) * 100vw);
  }
  .block-special1-1 p._note {
    font-size: calc(10 / var(--w) * 100vw);
    line-height: 1.4;
    text-align: center;
    color: #fff;
  }
  .block-special1-1 p._doc {
    font-size: calc(13 / var(--w) * 100vw);
    line-height: 2.15;
    letter-spacing: 0.18em;
    font-weight: bold;
    text-align: center;
    color: #fbf7ce;
  }
  /* -------------------------------------------------- */
  .block-special1-2 {
    position: relative;
    width: calc(376 / var(--w) * 100vw);
    height: calc(1082 / var(--w) * 100vw);
  }
  .block-special1-2 ._copy {
    width: calc(375 / var(--w) * 100vw);
    position: absolute;
    top: calc(11 / var(--w) * 100vw);
    left: 0;
  }
  .block-special1-2 ._title {
    width: calc(263 / var(--w) * 100vw);
    position: absolute;
    top: calc(387 / var(--w) * 100vw);
    left: calc(55 / var(--w) * 100vw);
  }
  .block-special1-2 ._star {
    width: calc(342 / var(--w) * 100vw);
    position: absolute;
    top: calc(457 / var(--w) * 100vw);
    left: calc(23 / var(--w) * 100vw);
    z-index: 2;
  }
  .block-special1-2 ._covers1 {
    position: absolute;
    top: calc(682 / var(--w) * 100vw);
    right: 0;
    left: 0;
  }
  .block-special1-2 ._covers2 {
    position: absolute;
    top: calc(882 / var(--w) * 100vw);
    right: 0;
    left: 0;
  }
  .mod-special1-2-covers1 {
    width: calc(375 / var(--w) * 100vw);
    height: calc(200 / var(--w) * 100vw);
    background-image: url("/30th/images/special1-2/covers1.webp?");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-position: left top;
    background-size: calc(720 / var(--w) * 100vw) auto;
    background-repeat: repeat;
  }
  .mod-special1-2-covers2 {
    width: calc(375 / var(--w) * 100vw);
    height: calc(200 / var(--w) * 100vw);
    background-image: url("/30th/images/special1-2/covers2.webp?");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-position: left top;
    background-size: calc(720 / var(--w) * 100vw) auto;
    background-repeat: repeat;
  }
  /* -------------------------------------------------- */
  .block-special1-3 {
    position: relative;
    width: calc(375 / var(--w) * 100vw);
    height: calc(923 / var(--w) * 100vw);
  }
  .block-special1-3 ._deco {
    width: calc(367 / var(--w) * 100vw);
    position: absolute;
    top: calc(6 / var(--w) * 100vw);
    left: calc(5 / var(--w) * 100vw);
  }
  .block-special1-3 p._doc {
    position: absolute;
    top: calc(23 / var(--w) * 100vw);
    left: calc(60 / var(--w) * 100vw);
  }
  .block-special1-3 p._doc {
    font-size: calc(13 / var(--w) * 100vw);
    line-height: 2.15;
    letter-spacing: 0.18em;
    font-weight: bold;
    text-align: center;
    color: #fbf7ce;
  }
  .block-special1-3 ._trophy {
    width: calc(198 / var(--w) * 100vw);
    position: absolute;
    top: calc(247 / var(--w) * 100vw);
    left: calc(104 / var(--w) * 100vw);
  }
  .block-special1-3 ._mask {
    width: calc(160 / var(--w) * 100vw);
    height: calc(275 / var(--w) * 100vw);
    position: absolute;
    top: calc(248 / var(--w) * 100vw);
    left: calc(108 / var(--w) * 100vw);
  }
  .block-special1-3 ._kira {
    width: calc(38 / var(--w) * 100vw);
    position: absolute;
    top: calc(246 / var(--w) * 100vw);
    left: calc(142 / var(--w) * 100vw);
  }
  .block-special1-3 ._covers1 {
    position: absolute;
    top: calc(523 / var(--w) * 100vw);
    right: 0;
    left: 0;
  }
  .block-special1-3 ._covers2 {
    position: absolute;
    top: calc(723 / var(--w) * 100vw);
    right: 0;
    left: 0;
  }
  .mod-special1-3-covers1 {
    width: calc(375 / var(--w) * 100vw);
    height: calc(200 / var(--w) * 100vw);
    background-image: url("/30th/images/special1-3/covers1.webp?2");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-position: left top;
    background-size: calc(720 / var(--w) * 100vw) auto;
    background-repeat: repeat;
  }
  .mod-special1-3-covers2 {
    width: calc(375 / var(--w) * 100vw);
    height: calc(200 / var(--w) * 100vw);
    background-image: url("/30th/images/special1-3/covers2.webp?2");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-position: left top;
    background-size: calc(720 / var(--w) * 100vw) auto;
    background-repeat: repeat;
  }
  /* -------------------------------------------------- */
  .block-special1-4 {
    position: relative;
    width: calc(375 / var(--w) * 100vw);
    background: #000;
  }
  .block-special1-4 ._navi-prev {
    position: absolute;
    top: calc(300 / var(--w) * 100vw);
    left: calc(2 / var(--w) * 100vw);
    z-index: 10;
    opacity: 0;
  }
  .block-special1-4 ._navi-next {
    position: absolute;
    top: calc(300 / var(--w) * 100vw);
    right: calc(2 / var(--w) * 100vw);
    z-index: 10;
    opacity: 0;
  }
  .block-special1-4 ._pagers {
    position: absolute;
    top: calc(620 / var(--w) * 100vw);
    right: 0;
    left: 0;
    z-index: 10;
  }
  .mod-card-navi-prev {
    width: calc(36 / var(--w) * 100vw);
    height: calc(72 / var(--w) * 100vw);
    transition-duration: 0.2s;
  }
  .mod-card-navi-prev span {
    display: block;
    width: calc(36 / var(--w) * 100vw);
    height: calc(72 / var(--w) * 100vw);
    background-image: url("/30th/images/common/icon-prev.webp");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    cursor: pointer;
    transition-duration: 0.2s;
  }
  .mod-card-navi-prev span:hover {
    opacity: 0.8;
  }
  .mod-card-navi-next {
    width: calc(36 / var(--w) * 100vw);
    height: calc(72 / var(--w) * 100vw);
    transition-duration: 0.2s;
  }
  .mod-card-navi-next span {
    display: block;
    width: calc(36 / var(--w) * 100vw);
    height: calc(72 / var(--w) * 100vw);
    background-image: url("/30th/images/common/icon-next.webp");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    cursor: pointer;
    transition-duration: 0.2s;
  }
  .mod-card-navi-next span:hover {
    opacity: 0.8;
  }
  body.is-card-slide2 .block-special1-4 ._navi-prev {
    opacity: 1;
  }
  body.is-card-slide3 .block-special1-4 ._navi-prev {
    opacity: 1;
  }
  body.is-card-slide4 .block-special1-4 ._navi-prev {
    opacity: 1;
  }
  body.is-card-slide5 .block-special1-4 ._navi-prev {
    opacity: 1;
  }
  body.is-card-slide1 .block-special1-4 ._navi-next {
    opacity: 1;
  }
  body.is-card-slide2 .block-special1-4 ._navi-next {
    opacity: 1;
  }
  body.is-card-slide3 .block-special1-4 ._navi-next {
    opacity: 1;
  }
  body.is-card-slide4 .block-special1-4 ._navi-next {
    opacity: 1;
  }
  body.is-card-slide5 .block-special1-4 ._navi-next {
    opacity: 0;
  }
  .mod-card-pagers {
    display: flex;
    gap: calc(4 / var(--w) * 100vw);
    justify-content: center;
  }
  .mod-card-pagers ._pager {
    width: calc(16 / var(--w) * 100vw);
    height: calc(16 / var(--w) * 100vw);
    background-image: url("/30th/images/common/icon-pager.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide1 .block-special1-4 ._pager.is-1 {
    background-image: url("/30th/images/common/icon-pager-on.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide2 .block-special1-4 ._pager.is-2 {
    background-image: url("/30th/images/common/icon-pager-on.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide3 .block-special1-4 ._pager.is-3 {
    background-image: url("/30th/images/common/icon-pager-on.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide4 .block-special1-4 ._pager.is-4 {
    background-image: url("/30th/images/common/icon-pager-on.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide5 .block-special1-4 ._pager.is-5 {
    background-image: url("/30th/images/common/icon-pager-on.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide2 .block-special1-4 ._pager.is-1 {
    background-image: url("/30th/images/common/icon-pager.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide3 .block-special1-4 ._pager.is-2 {
    background-image: url("/30th/images/common/icon-pager.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide4 .block-special1-4 ._pager.is-3 {
    background-image: url("/30th/images/common/icon-pager.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide5 .block-special1-4 ._pager.is-4 {
    background-image: url("/30th/images/common/icon-pager.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  body.is-card-slide2 .block-special1-4 ._cards {
    transform: translateX(var(--card-pos2));
  }
  body.is-card-slide3 .block-special1-4 ._cards {
    transform: translateX(var(--card-pos3));
  }
  body.is-card-slide4 .block-special1-4 ._cards {
    transform: translateX(var(--card-pos4));
  }
  body.is-card-slide5 .block-special1-4 ._cards {
    transform: translateX(var(--card-pos5));
  }
  .mod-year-card {
    height: calc(680 / var(--w) * 100vw);
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .mod-year-card.is-1 {
    background-image: url("/30th/images/special1-4/bg1.webp?14");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  .mod-year-card.is-2 {
    background-image: url("/30th/images/special1-4/bg2.webp?14");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  .mod-year-card.is-3 {
    background-image: url("/30th/images/special1-4/bg3.webp?14");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  .mod-year-card.is-4 {
    background-image: url("/30th/images/special1-4/bg4.webp?14");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  .mod-year-card.is-5 {
    background-image: url("/30th/images/special1-4/bg5.webp?14");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  .mod-year-card.is-1 ._deco {
    width: calc(79 / var(--w) * 100vw);
    position: absolute;
    top: calc(26 / var(--w) * 100vw);
    left: calc(23 / var(--w) * 100vw);
  }
  .mod-year-card.is-1 ._year {
    width: calc(67 / var(--w) * 100vw);
    position: absolute;
    top: calc(14 / var(--w) * 100vw);
    left: calc(154 / var(--w) * 100vw);
  }
  .mod-year-card.is-1 ._copy {
    width: calc(109 / var(--w) * 100vw);
    position: absolute;
    top: calc(80 / var(--w) * 100vw);
    left: calc(241 / var(--w) * 100vw);
  }
  .mod-year-card.is-1 ._name {
    width: calc(180 / var(--w) * 100vw);
    position: absolute;
    top: calc(368 / var(--w) * 100vw);
    left: calc(98 / var(--w) * 100vw);
  }
  .mod-year-card.is-1 ._texts {
    width: calc(327 / var(--w) * 100vw);
    position: absolute;
    top: calc(465 / var(--w) * 100vw);
    left: calc(24 / var(--w) * 100vw);
  }
  .mod-year-card.is-1 ._texts {
    color: #e8c689;
  }
  .mod-year-card.is-1 .c-card-btn {
    border-color: #e8c689;
    color: #e8c689;
  }
  .mod-year-card.is-2 ._deco {
    width: calc(79 / var(--w) * 100vw);
    position: absolute;
    top: calc(26 / var(--w) * 100vw);
    left: calc(271 / var(--w) * 100vw);
  }
  .mod-year-card.is-2 ._year {
    width: calc(67 / var(--w) * 100vw);
    position: absolute;
    top: calc(14 / var(--w) * 100vw);
    left: calc(154 / var(--w) * 100vw);
  }
  .mod-year-card.is-2 ._copy {
    width: calc(109 / var(--w) * 100vw);
    position: absolute;
    top: calc(80 / var(--w) * 100vw);
    left: calc(27 / var(--w) * 100vw);
  }
  .mod-year-card.is-2 ._name {
    width: calc(188 / var(--w) * 100vw);
    position: absolute;
    top: calc(368 / var(--w) * 100vw);
    left: calc(94 / var(--w) * 100vw);
  }
  .mod-year-card.is-2 ._texts {
    width: calc(327 / var(--w) * 100vw);
    position: absolute;
    top: calc(465 / var(--w) * 100vw);
    left: calc(24 / var(--w) * 100vw);
  }
  .mod-year-card.is-2 ._texts {
    color: #e8c689;
  }
  .mod-year-card.is-2 .c-card-btn {
    border-color: #e8c689;
    color: #e8c689;
  }
  .mod-year-card.is-3 ._deco {
    width: calc(79 / var(--w) * 100vw);
    position: absolute;
    top: calc(26 / var(--w) * 100vw);
    left: calc(23 / var(--w) * 100vw);
  }
  .mod-year-card.is-3 ._year {
    width: calc(67 / var(--w) * 100vw);
    position: absolute;
    top: calc(14 / var(--w) * 100vw);
    left: calc(154 / var(--w) * 100vw);
  }
  .mod-year-card.is-3 ._copy {
    width: calc(109 / var(--w) * 100vw);
    position: absolute;
    top: calc(80 / var(--w) * 100vw);
    left: calc(241 / var(--w) * 100vw);
  }
  .mod-year-card.is-3 ._name {
    width: calc(180 / var(--w) * 100vw);
    position: absolute;
    top: calc(368 / var(--w) * 100vw);
    left: calc(98 / var(--w) * 100vw);
  }
  .mod-year-card.is-3 ._texts {
    width: calc(327 / var(--w) * 100vw);
    position: absolute;
    top: calc(465 / var(--w) * 100vw);
    left: calc(24 / var(--w) * 100vw);
  }
  .mod-year-card.is-3 ._texts {
    color: #f9d1cb;
  }
  .mod-year-card.is-3 .c-card-btn {
    border-color: #f9d1cb;
    color: #f9d1cb;
  }
  .mod-year-card.is-4 ._deco {
    width: calc(79 / var(--w) * 100vw);
    position: absolute;
    top: calc(26 / var(--w) * 100vw);
    left: calc(271 / var(--w) * 100vw);
  }
  .mod-year-card.is-4 ._year {
    width: calc(67 / var(--w) * 100vw);
    position: absolute;
    top: calc(14 / var(--w) * 100vw);
    left: calc(154 / var(--w) * 100vw);
  }
  .mod-year-card.is-4 ._copy {
    width: calc(109 / var(--w) * 100vw);
    position: absolute;
    top: calc(80 / var(--w) * 100vw);
    left: calc(27 / var(--w) * 100vw);
  }
  .mod-year-card.is-4 ._name {
    width: calc(188 / var(--w) * 100vw);
    position: absolute;
    top: calc(368 / var(--w) * 100vw);
    left: calc(94 / var(--w) * 100vw);
  }
  .mod-year-card.is-4 ._texts {
    width: calc(327 / var(--w) * 100vw);
    position: absolute;
    top: calc(465 / var(--w) * 100vw);
    left: calc(24 / var(--w) * 100vw);
  }
  .mod-year-card.is-4 ._texts {
    color: #ebd56c;
  }
  .mod-year-card.is-4 .c-card-btn {
    border-color: #ebd56c;
    color: #ebd56c;
  }
  .mod-year-card.is-5 ._deco {
    width: calc(79 / var(--w) * 100vw);
    position: absolute;
    top: calc(26 / var(--w) * 100vw);
    left: calc(23 / var(--w) * 100vw);
  }
  .mod-year-card.is-5 ._year {
    width: calc(67 / var(--w) * 100vw);
    position: absolute;
    top: calc(14 / var(--w) * 100vw);
    left: calc(154 / var(--w) * 100vw);
  }
  .mod-year-card.is-5 ._copy {
    width: calc(109 / var(--w) * 100vw);
    position: absolute;
    top: calc(80 / var(--w) * 100vw);
    left: calc(241 / var(--w) * 100vw);
  }
  .mod-year-card.is-5 ._name {
    width: calc(180 / var(--w) * 100vw);
    position: absolute;
    top: calc(368 / var(--w) * 100vw);
    left: calc(98 / var(--w) * 100vw);
  }
  .mod-year-card.is-5 ._texts {
    width: calc(327 / var(--w) * 100vw);
    position: absolute;
    top: calc(465 / var(--w) * 100vw);
    left: calc(24 / var(--w) * 100vw);
  }
  .mod-year-card.is-5 ._texts {
    color: #efed72;
  }
  .mod-year-card.is-5 .c-card-btn {
    border-color: #efed72;
    color: #efed72;
  }
  .mod-year-card ._card-inner {
    width: calc(375 / var(--w) * 100vw);
    height: calc(650 / var(--w) * 100vw);
    position: relative;
  }
  .mod-year-card ._card-inner ._star {
    width: calc(318 / var(--w) * 100vw);
    position: absolute;
    top: calc(66 / var(--w) * 100vw);
    left: calc(29 / var(--w) * 100vw);
  }
  .mod-year-card ._card-inner ._cafe {
    width: calc(221 / var(--w) * 100vw);
    position: absolute;
    top: calc(80 / var(--w) * 100vw);
    left: calc(86 / var(--w) * 100vw);
    cursor: pointer;
    transition: filter 0.2s;
  }
  .mod-year-card ._card-inner ._cafe:hover {
    filter: brightness(1.05);
  }
  .mod-year-card ._card-inner ._title {
    font-size: calc(16 / var(--w) * 100vw);
    line-height: 1.4;
    font-weight: bold;
    text-align: center;
  }
  .mod-year-card ._card-inner ._title small {
    font-size: calc(10 / var(--w) * 100vw);
  }
  .mod-year-card ._card-inner p._lead {
    font-size: calc(12 / var(--w) * 100vw);
    line-height: 1.5;
    text-align: center;
  }
  .mod-year-card ._card-inner ._btn {
    margin-top: calc(12 / var(--w) * 100vw);
    display: flex;
    gap: 0;
    justify-content: center;
  }
  ._controllers {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  ._controllers ._controllers-inner {
    position: relative;
    width: calc(375 / var(--w) * 100vw);
    height: calc(660 / var(--w) * 100vw);
  }
  .c-card-btn {
    width: calc(180 / var(--w) * 100vw);
    height: calc(43 / var(--w) * 100vw);
    border: calc(1 / var(--w) * 100vw) solid #000;
    border-radius: calc(100 / var(--w) * 100vw);
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .c-card-btn span {
    font-size: calc(16 / var(--w) * 100vw);
    line-height: 1;
    font-weight: bold;
    text-align: center;
  }
  .c-card-btn {
    cursor: pointer;
    transition-duration: 0.2s;
  }
  .c-card-btn:hover {
    opacity: 0.8;
  }
  /* -------------------------------------------------- */
  .block-special1-5 {
    position: relative;
    width: calc(375 / var(--w) * 100vw);
    height: calc(1230 / var(--w) * 100vw);
    background-image: url("/30th/images/special1-5/bg.webp?4");
    background-size: 100% auto;
    background-position: top center;
    background-repeat: no-repeat;
  }
  .block-special1-5 ._copy {
    width: calc(375 / var(--w) * 100vw);
    position: absolute;
    top: calc(52 / var(--w) * 100vw);
    left: 0;
  }
  .block-special1-5 ._title {
    width: calc(269 / var(--w) * 100vw);
    position: absolute;
    top: calc(446 / var(--w) * 100vw);
    left: calc(54 / var(--w) * 100vw);
  }
  .block-special1-5 p._doc {
    position: absolute;
    top: calc(537 / var(--w) * 100vw);
    left: calc(64 / var(--w) * 100vw);
  }
  .block-special1-5 p._doc {
    font-size: calc(13 / var(--w) * 100vw);
    line-height: 2.15;
    letter-spacing: 0.2em;
    font-weight: bold;
    text-align: center;
    color: #fbf7ce;
  }
  .block-special1-5 ._cafe {
    width: calc(206 / var(--w) * 100vw);
    position: absolute;
    top: calc(699 / var(--w) * 100vw);
    left: calc(165 / var(--w) * 100vw);
  }
  .block-special1-5 ._photo {
    width: calc(290 / var(--w) * 100vw);
    position: absolute;
    top: calc(762 / var(--w) * 100vw);
    left: calc(42 / var(--w) * 100vw);
  }
  .block-special1-5 ._logo {
    width: calc(190 / var(--w) * 100vw);
    position: absolute;
    top: calc(995 / var(--w) * 100vw);
    left: calc(97 / var(--w) * 100vw);
  }
  /* -------------------------------------------------- */
  /* -------------------------------------------------- */
  /* -------------------------------------------------- */
  .block-special2-coming {
    width: calc(376 / var(--w) * 100vw);
    height: calc(583 / var(--w) * 100vw);
    position: relative;
    margin-top: calc(-93 / var(--w) * 100vw);
    background-image: url("/30th/images/special2-coming/bg.webp?2");
    background-size: 100% auto;
    background-position: top center;
    background-repeat: no-repeat;
  }
  .block-special2-coming ._title {
    width: calc(261 / var(--w) * 100vw);
    position: absolute;
    top: calc(66 / var(--w) * 100vw);
    left: calc(57 / var(--w) * 100vw);
  }
  .block-special2-coming ._copy {
    width: calc(375 / var(--w) * 100vw);
    position: absolute;
    top: calc(177 / var(--w) * 100vw);
    left: 0;
  }
  .mod-beverages-item {
    color: #fff;
  }
  .mod-beverages-item ._name {
    font-size: calc(20 / var(--w) * 100vw);
    line-height: 1.4;
    font-weight: bold;
  }
  .mod-beverages-item ._price {
    margin-top: calc(3 / var(--w) * 100vw);
    font-size: calc(18 / var(--w) * 100vw);
    line-height: 1.56;
    font-weight: 600;
  }
  .mod-beverages-item ._price b {
    font-size: calc(18 / var(--w) * 100vw);
    font-weight: 600;
  }
  .mod-beverages-item ._note {
    font-size: calc(12 / var(--w) * 100vw);
    line-height: 1.5;
    font-weight: bold;
  }
  .mod-beverages-item ._btns {
    margin-top: calc(15 / var(--w) * 100vw);
  }
  .mod-link-image-hover {
    opacity: 0;
  }
  .mod-sweets-item {
    color: #fff;
  }
  .mod-sweets-item ._name {
    font-size: calc(18 / var(--w) * 100vw);
    line-height: 1.11;
    font-weight: bold;
  }
  .mod-sweets-item ._price {
    margin-top: calc(5 / var(--w) * 100vw);
    font-size: calc(16 / var(--w) * 100vw);
    line-height: 1.75;
    font-weight: 600;
  }
  .mod-sweets-item ._text {
    font-size: calc(12 / var(--w) * 100vw);
    line-height: 1.5;
    font-weight: bold;
  }
  .mod-sweets-item ._btns {
    margin-top: calc(10 / var(--w) * 100vw);
  }
  .mod-btn-info {
    margin-left: calc(2 / var(--w) * 100vw);
    border-radius: calc(50 / var(--w) * 100vw);
    display: inline-block;
    background: #E0B671;
    width: calc(280 / var(--w) * 100vw);
    padding: calc(15 / var(--w) * 100vw) 0;
    text-align: center;
    font-size: calc(16 / var(--w) * 100vw);
    line-height: 1.33;
    font-weight: 500;
    color: #560c03;
  }
  .mod-btn-catalog {
    border: calc(1 / var(--w) * 100vw) solid #E0B671;
    border-radius: calc(40 / var(--w) * 100vw);
    display: inline-block;
    width: calc(240 / var(--w) * 100vw);
    background: transparent;
    padding: calc(10 / var(--w) * 100vw) 0;
    font-size: calc(14 / var(--w) * 100vw);
    line-height: 1.2;
    font-weight: bold;
    color: #E0B671;
  }
  .mod-btn-note {
    border-bottom: calc(1 / var(--w) * 100vw) solid #E0B671;
    display: inline-block;
    padding: 0 0 calc(4 / var(--w) * 100vw) 0;
    font-size: calc(12 / var(--w) * 100vw);
    line-height: 1.6;
    font-weight: bold;
    color: #E0B671;
  }
  .mod-swiper {
    position: relative;
    width: 100%;
    margin: 0 auto;
    --swiper-navigation-color: #007aff;
    --swiper-navigation-size: 44px;
    --swiper-navigation-sides-offset: 10px;
    --swiper-pagination-bottom: 25px;
  }
  .mod-swiper .swiper-button-prev:after {
    content: "";
  }
  .mod-swiper .swiper-button-prev {
    width: 36px;
    height: 72px;
    background-image: url("/30th/images/common/icon-prev.webp");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    top: calc(50% - 20px);
  }
  .mod-swiper .swiper-button-next:after {
    content: "";
  }
  .mod-swiper .swiper-button-next {
    width: 36px;
    height: 72px;
    background-image: url("/30th/images/common/icon-next.webp");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    top: calc(50% - 20px);
  }
  .mod-swiper .swiper-button-prev.swiper-button-disabled {
    opacity: 0;
  }
  .mod-swiper .swiper-button-next.swiper-button-disabled {
    opacity: 0;
  }
  .mod-swiper .swiper-pagination-bullet {
    width: 16px;
    height: 16px;
    background: none;
    background-image: url("/30th/images/common/icon-pager.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 1;
  }
  .mod-swiper .swiper-pagination-bullet-active {
    background-image: url("/30th/images/common/icon-pager-on.svg");
  }
  .u-pc {
    display: none;
  }
}
/* Lenis スムーススクロール推奨設定 */
html.lenis {
  height: auto;
}

.lenis.lenis-smooth {
  scroll-behavior: auto;
}

.lenis.lenis-smooth [data-lenis-prevent] {
  overscroll-behavior: contain;
}

.lenis.lenis-stopped {
  overflow: hidden;
}

.lenis.lenis-scrolling iframe {
  pointer-events: none;
}

.mod-special1-2-covers1 {
  animation: keyf_scroll1 40s linear 0s infinite;
}

.mod-special1-2-covers2 {
  animation: keyf_scroll2 40s linear 0s infinite;
}

.mod-special1-3-covers1 {
  animation: keyf_scroll1 40s linear 0s infinite;
}

.mod-special1-3-covers2 {
  animation: keyf_scroll2 40s linear 0s infinite;
}

@keyframes keyf_scroll1 {
  0% {
    background-position-x: 0;
  }
  100% {
    background-position-x: 208.33%;
  }
}
@keyframes keyf_scroll2 {
  0% {
    background-position-x: 0;
  }
  100% {
    background-position-x: -208.33%;
  }
}
.mod-anim-trophy-mask {
  mask-image: url("/30th/images/special1-3/mask.svg");
  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
}
.mod-anim-trophy-mask ._inner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  animation: none;
  transform: translate(-100%, 0);
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 14.51%, rgba(255, 255, 255, 0) 27.63%, #FFFFFF 34.86%, rgba(255, 255, 255, 0) 42.73%, rgba(255, 255, 255, 0) 82.78%);
}
.mod-anim-trophy-mask ._kira {
  transform: scale(0);
  opacity: 0;
}

.block-special1-3.is-active .mod-anim-trophy-mask {
  animation: keyf_trophy2 2.5s ease-in-out 0s 1 forwards;
}
.block-special1-3.is-active .mod-anim-trophy-mask ._inner {
  animation: keyf_trophy 2.5s ease-in-out 0s 1 forwards;
}
.block-special1-3.is-active ._kira {
  animation: keyf_kira 2.5s ease-in-out 0s 1 forwards;
}

@keyframes keyf_trophy {
  0% {
    transform: translate(-100%, 0);
  }
  100% {
    transform: translate(100%, 0);
  }
}
@keyframes keyf_trophy2 {
  45% {
    opacity: 1;
  }
  65% {
    opacity: 0;
  }
}
@keyframes keyf_kira {
  0% {
    transform: scale(0);
    opacity: 0;
  }
  35% {
    transform: scale(0);
    opacity: 0;
  }
  47% {
    transform: scale(2);
    opacity: 1;
  }
  100% {
    transform: scale(0);
    opacity: 0;
  }
}
.c-anim {
  transition-delay: 0.2s;
  transition-duration: 0.7s;
}
.c-anim.is-fade {
  opacity: 0;
}
.c-anim.is-fade.is-active {
  opacity: 1;
}
.c-anim.is-top {
  opacity: 0;
  transform: translate(0, -100px);
}
.c-anim.is-top.is-active {
  opacity: 1;
  transform: translate(0, 0);
}
.c-anim.is-bottom {
  opacity: 0;
  transform: translate(0, 50px);
}
.c-anim.is-bottom.is-active {
  opacity: 1;
  transform: translate(0, 0);
}
.c-anim.is-left {
  opacity: 0;
  transform: translate(-100px, 0);
}
.c-anim.is-left.is-active {
  opacity: 1;
  transform: translate(0, 0);
}
.c-anim.is-right {
  opacity: 0;
  transform: translate(100px, 0);
}
.c-anim.is-right.is-active {
  opacity: 1;
  transform: translate(0, 0);
}
.c-anim.is-text-up {
  overflow: hidden;
  opacity: 1;
  display: inline-block;
  vertical-align: bottom;
}
.c-anim.is-text-up > span > span {
  display: block;
  transform: translateY(110%);
  transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}
.c-anim.is-text-up.is-active > span > span {
  transform: translateY(0);
}
.c-anim.is-text-mask {
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1s cubic-bezier(0.16, 1, 0.3, 1);
}
.c-anim.is-text-mask.is-active {
  clip-path: inset(0 0 0 0);
}
.c-anim {
  /* Delay Utils */
}
.c-anim.is-delay-00 {
  transition-delay: 0s;
}
.c-anim.is-delay-01 {
  transition-delay: 0.1s;
}
.c-anim.is-delay-02 {
  transition-delay: 0.2s;
}
.c-anim.is-delay-03 {
  transition-delay: 0.3s;
}
.c-anim.is-delay-04 {
  transition-delay: 0.4s;
}
.c-anim.is-delay-05 {
  transition-delay: 0.5s;
}
.c-anim.is-delay-06 {
  transition-delay: 0.6s;
}
.c-anim.is-delay-07 {
  transition-delay: 0.7s;
}
.c-anim.is-delay-08 {
  transition-delay: 0.8s;
}
.c-anim.is-delay-09 {
  transition-delay: 0.9s;
}
.c-anim.is-delay-10 {
  transition-delay: 1s;
}