.kv {
  width: 100%;
  height: auto;
  aspect-ratio: 1440 / 1566;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  background-image: url("/assets/top/kv-640be7b8.jpg");
  background-size: cover;
  background-position: center;
}
.kv.--aeon-cup {
  aspect-ratio: 1440 / 1097;
  background-image: url("/assets/aeon_cup/top/kv-64afb009.png");
  background-size: cover;
  background-position: center;
  position: relative;
  z-index: 10;
}

.section__apply-top {
  background-color: #221a12;
  position: relative;
  margin-top: -42px;
  position: relative;
  z-index: 1;
}
.section__apply-top > .apply-box {
  margin-bottom: 0 !important;
}

.apply-box {
  padding: 24px 24px;
  margin: auto;
  margin-bottom: 5.74%;
  width: 100%;
  max-width: 960px;
  height: auto;
  /* aspect-ratio: 960 / 580;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  row-gap: 24px; */
  /* background-image: url("/assets/top/01-top_base-e9293477.jpg");
  background-size: cover;
  background-position: center; */
}

.apply-box > .button-box {
}
.apply-box > .button-box > .text {
  text-align: center;
  font-size: 14px;
}

.wrapper__apply {
  margin-top: 0;
  margin-bottom: -5.74%;
  padding-bottom: 5.74%;
  width: 100%;
  min-height: 300px;
  background-color: #221a12;
  position: relative;
}

.wrapper__apply > .apply-box {
  margin: auto;
  position: absolute;
  top: -500px;
  left: 0;
  right: 0;
  bottom: auto;
}

.section__campaigns {
  background-color: #221a12;
  position: relative;
}
.section__campaigns__inner {
  margin: auto;
  padding: 0 0 120px 0;
  width: 100%;
  max-width: 960px;
  position: relative;
}
.section__campaigns__inner > .image-box {
  margin-right: -110px;
}

.section__campaigns__inner > .button-box {
  margin: auto;
  width: fit-content;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 300px;
}
.section__campaigns__inner > .button-box > .link {
  display: block;
  width: 330px;
  height: auto;
}
.section__campaigns__inner > .button-box .text {
  font-size: 14px;
  text-align: center;
  color: #333;
}

.section__movie {
  background-color: #221a12;
  position: relative;
}

.section__movie__inner {
  margin: auto;
  padding: 120px 0 240px 0;
  width: 100%;
  max-width: 960px;
}
.section__movie__inner .title {
  margin: auto;
  width: 100%;
  max-width: 644px;
}

.section__movie__inner .movie-box {
  margin: 48px auto 0 auto;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  background-color: #fff;
  position: relative;
}
.section__movie__inner .movie-box > .video {
  width: 100%;
  height: 100%;
  object-fit: cover; /* ポスター画像を画面いっぱいにカバー */
}
.section__battle {
  margin: 0;
  padding: 353px 0 calc(50px + 180px) 0;
  width: 100%;
  background-image: url("/assets/top/03-bg-ec888684.jpg");
  background-size: cover;
  background-position: center;
}
.section__battle .image {
  margin: auto;
  width: 100%;
  max-width: 1313px;
}

.section__ranking {
  padding: 120px 0;
  width: 100%;
  position: relative;
}

.section__ranking::before {
  margin: auto;
  content: "";
  display: block;
  background-image: url("/assets/top/04-base_01top-8cbc42f9.png");
  background-size: contain;
  background-position: top;
  background-repeat: repeat-x;
  position: absolute;
  width: 100%;
  height: 497px;
  top: -180px;
  left: 0;
  right: 0;
}
.section__ranking::after {
  margin: auto;
  content: "";
  display: block;
  background-image: url("/assets/top/04-base_01bottom-0b0d830d.png");
  background-size: contain;
  background-position: top;
  background-repeat: repeat-x;
  position: absolute;
  width: 100%;
  height: 461px;
  bottom: -180px;
  left: 0;
  right: 0;
  z-index: 2;
}

.section__ranking__inner {
  margin: auto;
  width: 100%;
  max-width: 1200px;
  position: relative;
  z-index: 3;
}
.section__ranking__inner .title {
  margin: auto;
  width: 100%;
  max-width: 704px;
}

.section__ranking__inner .total-ranking {
  margin: 40px 0 0 0;
}
.section__ranking__inner .total-ranking .title {
  margin: auto;
  width: fit-content;
}
.section__ranking__inner .total-ranking .ranking-list {
  margin: 40px 0 0 0;
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  column-gap: 32px;
  row-gap: 32px;
}

.section__ranking__inner .total-ranking .button-box {
  margin: 54px auto 0 auto;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.section__ranking__inner .total-ranking .button-box > a {
  display: block;
  width: 265px;
  height: auto;
}

.section__ranking__inner .status-ranking-wrapper {
  margin: 140px 0 0 0;
  padding: 125px 0;
  background-image: url("/assets/top/04-base_02-bf925ce1.png");
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
  position: relative;
  border: 8px solid #3d352c;
}
.section__ranking__inner .status-ranking-wrapper > .title {
  margin: auto;
  width: 608px;
  height: 77px;
  position: absolute;
  top: -38px;
  left: 0;
  right: 0;
}
.section__ranking__inner .status-ranking-wrapper .status-ranking {
  margin: auto;
  width: 100%;
  max-width: 960px;
}

.section__ranking__inner .status-ranking-wrapper .status-ranking > .title {
  margin: auto;
  width: 951px;
  max-width: 951px;
  height: 68px;
}
.section__ranking__inner .status-ranking-wrapper .status-ranking .ranking-list {
  margin: 32px 0 0 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  column-gap: 32px;
  row-gap: 32px;
}

.section__ranking__inner
  .status-ranking-wrapper
  .status-ranking
  .ranking-list
  .dinosaur__card_small {
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}
.section__ranking__inner
  .status-ranking-wrapper
  .status-ranking
  .ranking-list
  .dinosaur__card_small
  > .dinosaur__card_small__inner {
  transform: scale(70%);
}
.section__ranking__inner .status-ranking-wrapper .status-ranking .button-box {
  margin: 54px auto 0 auto;
  width: 100%;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
.section__ranking__inner .status-ranking-wrapper .status-ranking .button-box a {
  display: block;
  width: 265px;
  height: auto;
}

.section__apply {
  margin: 0;
  padding: calc(175px + 180px) 0 160px 0;
  width: 100%;
  background-color: #322d28;
}
.section__apply__inner {
  margin: auto;
  padding: 125px 110px;
  width: 100%;
  max-width: 1200px;
  background-image: -moz-linear-gradient(
    45deg,
    rgb(0, 0, 0) 2%,
    rgb(29, 18, 9) 20%,
    rgb(57, 35, 17) 27%,
    rgb(0, 0, 0) 68%,
    rgb(71, 50, 28) 100%
  );
  background-image: -webkit-linear-gradient(
    45deg,
    rgb(0, 0, 0) 2%,
    rgb(29, 18, 9) 20%,
    rgb(57, 35, 17) 27%,
    rgb(0, 0, 0) 68%,
    rgb(71, 50, 28) 100%
  );
  background-image: -ms-linear-gradient(
    45deg,
    rgb(0, 0, 0) 2%,
    rgb(29, 18, 9) 20%,
    rgb(57, 35, 17) 27%,
    rgb(0, 0, 0) 68%,
    rgb(71, 50, 28) 100%
  );
  border-right: 1px solid rgb(224, 206, 144);
  border-left: 1px solid rgb(224, 206, 144);

  border-bottom: 5px solid rgb(236, 223, 188);

  position: relative;
}

.section__apply__inner .title {
  position: absolute;
  top: -60px;
  left: 0;
  right: 0;
  margin: 0;
}

.section__apply__inner .description-box {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: 70px;
  row-gap: 60px;
}
.section__apply__inner .description-box .image {
  width: 100%;
  max-width: 467px;
}

.section__apply .apply-box {
  margin-top: 140px;
  margin-bottom: 0;
}

.section__about {
  padding: 240px 0 240px 0;
  width: 100%;
  background-image: url("/assets/top/06-base-5c83989c.jpg");
  background-size: cover;
  background-position: center;
}
.section__about__inner {
  margin: auto;
  width: 100%;
  max-width: 960px;
}

.section__about__inner .title {
  margin: auto;
  width: 100%;
  max-width: 646px;
}

.section__about__inner .text-box {
  margin-top: 65px;
}
.section__about__inner .product-box {
  margin-top: 58px;
}
.section__about__inner .buttons-box {
  margin-top: 90px;
  width: 100%;
}
.section__about__inner .buttons-box .link {
  display: block;
  margin: auto;
  width: 540px;
}

.section__about__inner .apply-box {
  margin-top: 140px;
  margin-bottom: 0;
}

@media only screen and (max-width: 768px) {
  .kv {
    padding: 0 20px;
    aspect-ratio: 750 / 1926;
    background-image: url("/assets/top/sp/kv-0a039ea5.jpg");
  }
  .kv.--aeon-cup {
    aspect-ratio: 750 / 1521;
    background-image: url("/assets/aeon_cup/top/sp/kv-b87de6fa.png");
  }

  .section__apply-top {
    background-color: #221a12;
    position: relative;
    margin-top: 0;
    position: relative;
    z-index: 1;
  }

  .apply-box {
    max-width: 670px;
    margin-bottom: 60px;
  }
  .apply-box > .button-box {
    padding-bottom: 0;
  }
  .apply-box > .button-box > .text {
    font-size: 10px;
  }

  .wrapper__apply {
    margin-top: 0;
    margin-bottom: 0;
    padding: 0 20px;
    padding-bottom: 0;
    width: 100%;
    min-height: 100px;
    background-color: #221a12;
    position: relative;
  }

  .wrapper__apply > .apply-box {
    width: calc(100% - 40px);
    margin: auto;
    position: absolute;
    top: -200px;
    left: 0;
    right: 0;
    bottom: auto;
  }

  .section__campaigns {
    padding: 0 20px;
  }
  .section__campaigns__inner {
    margin: auto;
    padding: 0 0 60px 0;
    width: 100%;
    max-width: 960px;
    position: relative;
  }
  .section__campaigns__inner > .image-box {
    margin-right: 0;
  }

  .section__campaigns__inner > .button-box {
    margin: auto;
    width: fit-content;
    position: absolute;
    left: 0;
    right: 0;
    top: 650px;
    bottom: auto;
  }
  .section__campaigns__inner > .button-box > .link {
    display: block;
    width: 133px;
    height: auto;
  }

  .section__campaigns__inner > .button-box .text {
    width: 133px;
    font-size: 10px;
    text-align: center;
    color: #333;
  }

  .section__movie {
    background-color: #221a12;
    position: relative;
    padding: 20px;
  }

  .section__movie__inner {
    margin: auto;
    padding: 0 0 160px 0;
    width: 100%;
    max-width: 960px;
  }
  .section__movie__inner .title {
    margin: auto;
    width: 100%;
    max-width: 644px;
  }

  .section__movie__inner .movie-box {
    margin: 24px auto 0 auto;
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;
    background-color: #fff;
  }
  .section__battle {
    margin: 0;
    padding: 0 0 100px 0;
    width: 100%;
    background-image: url("/assets/top/03-bg-ec888684.jpg");
    background-size: cover;
    background-position: center;
  }
  .section__battle .image {
    margin: auto;
    width: 100%;
    max-width: 1313px;
  }

  .section__ranking {
    padding: 30px 20px;
    width: 100%;
    position: relative;
    background-image: url("/assets/top/sp/04-base_01-9dbf6e3b.png");
  }

  .section__ranking::before {
    margin: auto;
    content: "";
    display: block;
    background-image: url("/assets/top/sp/04-base_01top-ffbf8617.png");
    background-size: contain;
    background-position: top;
    background-repeat: repeat-x;
    position: absolute;
    width: 100%;
    height: 467px;
    top: -100px;
    left: 0;
    right: 0;
  }
  .section__ranking::after {
    margin: auto;
    content: "";
    display: block;
    background-image: url("/assets/top/sp/04-base_01bottom-9fb203a9.png");
    background-size: contain;
    background-position: top;
    background-repeat: repeat-x;
    position: absolute;
    width: 100%;
    height: 466px;
    bottom: -325px;
    left: 0;
    right: 0;
    z-index: 2;
  }

  .section__ranking__inner {
    margin: auto;
    width: 100%;
    max-width: 1200px;
    position: relative;
    z-index: 3;
  }
  .section__ranking__inner .title {
    margin: auto;
    width: 100%;
    max-width: 704px;
  }

  .section__ranking__inner .total-ranking {
    margin: 20px 0 0 0;
  }
  .section__ranking__inner .total-ranking .title {
    margin: auto;
    width: 144px;
  }
  .section__ranking__inner .total-ranking .ranking-list {
    margin: 30px 0 0 0;
    width: 100%;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 16px;
    row-gap: 16px;
  }

  .section__ranking__inner .total-ranking .button-box {
    margin: 27px auto 0 auto;
    width: 144px;
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .section__ranking__inner .status-ranking-wrapper {
    margin: 35px 0 0 0;
    padding: 55px 20px;
    background-image: url("/assets/top/sp/04-base_02-1ebb0292.png");
    background-size: 100% 100%;
    background-position: center;
    background-repeat: no-repeat;
    position: relative;
    border: 4px solid #3d352c;
  }
  .section__ranking__inner .status-ranking-wrapper > .title {
    margin: auto;
    width: 241px;
    height: auto;
    position: absolute;
    top: -20px;
    left: 0;
    right: 0;
  }
  .section__ranking__inner .status-ranking-wrapper .status-ranking {
    margin: auto;
    width: 100%;
    max-width: 960px;
  }

  .section__ranking__inner .status-ranking-wrapper .status-ranking > .title {
    margin: auto;
    width: 100%;
    height: auto;
  }
  .section__ranking__inner
    .status-ranking-wrapper
    .status-ranking
    .ranking-list-wrapper {
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding: 0 40px 40px 40px;
    overflow-x: scroll;
  }
  .section__ranking__inner
    .status-ranking-wrapper
    .status-ranking
    .ranking-list {
    width: fit-content;
    margin: 32px 0 0 0;
    display: flex;

    column-gap: 16px;
    row-gap: 16px;
  }
  .section__ranking__inner
    .status-ranking-wrapper
    .status-ranking
    .ranking-list
    .dinosaur__card_small {
    flex-shrink: 0;
    padding: 8px;
    display: block;
  }
  .section__ranking__inner
    .status-ranking-wrapper
    .status-ranking
    .ranking-list
    .dinosaur__card_small
    > .dinosaur__card_small__inner {
    transform: scale(80%);
  }

  .section__ranking__inner .status-ranking-wrapper .status-ranking .button-box {
    margin: 0 auto 20px auto;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .section__ranking__inner
    .status-ranking-wrapper
    .status-ranking
    .button-box
    a {
    width: 144px;
    height: auto;
  }

  .section__apply {
    margin: 0;
    padding: 180px 20px 40px 20px;
    width: 100%;
    background-color: #322d28;
  }
  .section__apply__inner {
    margin: auto;
    padding: 20px;
    width: 100%;
    max-width: 1200px;
    background-image: -moz-linear-gradient(
      45deg,
      rgb(0, 0, 0) 2%,
      rgb(29, 18, 9) 20%,
      rgb(57, 35, 17) 27%,
      rgb(0, 0, 0) 68%,
      rgb(71, 50, 28) 100%
    );
    background-image: -webkit-linear-gradient(
      45deg,
      rgb(0, 0, 0) 2%,
      rgb(29, 18, 9) 20%,
      rgb(57, 35, 17) 27%,
      rgb(0, 0, 0) 68%,
      rgb(71, 50, 28) 100%
    );
    background-image: -ms-linear-gradient(
      45deg,
      rgb(0, 0, 0) 2%,
      rgb(29, 18, 9) 20%,
      rgb(57, 35, 17) 27%,
      rgb(0, 0, 0) 68%,
      rgb(71, 50, 28) 100%
    );
    border-right: 1px solid rgb(224, 206, 144);
    border-left: 1px solid rgb(224, 206, 144);

    border-bottom: 5px solid rgb(236, 223, 188);

    position: relative;
  }

  .section__apply__inner .title {
    position: absolute;
    top: -26px;
    left: 0;
    right: 0;
    margin: 0;
  }

  .section__apply__inner .description-box {
    margin-top: 24px;
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    column-gap: 0;
    row-gap: 20px;
  }
  .section__apply__inner .description-box .image {
    width: 100%;
    max-width: 467px;
  }

  .section__apply .apply-box {
    margin-top: 45px;
    margin-bottom: 0;
  }

  .section__about {
    padding: 120px 20px 35px 20px;
    width: 100%;
    background-image: url("/assets/top/sp/06-base-2697daee.jpg");
    background-size: cover;
    background-position: center;
  }
  .section__about__inner {
    margin: auto;
    width: 100%;
    max-width: 960px;
  }

  .section__about__inner .title {
    margin: auto;
    width: 100%;
    max-width: 646px;
  }

  .section__about__inner .text-box {
    margin-top: 45px;
  }
  .section__about__inner .product-box {
    margin-top: 45px;
  }
  .section__about__inner .buttons-box {
    margin-top: 45px;
    width: 100%;
  }
  .section__about__inner .buttons-box .link {
    display: block;
    margin: auto;
    width: 100%;
  }

  .section__about__inner .apply-box {
    margin-top: 45px;
    margin-bottom: 0;
  }
  .apply-box {
    padding: 19px;
    row-gap: 24px;
  }
  .apply-box > .title {
    width: 100%;
    max-width: 267px;
  }
}
