@charset "UTF-8";
@media screen and (max-width: 320px) {
  html {
    font-size: 14px;
  }
}

body {
  background-color: #0A1227;
  color: #fff;
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
  overflow: hidden;
}
body::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-image: url(../img/bg.webp);
  background-size: cover;
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  body::before {
    background-image: url(../img/bg-sp.webp);
  }
}

a {
  color: #fff;
  text-decoration: none;
  cursor: pointer;
  -webkit-transition: 0.5s;
  transition: 0.5s;
  letter-spacing: 0.05rem;
}

p, li, dt, dd, th, td {
  line-height: 1.7;
  font-weight: normal;
  letter-spacing: 0.05rem;
}

h1, h2, h3, h4 {
  line-height: 1.7;
  font-weight: normal;
  letter-spacing: 0.05rem;
}

strong {
  font-weight: 700;
}

/* smartphone */
@media screen and (min-width: 768px) {
  .pc-only {
    display: block;
  }
  .sp-only {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  .pc-only {
    display: none !important;
  }
  .sp-only {
    display: block;
  }
}
/* layout */
.content-wrap {
  max-width: 1080px;
  margin: 0 auto;
}
@media screen and (max-width: 1120px) {
  .content-wrap {
    margin: 0 20px;
  }
}
@media screen and (max-width: 767px) {
  .content-wrap {
    margin: 0 20px;
  }
}

img {
  width: 100%;
  height: auto;
  vertical-align: middle;
}

.button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  font-size: 1.5rem;
  font-weight: bold;
  max-width: 450px;
  width: 100%;
  height: 80px;
  position: relative;
  text-align: center;
  padding: 0 48px;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  letter-spacing: 0.05rem;
}
@media screen and (max-width: 767px) {
  .button {
    font-size: 1rem;
    height: 56px;
    padding: 0 20px;
  }
}
.button::after {
  content: "";
  display: block;
  width: 26px;
  height: 17px;
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top: 50%;
  right: 16px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: 0.3s;
  transition: 0.3s;
  background-image: url(../img/ico-arrow.svg);
}
@media screen and (max-width: 767px) {
  .button::after {
    width: 16px;
    height: 12px;
    right: 12px;
  }
}
.button--center {
  margin: 0 auto;
}
.button--entry {
  background: linear-gradient(to right, #ED178A, #96007F);
}
.button--entry:hover {
  opacity: 1;
}
.button--border {
  border: 1px solid #fff;
  height: 56px;
  font-size: 1.25rem;
}
@media screen and (max-width: 767px) {
  .button--border {
    font-size: 1rem;
    height: 48px;
  }
}
.button--broadcast {
  border: 1px solid #fff;
  font-size: 1.25rem;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .button--broadcast {
    font-size: 1rem;
  }
}
.button--black {
  background: #000;
  color: #fff;
  font-size: 1.25rem;
  height: 56px;
  margin: 0 auto;
  max-width: 320px;
}
.button--black::after {
  content: none;
}
.button:hover {
  opacity: 0.7;
}
.button:hover::after {
  -webkit-transform: translateY(-50%) translateX(8px);
          transform: translateY(-50%) translateX(8px);
}

.title {
  text-shadow: 0 0 15px rgba(0, 0, 0, 0.16);
}
.title__english {
  display: block;
  font-size: 7rem;
  font-family: "Quantico", sans-serif;
  font-style: italic;
  font-weight: bold;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .title__english {
    font-size: 3rem;
  }
}
.title__japanese {
  display: block;
  font-size: 1.5rem;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .title__japanese {
    font-size: 1rem;
  }
}
.title--fukutoshin {
  color: #9C5E32;
}
.title--nanboku {
  color: #05AC9B;
}
.title--tozai {
  color: #009BBF;
}
.title--hanzomon {
  color: #8F76D6;
}
.title--hibiya {
  color: #B5B5AC;
}
.title--yurakucho {
  color: #C1A470;
}
.title--ginza {
  color: #FF9500;
}
.title--chiyoda {
  color: #03BB85;
}
.title--marunouchi {
  color: #F62F36;
}

.border-title {
  text-align: center;
  display: inline-block;
  background: rgba(5, 172, 155, 0.25);
  font-size: 2rem;
  font-weight: bold;
  padding: 0 12px;
  height: 92px;
  line-height: 92px;
  width: 330px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .border-title {
    width: 240px;
    height: 56px;
    line-height: 56px;
    font-size: 1.25rem;
  }
}
.border-title::before, .border-title::after {
  content: "";
  display: block;
  height: 100%;
  aspect-ratio: 31/92;
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top: 0;
}
.border-title::before {
  background-image: url(../img/border-left.webp);
  left: 0;
}
.border-title::after {
  background-image: url(../img/border-right.webp);
  right: 0;
}

.background-dot {
  background-image: url(../img/bg-dot.webp);
  background-size: 1714px auto;
  background-repeat: repeat;
}
@media screen and (max-width: 767px) {
  .background-dot {
    background-size: 1200px auto;
  }
}

.box {
  background-color: rgba(0, 0, 0, 0.6);
  position: relative;
  padding: 130px 32px;
}
@media screen and (max-width: 767px) {
  .box {
    padding: 56px 20px;
  }
}
.box::before, .box::after {
  content: "";
  display: block;
  width: 100%;
  aspect-ratio: 1074/230;
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  left: 0;
}
.box::before {
  background-image: url(../img/border-top.webp);
  top: 0;
}
.box::after {
  background-image: url(../img/border-bottom.webp);
  bottom: 0;
}

.table {
  width: calc(100% + 4px);
  margin-left: -2px;
  border-spacing: 2px;
}
.table .table-title {
  white-space: nowrap;
}
@media screen and (max-width: 767px) {
  .table .table-title {
    display: none;
  }
}
.table .table-title-sp {
  text-align: center;
  background: #222B43;
}
@media screen and (min-width: 768px) {
  .table .table-title-sp {
    display: none;
  }
}
.table th {
  background: #000;
  font-size: 1.125rem;
  font-weight: bold;
  padding: 16px 20px;
  vertical-align: top;
}
@media screen and (max-width: 767px) {
  .table th {
    font-size: 0.9rem;
    padding: 8px;
    width: 25%;
  }
}
.table td {
  background: #fff;
  color: #000;
  padding: 16px;
}
@media screen and (max-width: 767px) {
  .table td {
    font-size: 0.9rem;
    padding: 8px;
  }
}
.table td strong {
  font-weight: normal;
  color: #F62F36;
}

.link-s {
  color: #02AFDC;
  font-size: 0.875rem;
  font-weight: bold;
  padding-left: 22px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .link-s {
    font-size: 0.8rem;
    padding-left: 16px;
  }
}
.link-s::before {
  content: "";
  display: block;
  width: 13px;
  height: 8.5px;
  background-image: url(../img/ico-arrow-blue.svg);
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top: 6px;
  left: 0;
}
@media screen and (max-width: 767px) {
  .link-s::before {
    width: 12px;
  }
}

.comingsoon {
  display: inline-block;
  font-size: 3.75rem;
  font-weight: bold;
  font-family: "Quantico", sans-serif;
  font-style: italic;
  text-align: center;
  padding: 0 80px;
  height: 112px;
  line-height: 112px;
  background: -webkit-gradient(linear, left top, right top, from(rgba(0, 0, 0, 0)), color-stop(10%, rgb(0, 0, 0)), color-stop(90%, rgb(0, 0, 0)), to(rgba(0, 0, 0, 0)));
  background: linear-gradient(to right, rgba(0, 0, 0, 0) 0%, rgb(0, 0, 0) 10%, rgb(0, 0, 0) 90%, rgba(0, 0, 0, 0) 100%);
}
@media screen and (max-width: 767px) {
  .comingsoon {
    font-size: 2rem;
    padding: 0 32px;
    height: 64px;
    line-height: 64px;
  }
}

.remodal {
  max-width: 1080px;
  width: 100%;
  padding: 56px 32px;
  background-color: #222B43;
  -webkit-box-shadow: 0 0 15px rgba(0, 0, 0, 0.16);
          box-shadow: 0 0 15px rgba(0, 0, 0, 0.16);
}
@media screen and (max-width: 767px) {
  .remodal {
    padding: 32px 20px;
  }
}
.remodal__content--title {
  max-width: 768px;
  margin: 0 auto;
}

.remodal-close {
  width: 56px;
  height: 56px;
  left: inherit;
  right: 0;
}
@media screen and (max-width: 767px) {
  .remodal-close {
    width: 48px;
    height: 48px;
  }
}
.remodal-close::before {
  width: 56px;
  line-height: 56px;
  font-size: 56px;
  font-weight: normal;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .remodal-close::before {
    width: 48px;
    line-height: 48px;
    font-size: 48px;
  }
}

.remodal-overlay {
  background: #0A1227;
  opacity: 0.8;
}

.remodal-close-button {
  margin-top: 32px;
}

.block-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  grid-gap: 20px;
}
.block-list__content {
  width: calc(50% - 10px);
  text-align: left;
  margin-bottom: 24px;
}
@media screen and (max-width: 767px) {
  .block-list__content {
    width: 100%;
    margin-bottom: 16px;
  }
}
.block-list__content--col-01 {
  width: 100%;
}
.block-list__title {
  width: 120px;
  height: 32px;
  line-height: 32px;
  color: #fff;
  font-size: 1.125rem;
  padding: 0 8px;
  margin-bottom: 12px;
  text-align: center;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .block-list__title {
    font-size: 1rem;
    height: 24px;
    line-height: 24px;
    margin-bottom: 8px;
    width: 100px;
  }
}
.block-list__title--a {
  background: #F62F36;
}
.block-list__title--b {
  background: #03BB85;
}
.block-list__title--c {
  background: #FF9500;
}
.block-list__title--d {
  background: #C1A470;
}
.block-list__title--e {
  background: #B5B5AC;
}
.block-list__title--f {
  background: #8F76D6;
}
.block-list__title--g {
  background: #009BBF;
}
.block-list__title--h {
  background: #9C5E32;
}
.block-list__description {
  color: #fff;
}
@media screen and (max-width: 767px) {
  .block-list__description {
    font-size: 0.9rem;
  }
}
.block-list__logo {
  margin-top: 16px;
  background: rgba(10, 18, 39, 0.2588235294);
  padding: 8px;
}
.block-list__logo-title {
  font-size: 0.875rem;
  font-weight: bold;
  margin-bottom: 4px;
  color: #fff;
  width: 104px;
  border: 1px solid #fff;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .block-list__logo-title {
    margin-bottom: 8px;
  }
}

.logo-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  grid-gap: 5px;
}
@media screen and (max-width: 767px) {
  .logo-list {
    grid-gap: 4px;
  }
}
.logo-list__content {
  width: calc(20% - 4px);
}
@media screen and (max-width: 767px) {
  .logo-list__content {
    width: calc(25% - 3px);
  }
}

.game-title-wrap {
  text-align: center;
}

.game-title-content {
  display: inline-block;
}

.list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  grid-gap: 2px;
  padding-left: 20px;
  list-style: disc;
  margin-top: 8px;
}
.list__content {
  font-size: 0.875rem;
  color: #fff;
}

.mv {
  margin-top: 80px;
}
@media screen and (max-width: 767px) {
  .mv {
    margin-top: 56px;
  }
}

.entry {
  padding: 0 0 72px;
  background-color: #000;
}
@media screen and (max-width: 767px) {
  .entry {
    padding: 0 0 24px;
  }
}
.entry__banner {
  display: block;
  padding-top: 40px;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.entry__banner:hover {
  opacity: 0.7;
}
@media screen and (max-width: 767px) {
  .entry__banner {
    padding-top: 24px;
  }
}
.entry__content {
  padding-top: 54px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .entry__content {
    padding-top: 24px;
  }
}
.entry__text {
  display: inline-block;
  margin-bottom: 24px;
}
@media screen and (max-width: 767px) {
  .entry__text {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    display: inline-block;
  }
}
.entry__date {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 767px) {
  .entry__date {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.entry__date-title {
  width: 120px;
  height: 48px;
  line-height: 46px;
  border: 1px solid #fff;
  text-align: center;
  font-size: 1.75rem;
  font-weight: bold;
  margin-right: 24px;
}
@media screen and (max-width: 767px) {
  .entry__date-title {
    font-size: 1rem;
    height: 32px;
    line-height: 30px;
    margin-right: 16px;
    width: 80px;
  }
}
.entry__date-description {
  font-family: "Quantico", sans-serif;
  font-style: italic;
  font-size: 4rem;
  font-weight: bold;
  line-height: 1.2;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .entry__date-description {
    font-size: 2rem;
    width: calc(100% - 96px);
  }
}
.entry__button {
  padding-bottom: 32px;
  margin-bottom: 32px;
  border-bottom: 1px solid #fff;
}
@media screen and (max-width: 767px) {
  .entry__button {
    width: 100%;
    padding-bottom: 24px;
    margin-bottom: 24px;
  }
}
.entry__news {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  max-width: 912px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .entry__news {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
.entry__news-button {
  width: 48%;
}
@media screen and (max-width: 767px) {
  .entry__news-button {
    width: 100%;
  }
  .entry__news-button .button {
    margin: 0 auto;
  }
}
.entry__news-title {
  width: 50%;
  font-size: 1.5rem;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .entry__news-title {
    width: 100%;
    text-align: center;
    font-size: 1rem;
    margin-bottom: 8px;
  }
}

.concept {
  padding: 160px 0 80px;
}
@media screen and (max-width: 767px) {
  .concept {
    padding: 40px 0;
  }
}
.concept__content {
  max-width: 764px;
  margin: 0 auto;
}
.concept__title {
  text-align: center;
  margin-bottom: 56px;
  font-weight: bold;
  line-height: 1.2;
}
@media screen and (max-width: 767px) {
  .concept__title {
    margin-bottom: 32px;
  }
}
.concept__title span {
  display: inline-block;
}
.concept__sub-title {
  text-align: center;
  padding: 8px;
  background: rgba(2, 175, 220, 0.2);
  border: 2px solid #02AFDC;
  font-size: 1.4rem;
  font-weight: bold;
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  .concept__sub-title {
    font-size: 1rem;
  }
}
.concept__title-01 {
  font-size: 2rem;
  margin-bottom: 16px;
}
@media screen and (max-width: 767px) {
  .concept__title-01 {
    font-size: 1rem;
    line-height: 1.7;
  }
}
.concept__title-02 {
  font-family: "Quantico", sans-serif;
  font-size: 6.1875rem;
  font-style: italic;
  color: #02AFDC;
  text-shadow: 0 0 15px rgba(0, 0, 0, 0.16);
  letter-spacing: -0.5rem;
}
@media screen and (max-width: 767px) {
  .concept__title-02 {
    font-size: 3rem;
    letter-spacing: 0;
    line-height: 1;
    margin-bottom: 12px;
  }
}
.concept__title-03 {
  font-size: 2.75rem;
}
@media screen and (max-width: 767px) {
  .concept__title-03 {
    font-size: 1.5rem;
  }
}
.concept__description {
  font-size: 1.125rem;
  font-weight: bold;
  line-height: 2.33;
}
@media screen and (max-width: 767px) {
  .concept__description {
    font-size: 0.9rem;
    font-weight: normal;
    line-height: 2;
  }
}

.logo-area__list-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow: hidden;
}
.logo-area__list-wrap + .logo-area__list-wrap {
  margin-top: 24px;
}
@media screen and (max-width: 767px) {
  .logo-area__list-wrap + .logo-area__list-wrap {
    margin-top: 16px;
  }
}
.logo-area__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  list-style: none;
  padding: 0;
}
.logo-area__list--left {
  -webkit-animation: infinity-scroll-left 120s infinite linear 0s both;
          animation: infinity-scroll-left 120s infinite linear 0s both;
}
.logo-area__list--right {
  -webkit-animation: infinity-scroll-right 120s infinite linear 0s both;
          animation: infinity-scroll-right 120s infinite linear 0s both;
}
.logo-area__list-content {
  width: 1284px;
  margin: 0 16px;
}
@media screen and (max-width: 767px) {
  .logo-area__list-content {
    width: 640px;
    margin: 0 8px;
  }
}
.logo-area__list-content img {
  width: 100%;
}

@-webkit-keyframes infinity-scroll-left {
  from {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  to {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@keyframes infinity-scroll-left {
  from {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  to {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@-webkit-keyframes infinity-scroll-right {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@keyframes infinity-scroll-right {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
.overview {
  padding: 140px 0;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .overview {
    padding: 100px 0 64px;
  }
}
.overview .content-wrap {
  position: relative;
}
.overview__image {
  width: 376px;
  position: absolute;
  top: -120px;
  left: -120px;
  z-index: 0;
}
@media screen and (max-width: 767px) {
  .overview__image {
    width: 188px;
    top: -80px;
    left: -50px;
  }
}
.overview__title {
  text-align: left;
  margin-bottom: 112px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .overview__title {
    margin-bottom: 56px;
  }
}
.overview__all {
  display: inline-block;
  text-align: left;
  margin-bottom: 112px;
}
@media screen and (max-width: 767px) {
  .overview__all {
    margin-bottom: 56px;
  }
}
.overview__all-dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  grid-gap: 24px;
}
@media screen and (max-width: 767px) {
  .overview__all-dl {
    grid-gap: 0;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.overview__all-dl + .overview__all-dl {
  margin-top: 16px;
}
.overview__all-dt {
  background: #FF9500;
  width: 140px;
  height: 40px;
  line-height: 40px;
  text-align: center;
  font-weight: bold;
  font-size: 1.125rem;
}
@media screen and (max-width: 767px) {
  .overview__all-dt {
    width: 28%;
    height: auto;
    line-height: 1.5;
    font-size: 0.9rem;
    padding: 4px 8px;
    text-align: left;
  }
}
.overview__all-dd {
  font-size: 1.125rem;
  font-weight: bold;
  margin-top: 5px;
}
@media screen and (max-width: 767px) {
  .overview__all-dd {
    width: 72%;
    padding: 4px 0 4px 12px;
    font-size: 0.9rem;
    margin-top: 0;
  }
}
.overview__detail {
  text-align: left;
}
.overview__detail-title {
  text-align: center;
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  .overview__detail-title {
    margin-bottom: 32px;
  }
}

.overview__button {
  margin-top: 64px;
}

@media screen and (max-width: 767px) {
  .overview__button {
    margin-top: 40px;
  }
}

.casts {
  padding: 190px 0 120px;
}
@media screen and (max-width: 767px) {
  .casts {
    padding: 100px 0 64px;
  }
}
.casts .content-wrap {
  position: relative;
}
.casts__image {
  width: 834px;
  position: absolute;
  top: -210px;
  right: -370px;
}
@media screen and (max-width: 767px) {
  .casts__image {
    width: 417px;
    top: -100px;
    right: -162px;
  }
}
.casts__title {
  text-align: center;
  margin-bottom: 120px;
}
@media screen and (max-width: 767px) {
  .casts__title {
    margin-bottom: 56px;
  }
}
.casts__comingsoon {
  text-align: center;
}

.prize {
  padding: 190px 0 160px;
}
@media screen and (max-width: 767px) {
  .prize {
    padding: 100px 0 80px;
  }
}
.prize .content-wrap {
  position: relative;
}
.prize__image {
  width: 829px;
  position: absolute;
  top: -390px;
  left: -460px;
}
@media screen and (max-width: 767px) {
  .prize__image {
    width: 414.5px;
    top: -220px;
    left: -162px;
  }
}
.prize__title {
  text-align: center;
  margin-bottom: 120px;
}
@media screen and (max-width: 767px) {
  .prize__title {
    margin-bottom: 56px;
  }
}
.prize__comingsoon {
  text-align: center;
}

.schedule {
  padding: 112px 0 120px;
  margin-top: 24px;
  background-color: #222B43;
}
@media screen and (max-width: 767px) {
  .schedule {
    padding: 64px 0;
  }
}
.schedule__title {
  text-align: center;
  margin-bottom: 80px;
}
@media screen and (max-width: 767px) {
  .schedule__title {
    margin-bottom: 64px;
  }
}
.schedule__slide {
  max-width: 688px;
  margin: 0 auto;
  overflow: hidden;
  position: relative;
}
.schedule .swiper-button-prev,
.schedule .swiper-button-next {
  width: 8%;
  top: 15.5%;
  -webkit-transform: inherit;
          transform: inherit;
}
.schedule .swiper-button-prev svg,
.schedule .swiper-button-next svg {
  display: none;
}
.schedule .swiper-button-prev {
  left: inherit;
  right: 12%;
}
.schedule__button {
  max-width: 688px;
  margin: 40px auto 0;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .schedule__button {
    margin: 20px auto 0;
    padding-left: 4px;
  }
}
.schedule__button .link-s {
  color: #fff;
  font-size: 1.25rem;
  padding-left: 26px;
}
@media screen and (max-width: 767px) {
  .schedule__button .link-s {
    font-size: 0.9rem;
    padding-left: 20px;
  }
}
.schedule__button .link-s::before {
  background-image: url(../img/ico-arrow.svg);
  width: 17px;
  height: 11.5px;
  top: 9px;
}
@media screen and (max-width: 767px) {
  .schedule__button .link-s::before {
    width: 13px;
    height: 8.5px;
    top: 6px;
  }
}

.access {
  padding: 180px 0 350px;
}
@media screen and (max-width: 767px) {
  .access {
    padding: 100px 0 140px;
  }
}
.access .content-wrap {
  position: relative;
}
.access__image {
  width: 406px;
  position: absolute;
  top: -190px;
  right: -130px;
}
@media screen and (max-width: 767px) {
  .access__image {
    width: 203px;
    top: -112px;
    right: -72px;
  }
}
.access__image-02 {
  width: 898px;
  position: absolute;
  bottom: -232px;
  left: -520px;
}
@media screen and (max-width: 767px) {
  .access__image-02 {
    width: 449px;
    bottom: -100px;
    left: -190px;
  }
}
.access__title {
  margin-bottom: 80px;
}
@media screen and (max-width: 767px) {
  .access__title {
    margin-bottom: 56px;
  }
}
.access__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
@media screen and (max-width: 767px) {
  .access__content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    grid-gap: 24px;
  }
}
.access__text {
  width: 48%;
}
@media screen and (max-width: 767px) {
  .access__text {
    width: 100%;
  }
}
.access__map {
  width: 50%;
  aspect-ratio: 540/375;
  position: relative;
}
@media screen and (max-width: 767px) {
  .access__map {
    width: 100%;
  }
}
.access__map iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
.access__dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  grid-gap: 24px;
}
@media screen and (max-width: 767px) {
  .access__dl {
    grid-gap: 12px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.access__dl + .access__dl {
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  .access__dl + .access__dl {
    margin-top: 24px;
  }
}
.access__dt {
  background: #009BBF;
  width: 140px;
  height: 40px;
  line-height: 40px;
  text-align: center;
  font-weight: bold;
  font-size: 1.25rem;
}
@media screen and (max-width: 767px) {
  .access__dt {
    width: 100%;
    font-size: 0.9rem;
  }
}
.access__dd {
  font-size: 1.25rem;
  font-weight: bold;
  margin-top: 5px;
}
@media screen and (max-width: 767px) {
  .access__dd {
    font-size: 0.9rem;
  }
}
.access__dd span {
  display: block;
  margin-top: 12px;
}

.broadcast {
  padding: 100px 0 120px;
  background-color: #222B43;
}
@media screen and (max-width: 767px) {
  .broadcast {
    padding: 64px 0;
  }
}
.broadcast__title {
  margin-bottom: 56px;
}
@media screen and (max-width: 767px) {
  .broadcast__title {
    margin-bottom: 40px;
  }
}
.broadcast__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 767px) {
  .broadcast__content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.broadcast__description {
  width: calc(100% - 500px);
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .broadcast__description {
    width: 100%;
    margin-bottom: 32px;
    font-size: 0.9rem;
  }
}
.broadcast__button {
  width: 460px;
}
@media screen and (max-width: 767px) {
  .broadcast__button {
    width: 100%;
  }
}

.partner {
  padding: 100px 0 160px;
}
@media screen and (max-width: 767px) {
  .partner {
    padding: 64px 0;
  }
}
.partner__title {
  text-align: center;
}

.footer {
  background: #222B43;
}

.footer .content-wrap {
  position: relative;
}

.footer__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 32px 0;
}
@media screen and (max-width: 767px) {
  .footer__content {
    padding: 32px 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.footer__logo-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
@media screen and (max-width: 767px) {
  .footer__logo-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    grid-gap: 24px;
    margin-bottom: 32px;
  }
}
.footer__logo {
  margin-right: 40px;
}
@media screen and (max-width: 767px) {
  .footer__logo {
    margin-right: 0;
    margin: 0 12px;
  }
}
.footer__logo-title {
  font-size: 1.125rem;
  font-weight: bold;
  margin-bottom: 14px;
}
@media screen and (max-width: 767px) {
  .footer__logo-title {
    font-size: 0.9rem;
    text-align: center;
  }
}
.footer__logo-image-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  grid-gap: 12px;
}
.footer__logo-image {
  width: 190px;
}
@media screen and (max-width: 1080px) {
  .footer__logo-image {
    width: 140px;
  }
}
@media screen and (max-width: 767px) {
  .footer__logo-image {
    width: 140px;
    margin: 0 auto;
  }
}
.footer__menu {
  text-align: right;
  position: relative;
  width: calc(100% - 700px);
  padding-bottom: 24px;
}
@media screen and (max-width: 1080px) {
  .footer__menu {
    width: calc(100% - 550px);
  }
}
@media screen and (max-width: 767px) {
  .footer__menu {
    text-align: center;
    width: 100%;
    padding-bottom: 0;
  }
}

.footer__contact {
  display: inline-block;
  max-width: 300px;
  width: 100%;
  text-align: left;
}

@media screen and (max-width: 767px) {
  .footer__contact {
    display: block;
    max-width: 450px;
    margin: 0 auto;
  }
}

.footer__contact-mail {
  display: inline-block;
  width: 100%;
  border: 1px solid #fff;
  height: 48px;
  font-size: 0.75rem;
  text-align: left;
  font-weight: bold;
  position: relative;
  padding: 5px 24px;
}

.footer__contact-mail span {
  display: block;
  font-size: 0.6rem;
  font-weight: normal;
  margin-top: 2px;
}

.footer__contact-mail::after {
  content: "";
  display: block;
  width: 16px;
  height: 12px;
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top: 50%;
  right: 8px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: 0.3s;
  transition: 0.3s;
  background-image: url(../img/ico-arrow.svg);
}

.footer__contact-mail:hover {
  opacity: 0.7;
}

.footer__contact-mail:hover::after {
  transform: translate(3px, -50%);
}

.footer__contact-description {
  font-size: 0.6rem;
  margin-top: 12px;
  opacity: 0.7;
}

.footer__contact + .footer__contact {
  margin-top: 12px;
}

@media screen and (max-width: 767px) {
  .footer__contact-mail {
    width: 100%;
  }

  .footer__contact-mail::after {
    width: 16px;
    height: 12px;
    right: 12px;
  }
}

.footer__privacy {
  display: block;
  color: #fff;
  font-weight: bold;
  margin-bottom: 12px;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.footer__privacy:hover {
  opacity: 0.7;
}
.footer__copyright {
  display: block;
  width: 100%;
  font-size: 0.75rem;
  font-weight: bold;
  font-family: "Quantico", sans-serif;
  position: absolute;
  bottom: 32px;
  left: 0;
}
@media screen and (max-width: 767px) {
  .footer__copyright {
    position: relative;
    bottom: inherit;
    left: inherit;
    font-size: 0.75rem;
    text-align: center;
    padding: 32px 0;
  }
}

.header {
  width: 100%;
  background-color: #0A1227;
  height: 80px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  z-index: 999;
  position: fixed;
  top: 0;
  left: 0;
}
@media screen and (max-width: 767px) {
  .header {
    height: 56px;
  }
}
.header__logo {
  padding-left: 8px;
}
@media screen and (max-width: 767px) {
  .header__logo {
    padding-left: 4px;
  }
}
.header__logo a {
  display: block;
  width: 136px;
  line-height: 80px;
}
@media screen and (max-width: 767px) {
  .header__logo a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    width: 90px;
    line-height: 56px;
  }
}
.header__menu-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  grid-gap: 32px;
}
@media screen and (max-width: 1024px) {
  .header__menu-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    grid-gap: 0;
  }
}
.header__menu-list-content {
  display: inline-block;
  height: 100%;
}
@media screen and (max-width: 1024px) {
  .header__menu-list-content {
    height: auto;
    display: block;
    width: 100%;
  }
}
.header__menu-list-link {
  display: block;
  color: #fff;
}
.header__menu-list-link:hover {
  opacity: 0.7;
}
@media screen and (max-width: 1024px) {
  .header__menu-list-link {
    color: #fff;
    padding: 8px 32px;
    position: relative;
    text-align: center;
    width: 100%;
    text-align: left;
    border-bottom: 1px solid #fff;
  }
  .header__menu-list-link::after {
    content: "";
    display: block;
    width: 16px;
    height: 12px;
    background-image: url(../img/ico-arrow.svg);
    background-size: contain;
    position: absolute;
    top: 50%;
    right: 16px;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}
.header__menu-list-link--button {
  color: #fff;
  width: 160px;
  height: 80px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: left;
  background: linear-gradient(to right, #ED178A, #96007F);
}
.header__menu-list-link--button:hover {
  opacity: 1;
}
@media screen and (max-width: 1024px) {
  .header__menu-list-link--button {
    margin: 0 20px;
    height: 56px;
    width: 100%;
    text-align: center;
    max-width: 480px;
    margin: 32px auto 0;
    position: fixed;
    bottom: 0;
    left: 0;
    border-bottom: none;
  }
}
.header__menu-list-link--button .header__menu-list-link-english {
  font-size: 1.75rem;
  line-height: 1.2;
}
.header__menu-list-link--button .header__menu-list-link-japanese {
  font-size: 0.875rem;
}
@media screen and (max-width: 1024px) {
  .header__menu-list-link--button .header__menu-list-link-japanese {
    font-size: 1.25rem;
  }
}
.header__menu-list-link-english {
  display: block;
  font-family: "Quantico", sans-serif;
  font-size: 1.125rem;
  font-weight: bold;
}
.header__menu-list-link-japanese {
  display: block;
  font-size: 0.75rem;
  font-weight: bold;
}
.header__button-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.header__button-list--sp {
  display: none;
}
@media screen and (max-width: 1024px) {
  .header__button-list--sp {
    display: block;
  }
}
.header__button-list-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: left;
  width: 120px;
  height: 80px;
  background: linear-gradient(to right, #ED178A, #96007F);
  -webkit-transition: 0.3s;
  transition: 0.3s;
  line-height: 1.2;
  margin-right: 56px;
}
.header__button-list-link:hover {
  opacity: 1;
}
@media screen and (max-width: 767px) {
  .header__button-list-link {
    width: 100px;
    height: 56px;
  }
}
.header__button-list-link span {
  display: block;
}
.header__button-list-link:hover {
  opacity: 0.7;
}
.header__button-list-link-english {
  font-size: 1.25rem;
  font-family: "Quantico", sans-serif;
  font-weight: bold;
}
.header__button-list-link-japanese {
  font-size: 0.65rem;
  font-weight: bold;
  margin-top: 2px;
}
.header #nav-toggle {
  display: none;
}

@media screen and (max-width: 1024px) {
  .header #nav-toggle {
    display: block;
    position: absolute;
    top: 12px;
    right: 0;
    width: 56px;
    height: 56px;
    cursor: pointer;
    z-index: 101;
  }
  .header #nav-toggle div {
    position: relative;
  }
  .header #nav-toggle span {
    display: block;
    position: absolute;
    height: 1px;
    width: 45%;
    background: #fff;
    left: 27.5%;
    -webkit-transition: 0.35s ease-in-out;
    transition: 0.35s ease-in-out;
  }
  .header #nav-toggle span:nth-child(1) {
    top: 20px;
    width: 50%;
    left: 25%;
  }
  .header #nav-toggle span:nth-child(2) {
    top: 28px;
    width: 50%;
    left: 25%;
  }
  .header #nav-toggle span:nth-child(3) {
    top: 36px;
    width: 50%;
    left: 25%;
  }
  .header #global-nav {
    position: fixed;
    /* 開いてないときは画面外に配置 */
    right: 0;
    top: 0;
    background-color: #000;
    text-align: left;
    padding: 64px 0 80px;
    opacity: 0;
    z-index: -999;
    visibility: hidden;
    width: 100%;
    height: 100vh;
    overflow-y: auto;
    background-image: url(../img/bg-dot.webp);
    background-size: 1714px auto;
    background-repeat: repeat;
  }
  .fade #global-nav {
    -webkit-transition: 0.5s ease-in-out;
    transition: 0.5s ease-in-out;
  }
  /* #nav-toggle 切り替えアニメーション */
  .header.open {
    /* #global-nav スライドアニメーション */
  }
  .header.open #nav-toggle {
    position: fixed;
    top: 0;
    right: 0;
  }
  .header.open #nav-toggle span {
    background: #fff;
  }
  .header.open #nav-toggle span:nth-child(1) {
    top: 26px;
    -webkit-transform: rotate(315deg);
    transform: rotate(315deg);
    left: 30%;
  }
  .header.open #nav-toggle span:nth-child(2) {
    width: 0;
    left: 50%;
  }
  .header.open #nav-toggle span:nth-child(3) {
    width: 50%;
    top: 26px;
    -webkit-transform: rotate(-315deg);
    transform: rotate(-315deg);
    left: 30%;
  }
  .header.open #global-nav {
    position: fixed;
    opacity: 1;
    visibility: visible;
    -webkit-box-shadow: 0px 2px 15px 0px rgba(0, 0, 0, 0.05);
    box-shadow: 0px 2px 15px 0px rgba(0, 0, 0, 0.05);
    z-index: 100;
  }
}
@media screen and (max-width: 767px) {
  .header #nav-toggle {
    top: 0;
    right: 0;
  }
  .header #global-nav {
    background-size: 1200px auto;
  }
}
