:root {
  --noto-sans: "Noto Sans JP", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  --arial: "Arial", "Noto Sans JP", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  --akshar: "Akshar", sans-serif;
  --poppins: "poppins", sans-serif;
  --white: #fff;
  --black: #000;
  --red: #cf142b;
  --ease: cubic-bezier(0.83, 0, 0.17, 1);
}

header nav .logo {
  margin-right: auto;
}

main {
  position: relative;
}
main section.lead {
  background: url("/media/images/cms/index/bg_lead_l.jpg") no-repeat left center/auto 100%, url("/media/images/cms/index/bg_lead_r.jpg") no-repeat right center/auto 100%;
  background-color: var(--black);
  width: 100%;
  text-align: center;
  color: var(--white);
  padding: 40px 15px;
}
@media screen and (max-width: 767px) {
  main section.lead {
    background: url("/media/images/cms/index/bg_lead_l_sp.jpg") no-repeat left bottom/65% auto, url("/media/images/cms/index/bg_lead_r_sp.jpg") no-repeat right top/65% auto;
    background-color: var(--black);
    padding: 5vw 3%;
  }
}
main section.lead .offline {
  font-size: 42px;
  font-weight: 900;
  font-style: italic;
  display: inline-block;
  background: -webkit-gradient(linear, left top, right top, from(#d4b439), color-stop(50%, #f7f1cf), to(#d4b439));
  background: linear-gradient(90deg, #d4b439 0%, #f7f1cf 50%, #d4b439 100%);
  color: transparent;
  -webkit-background-clip: text;
  letter-spacing: 0.1em;
  line-height: 1.5;
}
@media screen and (max-width: 960px) {
  main section.lead .offline {
    font-size: 4.1666666667vw;
  }
}
@media screen and (max-width: 767px) {
  main section.lead .offline {
    font-size: 6.5vw;
    line-height: 1.3;
  }
}
main section.lead .offline .small {
  font-size: 36px;
}
@media screen and (max-width: 767px) {
  main section.lead .offline .small {
    font-size: 5vw;
  }
}
main section.lead .offline .small-group {
  font-size: 75%;
  display: block;
}
@media screen and (max-width: 767px) {
  main section.lead .offline .small-group {
    margin-bottom: 5px;
  }
}
main section.lead .offline .large {
  font-size: 54px;
}
@media screen and (max-width: 767px) {
  main section.lead .offline .large {
    font-size: 6.5vw;
  }
}
main section.lead .enjoy {
  font-size: 32px;
  font-style: italic;
  font-weight: bold;
  margin-top: 5px;
}
@media screen and (max-width: 767px) {
  main section.lead .enjoy {
    font-size: 4.2vw;
    margin-top: 1vw;
  }
}
main section.lead .announcement {
  margin-top: 20px;
  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;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 30px;
}
@media screen and (max-width: 767px) {
  main section.lead .announcement {
    margin-top: 4vw;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 2vw;
  }
}
main section.lead .announcement p {
  line-height: 1;
}
main section.lead .announcement p:nth-child(1) {
  font-weight: 900;
  font-size: 35px;
}
@media screen and (max-width: 767px) {
  main section.lead .announcement p:nth-child(1) {
    font-size: 4vw;
  }
}
main section.lead .announcement p:nth-child(2) {
  font-size: 57px;
  font-weight: 900;
}
@media screen and (max-width: 767px) {
  main section.lead .announcement p:nth-child(2) {
    font-size: 7vw;
  }
}
main section.lead .announcement p:nth-child(2) span {
  font-size: 35px;
}
@media screen and (max-width: 767px) {
  main section.lead .announcement p:nth-child(2) span {
    font-size: 5vw;
  }
}
main section.lead .announcement p:nth-child(3) {
  font-size: 20px;
}
@media screen and (max-width: 767px) {
  main section.lead .announcement p:nth-child(3) {
    font-size: 3vw;
    margin-top: 1vw;
  }
}
main section.venue-area {
  padding: 60px 40px 80px;
  position: relative;
  color: var(--white);
  text-align: center;
  background: url(/media/images/cms/index/bg_concept01.png) no-repeat right top/650px, url(/media/images/cms/index/bg_concept02.png) no-repeat left bottom/500px;
  background-color: var(--red);
}
@media screen and (max-width: 767px) {
  main section.venue-area {
    padding: 40px 5%;
    background: url(/media/images/cms/index/bg_concept01.png) no-repeat right top/350px, url(/media/images/cms/index/bg_concept02.png) no-repeat left bottom/250px;
    background-color: var(--red);
  }
}
main section.venue-area h2 {
  font-size: 56px;
  font-family: var(--arial);
  font-weight: 700;
  font-style: italic;
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  main section.venue-area h2 {
    font-size: 36px;
  }
}
main section.venue-area ul.venue-list {
  max-width: 900px;
  margin: 60px auto 0;
  gap: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 767px) {
  main section.venue-area ul.venue-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-top: 40px;
    gap: 40px;
  }
}
main section.venue-area ul.venue-list li {
  background-color: var(--white);
  width: calc((100% - 60px) / 2);
  border-radius: 20px;
  padding: 20px;
  color: var(--red);
}
@media screen and (max-width: 767px) {
  main section.venue-area ul.venue-list li {
    width: 100%;
  }
}
main section.venue-area ul.venue-list li h3 {
  font-size: 28px;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  main section.venue-area ul.venue-list li h3 {
    font-size: 24px;
  }
}
main section.venue-area ul.venue-list li p {
  font-size: 18px;
  margin-top: 15px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  main section.venue-area ul.venue-list li p {
    font-size: 16px;
    margin-top: 15px;
  }
}
main section.venue-area ul.venue-list li a {
  margin: 25px auto 0;
  background-color: var(--white);
  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;
  border: 3px solid var(--red);
  max-width: 300px;
  height: 70px;
  color: var(--red);
  font-size: 19px;
  border-radius: 50px;
  font-weight: 600;
  letter-spacing: 0.1em;
  line-height: 1.3;
  -webkit-transition: background-color 0.3s, color 0.3s, border-color 0.3s;
  transition: background-color 0.3s, color 0.3s, border-color 0.3s;
}
@media (hover) {
  main section.venue-area ul.venue-list li a:hover {
    background-color: var(--red);
    color: var(--white);
  }
}
@media screen and (max-width: 767px) {
  main section.venue-area ul.venue-list li a {
    width: 300px;
    height: 60px;
    font-size: 18px;
    margin-top: 25px;
  }
}
main section.venue-area ul.venue-list li a.coming-soon {
  pointer-events: none;
  background-color: #666;
  border-color: #666;
  color: #c3c2c2;
}
main section.mv {
  aspect-ratio: 2000/836;
  background: -webkit-gradient(linear, left top, right top, color-stop(0, #fff), color-stop(5%, #fff), color-stop(5%, #f6f6f6), color-stop(95%, #c9caca), color-stop(95%, #fff), to(#fff));
  background: linear-gradient(90deg, #fff 0, #fff 5%, #f6f6f6 5%, #c9caca 95%, #fff 95%, #fff 100%);
  position: relative;
}
@media screen and (max-width: 767px) {
  main section.mv {
    aspect-ratio: 750/700;
    background: -webkit-gradient(linear, left top, right top, color-stop(0, #f6f6f6), to(#c9caca));
    background: linear-gradient(90deg, #f6f6f6 0, #c9caca 100%);
  }
}
main section.mv .obj {
  position: absolute;
  top: 19.3333333333vw;
  left: 72.6666666667vw;
  width: 15.2%;
  z-index: 5;
}
@media screen and (max-width: 767px) {
  main section.mv .obj {
    top: 64vw;
    left: auto;
    right: 1.3333333333vw;
    width: 17.3333333333%;
  }
}
main section.mv .bg2 {
  height: 100%;
}
@media screen and (max-width: 767px) {
  main section.mv .bg2 img {
    -o-object-fit: cover;
       object-fit: cover;
    width: 100%;
    height: 100%;
  }
}
main section.mv .bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
main section.mv h1 {
  width: 12.9333333333%;
  position: absolute;
  top: 3vw;
  left: 14%;
  z-index: 3;
}
@media screen and (max-width: 767px) {
  main section.mv h1 {
    width: 76.9333333333%;
    position: absolute;
    top: 6.6666666667vw;
    left: 5.3333333333%;
  }
}
main section.mv .copy {
  width: 38.2%;
  position: absolute;
  top: 50% !important;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) !important;
          transform: translate(-50%, -50%) !important;
  z-index: 3;
}
@media screen and (max-width: 767px) {
  main section.mv .copy {
    -webkit-transform: none;
            transform: none;
    top: auto !important;
    bottom: -14vw;
    width: 68.4vw;
  }
}
main section.mv .human {
  width: 21.6666666667%;
  position: absolute;
  top: 1.6666666667vw;
  left: 69.3333333333%;
  z-index: 3;
}
@media screen and (max-width: 767px) {
  main section.mv .human {
    width: 28%;
    top: 44.6666666667vw;
    left: auto;
    right: 1.3333333333%;
    z-index: 1;
  }
}