.float__link, .modal__container, .modal__container--info, .modal__container--special, .modal__body--special, .modal__item-head, .modal__item-head--special, .footer__top, .footer__bottom, .other, .event__container, .movie__container, .special__container, .qa__container, .info__container, .episode__container, .about__container, .cont__center {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.float__link > *, .modal__container > *, .modal__container--info > *, .modal__container--special > *, .modal__body--special > *, .modal__item-head > *, .modal__item-head--special > *, .footer__top > *, .footer__bottom > *, .other > *, .event__container > *, .movie__container > *, .special__container > *, .qa__container > *, .info__container > *, .episode__container > *, .about__container > *, .cont__center > * {
  min-height: 0%;
}

.cont__container, .cont__container--small {
  box-sizing: content-box !important;
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
}
@media screen and (max-width: 768px) {
  .cont__container, .cont__container--small {
    max-width: 100%;
    padding-left: 20px;
    padding-right: 20px;
  }
}
@media screen and (max-width: 375px) {
  .cont__container, .cont__container--small {
    padding-left: 5.3333333333vw;
    padding-right: 5.3333333333vw;
  }
}

.cont__container--small {
  max-width: 990px;
}
@media screen and (max-width: 768px) {
  .cont__container--small {
    max-width: 89.3333333333vw;
  }
}

.float__link, .modal__text-link, .modal__link, .modal__close, .modal__detail-link, .footer__sns-link, .other__link, .event__link, .special__link, .qa__link, .info__link, .episode__link, .episode__link-back, .kv__link, .header__logo, .header__share-link, .link {
  color: inherit;
  transition: opacity 0.3s;
  cursor: pointer;
}
@media (any-hover: hover) {
  .float__link:hover, .modal__text-link:hover, .modal__link:hover, .modal__close:hover, .modal__detail-link:hover, .footer__sns-link:hover, .other__link:hover, .event__link:hover, .special__link:hover, .qa__link:hover, .info__link:hover, .episode__link:hover, .episode__link-back:hover, .kv__link:hover, .header__logo:hover, .header__share-link:hover, .link:hover {
    opacity: 0.7;
  }
}
.float__link:focus-visible, .modal__text-link:focus-visible, .modal__link:focus-visible, .modal__close:focus-visible, .modal__detail-link:focus-visible, .footer__sns-link:focus-visible, .other__link:focus-visible, .event__link:focus-visible, .special__link:focus-visible, .qa__link:focus-visible, .info__link:focus-visible, .episode__link:focus-visible, .episode__link-back:focus-visible, .kv__link:focus-visible, .header__logo:focus-visible, .header__share-link:focus-visible, .link:focus-visible {
  opacity: 0.7;
}

/* common:start */
[v-cloak] {
  display: none;
}

@media screen and (max-width: 768px) {
  .pcOnly {
    display: none !important;
  }
}

@media screen and (min-width: 769px) {
  .spOnly {
    display: none !important;
  }
}

html {
  scrollbar-gutter: stable;
}

@media screen and (min-width: 769px) {
  body {
    min-width: inherit;
  }
}

picture {
  display: block;
}

button:focus-visible {
  outline: -webkit-focus-ring-color auto 1px;
}

.wrap {
  min-width: inherit;
  padding-top: 16.4vw;
}
@media screen and (min-width: 769px) {
  .wrap {
    padding-top: 0;
    margin-left: 19.53125vw;
  }
}
@media screen and (min-width: 1280px) {
  .wrap {
    margin-left: 250px;
  }
}

.container {
  min-height: auto;
}

.bg__sky {
  background-image: url(/brand/jumbo/assets/2026/img/bg-sky001.png);
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
}
@media screen and (min-width: 769px) {
  .bg__sky {
    background-image: url(/brand/jumbo/assets/2026/img/pc/bg-sky001.png);
  }
}

/* common:end */
/* header:start */
html.js-drawer-lock {
  overflow: hidden;
}
@media screen and (min-width: 769px) {
  html.js-drawer-lock {
    overflow: auto;
  }
}

header.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
  background-color: #fff;
}
@media screen and (min-width: 769px) {
  header.header {
    width: 19.53125vw;
    height: 100%;
    background-color: #fafafa;
    display: flex;
    flex-direction: column;
  }
}
@media screen and (min-width: 1280px) {
  header.header {
    width: 250px;
  }
}

.header__overlay {
  position: fixed;
  inset: 0;
  z-index: 99;
  background-color: rgba(78, 0, 24, 0.82);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.js-drawer-open .header__overlay {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
@media screen and (min-width: 769px) {
  .header__overlay {
    display: none;
  }
}
.header__container {
  position: relative;
  z-index: 100;
  display: flex;
  flex-direction: column;
  background-color: #fff;
  padding-bottom: 2.6666666667vw;
}
@media screen and (min-width: 769px) {
  .header__container {
    height: 100%;
    background-color: #fafafa;
    padding-bottom: 0;
  }
}
.header__logo {
  padding-top: 2.9333333333vw;
  padding-left: 29.3333333333vw;
}
@media screen and (min-width: 769px) {
  .header__logo {
    padding: 1.09375vw 0;
  }
}
@media screen and (min-width: 1280px) {
  .header__logo {
    padding: 14px 0;
  }
}
.header__logo-link {
  display: block;
  max-width: 52.5333333333vw;
}
@media screen and (min-width: 769px) {
  .header__logo-link {
    max-width: 100%;
  }
}
.header__btn {
  appearance: none;
  border: 0;
  padding: 0;
  cursor: pointer;
  position: absolute;
  top: 0;
  left: 0;
  width: 16vw;
  height: 16vw;
  background-color: #c81332;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 769px) {
  .header__btn {
    display: none;
  }
}
.header__btn-icon {
  width: 9.3333333333vw;
  height: 8vw;
  position: relative;
}
.header__btn-line {
  display: block;
  position: absolute;
  width: 100%;
  height: 0.5333333333vw;
  background: #fff;
  left: 0;
  top: 50%;
  transition: transform 0.3s ease, opacity 0.3s ease;
}
.header__btn-line--1 {
  transform: translateY(calc(-50% - 3.7333333333vw));
}
.js-drawer-open .header__btn-line--1 {
  transform: translateY(-50%) rotate(45deg);
}
.header__btn-line--2 {
  transform: translateY(-50%);
}
.js-drawer-open .header__btn-line--2 {
  opacity: 0;
}
.header__btn-line--3 {
  transform: translateY(calc(-50% + 3.7333333333vw));
}
.js-drawer-open .header__btn-line--3 {
  transform: translateY(-50%) rotate(-45deg);
}
.header__drawer {
  position: fixed;
  top: 16vw;
  right: 0;
  width: 100%;
  height: calc(100% - 16vw);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  transform: translateX(100%);
  transition: transform 0.4s cubic-bezier(0.23, 1, 0.32, 1);
  z-index: 100;
}
.js-drawer-open .header__drawer {
  transform: translateX(0);
}
@media screen and (min-width: 769px) {
  .header__drawer {
    position: static;
    width: 100%;
    height: auto;
    overflow-y: visible;
    transform: none;
    transition: none;
  }
}
.header__nav {
  display: flex;
  flex-direction: column;
}
.header__nav-item--red {
  background-color: #c81332;
  border-bottom: 0.2666666667vw solid #fff;
}
@media screen and (min-width: 769px) {
  .header__nav-item--red {
    border-bottom-width: 0.15625vw;
  }
}
@media screen and (min-width: 1280px) {
  .header__nav-item--red {
    border-bottom-width: 2px;
  }
}
.header__nav-item--no-border {
  border-bottom-color: transparent;
}
.header__nav-link {
  position: relative;
  display: flex;
  align-items: center;
  height: 16vw;
  text-decoration: none;
  transition: opacity 0.2s ease;
}
@media screen and (min-width: 769px) {
  .header__nav-link {
    height: 4.6875vw;
  }
}
@media screen and (min-width: 1280px) {
  .header__nav-link {
    height: 60px;
  }
}
.header__nav-link:hover, .header__nav-link:active {
  opacity: 0.8;
}
.header__nav-image {
  display: flex;
  max-width: 32.1333333333vw;
}
@media screen and (min-width: 769px) {
  .header__nav-image {
    max-width: 100%;
  }
}
.header__nav-icon {
  position: absolute;
  top: 50%;
  right: 5.3333333333vw;
  transform: translateY(-50%);
  width: 3.7333333333vw;
  display: inline-flex;
}
@media screen and (min-width: 769px) {
  .header__nav-icon {
    right: 1.171875vw;
    width: 1.25vw;
  }
}
@media screen and (min-width: 1280px) {
  .header__nav-icon {
    right: 15px;
    width: 16px;
  }
}
.header__nav-share {
  background-color: #fff;
  padding: 0 0 0 13.3333333333vw;
  height: 16vw;
  display: flex;
  align-items: center;
  gap: 3.3333333333vw;
}
@media screen and (min-width: 769px) {
  .header__nav-share {
    justify-content: center;
    padding: 1.25vw 0;
    height: auto;
    flex-wrap: wrap;
    gap: 1.09375vw;
  }
}
@media screen and (min-width: 1280px) {
  .header__nav-share {
    padding: 16px 0;
    gap: 14px;
  }
}
.header__share-list {
  display: flex;
  align-items: center;
  gap: 3.3333333333vw;
  list-style: none;
  margin: 0;
  padding: 0;
}
@media screen and (min-width: 769px) {
  .header__share-list {
    justify-content: center;
    gap: 1.25vw;
  }
}
@media screen and (min-width: 1280px) {
  .header__share-list {
    gap: 16px;
  }
}
.header__share-link {
  display: block;
  width: 8vw;
}
@media screen and (min-width: 769px) {
  .header__share-link {
    width: 2.5vw;
  }
}
@media screen and (min-width: 1280px) {
  .header__share-link {
    width: 32px;
  }
}
.header__share-image {
  display: block;
  max-width: 8vw;
}
@media screen and (min-width: 769px) {
  .header__share-image {
    max-width: 2.5vw;
  }
}
@media screen and (min-width: 1280px) {
  .header__share-image {
    max-width: 32px;
  }
}

/* header:end */
/* kv:start */
.kv__container {
  background-color: #fff;
}
.kv__links {
  margin-top: 8vw;
  display: flex;
  justify-content: center;
  gap: 4vw;
}
@media screen and (min-width: 769px) {
  .kv__links {
    margin-top: 3.125vw;
  }
}
@media screen and (min-width: 1280px) {
  .kv__links {
    margin-top: 40px;
  }
}
.kv__link-img {
  display: block;
  max-width: 42.6666666667vw;
}
@media screen and (min-width: 769px) {
  .kv__link-img {
    max-width: 21.875vw;
  }
}
@media screen and (min-width: 1280px) {
  .kv__link-img {
    max-width: 280px;
  }
}

/* kv:end */
/* about:start */
@media screen and (min-width: 769px) {
  .about__container {
    max-width: 80.46875vw;
    margin-inline: auto;
  }
}
@media screen and (min-width: 1280px) {
  .about__container {
    max-width: 1030px;
  }
}
.about__movie {
  width: 89.3333333333vw;
  height: 50.2666666667vw;
  margin-top: 10.6666666667vw;
  margin-inline: auto;
}
@media screen and (min-width: 769px) {
  .about__movie {
    width: 46.09375vw;
    height: 25.9375vw;
    margin-top: 4.6875vw;
  }
}
@media screen and (min-width: 1280px) {
  .about__movie {
    width: 590px;
    height: 332px;
    margin-top: 60px;
  }
}
.about__movie iframe {
  width: 100%;
  height: 100%;
  display: block;
  border: none;
}
.about__heading {
  margin-top: 6.4vw;
}
@media screen and (min-width: 769px) {
  .about__heading {
    margin-top: 3.125vw;
  }
}
@media screen and (min-width: 1280px) {
  .about__heading {
    margin-top: 40px;
  }
}
.about__text {
  margin-top: 9.6vw;
  width: 100%;
}
@media screen and (min-width: 769px) {
  .about__text {
    margin-top: 3.75vw;
    max-width: 80.46875vw;
    margin-inline: auto;
  }
}
@media screen and (min-width: 1280px) {
  .about__text {
    margin-top: 48px;
    max-width: 1030px;
  }
}
.about__logo {
  margin-top: 11.7333333333vw;
}
@media screen and (min-width: 769px) {
  .about__logo {
    margin-top: 5vw;
  }
}
@media screen and (min-width: 1280px) {
  .about__logo {
    margin-top: 64px;
  }
}

/* about:end */
/* episode:start */
.episode {
  background-color: #c81332;
}
.episode__container {
  padding-top: 13.3333333333vw;
  padding-bottom: 13.3333333333vw;
}
@media screen and (min-width: 769px) {
  .episode__container {
    max-width: 80.46875vw;
    margin-inline: auto;
    padding-top: 7.5vw;
    padding-bottom: 5vw;
  }
}
@media screen and (min-width: 1280px) {
  .episode__container {
    max-width: 1030px;
    padding-top: 96px;
    padding-bottom: 64px;
  }
}
.episode__lead {
  margin-top: 1.3333333333vw;
}
@media screen and (min-width: 769px) {
  .episode__lead {
    margin-top: 0;
  }
}
.episode__list {
  margin-top: 8vw;
  display: grid;
  gap: 8vw;
}
@media screen and (min-width: 769px) {
  .episode__list {
    grid-template-columns: repeat(2, 30.078125vw);
    margin-top: 4.0625vw;
    gap: 2.34375vw;
  }
}
@media screen and (min-width: 1280px) {
  .episode__list {
    grid-template-columns: repeat(2, 385px);
    margin-top: 52px;
    gap: 30px;
  }
}
.episode__link {
  margin-top: 13.3333333333vw;
  display: inline-flex;
  align-items: center;
  width: 36vw;
  height: 9.8666666667vw;
  background: #fff;
  padding-left: 8vw;
  transform: skewX(-12deg);
  box-shadow: 0.4vw 0.4vw 0 #000;
}
@media screen and (min-width: 769px) {
  .episode__link {
    margin-top: 7.8125vw;
    width: 15.3125vw;
    height: 4.0625vw;
    padding-left: 3.125vw;
    box-shadow: 0.234375vw 0.234375vw 0 #000;
  }
}
@media screen and (min-width: 1280px) {
  .episode__link {
    margin-top: 100px;
    width: 196px;
    height: 52px;
    padding-left: 40px;
    box-shadow: 3px 3px 0 #000;
  }
}
.episode__link-back {
  margin-top: 13.3333333333vw;
  width: 37.7333333333vw;
  height: 10.2666666667vw;
}
@media screen and (min-width: 769px) {
  .episode__link-back {
    margin-top: 7.8125vw;
    width: 15.625vw;
    height: 4.296875vw;
  }
}
@media screen and (min-width: 1280px) {
  .episode__link-back {
    margin-top: 100px;
    width: 200px;
    height: 55px;
  }
}
.episode__link-text {
  transform: skewX(12deg);
  display: block;
  max-width: 26.6666666667vw;
}
@media screen and (min-width: 769px) {
  .episode__link-text {
    max-width: 10.390625vw;
  }
}
@media screen and (min-width: 1280px) {
  .episode__link-text {
    max-width: 133px;
  }
}
.episode__link-text img {
  display: block;
}

/* episode:end */
/* info:start */
.info {
  background-image: url(/brand/jumbo/assets/2026/img/bg-info001.png);
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
}
@media screen and (min-width: 769px) {
  .info {
    background-image: url(/brand/jumbo/assets/2026/img/pc/bg-info001.png);
  }
}
.info__container {
  position: relative;
  margin-inline: auto;
  padding-top: 22.1333333333vw;
  padding-bottom: 16vw;
}
@media screen and (min-width: 769px) {
  .info__container {
    max-width: 80.46875vw;
    padding-top: 8.125vw;
    padding-bottom: 7.03125vw;
  }
}
@media screen and (min-width: 1280px) {
  .info__container {
    max-width: 1030px;
    padding-top: 104px;
    padding-bottom: 90px;
  }
}
.info__container::before {
  content: "";
  position: absolute;
  top: -4.6666666667vw;
  right: 0;
  background-image: url(/brand/jumbo/assets/2026/img/pic-info001.png);
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
  width: 42.4vw;
  height: 48.5333333333vw;
}
@media screen and (min-width: 769px) {
  .info__container::before {
    top: -1.5625vw;
    right: 12.1875vw;
    background-image: url(/brand/jumbo/assets/2026/img/pc/pic-info001.png);
    width: 18.125vw;
    height: 17.8125vw;
  }
}
@media screen and (min-width: 1280px) {
  .info__container::before {
    top: -20px;
    right: 156px;
    width: 232px;
    height: 228px;
  }
}
.info__text--terms {
  margin-top: 9.3333333333vw;
}
@media screen and (min-width: 769px) {
  .info__text--terms {
    margin-top: 3.4375vw;
  }
}
@media screen and (min-width: 1280px) {
  .info__text--terms {
    margin-top: 44px;
  }
}
.info__text--number {
  margin-top: 9.6vw;
}
@media screen and (min-width: 769px) {
  .info__text--number {
    margin-top: 4.375vw;
  }
}
@media screen and (min-width: 1280px) {
  .info__text--number {
    margin-top: 56px;
  }
}
.info__list {
  display: flex;
  flex-direction: column;
  margin-inline: auto;
  max-width: 89.3333333333vw;
  gap: 4vw;
  margin-top: 5.3333333333vw;
}
@media screen and (min-width: 769px) {
  .info__list {
    flex-direction: row;
    justify-content: center;
    margin-top: 1.875vw;
    gap: 2.34375vw;
    max-width: 100%;
  }
}
@media screen and (min-width: 1280px) {
  .info__list {
    margin-top: 24px;
    gap: 30px;
  }
}
@media screen and (min-width: 769px) {
  .info__link {
    max-width: 30.078125vw;
  }
}
@media screen and (min-width: 1280px) {
  .info__link {
    max-width: 385px;
  }
}
.info__link img {
  display: block;
}

/* info:end */
/* qa:start */
.qa {
  background-color: #c81332;
}
.qa__container {
  position: relative;
  padding-top: 10.6666666667vw;
  padding-bottom: 22.6666666667vw;
}
@media screen and (min-width: 769px) {
  .qa__container {
    max-width: 80.46875vw;
    margin-inline: auto;
    padding-top: 7.8125vw;
    padding-bottom: 9.375vw;
  }
}
@media screen and (min-width: 1280px) {
  .qa__container {
    max-width: 1030px;
    padding-top: 100px;
    padding-bottom: 120px;
  }
}
.qa__container::before {
  content: "";
  position: absolute;
  top: -5.3333333333vw;
  left: 3.3333333333vw;
  background-image: url(/brand/jumbo/assets/2026/img/pic-qa001.png);
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
  width: 46.4vw;
  height: 66vw;
}
@media screen and (min-width: 769px) {
  .qa__container::before {
    top: -3.90625vw;
    left: 11.71875vw;
    background-image: url(/brand/jumbo/assets/2026/img/pc/pic-qa001.png);
    width: 17.03125vw;
    height: 24.140625vw;
  }
}
@media screen and (min-width: 1280px) {
  .qa__container::before {
    top: -50px;
    left: 150px;
    width: 218px;
    height: 309px;
  }
}
.qa__list {
  display: grid;
  max-width: 89.3333333333vw;
  gap: 4vw;
  margin-top: 20vw;
}
@media screen and (min-width: 769px) {
  .qa__list {
    grid-template-columns: repeat(2, 30.078125vw);
    gap: 2.34375vw;
    margin-top: 8.59375vw;
    max-width: 100%;
  }
}
@media screen and (min-width: 1280px) {
  .qa__list {
    grid-template-columns: repeat(2, 385px);
    gap: 30px;
    margin-top: 110px;
  }
}
/* qa:end */
/* special:start */
.special__container {
  position: relative;
  padding-top: 20.1333333333vw;
  padding-bottom: 26.6666666667vw;
}
@media screen and (min-width: 769px) {
  .special__container {
    max-width: 80.46875vw;
    margin-inline: auto;
    padding-top: 7.8125vw;
    padding-bottom: 9.375vw;
  }
}
@media screen and (min-width: 1280px) {
  .special__container {
    max-width: 1030px;
    padding-top: 100px;
    padding-bottom: 120px;
  }
}
.special__container::before {
  content: "";
  position: absolute;
  top: 0.6666666667vw;
  right: 0;
  background-image: url(/brand/jumbo/assets/2026/img/pic-special001.png);
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
  width: 41.7333333333vw;
  height: 43.0666666667vw;
}
@media screen and (min-width: 769px) {
  .special__container::before {
    top: 0;
    right: 15.15625vw;
    background-image: url(/brand/jumbo/assets/2026/img/pc/pic-special001.png);
    width: 17.1875vw;
    height: 16.875vw;
  }
}
@media screen and (min-width: 1280px) {
  .special__container::before {
    right: 194px;
    width: 220px;
    height: 216px;
  }
}
.special__list {
  display: grid;
  max-width: 89.3333333333vw;
  gap: 8vw;
  margin-top: 22.6666666667vw;
}
@media screen and (min-width: 769px) {
  .special__list {
    grid-template-columns: repeat(2, 30.078125vw);
    gap: 2.34375vw;
    max-width: 100%;
    margin-top: 6.875vw;
  }
}
@media screen and (min-width: 1280px) {
  .special__list {
    grid-template-columns: repeat(2, 385px);
    gap: 30px;
    margin-top: 88px;
  }
}
/* special:end */
/* movie:start */
.movie__container {
  position: relative;
  padding-top: 10.6666666667vw;
}
@media screen and (min-width: 769px) {
  .movie__container {
    max-width: 80.46875vw;
    margin-inline: auto;
    padding-top: 7.8125vw;
  }
}
@media screen and (min-width: 1280px) {
  .movie__container {
    max-width: 1030px;
    padding-top: 100px;
  }
}
.movie__container::before {
  content: "";
  position: absolute;
  top: 5.3333333333vw;
  left: 3.3333333333vw;
  background-image: url(/brand/jumbo/assets/2026/img/pic-movie001.png);
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
  width: 39.3333333333vw;
  height: 52.4vw;
}
@media screen and (min-width: 769px) {
  .movie__container::before {
    top: 1.5625vw;
    left: 14.375vw;
    background-image: url(/brand/jumbo/assets/2026/img/pc/pic-movie001.png);
    width: 14.375vw;
    height: 19.21875vw;
  }
}
@media screen and (min-width: 1280px) {
  .movie__container::before {
    top: 20px;
    left: 184px;
    width: 184px;
    height: 246px;
  }
}
.movie__text {
  margin-top: 4.8vw;
}
@media screen and (min-width: 769px) {
  .movie__text {
    margin-top: 1.25vw;
  }
}
@media screen and (min-width: 1280px) {
  .movie__text {
    margin-top: 16px;
  }
}
.movie__movie {
  width: 89.3333333333vw;
  height: 50.2666666667vw;
  margin-top: 12vw;
  margin-inline: auto;
}
@media screen and (min-width: 769px) {
  .movie__movie {
    width: 46.09375vw;
    height: 25.9375vw;
    margin-top: 4.6875vw;
  }
}
@media screen and (min-width: 1280px) {
  .movie__movie {
    width: 590px;
    height: 332px;
    margin-top: 60px;
  }
}
.movie__movie iframe {
  width: 100%;
  height: 100%;
  display: block;
  border: none;
}

/* movie:end */
/* event:start */
.event__container {
  position: relative;
  padding-top: 26.6666666667vw;
  padding-bottom: 13.3333333333vw;
}
@media screen and (min-width: 769px) {
  .event__container {
    max-width: 80.46875vw;
    margin-inline: auto;
    padding-top: 10.9375vw;
    padding-bottom: 7.8125vw;
  }
}
@media screen and (min-width: 1280px) {
  .event__container {
    max-width: 1030px;
    padding-top: 140px;
    padding-bottom: 100px;
  }
}
.event__container::before {
  content: "";
  position: absolute;
  top: 30.6666666667vw;
  right: 1.3333333333vw;
  background-image: url(/brand/jumbo/assets/2026/img/pic-event001.png);
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
  width: 38.9333333333vw;
  height: 50.1333333333vw;
}
@media screen and (min-width: 769px) {
  .event__container::before {
    top: 11.09375vw;
    right: 13.59375vw;
    background-image: url(/brand/jumbo/assets/2026/img/pc/pic-event001.png);
    width: 14.765625vw;
    height: 18.359375vw;
  }
}
@media screen and (min-width: 1280px) {
  .event__container::before {
    top: 142px;
    right: 174px;
    width: 189px;
    height: 235px;
  }
}
.event__text {
  margin-top: 5.3333333333vw;
}
@media screen and (min-width: 769px) {
  .event__text {
    margin-top: 1.171875vw;
  }
}
@media screen and (min-width: 1280px) {
  .event__text {
    margin-top: 15px;
  }
}
.event__img {
  margin-top: 5.8666666667vw;
}
@media screen and (min-width: 769px) {
  .event__img {
    margin-top: 3.125vw;
    max-width: 46.09375vw;
  }
}
@media screen and (min-width: 1280px) {
  .event__img {
    margin-top: 40px;
    max-width: 590px;
  }
}
.event__link {
  margin-top: 10.6666666667vw;
  max-width: 69.2vw;
}
@media screen and (min-width: 769px) {
  .event__link {
    margin-top: 4.6875vw;
    max-width: 25.703125vw;
  }
}
@media screen and (min-width: 1280px) {
  .event__link {
    margin-top: 60px;
    max-width: 329px;
  }
}
.event__link img {
  display: block;
}

/* event:end */
/* other:start */
.other {
  background-color: #c81332;
}
.other__container {
  padding-top: 9.6vw;
  padding-bottom: 10.6666666667vw;
}
@media screen and (min-width: 769px) {
  .other__container {
    max-width: 80.46875vw;
    padding-top: 4.375vw;
    padding-bottom: 4.6875vw;
  }
}
@media screen and (min-width: 1280px) {
  .other__container {
    max-width: 1030px;
    margin-inline: auto;
    padding-top: 56px;
    padding-bottom: 60px;
  }
}
.other__list {
  display: grid;
  max-width: 89.3333333333vw;
  gap: 4vw;
  margin-top: 8vw;
  margin-inline: auto;
}
@media screen and (min-width: 769px) {
  .other__list {
    grid-template-columns: repeat(3, 19.765625vw);
    max-width: fit-content;
    gap: 1.5625vw;
    margin-top: 3.125vw;
  }
}
@media screen and (min-width: 1280px) {
  .other__list {
    grid-template-columns: repeat(3, 253px);
    gap: 20px;
    margin-top: 40px;
  }
}
/* other:end */
/* footer:start */
.footer__container {
  background-color: #fff;
  padding-top: 12vw;
}
@media screen and (min-width: 769px) {
  .footer__container {
    padding-top: 7.8125vw;
    margin-left: 19.53125vw;
  }
}
@media screen and (min-width: 1280px) {
  .footer__container {
    padding-top: 100px;
    margin-left: 250px;
  }
}
@media screen and (min-width: 769px) {
  .footer__top {
    max-width: 80.46875vw;
    margin-inline: auto;
  }
}
@media screen and (min-width: 1280px) {
  .footer__top {
    max-width: 1030px;
  }
}
.footer__sns {
  background-color: #fafafa;
  margin-top: 10.6666666667vw;
  padding-top: 10.6666666667vw;
  padding-bottom: 10.6666666667vw;
}
@media screen and (min-width: 769px) {
  .footer__sns {
    margin-top: 7.03125vw;
    padding-top: 4.375vw;
    padding-bottom: 4.6875vw;
  }
}
@media screen and (min-width: 1280px) {
  .footer__sns {
    margin-top: 90px;
    padding-top: 56px;
    padding-bottom: 60px;
  }
}
@media screen and (min-width: 769px) {
  .footer__sns-container {
    max-width: 80.46875vw;
    margin-inline: auto;
  }
}
@media screen and (min-width: 1280px) {
  .footer__sns-container {
    max-width: 1030px;
  }
}
.footer__sns-list {
  display: flex;
  justify-content: center;
  gap: 5.3333333333vw;
  margin-top: 4vw;
}
@media screen and (min-width: 769px) {
  .footer__sns-list {
    gap: 2.734375vw;
    margin-top: 1.25vw;
  }
}
@media screen and (min-width: 1280px) {
  .footer__sns-list {
    gap: 35px;
    margin-top: 16px;
  }
}
.footer__sns-link {
  display: block;
  max-width: 10.6666666667vw;
  width: 100%;
}
@media screen and (min-width: 769px) {
  .footer__sns-link {
    max-width: 3.515625vw;
  }
}
@media screen and (min-width: 1280px) {
  .footer__sns-link {
    max-width: 45px;
  }
}
.footer__bottom {
  height: 21.3333333333vw;
  background-color: #e50000;
}
@media screen and (min-width: 769px) {
  .footer__bottom {
    height: 7.8125vw;
  }
}
@media screen and (min-width: 1280px) {
  .footer__bottom {
    height: 100px;
  }
}
@media screen and (min-width: 769px) {
  .footer__bottom-image {
    max-width: 80.46875vw;
    margin-inline: auto;
  }
}
@media screen and (min-width: 1280px) {
  .footer__bottom-image {
    max-width: 1030px;
  }
}

/* footer:end */
/* calc:start */
.calc {
  max-width: 81.3333333333vw;
  margin-inline: auto;
}
@media screen and (min-width: 769px) {
  .calc {
    max-width: 62.5vw;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto auto auto auto;
    grid-template-areas: "mode     mode" "input    keypad" "pcerror  keypad" "result   keypad" ".        submit";
    background-color: #ffd900;
  }
}
@media screen and (min-width: 1280px) {
  .calc {
    max-width: 800px;
  }
}
.calc.is-yearly .calc__mode-radio:checked + .calc__mode-label .calc__mode-image--active, .calc.is-lifespan .calc__mode-radio:checked + .calc__mode-label .calc__mode-image--active {
  display: block;
}
.calc.is-yearly .calc__mode-radio:checked + .calc__mode-label .calc__mode-image--inactive, .calc.is-lifespan .calc__mode-radio:checked + .calc__mode-label .calc__mode-image--inactive {
  display: none;
}
.calc.is-yearly .calc__mode-radio:not(:checked) + .calc__mode-label .calc__mode-image--active, .calc.is-lifespan .calc__mode-radio:not(:checked) + .calc__mode-label .calc__mode-image--active {
  display: none;
}
.calc.is-yearly .calc__mode-radio:not(:checked) + .calc__mode-label .calc__mode-image--inactive, .calc.is-lifespan .calc__mode-radio:not(:checked) + .calc__mode-label .calc__mode-image--inactive {
  display: block;
}
.calc.is-yearly .calc__input--lifespan,
.calc.is-yearly .calc__result--lifespan {
  display: none;
}
.calc.is-lifespan .calc__input--yearly,
.calc.is-lifespan .calc__result--yearly {
  display: none;
}
.calc__mode {
  display: flex;
  justify-content: center;
  gap: 2.6666666667vw;
  background-color: #fff;
  border-bottom: 1.7333333333vw solid #c81332;
}
@media screen and (min-width: 769px) {
  .calc__mode {
    grid-area: mode;
    gap: 2.34375vw;
    border-bottom-width: 0.625vw;
  }
}
@media screen and (min-width: 1280px) {
  .calc__mode {
    border-bottom-width: 8px;
    gap: 30px;
  }
}
.calc__mode-item {
  display: block;
  cursor: pointer;
}
.calc__mode-label {
  display: block;
}
.calc__mode-radio {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}
.calc__mode-radio:focus-visible + .calc__mode-label {
  outline: 3px solid #000;
  outline-offset: 2px;
}
.calc__mode-image {
  display: block;
  max-width: 36vw;
  transition: opacity 0.2s ease;
}
@media screen and (min-width: 769px) {
  .calc__mode-image {
    max-width: 21.09375vw;
  }
}
@media screen and (min-width: 1280px) {
  .calc__mode-image {
    max-width: 270px;
  }
}
.calc__mode-image--active {
  display: none;
}
.calc__mode-image--inactive {
  display: block;
}
.calc__input {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 1.3333333333vw;
  padding: 12vw 0 0;
  background-color: #ffd900;
}
@media screen and (min-width: 769px) {
  .calc__input {
    align-items: flex-end;
    grid-area: input;
    flex-wrap: nowrap;
    gap: 0.625vw;
    padding: 3.125vw 1.171875vw 1.5625vw 1.5625vw;
  }
}
@media screen and (min-width: 1280px) {
  .calc__input {
    gap: 8px;
    padding: 40px 15px 20px 20px;
  }
}
.calc__input--lifespan {
  padding-top: 6.6666666667vw;
  padding-bottom: 0vw;
}
@media screen and (min-width: 769px) {
  .calc__input--lifespan {
    flex-wrap: wrap;
    padding-top: 1.5625vw;
    padding-bottom: 0.78125vw;
  }
}
@media screen and (min-width: 1280px) {
  .calc__input--lifespan {
    padding-top: 20px;
    padding-bottom: 10px;
  }
}
.calc__input-prefix {
  display: block;
  max-width: 23.0666666667vw;
}
@media screen and (min-width: 769px) {
  .calc__input-prefix {
    max-width: 6.25vw;
    flex-shrink: 0;
  }
}
@media screen and (min-width: 1280px) {
  .calc__input-prefix {
    max-width: 80px;
  }
}
.calc__input-display {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 15.2vw;
  min-width: 15.2vw;
  max-width: 15.2vw;
  height: 10.1333333333vw;
  background-color: #fff;
  border: 0.8vw solid #c81332;
  font-size: 5.3333333333vw;
  font-weight: bold;
  color: #000;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .calc__input-display {
    width: 4.6875vw;
    min-width: 4.6875vw;
    max-width: 4.6875vw;
    height: 2.96875vw;
    border-width: 0.234375vw;
    font-size: 1.40625vw;
    flex-shrink: 0;
  }
}
@media screen and (min-width: 1280px) {
  .calc__input-display {
    width: 60px;
    min-width: 60px;
    max-width: 60px;
    height: 38px;
    border-width: 3px;
    font-size: 18px;
  }
}
.calc__input-suffix {
  display: block;
  max-width: 23.7333333333vw;
  margin-top: auto;
}
@media screen and (min-width: 769px) {
  .calc__input-suffix {
    max-width: 7.734375vw;
    margin-top: 0;
    flex-shrink: 0;
    line-height: 1;
  }
}
@media screen and (min-width: 1280px) {
  .calc__input-suffix {
    max-width: 99px;
  }
}
.calc__input-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.3333333333vw;
  width: 100%;
}
@media screen and (min-width: 769px) {
  .calc__input-row {
    align-items: flex-end;
    gap: 0.46875vw;
  }
}
@media screen and (min-width: 1280px) {
  .calc__input-row {
    gap: 6px;
  }
}
.calc__input-money {
  display: block;
  max-width: 18.2666666667vw;
}
@media screen and (min-width: 769px) {
  .calc__input-money {
    max-width: 5.234375vw;
  }
}
@media screen and (min-width: 1280px) {
  .calc__input-money {
    max-width: 67px;
  }
}
.calc__input-mid {
  display: block;
  max-width: 14.6666666667vw;
  margin-top: auto;
  line-height: 1;
}
@media screen and (min-width: 769px) {
  .calc__input-mid {
    max-width: 4.6875vw;
    margin-top: 0;
  }
}
@media screen and (min-width: 1280px) {
  .calc__input-mid {
    max-width: 60px;
  }
}
.calc__input-unit {
  display: block;
  max-width: 19.3333333333vw;
}
@media screen and (min-width: 769px) {
  .calc__input-unit {
    max-width: 6.015625vw;
  }
}
@media screen and (min-width: 1280px) {
  .calc__input-unit {
    max-width: 77px;
  }
}
.calc__input-error {
  width: 100%;
  margin-top: 0.5333333333vw;
  margin-bottom: 2.1333333333vw;
  font-size: 2.9333333333vw;
  color: #c81332;
  text-align: center;
  min-height: 4vw;
}
.calc__pc-error {
  font-size: 0.9375vw;
  color: #c81332;
  text-align: center;
  min-height: 1.25vw;
  padding: 0 1.5625vw;
  margin: 0;
}
@media screen and (min-width: 769px) {
  .calc__pc-error {
    grid-area: pcerror;
    font-size: 0.9375vw;
    min-height: 1.25vw;
    padding: 0 1.5625vw 1.5625vw;
  }
}
@media screen and (min-width: 1280px) {
  .calc__pc-error {
    font-size: 12px;
    min-height: 16px;
    padding: 0 20px 20px;
  }
}
.calc__result {
  background-color: #ffd900;
  padding: 2.6666666667vw 0 5.3333333333vw;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .calc__result {
    grid-area: result;
    padding: 0 1.171875vw 2.34375vw 1.5625vw;
  }
}
@media screen and (min-width: 1280px) {
  .calc__result {
    padding: 0 15px 30px 20px;
  }
}
.calc__result--lifespan {
  padding-top: 0;
}
@media screen and (min-width: 769px) {
  .calc__result--lifespan {
    padding-top: 0;
  }
}
.calc__result-main {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.8vw;
  width: 76vw;
  height: 36vw;
  margin: 0 auto;
  padding: 2.6666666667vw;
  background-color: #fff;
  position: relative;
}
@media screen and (min-width: 769px) {
  .calc__result-main {
    gap: 0.3125vw;
    width: 20.703125vw;
    height: 14.0625vw;
    padding: 0.9375vw;
  }
}
@media screen and (min-width: 1280px) {
  .calc__result-main {
    gap: 4px;
    width: 265px;
    height: 180px;
    padding: 12px;
  }
}
.calc__result-main picture {
  display: block;
  line-height: 1;
  flex-shrink: 0;
}
.calc__result-main picture img {
  width: 100%;
  height: auto;
}
.calc__result-number {
  display: flex;
  align-items: flex-end;
  margin-bottom: 1.0666666667vw;
}
@media screen and (min-width: 769px) {
  .calc__result-number {
    margin-bottom: 0;
    flex-shrink: 1;
    min-width: 0;
  }
}
.calc__result-number.is-large .calc__digit-img {
  height: 6.6666666667vw;
}
@media screen and (min-width: 769px) {
  .calc__result-number.is-large .calc__digit-img {
    height: 1.40625vw;
  }
}
@media screen and (min-width: 1280px) {
  .calc__result-number.is-large .calc__digit-img {
    height: 18px;
  }
}
.calc__result-number.is-large .calc__digit-comma {
  font-size: 4vw;
}
@media screen and (min-width: 769px) {
  .calc__result-number.is-large .calc__digit-comma {
    font-size: 1.171875vw;
  }
}
@media screen and (min-width: 1280px) {
  .calc__result-number.is-large .calc__digit-comma {
    font-size: 15px;
  }
}
.calc__result--yearly .calc__result-main picture:nth-child(1) {
  max-width: 11.3333333333vw;
  margin-right: 1.0666666667vw;
}
@media screen and (min-width: 769px) {
  .calc__result--yearly .calc__result-main picture:nth-child(1) {
    max-width: 3.75vw;
    margin-right: 0;
  }
}
@media screen and (min-width: 1280px) {
  .calc__result--yearly .calc__result-main picture:nth-child(1) {
    max-width: 48px;
  }
}
.calc__result--yearly .calc__result-main picture:nth-child(3) {
  max-width: 23.4666666667vw;
  margin-left: 1.0666666667vw;
}
@media screen and (min-width: 769px) {
  .calc__result--yearly .calc__result-main picture:nth-child(3) {
    max-width: 7.65625vw;
    margin-left: 0;
  }
}
@media screen and (min-width: 1280px) {
  .calc__result--yearly .calc__result-main picture:nth-child(3) {
    max-width: 98px;
  }
}
.calc__result--lifespan .calc__result-main {
  height: 36vw;
  align-items: center;
}
@media screen and (min-width: 769px) {
  .calc__result--lifespan .calc__result-main {
    height: 14.0625vw;
  }
}
@media screen and (min-width: 1280px) {
  .calc__result--lifespan .calc__result-main {
    height: 180px;
  }
}
.calc__result--lifespan .calc__result-main::after {
  display: none;
}
.calc__result--lifespan .calc__result-main picture {
  max-width: 23.3333333333vw;
}
@media screen and (min-width: 769px) {
  .calc__result--lifespan .calc__result-main picture {
    max-width: 7.8125vw;
  }
}
@media screen and (min-width: 1280px) {
  .calc__result--lifespan .calc__result-main picture {
    max-width: 100px;
  }
}
.calc__keypad {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  row-gap: 1.3333333333vw;
  column-gap: 0.5333333333vw;
  padding: 0 2.6666666667vw;
  background-color: #ffd900;
}
@media screen and (min-width: 769px) {
  .calc__keypad {
    grid-area: keypad;
    row-gap: 0.234375vw;
    column-gap: 0.3125vw;
    padding: 2.34375vw 1.25vw 0;
    align-content: start;
  }
}
@media screen and (min-width: 1280px) {
  .calc__keypad {
    row-gap: 3px;
    column-gap: 4px;
    padding: 30px 16px 0;
  }
}
.calc__key {
  appearance: none;
  border: 0;
  padding: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 13.0666666667vw;
  background: url("/brand/jumbo/assets/2026/img/btn-calc003.png") center/contain no-repeat;
  transition: opacity 0.2s ease;
}
@media screen and (min-width: 769px) {
  .calc__key {
    height: 3.515625vw;
    background: url("/brand/jumbo/assets/2026/img/pc/btn-calc003.png") center/contain no-repeat;
  }
}
@media screen and (min-width: 1280px) {
  .calc__key {
    height: 45px;
  }
}
.calc__key picture {
  display: block;
  max-width: 6.4vw;
}
@media screen and (min-width: 769px) {
  .calc__key picture {
    max-width: 1.71875vw;
  }
}
@media screen and (min-width: 1280px) {
  .calc__key picture {
    max-width: 22px;
  }
}
.calc__key--one picture {
  max-width: 4.4vw;
}
@media screen and (min-width: 769px) {
  .calc__key--one picture {
    max-width: 1.171875vw;
  }
}
@media screen and (min-width: 1280px) {
  .calc__key--one picture {
    max-width: 15px;
  }
}
.calc__key:active {
  opacity: 0.7;
}
.calc__key:focus-visible {
  outline: 3px solid #000;
  outline-offset: 2px;
}
.calc__key--zero {
  grid-column: 1;
}
.calc__key--clear {
  grid-column: 2/4;
  background: none;
}
.calc__key--clear picture {
  display: block;
  max-width: 50.4vw;
}
@media screen and (min-width: 769px) {
  .calc__key--clear picture {
    max-width: 175px;
  }
}
.calc__submit {
  appearance: none;
  border: 0;
  padding: 2.6666666667vw 4vw 8vw;
  width: 100%;
  cursor: pointer;
  background-color: #ffd900;
  transition: opacity 0.2s ease;
}
@media screen and (min-width: 769px) {
  .calc__submit {
    grid-area: submit;
    padding: 0.15625vw 1.25vw 1.25vw;
    align-self: start;
    margin-top: -6.09375vw;
  }
}
@media screen and (min-width: 1280px) {
  .calc__submit {
    padding: 2px 16px 16px;
    margin-top: -78px;
  }
}
.calc__submit:active {
  opacity: 0.7;
}
.calc__submit:focus-visible {
  outline: 3px solid #000;
  outline-offset: 2px;
}
.calc__submit-image {
  display: block;
  max-width: 50.2666666667vw;
  margin: 0 auto;
}
@media screen and (min-width: 769px) {
  .calc__submit-image {
    max-width: 175px;
  }
}
.calc__submit-image--disabled {
  display: none;
}
.calc__submit.is-disabled {
  pointer-events: none;
}
.calc__submit.is-disabled .calc__submit-image--default {
  display: none;
}
.calc__submit.is-disabled .calc__submit-image--disabled {
  display: block;
}
.calc__digit-img {
  height: 9.0666666667vw;
  width: auto;
  display: inline-block;
  vertical-align: bottom;
  filter: brightness(0);
}
@media screen and (min-width: 769px) {
  .calc__digit-img {
    height: 1.875vw;
  }
}
@media screen and (min-width: 1280px) {
  .calc__digit-img {
    height: 24px;
  }
}
.calc__digit-comma {
  display: inline-block;
  font-size: 5.3333333333vw;
  font-weight: bold;
  color: #000;
  vertical-align: bottom;
  line-height: 1;
}
@media screen and (min-width: 769px) {
  .calc__digit-comma {
    font-size: 1.5625vw;
  }
}
@media screen and (min-width: 1280px) {
  .calc__digit-comma {
    font-size: 20px;
  }
}

/* calc:end */
.modal__box--info, .modal__box--special, .modal__box {
  width: 100%;
  max-width: 89.3333333333vw;
  max-height: calc(100vh - 5.3333333333vw);
  max-height: calc(100dvh - 5.3333333333vw);
  overflow-y: auto;
  background-color: #fff;
}
@media screen and (min-width: 769px) {
  .modal__box--info, .modal__box--special, .modal__box {
    max-width: 62.5vw;
    max-height: calc(100vh - 3.125vw);
    max-height: calc(100dvh - 3.125vw);
  }
}
@media screen and (min-width: 1280px) {
  .modal__box--info, .modal__box--special, .modal__box {
    max-width: 800px;
    max-height: calc(100vh - 40px);
    max-height: calc(100dvh - 40px);
  }
}

.modal__container--special, .modal__container--info, .modal__container {
  margin-inline: auto;
}

.modal__body--special, .modal__body--calc, .modal__body {
  margin-top: 5.3333333333vw;
  padding-bottom: 9.3333333333vw;
}
@media screen and (min-width: 769px) {
  .modal__body--special, .modal__body--calc, .modal__body {
    padding-bottom: 0;
  }
}

.modal__item-head--special, .modal__item-head {
  background-color: #c81332;
  min-height: 10.6666666667vw;
  margin-inline: auto;
}
@media screen and (min-width: 769px) {
  .modal__item-head--special, .modal__item-head {
    min-height: 3.90625vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__item-head--special, .modal__item-head {
    min-height: 50px;
  }
}

.modal__item-body--special, .modal__item-body {
  margin-inline: auto;
  padding-top: 2.6666666667vw;
  padding-bottom: 4vw;
  border-right: 0.2666666667vw solid #c81332;
  border-left: 0.2666666667vw solid #c81332;
  border-bottom: 0.2666666667vw solid #c81332;
}
@media screen and (min-width: 769px) {
  .modal__item-body--special, .modal__item-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding-top: 1.09375vw;
    padding-bottom: 2.34375vw;
    border-right: 1px solid #c81332;
    border-left: 1px solid #c81332;
    border-bottom: 1px solid #c81332;
  }
}
@media screen and (min-width: 1280px) {
  .modal__item-body--special, .modal__item-body {
    padding-top: 14px;
    padding-bottom: 30px;
  }
}

/* modal:start */
html.js-modal-body-open,
body.js-modal-body-open {
  overflow: hidden;
}

.modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2.6666666667vw;
  background-color: rgba(78, 0, 24, 0.82);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
@media screen and (min-width: 769px) {
  .modal {
    padding: 1.5625vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal {
    padding: 20px;
  }
}
.modal.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.modal__box {
  padding: 18.6666666667vw 2.4vw 3.7333333333vw;
  clip-path: polygon(10.6666666667vw 0, 100% 0, 100% 100%, 0 100%, 0 10.6666666667vw);
}
@media screen and (min-width: 769px) {
  .modal__box {
    padding: 7.5vw 0 4.6875vw;
    clip-path: polygon(7.8125vw 0, 100% 0, 100% 100%, 0 100%, 0 7.8125vw);
  }
}
@media screen and (min-width: 1280px) {
  .modal__box {
    padding: 96px 0 60px;
    clip-path: polygon(100px 0, 100% 0, 100% 100%, 0 100%, 0 100px);
  }
}
.modal__box:focus {
  outline: none;
}
.modal__box--special {
  padding: 0 0 4vw;
}
@media screen and (min-width: 769px) {
  .modal__box--special {
    padding: 0 0 4.6875vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__box--special {
    padding: 0 0 60px;
  }
}
.modal__box--special:focus {
  outline: none;
}
.modal__box--info {
  padding: 10.6666666667vw 0 10.6666666667vw;
}
@media screen and (min-width: 769px) {
  .modal__box--info {
    padding: 4.0625vw 0 4.6875vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__box--info {
    padding: 52px 0 60px;
  }
}
.modal__box--info:focus {
  outline: none;
}
.modal__container {
  max-width: 73.3333333333vw;
}
@media screen and (min-width: 769px) {
  .modal__container {
    max-width: 46.875vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__container {
    max-width: 600px;
  }
}
.modal__container--info {
  max-width: 81.3333333333vw;
}
@media screen and (min-width: 769px) {
  .modal__container--info {
    max-width: 53.125vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__container--info {
    max-width: 680px;
  }
}
.modal__container--special {
  max-width: 81.3333333333vw;
}
@media screen and (min-width: 769px) {
  .modal__container--special {
    max-width: 46.875vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__container--special {
    max-width: 600px;
  }
}
@media screen and (min-width: 769px) {
  .modal__body {
    margin-top: 2.34375vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__body {
    margin-top: 30px;
  }
}
@media screen and (min-width: 769px) {
  .modal__body--calc {
    margin-top: 3.125vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__body--calc {
    margin-top: 40px;
  }
}
.modal__body--special {
  margin-top: 13.3333333333vw;
}
@media screen and (min-width: 769px) {
  .modal__body--special {
    margin-top: 3.125vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__body--special {
    margin-top: 40px;
  }
}
.modal__list {
  width: 100%;
}
@media screen and (min-width: 769px) {
  .modal__list {
    display: grid;
    grid-template-columns: repeat(2, 22.265625vw);
    gap: 2.34375vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__list {
    grid-template-columns: repeat(2, 285px);
    gap: 30px;
  }
}
@media screen and (min-width: 769px) {
  .modal__item {
    display: flex;
    flex-direction: column;
  }
}
.modal__item + .modal__item {
  margin-top: 5.3333333333vw;
}
@media screen and (min-width: 769px) {
  .modal__item + .modal__item {
    margin-top: 0;
  }
}
.modal__item-desc {
  display: block;
  margin-bottom: 2vw;
}
@media screen and (min-width: 769px) {
  .modal__item-desc {
    margin-bottom: 0.3125vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__item-desc {
    margin-bottom: 4px;
  }
}
.modal__item-head {
  max-width: 73.3333333333vw;
}
@media screen and (min-width: 769px) {
  .modal__item-head {
    max-width: 22.265625vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__item-head {
    max-width: 285px;
  }
}
.modal__item-head--special {
  max-width: 81.3333333333vw;
}
@media screen and (min-width: 769px) {
  .modal__item-head--special {
    max-width: 22.265625vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__item-head--special {
    max-width: 285px;
  }
}
.modal__item-body {
  max-width: 73.3333333333vw;
  padding-inline: 4.6666666667vw;
}
@media screen and (min-width: 769px) {
  .modal__item-body {
    max-width: 100%;
    padding-inline: 1.25vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__item-body {
    padding-inline: 16px;
  }
}
.modal__item-body--special {
  max-width: 81.3333333333vw;
  padding-inline: 4vw;
}
@media screen and (min-width: 769px) {
  .modal__item-body--special {
    max-width: 22.265625vw;
    padding-inline: 1.5625vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__item-body--special {
    max-width: 285px;
    padding-inline: 20px;
  }
}
.modal__note {
  max-width: 73.3333333333vw;
  margin-top: 0.6666666667vw;
}
@media screen and (min-width: 769px) {
  .modal__note {
    max-width: 100%;
    margin-top: 0.15625vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__note {
    margin-top: 2px;
  }
}
.modal__note-item {
  font-size: 2.8vw;
  padding-left: 1em;
  text-indent: -1em;
  line-height: 1.7;
}
@media screen and (min-width: 769px) {
  .modal__note-item {
    font-size: 0.9375vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__note-item {
    font-size: 12px;
  }
}
.modal__image {
  display: block;
  margin: 0 auto;
  max-width: 73.3333333333vw;
  margin-bottom: 2.4vw;
}
@media screen and (min-width: 769px) {
  .modal__image {
    margin-bottom: 1.09375vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__image {
    margin-bottom: 14px;
  }
}
.modal__text {
  max-width: 73.3333333333vw;
  font-size: 3.7333333333vw;
  line-height: 1.7;
}
@media screen and (min-width: 769px) {
  .modal__text {
    max-width: 100%;
    font-size: 1.25vw;
    line-height: 1.6;
  }
}
@media screen and (min-width: 1280px) {
  .modal__text {
    font-size: 16px;
  }
}
.modal__text-link {
  color: #0084c8;
  text-decoration: underline;
}
.modal__link {
  margin-inline: auto;
  display: block;
  margin-top: 4vw;
  max-width: 58.6666666667vw;
}
@media screen and (min-width: 769px) {
  .modal__link {
    margin-top: auto;
    padding-top: 2.1875vw;
    max-width: 19.0625vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__link {
    padding-top: 28px;
    max-width: 244px;
  }
}
.modal__link:focus-visible {
  outline: 3px solid #000;
  outline-offset: 2px;
}
.modal__close-box {
  text-align: center;
}
.modal__close {
  margin: 6.6666666667vw auto 0;
  width: 37.2vw;
  height: 9.8666666667vw;
  cursor: pointer;
}
@media screen and (min-width: 769px) {
  .modal__close {
    margin: 3.125vw auto 0;
    width: 15.3125vw;
    height: 4.0625vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__close {
    margin: 40px auto 0;
    width: 196px;
    height: 52px;
  }
}
.modal__close:focus-visible {
  outline: 3px solid #000;
  outline-offset: 2px;
}
.modal__calendar {
  margin-top: 2.6666666667vw;
}
@media screen and (min-width: 769px) {
  .modal__calendar {
    margin-top: 0.78125vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__calendar {
    margin-top: 10px;
  }
}
.modal__point {
  margin-top: 4vw;
}
@media screen and (min-width: 769px) {
  .modal__point {
    margin-top: 1.5625vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__point {
    margin-top: 20px;
  }
}
.modal__more {
  margin-top: 4.6666666667vw;
  display: block;
  max-width: 37.2vw;
  margin-inline: auto;
}
@media screen and (min-width: 769px) {
  .modal__more {
    margin-top: 1.875vw;
    max-width: 15.3125vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__more {
    margin-top: 24px;
    max-width: 196px;
  }
}
.modal__more:focus-visible {
  outline: 3px solid #000;
  outline-offset: 2px;
}
.modal__detail {
  margin-top: 1.6vw;
  text-align: center;
  font-size: 3.7333333333vw;
}
@media screen and (min-width: 769px) {
  .modal__detail {
    margin-top: 0.78125vw;
    font-size: 1.25vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__detail {
    margin-top: 10px;
    font-size: 16px;
  }
}
.modal__detail-link {
  color: #0084c8;
  text-decoration: underline;
}
.modal__product-item + .modal__product-item {
  margin-top: 8vw;
}
@media screen and (min-width: 769px) {
  .modal__product-item + .modal__product-item {
    margin-top: 2.5vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__product-item + .modal__product-item {
    margin-top: 32px;
  }
}
.modal__table {
  display: block;
  margin-top: 4vw;
}
@media screen and (min-width: 769px) {
  .modal__table {
    margin-top: 1.40625vw;
  }
}
@media screen and (min-width: 1280px) {
  .modal__table {
    margin-top: 18px;
  }
}

/* modal:end */
/* float:start */
.float {
  margin-top: 16vw;
}
@media screen and (min-width: 769px) {
  .float {
    margin-top: 6.875vw;
  }
}
@media screen and (min-width: 1280px) {
  .float {
    margin-top: 88px;
  }
}
.float__container {
  position: sticky;
  bottom: 0;
  z-index: 100;
  background-color: #e50000;
}
@media screen and (min-width: 769px) {
  .float__container {
    bottom: 0;
  }
}
.float__list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  max-width: 100vw;
  margin-inline: auto;
}
@media screen and (min-width: 769px) {
  .float__list {
    max-width: 80.46875vw;
    justify-content: center;
  }
}
@media screen and (min-width: 1280px) {
  .float__list {
    max-width: 1030px;
  }
}
.float__item {
  position: relative;
}
.float__item::before {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  width: 1px;
  height: 10.6666666667vw;
  background-color: #fff;
}
@media screen and (min-width: 769px) {
  .float__item::before {
    width: 0.15625vw;
    height: 3.90625vw;
  }
}
@media screen and (min-width: 1280px) {
  .float__item::before {
    width: 2px;
    height: 50px;
  }
}
.float__item:last-child::before {
  width: 0;
  height: 0;
}
.float__link {
  min-height: 16.6666666667vw;
  width: 100%;
}
@media screen and (min-width: 769px) {
  .float__link {
    min-height: 5.46875vw;
  }
}
@media screen and (min-width: 1280px) {
  .float__link {
    min-height: 70px;
  }
}
.float__link img {
  display: block;
}
.float__text--info {
  display: block;
  max-width: 15.4666666667vw;
}
@media screen and (min-width: 769px) {
  .float__text--info {
    max-width: 6.796875vw;
  }
}
@media screen and (min-width: 1280px) {
  .float__text--info {
    max-width: 87px;
  }
}
.float__text--qa {
  display: block;
  max-width: 11.3333333333vw;
}
@media screen and (min-width: 769px) {
  .float__text--qa {
    max-width: 8.90625vw;
  }
}
@media screen and (min-width: 1280px) {
  .float__text--qa {
    max-width: 114px;
  }
}
.float__text--special {
  display: block;
  max-width: 17.7333333333vw;
}
@media screen and (min-width: 769px) {
  .float__text--special {
    max-width: 7.8125vw;
  }
}
@media screen and (min-width: 1280px) {
  .float__text--special {
    max-width: 100px;
  }
}
.float__text--movie {
  display: block;
  max-width: 13.8666666667vw;
}
@media screen and (min-width: 769px) {
  .float__text--movie {
    max-width: 6.09375vw;
  }
}
@media screen and (min-width: 1280px) {
  .float__text--movie {
    max-width: 78px;
  }
}
.float__text--event {
  display: block;
  max-width: 17.6vw;
}
@media screen and (min-width: 769px) {
  .float__text--event {
    max-width: 14.21875vw;
  }
}
@media screen and (min-width: 1280px) {
  .float__text--event {
    max-width: 182px;
  }
}

/* float:end */