@charset "UTF-8";
:root {
  --color-page-primary-blue: #014084;
  --color-page-bg-gray: #F2F5F6;
  --ff-noto-sans: "Noto Sans JP";
  --ff-yu-gothic: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  --color-page-text-default: #602C2C;
  --color-page-red: #EF153B;
  --color-page-light-blue: #0073D5;
}

:where(a) {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.c-breadcrumb {
  display: none;
}

.global-contents > .global-contents__inner {
  width: 100%;
  /* background-color: var(--color-page-bg-gray); */
  padding-bottom: 0;
  overflow: hidden;
}

.page-container {
  max-width: 1600px;
  margin-inline: auto;
  font-family: var(--ff-noto-sans), sans-serif;
  color: var(--color-page-text-default);
  background-color: var(--color-white);
}
@media (min-width: 768px) {
  .page-container {
    margin-left: auto;
    margin-right: auto;
  }
}

.u-paragraph {
  font-weight: var(--fw-regular);
  font-size: 1.6rem;
  line-height: 1.75;
}
@media (max-width: 767px) {
  .u-paragraph {
    font-size: 1.4rem;
  }
}
.u-paragraph--bold {
  font-weight: var(--fw-bold);
}
.u-paragraph--center {
  text-align: center;
}

.u-color--red {
  color: var(--color-page-red);
  font-weight: var(--fw-bold);
}

.page-inner {
  width: min(95%, 118rem);
  margin-left: auto;
  margin-right: auto;
}

.page-kv {
  position: relative;
}
.page-kv__title {
  position: absolute;
  left: 50%;
  bottom: min(8.75svw, 14rem);
  translate: -50% 0;
  width: min(41.5625svw, 66.5rem);
}
@media (max-width: 767px) {
  .page-kv__title {
    width: 32rem;
    bottom: 6.5rem;
  }
}
.page-kv__visual {
  max-width: 1600px;
  margin-left: auto;
  margin-right: auto;
}

.page-notice {
  margin-top: max(-7rem, -4.375svw);
  position: relative;
  padding-bottom: 8rem;
}
@media (max-width: 767px) {
  .page-notice {
    margin-top: 0;
    padding-bottom: 4rem;
  }
}
.page-notice__inner {
  width: min(95%, 103rem);
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 767px) {
  .page-notice__inner {
    width: 100%;
    padding-inline: 1.6rem;
  }
}
.page-notice__title {
  width: 44rem;
  height: 6rem;
  margin-left: auto;
  margin-right: auto;
  background-image: url("../img/bg_guide_title_pc.png");
  background-repeat: no-repeat;
  background-size: contain;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #fff;
  font-weight: var(--fw-bold);
  font-size: 2.4rem;
  padding-right: 4.9rem;
  margin-bottom: 2rem;
}
@media (max-width: 767px) {
  .page-notice__title {
    width: 28.6rem;
    height: 3.9rem;
    font-size: 1.6rem;
    padding-right: 0;
    text-align: center;
    background-image: url("../img/bg_guide_title_sp.png");
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
.page-notice__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 0.3rem;
}
.page-notice__list-item {
  font-weight: var(--fw-medium);
  font-size: 1.8rem;
  line-height: 2;
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr;
  -webkit-column-gap: 0.6rem;
     -moz-column-gap: 0.6rem;
          column-gap: 0.6rem;
}
@media (max-width: 767px) {
  .page-notice__list-item {
    font-size: 1.2rem;
  }
}
.page-notice__list-item a {
  color: #107F80;
  font-family: inherit;
  font-weight: inherit;
  font-size: inherit;
  line-height: inherit;
  letter-spacing: inherit;
}
@media (hover: hover) and (pointer: fine) {
  .page-notice__list-item a {
    -webkit-transition: opacity var(--transition-default);
    transition: opacity var(--transition-default);
  }
  .page-notice__list-item a:hover {
    opacity: 0.6;
    text-decoration: none;
  }
}
/* .page-notice__list-item::before {
  content: "";
  display: inline-block;
  width: 2.2rem;
  height: 2rem;
  background-image: url("../img/decor_marker.png");
  background-repeat: no-repeat;
  background-size: contain;
  margin-top: 0.8rem;
} */
@media (max-width: 767px) {
  .page-notice__list-item::before {
    width: 1.4rem;
    height: 1.3rem;
    margin-top: 0.6rem;
  }
}

.page-howto__title {
  width: 37.7rem;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 767px) {
  .page-howto__title {
    width: 20.6rem;
    margin-bottom: 1rem;
  }
}

.page-howto__body {
  position: relative;
  z-index: 2;
  width: min(68.75svw, 110rem);
  margin-left: auto;
  margin-right: auto;
}
.page-howto__body::before {
  content: '';
  display: block;
  position: absolute;
  z-index: -1;
  width: min(89.375svw, 143rem);
  height: min(13.75svw, 22rem);
  background-image: url("../img/howto_decor_pc.png");
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: center;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
}
.page-howto__flow {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
@media (max-width: 767px) {
  .page-howto {
  }
  .page-howto__body {
    width: 34.5rem;
  }
  .page-howto__flow {
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
    padding-bottom: 2rem;
  }
  .page-howto__body::before {
    width: 100svw;
    height: 65rem;
    background-image: url("../img/howto_decor_sp.png");
    background-size: auto 100%;
    background-position: unset;
    translate: 0 -50%;
    left: -1.5rem;
  }
}
.page-howto__flow-step {
  position: relative;
}
.page-howto__flow-step:nth-child(even) {
  margin-top: 3rem;
}
.page-howto__flow-step[data-step-index="1"] .button-flowstep {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  width: min(12.8125svw, 20.5rem);
  height: min(3.125svw, 5rem);
  color: #fff;
  font-weight: var(--fw-bold);
  text-decoration: none;
  position: absolute;
  z-index: 2;
  bottom: min(4.5svw, 6.3rem);
  left: 50%;
  translate: -50% 0;
  transition: translate var(--transition-default);
}
.page-howto__flow-step[data-step-index="1"] .button-flowstep::after {
  content: '';
  display: block;
  width: 100%;
  height: 95%;
  border-radius: min(1.5625svw, 2.5rem);
  background-color: #7D5550;
  position: absolute;
  z-index: -1;
  top: min(0.2svw, 0.4rem);
  left: 0;
  transition: top var(--transition-default);
}

@media (hover: hover) and (pointer: fine) {
  .page-howto__flow-step[data-step-index="1"] .button-flowstep:hover {
    translate: -50% min(0.3svw, 0.4rem);
  }
  .page-howto__flow-step[data-step-index="1"] .button-flowstep:hover:after {
    top: 0;
  }
}

@media (max-width: 767px) {
  .page-howto__flow-step[data-step-index="1"] .button-flowstep {
    width: 13rem;
    height: 2.9rem;
    font-size: 1rem;
    bottom: 2.7rem;
  }
  .page-howto__flow-step[data-step-index="1"] .button-flowstep::after {
    top: 0.4rem;
    border-radius: 2.5rem;
  }
}

.button-charaselect {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 52rem;
  height: 10rem;
  margin-left: auto;
  margin-right: auto;
  color: var(--color-white);
  font-weight: var(--fw-bold);
  background-image: url("../img/btn_red_pc.png");
  background-repeat: no-repeat;
  background-size: contain;
  text-decoration: none;
  margin-top: 6.5rem;
  position: relative;
  z-index: 2;
}
.button-charaselect::after {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 5rem;
  background-color: #7D5550;
  position: absolute;
  z-index: -1;
  top: 1rem;
  left: 0;
  transition: top var(--transition-default);
}
@media (max-width: 767px) {
  .button-charaselect {
    width: 34rem;
    height: 6.2rem;
    margin-top: 5rem;
  }
}

.page-lineup {
  padding-bottom: 4.5rem;
}
@media (max-width: 767px) {
  .page-lineup {
    padding-bottom: 4rem;
  }
}
.page-lineup__title {
  width: 70.8rem;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 4.2rem;
}
@media (max-width: 767px) {
  .page-lineup__title {
    width: 25.8rem;
    margin-bottom: 2rem;
  }
}
.page-lineup__body {
  width: min(68.75svw, 110rem);
  margin-top: 1rem;
  margin-left: auto;
  margin-right: auto;
  position: relative;
}
@media (max-width: 767px) {
  .page-lineup__body {
    width: 95%;
  }
}
.page-lineup__decor--all {
  position: absolute;
  z-index: 2;
  width: min(68.9375svw, 110.3rem);
  top: 48.5%;
  left: 49.5%;
  translate: -50% -50%;
  pointer-events: none;
}
@media (max-width: 767px) {
  .page-lineup__decor--all {
    width: 100svw;
  }
}
.page-lineup__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0.5rem ;
}
.page-lineup__list-item {
  position: relative;
  width: min(20.625svw, 33rem);
}
@media (max-width: 767px) {
  .page-lineup__list-item {
    width: 16rem;
  }
}
.page-lineup__list-item-decor {
  position: absolute;
  z-index: 2;
  display: block;
}

.page-donation__inner {
  background-color: var(--color-white);
  margin-left: auto;
  margin-right: auto;
  background-image: url("../img/bg_donation.png");
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: center bottom;
  position: relative;
  -webkit-box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
          box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (min-width: 768px) {
  .page-donation__inner {
    width: min(56.25svw, 90rem);
    height: min(20svw, 32rem);
    border-radius: min(2.5svw, 4rem);
  }
}
@media (max-width: 767px) {
  .page-donation__inner {
    width: 33rem;
    height: 41rem;
    border-radius: 3.2rem;
  }
}
@media (max-width: 767px) {
  .page-donation__inner {
    background-image: url("../img/bg_donation_sp.png");
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    padding-bottom: 4.5rem;
  }
}
.page-donation__inner::after {
  content: "";
  display: block;
  background-image: url("../img/donation_tag_decor_pc.png");
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  top: 0;
  right: max(-3.5rem, -2.1875svw);
}
@media (min-width: 768px) {
  .page-donation__inner::after {
    width: min(18.25svw, 29.2rem);
    height: min(9.8125svw, 15.7rem);
  }
}
@media (max-width: 767px) {
  .page-donation__inner::after {
    width: 19rem;
    height: 10.2rem;
    top: 6rem;
    right: -2.2rem;
  }
}
.page-donation__body {
  position: relative;
  z-index: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding-left: min(3svw, 4.8rem);
  -webkit-column-gap: min(0.75svw, 1.2rem);
     -moz-column-gap: min(0.75svw, 1.2rem);
          column-gap: min(0.75svw, 1.2rem);
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
@media (max-width: 767px) {
  .page-donation__body {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 1.4rem;
    padding-left: 0;
  }
}
.page-donation__title {
  background-image: url("../img/bg_donation_ttl_pc.png");
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: var(--color-white);
}
@media (min-width: 768px) {
  .page-donation__title {
    width: min(22.5svw, 36rem);
    height: min(3.75svw, 6rem);
    font-size: min(1.5svw, 2.4rem);
    top: min(1.875svw, 3rem);
    left: max(-2rem, -1.25svw);
    padding-left: min(4.625svw, 7.4rem);
  }
}
@media (max-width: 767px) {
  .page-donation__title {
    width: 23.4rem;
    height: 3.9rem;
    font-size: 1.6rem;
    top: 2.4rem;
    left: -0.7rem;
    padding-left: 4.8rem;
    text-align: center;
    z-index: 3;
  }
}
.page-donation__title--sub {
  font-weight: var(--fw-bold);
  font-size: min(1.375svw, 2.2rem);
  line-height: 1.45;
  letter-spacing: 0.1em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: min(0.5svw, 0.8rem);
     -moz-column-gap: min(0.5svw, 0.8rem);
          column-gap: min(0.5svw, 0.8rem);
  color: #107F80;
}
@media (max-width: 767px) {
  .page-donation__title--sub {
    font-size: 1.4rem;
    margin-bottom: 0.7rem;
    -webkit-column-gap: 0.8rem;
       -moz-column-gap: 0.8rem;
            column-gap: 0.8rem;
  }
}
.page-donation__title--sub::before {
  content: "";
  display: inline-block;
  width: min(1.875svw, 3rem);
  height: min(1.75svw, 2.8rem);
  background-image: url("../img/footprints.png");
  background-repeat: no-repeat;
  background-size: contain;
}
@media (max-width: 767px) {
  .page-donation__title--sub::before {
    width: 2rem;
    height: 1.8rem;
  }
}
.page-donation__text {
  width: min(31.25svw, 50rem);
  padding-bottom: min(3.125svw, 5rem);
}
@media (max-width: 767px) {
  .page-donation__text {
    width: auto;
    padding-inline: 2rem;
    padding-bottom: 0;
  }
}
.page-donation__description {
  color: #602C2C;
  font-weight: var(--fw-bold);
  font-size: min(1.125svw, 1.8rem);
  line-height: 1.75;
}
.page-donation__description span {
  font-size: min(0.875svw, 1.4rem);
}
@media (max-width: 767px) {
  .page-donation__description {
    font-size: 1rem;
  }
  .page-donation__description span {
    font-size: 0.9rem;
    letter-spacing: -0.09em;
  }
}
.page-donation__image {
  width: min(16svw, 24rem);
}
@media (max-width: 767px) {
  .page-donation__image {
    width: 16.4rem;
  }
}

.page-notes {
  background-image: url("../img/bg_notes_pc.jpg");
  background-repeat: repeat;
  background-size: 100% auto;
  padding-block: 6.4rem 6.4rem;
}
.page-notes__inner {
  max-width: 95%;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 767px) {
  .page-notes {
    background-image: url("../img/bg_notes_sp.jpg");
  }
  .page-notes__inner {
    max-width: 100%;
  }
}
.page-notes__title {
  width: 27.4rem;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 2.4rem;
}
@media (max-width: 767px) {
  .page-notes__title {
    width: 19.2rem;
    margin-bottom: 2.4rem;
  }
}
.page-notes__list {
  width: min(90%, 88rem);
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 767px) {
  .page-notes__list {
    width: 100%;
    padding-inline: 2.4rem;
  }
}
.page-notes__list-item {
  font-weight: 500;
  font-size: 1.8rem;
  line-height: 2;
  color: #501122;
  display: grid;
  grid-template-columns: auto 1fr;
  -webkit-column-gap: 0.3rem;
     -moz-column-gap: 0.3rem;
          column-gap: 0.3rem;
}
.page-notes__list-item a {
  font-size: inherit;
  color: inherit;
}
.page-notes__list-item::before {
  content: "・";
}
@media (max-width: 767px) {
  .page-notes__list-item {
    font-size: 1.2rem;
  }
}

.page-guide {
  background-image: url("../img/bg_guide_pc.jpg");
  background-repeat: repeat;
  background-size: 100% auto;
  padding-block: 6.4rem 6.4rem;
}
.page-guide__inner {
  max-width: 95%;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 767px) {
  .page-guide {
    background-image: url("../img/bg_guide_sp.jpg");
  }
  .page-guide__inner {
    max-width: 88%;
  }
}
.page-guide__title {
  width: 56.2rem;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 2.4rem;
}
@media (max-width: 767px) {
  .page-guide__title {
    width: 26.7rem;
    margin-bottom: 2.4rem;
  }
}
.page-guide__lead {
  color: #fff;
  font-weight: var(--fw-bold);
  font-size: 1.8rem;
  text-align: center;
  margin-bottom: 3.4rem;
}
@media (max-width: 767px) {
  .page-guide__lead {
    font-size: 1.2rem;
    margin-bottom: 3rem;
    text-align: left;
  }
}

.page-foot {
  position: relative;
  overflow: hidden;
}
.page-foot__decor {
  position: absolute;
  z-index: 2;
  top: 56.3%;
  left: 50%;
  width: min(calc(1600* (100vw / 1600)), 1600px);
  translate: -50% -50%;
  pointer-events: none;
}
@media (max-width: 767px) {
  .page-foot__decor {
    width: 100%;
    top: auto;
    bottom: -1.4rem;
    translate: -50% 0;
  }
}

.button-guide {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  width: 52rem;
  height: 10rem;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  color: #107F80;
  font-weight: var(--fw-bold);
  font-size: 2rem;
  text-align: center;
  text-decoration: none;
  position: relative;
  z-index: 2;
  margin-top: 2.4rem;
}
.button-guide::after {
  content: '';
  display: block;
  position: absolute;
  z-index: -1;
  top: 0.8rem;
  left: 50%;
  translate: -50% 0;
  border-radius: 5rem;
  width: 100%;
  height: 100%;
  background-color: #61312B;
  transition: top var(--transition-default);
}
@media (max-width: 767px) {
  .button-guide {
    width: 100%;
    height: 6.2rem;
    font-size: 1.6rem;
  }
  .button-guide::after {
    top: 0.6rem;
  }
}

@media (hover: hover) and (pointer: fine) {
  [class^=button-] {
    -webkit-transition: opacity var(--transition-default), scale var(--transition-default);
    transition: translate var(--transition-default), scale var(--transition-default);
  }
  [class^=button-]:hover {
    translate: 0 1rem;
  }
  [class^=button-]:hover::after {
    top: 0;
  }
  .page-notes__list-item a {
    transition: opacity var(--transition-default);
  }
  .page-notes__list-item a:hover {
    opacity: 0.6;
  }
}

.page-maincontent {
  position: relative;
  z-index: 2;
  margin-top: min(-12.5rem, calc(-160* (100% / 1600)));
}

.page-maincontent-upper {
  background-image: url("../img/bg_mainupper_pc.png");
  background-repeat: no-repeat;
  background-size: 100% auto;
  padding-top: 17.8rem;
  padding-bottom: 8rem;
}
.page-maincontent-lower {
  background-image: url("../img/bg_mainlower_pc.jpg");
  background-repeat: no-repeat;
  background-size: auto 100%;
  padding-top: 17.6rem;
  padding-bottom: 12rem;
}

.page-donation {
  width: min(97.2%, 95rem);
  margin-inline: auto;
}


.page-guide .page-notes__list-item {
  color: #fff;
}
.page-guide .page-notes__list-item:last-of-type {
  display: block;
  margin-top: 2rem;
}
.page-guide .page-notes__list-item:last-of-type::before {
  content: none;
}

@media screen and (max-width: 767px) {
  .page-maincontent {
    margin-top: -4rem;
  }
  .page-maincontent-upper {
    background-image: url("../img/bg_mainupper_sp.png");
    padding-top: 5.2rem;
    padding-bottom: 8rem;
  }
  .page-maincontent-lower {
    background-image: url("../img/bg_mainlower.jpg");
    padding-top: 8rem;
    padding-bottom: 5rem;
    background-position: top center;
    background-size: 100% auto;
  }
  .page-howto__flow-step:nth-child(even) {
    margin-top: 0;
  }

  .page-guide .page-notes__list {
    padding-inline: 0;
  }

  .page-donation {
    margin-inline-start: 0;
  }
}