﻿.inner .flex_wrap {
  display: flex;
  justify-content: space-between
}
@media screen and (max-width: 768px) {
  .inner .flex_wrap {
    display: block;
    margin-top: 5.333333vw
  }
}
.inner .flex_wrap .ttl {
  margin-bottom: 2em
}
.inner .flex_wrap .ttl span {
  display: inline-block;
  padding-top: 10px;
  padding-right: 0;
  border-bottom: 4px solid var(--color-base-blue);
  border-image: var(--color-grad);
  border-image-slice: 1;
  color: var(--color-base-blue-dark);
  letter-spacing: .04em;
  font-size: 3.2rem;
  line-height: 1.2
}
@media screen and (max-width: 768px) {
  .inner .flex_wrap .ttl span {
    border-bottom-width: 2px;
    font-size: 5.6vw
  }
}
.inner .flex_wrap.reverse {
  flex-direction: row-reverse
}
.inner .flex_wrap.reverse .img_box {
  flex: 1;
  margin-right: 6%;
  margin-left: calc(50% - 50vw)
}
@media screen and (max-width: 768px) {
  .inner .flex_wrap.reverse .img_box {
    margin: 0 calc(50% - 50vw);
    width: 100vw
  }
}
.inner .flex_wrap.reverse .img_box img {
  width: 100%;
  box-shadow: var(--box-shadow)
}
@media screen and (max-width: 768px) {
  .inner .flex_wrap.reverse .img_box img {
    box-shadow: var(--box-shadow-sp)
  }
}
.inner .text_box {
  text-align: left
}
@media screen and (max-width: 768px) {
  .inner .text_box {
    margin-bottom: 10.666666vw
  }
}
.inner .text_box p {
  font-size: 2rem;
  line-height: 1.8
}
@media screen and (max-width: 768px) {
  .inner .text_box p {
    font-size: 3.466666vw;
    line-height: 1.769
  }
}
.inner .text_box p + p {
  margin-top: 2em
}
@media screen and (max-width: 768px) {
  .inner .text_box p + p {
    margin-top: 5.333333vw
  }
}
.inner .img_box {
  overflow: hidden;
  flex: 1;
  justify-content: center;
  margin-right: calc(50% - 50vw);
  margin-left: 9.8484848485%;
  height: 550px
}
@media screen and (max-width: 768px) {
  .inner .img_box {
    margin: 0
  }
}
.inner .img_box img {
  width: 100%;
  height: 100%;
  object-fit: cover
}
#fastLogo {
  position: fixed;
  z-index: 999;
  width: 100%;
  height: 100%;
  background: #4ab9f1;
  background: linear-gradient(90deg, rgb(74, 185, 241) 0%, rgb(0, 148, 224) 50%, rgb(74, 185, 241) 100%);
  color: var(--color-base-white);
  text-align: center
}
@media screen and (max-width: 768px) {
  #fastLogo {
    display: none
  }
}
#fastLogo_img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%)
}
#fastLogo_img img {
  width: 50%
}
.logo_anime {
  opacity: 0;
  animation-name: logoAnime;
  animation-duration: .5s;
  animation-fill-mode: forwards
}
@keyframes logoAnime {
  from {
    opacity: 0;
    transform: translateY(100px)
  }
  to {
    opacity: 1;
    transform: translateY(0)
  }
}
.mv {
  position: relative;
  overflow: hidden;
  margin: auto;
  padding: 0 min(2.9761904762%, 50px);
  max-width: 1680px
}
@media screen and (max-width: 768px) {
  .mv {
    padding: 0
  }
}
.mv .js-video {
  width: 100%;
  height: auto;
  vertical-align: bottom
}
@media screen and (max-width: 768px) {
  .mv .js-video {
    display: none
  }
}
.mv .movie_btn {
  position: absolute;
  right: min(3%, 50px);
  bottom: 5%;
  z-index: 22
}
.mv .movie_btn button {
  cursor: pointer
}
.mv .mv_slider_sp {
  background: var(--color-base-blue)
}
.mv .mv_slider_sp img {
  width: 100%;
  border-radius: 30px;
  transition: transform var(--sec-anime) ease-in-out;
  transform: scale(0.7)
}
.mv .mv_slider_sp.slick-dotted.slick-slider {
  margin-bottom: 0
}
.mv .mv_slider_sp .slick-active img {
  animation: 5s currentSlide 0s ease-in-out forwards
}
.mv .mv_slider_sp .slick-active img.first {
  border-radius: 0;
  transform: scale(1);
  animation: 5s firstSlide 0s ease-in-out forwards !important
}
.mv .mv_slider_sp .slick-slide {
  margin: 0 0
}
@keyframes firstSlide {
  0% {
    border-radius: 0;
    transform: scale(1)
  }
  90% {
    border-radius: 0;
    transform: scale(1)
  }
  100% {
    border-radius: 30px;
    transform: scale(0.7)
  }
}
@keyframes currentSlide {
  0% {
    border-radius: 30px;
    transform: scale(0.7)
  }
  20% {
    border-radius: 30px;
    transform: scale(0.7)
  }
  25% {
    border-radius: 0;
    transform: scale(1)
  }
  90% {
    border-radius: 0;
    transform: scale(1)
  }
  100% {
    border-radius: 30px;
    transform: scale(0.7)
  }
}
.mv .mv_slider_sp .slick-dots {
  bottom: 8px
}
.mv .mv_slider_sp .slick-dots button {
  display: none
}
.mv .mv_slider_sp .slick-dots li {
  position: relative;
  margin: 0 1px;
  width: 30px;
  height: 2px;
  background: rgba(255, 255, 255, .5);
  pointer-events: none
}
.mv .mv_slider_sp .slick-dots li.slick-active:before {
  animation: 5s slideBar 0s linear forwards !important
}
.mv .mv_slider_sp .slick-dots li:before {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 0;
  background: #fff;
  content: ""
}
@keyframes slideBar {
  0% {
    width: 0
  }
  100% {
    width: 100%
  }
}
.mv__visual {
  position: relative;
  overflow: hidden;
  border-top-left-radius: 30px;
  border-top-right-radius: 30px
}
@media screen and (max-width: 768px) {
  .mv__visual {
    border-radius: 0
  }
}
.form {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px 20px 14px;
  border-radius: 30px;
  background: #4ab9f1;
  background: linear-gradient(90deg, rgb(74, 185, 241) 0%, rgb(0, 148, 224) 100%);
  color: #fff;
  text-align: center;
  font-size: 42px;
  line-height: 1.333;
  margin: 30px auto;
  width: 95%;
}
.form a {
  color: #fff;
}
.mv__title {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px 20px 14px;
  border-bottom-right-radius: 30px;
  border-bottom-left-radius: 30px;
  background: #4ab9f1;
  background: linear-gradient(90deg, rgb(74, 185, 241) 0%, rgb(0, 148, 224) 100%);
  color: #fff;
  text-align: center;
  font-size: 46px;
  line-height: 1.333
}
.mv__title a {
  color: #fff;
}
@media screen and (max-width: 768px) {
  .mv__title {
    padding: 2.666666vw 2.666666vw 1.866666vw;
    border-radius: 0;
    font-size: 5.333333vw
  }
  .mv__title a {
  }
  .form {
    padding: 2.666666vw 2.666666vw 1.866666vw;
    border-radius: 0;
    font-size: 5.333333vw
  }
}
.mv__title span {
  display: inline-block;
  padding-bottom: 4px;
  font-size: 38px
}
@media screen and (max-width: 768px) {
  .mv__title span {
    padding-bottom: 0.266666vw;
    font-size: 4.533333vw
  }
}
.mv__title small {
  display: inline-block;
  padding-bottom: 8px;
  font-size: 30px
}
@media screen and (max-width: 768px) {
  .mv__title small {
    padding-bottom: 0.666666vw;
    font-size: 3.466666vw
  }
}
.mv #hideMe {
  position: absolute;
  right: 0;
  bottom: 30%;
  left: 0;
  z-index: 22;
  margin: auto;
  animation: cssAnimation .5s ease-in 8s forwards;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards
}
@media screen and (max-width: 768px) {
  .mv #hideMe {
    display: none
  }
}
@media screen and (-webkit-min-device-pixel-ratio: 1)and (max-height: 572px)and (min-width: 769px) {
  .mv #hideMe {
    bottom: 38%;
    width: 20%
  }
}
@keyframes cssAnimation {
  0% {
    opacity: 1
  }
  100% {
    opacity: 0
  }
}
.countDown {
  position: absolute;
  right: 0;
  bottom: 5%;
  left: 0
}
@media screen and (max-width: 768px) {
  .countDown {
    bottom: 5.333333vw
  }
}
.countDown .countDownText {
  display: flex;
  justify-content: center;
  gap: 10px
}
@media screen and (max-width: 768px) {
  .countDown .countDownText {
    gap: 2.666666vw
  }
}
.countDown .countDownText .clock {
  position: relative;
  display: flex;
  align-items: stretch;
  flex-direction: column;
  justify-content: center;
  padding: 16px 10px 4px;
  width: 120px;
  outline: 1px solid rgba(255, 255, 255, .3);
  outline-offset: -2px;
  border-radius: 5px;
  background: #004c73;
  background: linear-gradient(0deg, rgba(0, 76, 115, 0.9) 50%, rgba(0, 32, 49, 0.9) 50%);
  box-shadow: 0 4px 30px rgba(0, 0, 0, .1);
  color: var(--color-base-white)
}
@media screen and (max-width: 768px) {
  .countDown .countDownText .clock {
    padding: 2.666666vw 2.666666vw 1.066666vw;
    width: 16.533333vw;
    border-radius: 1.066666vw
  }
}
.countDown .countDownText .clock::before {
  position: absolute;
  top: 50%;
  left: 0;
  width: 3px;
  height: 15px;
  background-color: var(--color-base-white);
  content: "";
  transform: translateY(-50%)
}
@media screen and (max-width: 768px) {
  .countDown .countDownText .clock::before {
    width: 0.8vw;
    height: 4vw
  }
}
.countDown .countDownText .clock::after {
  position: absolute;
  top: 50%;
  right: 0;
  width: 3px;
  height: 15px;
  background-color: var(--color-base-white);
  content: "";
  transform: translateY(-50%)
}
@media screen and (max-width: 768px) {
  .countDown .countDownText .clock::after {
    width: 0.8vw;
    height: 4vw
  }
}
.countDown .countDownText .clock span {
  display: inline-block;
  color: var(--color-base-white);
  font-size: 8rem;
  font-family: "Bebas Neue", sans-serif;
  line-height: .8
}
@media screen and (max-width: 768px) {
  .countDown .countDownText .clock span {
    font-size: 8.8vw
  }
}
.countDown .countDownText .clock small {
  display: inline-block;
  font-weight: 700
}
@media screen and (max-width: 768px) {
  .countDown .countDownText .clock small {
    font-size: 2.933333vw
  }
}
.hover_effect {
  margin: 20px auto 0;
  padding: 0 min(2.9761904762%, 50px);
  max-width: 1680px
}
@media screen and (max-width: 768px) {
  .hover_effect {
    padding: 0
  }
}
.hover_effect .inner_i {
  position: relative
}
@media screen and (max-width: 768px) {
  .hover_effect .inner_i {
    width: 100%;
    height: auto
  }
}
.hover_effect .inner_i::before {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 100%;
  height: 100%;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  content: "";
  opacity: 0;
  transform: translate(-50%, -50%)
}
@media screen and (max-width: 768px) {
  .hover_effect .inner_i::before {
    content: none;
    opacity: 1
  }
}
.hover_effect .inner_i .change_col {
  position: relative;
  display: flex;
  overflow: hidden;
  align-items: center;
  justify-content: space-between;
  border-radius: 30px
}
@media screen and (max-width: 768px) {
  .hover_effect .inner_i .change_col {
    border-radius: 0
  }
}
.hover_effect .inner_i .change_col .bg-change {
  position: relative;
  display: block;
  width: 33.3333333333%;
  transition: opacity .6s;
  transform: none
}
.hover_effect .inner_i .change_col .bg-change .bg-txt {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3;
  width: 100%;
  height: 100%
}
.hover_effect .inner_i .change_col .bg-change .bg-img {
  position: relative;
  display: block;
  width: 100%;
  height: 100%
}
.hover_effect .inner_i .change_col .bg-change .effect {
  opacity: 0;
  transition: all 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transform: translateX(100px)
}
.hover_effect .inner_i .change_col .bg-change .overlay {
  opacity: 0;
  transition: all .5s cubic-bezier(0.25, 0.46, 0.45, 0.94)
}
.hover_effect .inner_i .change_col .bg-change a:hover {
  opacity: 1
}
.hover_effect .inner_i .change_col .bg-change a:hover .overlay {
  opacity: 1
}
.hover_effect .inner_i .change_col .bg-change.js-btn1 .bg-txt {
  background: url(../img/index/img1.png) center/cover no-repeat
}
.hover_effect .inner_i .change_col .bg-change.js-btn1 .bg-txt.bg-txt1 {
  background-image: url(../img/index/img1_on.png)
}
.hover_effect .inner_i .change_col .bg-change.js-btn2 .bg-txt {
  background: url(../img/index/img2.png) center/cover no-repeat
}
.hover_effect .inner_i .change_col .bg-change.js-btn2 .bg-txt.bg-txt2 {
  background-image: url(../img/index/img2_on.png)
}
.hover_effect .inner_i .change_col .bg-change.js-btn3 .bg-txt {
  background: url(../img/index/img3.png) center/cover no-repeat
}
.hover_effect .inner_i .change_col .bg-change.js-btn3 .bg-txt.bg-txt3 {
  background-image: url(../img/index/img3_on.png)
}
.change_img1::before {
  background-image: url("../img/index/after_img1_2.jpg");
  opacity: 1 !important
}
.change_img2::before {
  background-image: url("../img/index/after_img2_2.jpg");
  opacity: 1 !important
}
.change_img3::before {
  background-image: url("../img/index/after_img3_2.jpg");
  opacity: 1 !important
}
.news .inner {
  margin: 0 auto;
  padding-bottom: 0;
  width: 100%;
  max-width: 1420px
}
@media screen and (max-width: 768px) {
  .news .inner {
    padding-top: 12vw;
    padding-bottom: 9.333333vw
  }
}
.news .inner .news_ttl {
  margin-bottom: 40px;
  color: var(--color-base-blue-dark);
  text-align: left;
  font-size: 2.8rem
}
@media screen and (max-width: 768px) {
  .news .inner .news_ttl {
    margin-bottom: 5.333333vw;
    font-size: 5.066666vw
  }
}
.news .inner .news_wrap .new_item {
  position: relative;
  display: block;
  padding: 50px 140px 50px 0;
  border-top: 1px solid var(--color-base-blue-light);
  text-align: left
}
@media screen and (max-width: 768px) {
  .news .inner .news_wrap .new_item {
    padding: 6.666666vw 13.333333vw 6.666666vw 0;
    border-top: 0.266666vw solid var(--color-base-blue-light)
  }
}
@media(hover: hover)and (pointer: fine) {
  .news .inner .news_wrap .new_item:hover::after {
    right: 1.6em
  }
}
.news .inner .news_wrap .new_item:last-of-type {
  border-bottom: 1px solid var(--color-base-blue-light)
}
@media screen and (max-width: 768px) {
  .news .inner .news_wrap .new_item:last-of-type {
    border-bottom: 0.266666vw solid var(--color-base-blue-light)
  }
}
.news .inner .news_wrap .new_item:not(span)::after {
  position: absolute;
  top: 50%;
  right: 2em;
  display: block;
  width: 70px;
  height: 70px;
  background: url("../img/common/btn_arrow.png") no-repeat center;
  background-size: contain;
  content: "";
  transition: right .2s;
  transform: translateY(-50%)
}
@media screen and (max-width: 768px) {
  .news .inner .news_wrap .new_item:not(span)::after {
    right: 0;
    width: 9.333333vw;
    height: 9.333333vw
  }
}
.news .inner .news_wrap .new_item .new_time {
  font-weight: 700;
  font-size: 1.8rem
}
@media screen and (max-width: 768px) {
  .news .inner .news_wrap .new_item .new_time {
    margin-bottom: 2.666666vw;
    font-size: 3.733333vw
  }
}
.news .inner .news_wrap .new_item .new_time time {
  color: var(--color-gray)
}
.news .inner .news_wrap .new_item .new_time span {
  padding-left: 20px;
  color: var(--color-base-blue)
}
@media screen and (max-width: 768px) {
  .news .inner .news_wrap .new_item .new_time span {
    padding-left: 4vw
  }
}
.news .inner .news_wrap .new_item .news_text {
  margin-bottom: 20px;
  font-size: 1.8rem
}
@media screen and (max-width: 768px) {
  .news .inner .news_wrap .new_item .news_text {
    font-size: 3.733333vw
  }
}
.about {
  overflow: hidden
}
.about .ttl_wrap {
  padding: 0 60px 60px 0;
  width: 520px;
  border-radius: 30px;
  background: #fff;
  text-align: left
}
@media screen and (max-width: 768px) {
  .about .ttl_wrap {
    padding: 0 5.333333vw 6.666666vw 0;
    width: 50.133333vw;
    border-radius: 3.333333vw
  }
}
.about .inner {
  padding-bottom: 90px
}
@media screen and (max-width: 768px) {
  .about .inner {
    padding-top: 9.333333vw;
    padding-bottom: 9.333333vw
  }
}
.about .about_image-1 {
  margin-top: -256px;
  border-top-left-radius: 30px;
  border-bottom-left-radius: 30px
}
@media screen and (max-width: 768px) {
  .about .about_image-1 {
    margin-top: -29.333334vw;
    margin-right: -5.333334vw;
    margin-left: 12vw;
    height: 53.333333vw;
    border-top-left-radius: 3.333333vw;
    border-bottom-left-radius: 3.333333vw
  }
}
.about .about_image-2-3_wrap {
  position: relative;
  margin-right: 7.5757575758%;
  margin-left: calc(50% - 50vw);
  width: 100%
}
@media screen and (max-width: 768px) {
  .about .about_image-2-3_wrap {
    margin: 13.333333vw 0 0 -5.333334vw
  }
}
.about .about_image-2 {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 10.6976744186%;
  width: 89.5348837209%;
  height: 568px
}
@media screen and (max-width: 768px) {
  .about .about_image-2 {
    margin-right: 9.333333vw;
    width: auto;
    height: 62.666666vw
  }
}
.about .about_image-2 img {
  width: 100%;
  height: 100%;
  border-top-right-radius: 30px;
  border-bottom-right-radius: 30px;
  object-fit: cover
}
@media screen and (max-width: 768px) {
  .about .about_image-2 img {
    border-top-right-radius: 3.333333vw;
    border-bottom-right-radius: 3.333333vw
  }
}
.about .about_image-3 {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: -88px 0 0 auto;
  width: 43.9534883721%;
  min-width: 378px;
  height: 240px
}
@media screen and (max-width: 768px) {
  .about .about_image-3 {
    margin: -9.333334vw 0 0 auto;
    width: 41.866666vw;
    min-width: initial;
    height: 26.666666vw
  }
}
.about .about_image-3 img {
  width: 100%;
  height: 100%;
  border-radius: 15px;
  object-fit: cover
}
@media screen and (max-width: 768px) {
  .about .about_image-3 img {
    border-radius: 2vw
  }
}
.about .about_lede {
  margin-top: 150px
}
@media screen and (max-width: 768px) {
  .about .about_lede {
    margin-top: 6.666666vw
  }
}
.about .about_lede .text_box {
  flex: none;
  width: 570px
}
@media screen and (max-width: 768px) {
  .about .about_lede .text_box {
    width: auto
  }
}
.detail_ticket {
  overflow: hidden;
  padding: 100px 0
}
@media screen and (max-width: 768px) {
  .detail_ticket {
    padding: 0 0 13.333333vw
  }
}
.detail_ticket__wrap {
  background: #f2f2f2;
  background: linear-gradient(90deg, rgb(242, 242, 242) 0%, rgb(218, 232, 241) 100%)
}
.detail_ticket .inner {
  display: flex;
  align-items: center;
  padding-top: 0;
  padding-bottom: 0;
  width: 84.5238095238%;
  height: 730px
}
@media screen and (max-width: 768px) {
  .detail_ticket .inner {
    padding-top: 21.333333vw;
    width: auto;
    height: auto
  }
}
.detail_ticket .inner .flex_wrap {
  align-items: center;
  width: 100%
}
.detail_ticket .text_box {
  flex: none;
  width: 600px
}
@media screen and (max-width: 768px) {
  .detail_ticket .text_box {
    width: auto
  }
}
.detail_ticket .img_box {
  margin-top: -160px;
  margin-bottom: -120px;
  margin-left: 4.8484848485%;
  height: 830px
}
@media screen and (max-width: 768px) {
  .detail_ticket .img_box {
    overflow: visible;
    margin: 0;
    height: auto
  }
}
.detail_ticket_image {
  display: flex;
  align-items: center;
  justify-content: center
}
.detail_ticket_image img {
  object-fit: cover
}
.detail_ticket_image-1 {
  margin-left: auto;
  width: 93.9024390244%;
  height: 508px
}
@media screen and (max-width: 768px) {
  .detail_ticket_image-1 {
    margin-right: -5.333334vw;
    height: 62.666666vw
  }
}
.detail_ticket_image-1 img {
  border-top-left-radius: 30px;
  border-bottom-left-radius: 30px
}
@media screen and (max-width: 768px) {
  .detail_ticket_image-1 img {
    border-top-left-radius: 3.333333vw;
    border-bottom-left-radius: 3.333333vw
  }
}
.detail_ticket_image-2 {
  margin-top: -80px;
  margin-right: auto;
  width: 46.0975609756%;
  min-width: 378px;
  height: 240px
}
@media screen and (max-width: 768px) {
  .detail_ticket_image-2 {
    margin-top: -12vw;
    margin-right: auto;
    width: 41.866666vw;
    min-width: initial;
    height: 26.666666vw
  }
}
.detail_ticket_image-2 img {
  border-radius: 15px
}
@media screen and (max-width: 768px) {
  .detail_ticket_image-2 img {
    border-radius: 2.666666vw
  }
}
.detail_ticket_image-3 {
  margin-top: -80px;
  margin-left: 50.487804878%;
  width: 46.0975609756%;
  min-width: 378px;
  height: 240px
}
@media screen and (max-width: 768px) {
  .detail_ticket_image-3 {
    margin-top: -8.533334vw;
    margin-right: 3.333333vw;
    margin-bottom: -7.466667vw;
    margin-left: auto;
    width: 41.866666vw;
    min-width: initial;
    height: 26.666666vw
  }
}
.detail_ticket_image-3 img {
  border-radius: 15px
}
@media screen and (max-width: 768px) {
  .detail_ticket_image-3 img {
    border-radius: 2.666666vw
  }
}
.fee_schedule {
  margin-top: 100px;
  background: #4bb9f1;
  background: linear-gradient(90deg, rgb(75, 185, 241) 0%, rgb(0, 148, 224) 100%)
}
@media screen and (max-width: 768px) {
  .fee_schedule {
    margin-top: 13.333333vw
  }
}
.fee_schedule .inner {
  margin: 0 auto;
  padding: 10px 0 180px;
  width: 100%;
  max-width: none
}
@media screen and (max-width: 768px) {
  .fee_schedule .inner {
    padding: 18.666666vw 0 17.333333vw
  }
}
.fee_schedule .inner .ttl_inner {
  margin: 0 auto 40px;
  padding: 0 min(4.3103448276%, 50px);
  max-width: 1160px
}
@media screen and (max-width: 768px) {
  .fee_schedule .inner .ttl_inner {
    padding: 0 9.333333vw 0 5.333333vw
  }
}
.fee_schedule .inner .ttl_inner .ttl span {
  font-size: 10rem
}
@media screen and (max-width: 768px) {
  .fee_schedule .inner .ttl_inner .ttl span {
    font-size: 11.466666vw
  }
}
.fee_schedule .inner .ttl_inner .ttl span .small {
  font-size: 6rem
}
@media screen and (max-width: 768px) {
  .fee_schedule .inner .ttl_inner .ttl span .small {
    font-size: 8vw
  }
}
.fee_schedule .inner .ttl_inner .sub_ttl {
  margin-top: .5em
}
.event {
  overflow: hidden
}
.event .inner {
  padding-top: 150px;
  padding-bottom: 150px
}
@media screen and (max-width: 768px) {
  .event .inner {
    padding-top: 16vw;
    padding-bottom: 18.666666vw
  }
}
.event .ttl_wrap {
  padding: 0 60px 60px 0;
  width: 488px;
  border-radius: 30px;
  background: #fff;
  text-align: left
}
@media screen and (max-width: 768px) {
  .event .ttl_wrap {
    padding: 0 6vw 6.666666vw 0;
    width: 47.2vw
  }
}
.event .event_image-1 {
  overflow: hidden;
  margin-top: -256px;
  border-top-left-radius: 30px;
  border-bottom-left-radius: 30px
}
@media screen and (max-width: 768px) {
  .event .event_image-1 {
    margin-top: -29.333334vw;
    margin-right: -5.333334vw;
    margin-left: 12vw;
    height: 53.333333vw;
    border-top-left-radius: 3.333333vw;
    border-bottom-left-radius: 3.333333vw
  }
}
.event__info {
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding: 30px;
  border: 1px solid var(--color-base-blue-light);
  border-radius: 15px;
  text-align: left
}
@media screen and (max-width: 768px) {
  .event__info {
    gap: 2.666666vw 0;
    padding: 4vw
  }
}
.event__info__wrap {
  display: flex;
  justify-content: center;
  margin: 100px auto 0;
  max-width: 1060px
}
.event__info__item {
  display: flex;
  font-weight: 700;
  font-size: 22px
}
@media screen and (max-width: 768px) {
  .event__info__item {
    width: 100%;
    font-size: 3.466666vw
  }
}
.event__info__item dt {
  flex: none;
  color: var(--color-base-blue)
}
.event__info__item dt .icon {
  margin: 0 4px 4px 0;
  width: 32px;
  height: 32px
}
@media screen and (max-width: 768px) {
  .event__info__item dt .icon {
    margin: 0 0.533333vw 0.533333vw 0;
    width: 4.8vw;
    height: 4.8vw
  }
}
.event__info__item dd {
  position: relative;
  padding-left: 1em
}
.event__info__item dd:before {
  position: absolute;
  left: 0;
  content: "："
}
.event__map__title {
  margin-top: 100px;
  text-align: center;
  font-size: 32px
}
@media screen and (max-width: 768px) {
  .event__map__title {
    margin-top: 13.333333vw;
    font-size: 5.066666vw
  }
}
.event__map__image {
  position: relative;
  margin: 60px auto 0;
  width: 100%;
  max-width: 1060px
}
@media screen and (max-width: 768px) {
  .event__map__image {
    margin: 4vw auto 0
  }
}
.event__map__image .deco {
  position: absolute
}
.event__map__image .deco-1 {
  top: 12.8%;
  right: -8.4905660377%;
  width: 26.4150943396%
}
@media screen and (max-width: 768px) {
  .event__map__image .deco-1 {
    top: 12vw;
    right: -4.266667vw;
    width: 30.666666vw
  }
}
.event__map__image .deco-2 {
  top: 50.1333333333%;
  left: -12.2641509434%;
  width: 21.8867924528%
}
@media screen and (max-width: 768px) {
  .event__map__image .deco-2 {
    top: 58.666666vw;
    left: -4.266667vw;
    width: 25.6vw
  }
}
.event__map__note {
  margin-top: 20px;
  padding-left: 1em;
  text-align: left;
  text-indent: -1em;
  font-size: 14px
}
@media screen and (max-width: 768px) {
  .event__map__note {
    margin-top: 1.333333vw;
    font-size: 2.933333vw
  }
}
.event__movie__title {
  margin-top: 80px;
  text-align: center;
  font-size: 32px;
  line-height: 1.2
}
@media screen and (max-width: 768px) {
  .event__movie__title {
    margin-top: 8vw;
    font-size: 5.066666vw
  }
}
.event__movie__title span {
  display: inline-block;
  border-bottom: 4px solid var(--color-base-blue);
  border-image: var(--color-grad);
  border-image-slice: 1
}
@media screen and (max-width: 768px) {
  .event__movie__title span {
    border-bottom-width: 2px
  }
}
.event__movie__player {
  margin: 60px auto 0;
  max-width: 1060px
}
@media screen and (max-width: 768px) {
  .event__movie__player {
    margin-top: 6.666666vw
  }
}
.event__movie__player__thumb {
  display: flex;
  justify-content: center
}
.event__movie__player__thumb.disabled {
  display: none
}
.event__movie__player__thumb .play-btn {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 130px;
  height: 130px;
  cursor: pointer
}
@media screen and (max-width: 768px) {
  .event__movie__player__thumb .play-btn {
    width: 16.533333vw;
    height: 16.533333vw
  }
}
.event__movie__player video {
  max-width: 100%
}
.event__movie__player video.disabled {
  display: none
}
.gallery .inner {
  margin: 0 auto;
  padding: 25px 0 180px;
  width: 100%;
  max-width: none
}
@media screen and (max-width: 768px) {
  .gallery .inner {
    padding: 6.666666vw 0 18.666666vw
  }
}
.gallery .inner .ttl_inner {
  margin: 0 auto 40px;
  padding: 0 min(4.3103448276%, 50px);
  max-width: 1160px
}
@media screen and (max-width: 768px) {
  .gallery .inner .ttl_inner {
    margin: 0 auto 8vw;
    padding: 0 18.666666vw 0 5.333333vw
  }
}
.gallery .inner .ttl_inner .ttl span {
  font-size: 10rem
}
@media screen and (max-width: 768px) {
  .gallery .inner .ttl_inner .ttl span {
    font-size: 11.466666vw
  }
}
.gallery .inner .ttl_inner .sub_ttl {
  margin-top: .5em
}
.gallery .inner .gallery_slide {
  overflow: hidden
}
.gallery .inner .gallery_slide .slick-slide {
  margin: 0;
  transition: 1.2s;
  transform: scale(0.8)
}
.gallery .inner .gallery_slide .slick-slide .item_list_wrap {
  padding-bottom: 60px
}
@media screen and (max-width: 768px) {
  .gallery .inner .gallery_slide .slick-slide .item_list_wrap {
    padding-bottom: 14.666666vw
  }
}
.gallery .inner .gallery_slide .slick-slide .item_list_wrap img {
  width: 100%;
  max-width: none;
  border-radius: 12px;
  box-shadow: var(--box-shadow)
}
@media screen and (max-width: 768px) {
  .gallery .inner .gallery_slide .slick-slide .item_list_wrap img {
    border-radius: 0.8vw;
    box-shadow: var(--box-shadow-sp)
  }
}
.gallery .inner .gallery_slide .slick-slide.slick-current, .gallery .inner .gallery_slide .slick-slide.is-active-next {
  transform: scale(1)
}
@-webkit-keyframes anim {
  0% {
    right: 100%;
    left: 0
  }
  80% {
    right: 100%;
    left: 0;
    -webkit-animation-timing-function: cubic-bezier(0.545, 0.08, 0.52, 0.975);
    animation-timing-function: cubic-bezier(0.545, 0.08, 0.52, 0.975)
  }
  90% {
    right: 0;
    left: 0;
    -webkit-animation-timing-function: cubic-bezier(0.545, 0.08, 0.52, 0.975);
    animation-timing-function: cubic-bezier(0.545, 0.08, 0.52, 0.975)
  }
  100% {
    right: 0;
    left: 100%
  }
}
@keyframes anim {
  0% {
    right: 100%;
    left: 0
  }
  80% {
    right: 100%;
    left: 0;
    -webkit-animation-timing-function: cubic-bezier(0.545, 0.08, 0.52, 0.975);
    animation-timing-function: cubic-bezier(0.545, 0.08, 0.52, 0.975)
  }
  90% {
    right: 0;
    left: 0;
    -webkit-animation-timing-function: cubic-bezier(0.545, 0.08, 0.52, 0.975);
    animation-timing-function: cubic-bezier(0.545, 0.08, 0.52, 0.975)
  }
  100% {
    right: 0;
    left: 100%
  }
}
#fixed_link {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 60;
  display: none;
  margin: 0 auto;
  width: 100%;
  background: #0075c2
}
#fixed_link .page_anc {
  box-shadow: 2px 2px 4px rgba(0, 0, 0, .1)
}