
@font-face {
  font-family: "Noto Sans JP";
  font-weight: 500;
  src: url("fonts/notosansjp/NotoSansJP-Medium_subset.ttf") format("truetype");
}
/* @font-face {
  font-family: "Noto Sans JP";
  font-weight: 700;
  src: url("fonts/notosansjp/NotoSansJP-Bold_subset.ttf") format("truetype");
} */

@font-face {
  font-family: "Noto Sans JP";
  font-weight: 900;
  src: url("fonts/notosansjp/NotoSansJP-Black_new.ttf") format("truetype");
}

@font-face {
  font-family: "Noto Sans JP";
  font-weight: 700;
  src: url("fonts/notosansjp/NotoSansJP-Bold_new.ttf") format("truetype");
}
*,
*:before,
*:after {
  box-sizing: border-box;
}

html {
  overflow: auto;
  /* iOS・レスポンシブモード用*/
}

body {
  position: relative;
  /* iOS用 */
  margin: 0;
  overflow: visible;
  overflow-x: hidden;
  width: 100%;
  background-color: #02072d;
  background-image:url(../images/main/bg_bottom.webp),url(../images/main/bg_top.webp),url(../images/main/bg_main_pc.webp);
  font-family: "Noto Sans JP", "メイリオ", "ヒラギノ角ゴ StdN w6", sans-serif;
  background-position: bottom center,top center, top center;
  /* background-size: contain, cover, cover; */
  background-repeat: no-repeat,no-repeat,repeat;
  min-height: 100vh;
}


/* スクロールバー非表示（ページ全体スクロール禁止） */
html.is-mv-loading,
body.is-mv-loading {
  overflow: hidden;
}

/* MV内のアニメーションを全部止める */
body.is-mv-loading .mv_container * {
  animation-play-state: paused !important;
}


@media (max-width: 1199px) {
  body {
  background-image:url(../images/main/bg_bottom.webp),url(../images/main/bg_top_sp.webp),url(../images/main/bg_main_sp.jpg);
  font-family: "Noto Sans JP", "メイリオ", "ヒラギノ角ゴ StdN w6", sans-serif;
  background-position: bottom center,top center, top center;
  background-size: contain, contain, cover;
  background-repeat: no-repeat,no-repeat,repeat;
  }
}

@media (min-width: 1920px) {
  body {
   background-size: cover;
   background-size: 100% auto;
  }
}
body.nav_scroll_on {
  overflow: hidden;
}

img {
  max-width: 100%;
  vertical-align: bottom;
}

h2 {
  font-weight: 900;
  font-style: normal;
  position: relative;
}

.top_s + .top_s{
  margin-top: 100px;
}
.in-bl {
  display: inline-block;
}
@media (max-width: 1199px) {
  .in-bl_sp {
    display: inline-block;
  }
}

.second_title_img img {
  top: 5px;
  position: relative;
}

@media (max-width: 500px) {
  h2 {
    letter-spacing: 7px;
  }
}

/* main_nav.php css start */
@media (max-width: 768px) {
  .head_container_pc {
    display: none;
  }

  .head_container_tb {
    display: none;
  }

  .head_container_sp {
    display: block;
  }
}

@media (min-width: 769px) and (max-width: 1199px) {
  .head_container_pc {
    display: none;
  }

  .head_container_tb {
    display: block;
  }

  .head_container_sp {
    display: none;
  }
}

@media (min-width: 1200px) {
  .head_container_pc {
    display: block;
  }

  .head_container_tb {
    display: none;
  }

  .head_container_sp {
    display: none;
  }
}

.head_container_pc {
  width: 100%;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 100;
  background-image: url(../images/main/bg_top.webp);
  background-position: top center;
    background-repeat: no-repeat;
}

.head_container_tb,
.head_container_sp {
  width: 100%;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 100;
  background-image: url(../images/main/bg_top_sp.webp);
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
  overflow: hidden;
}

@media (min-width: 1920px) {
  .head_container_pc {
      background-size: cover;
  }
}

.head-thunder {
  position: absolute;
  top: 0;
  left: 0;
  mix-blend-mode: screen;
  width: 20%;
  z-index: -1;
}

@media (max-width: 500px) {
  .head-thunder {
    width: 30%;
  }
}

.head_container_pc {
  height: 152px;
}

.head_ul_pc li a:hover,
.head_ul_tb li a:hover,
.head_ul_sp li a:hover {
  opacity: 0.7;
}

ul.head_ul_pc {
  max-width: 1200px;
  margin: 0 auto;
  list-style: none;
  padding: 0;
  display: flex;
  justify-content: flex-start;
  align-items:flex-start;
  position: relative;
}

ul.head_ul_pc li:nth-child(1) {
  margin-top: 60px;
}

ul.head_ul_pc li:nth-child(2) {
  margin-top: 40px;
  margin-left: 50px;
  margin-right: 53px;
}


ul.head_ul_pc li:nth-child(3) {
  display: flex;
  justify-content: flex-end;
  margin-top: 60px;
  width: 249px;
  position: absolute;
  right: 0;
  gap: 25px;
}

ul.head_ul_pc li:nth-child(3) a {
  display: inline-block;
}

.icon_wrapper {
  display: flex;
  justify-content: center;
  margin: auto;
  max-width: 700px;
  gap: 32px;
  padding: 60px 0 10px;
  width: 40%;
}

.icon_wrapper a {
  display: inline-block;
  margin: 0;
  width: 12vw;
  height: auto;
  text-align: center;
}
.icon_wrapper a:hover {
  opacity: 0.7;
}

@media (max-width: 767px) {
  .icon_wrapper {
    max-width: 700px;
    gap: 10%;
    padding: 6vw 0 3vw;
    width: 60%;
  }

  .icon_wrapper a {
    margin: 0;
    width: 12vw;
  }
}


ul.head_ul_tb {
  height: 100px;
  margin: 0 auto;
  list-style: none;
  padding: 0 3%;
  display: flex;
  display: -ms-flexbox;
  justify-content: space-between;
  -ms-flex-pack: justify;
  align-items: flex-start;
  -ms-flex-align: end;
}

.head_img1_tb {
  position: relative;
  margin-top: 36px;
}

.head_img1_tb a {
  display: block;
}

.head_img2_tb {
  margin-top: 18px;
  width: 60%;
  max-width: 500px;
}

.head_img2_tb a {
  display: block;
}

.head_img3_tb {
  max-width: 240px;
  margin-bottom: 5px;
}

.nav_btn {
  width: 50px;
  height: 64px;
  position: relative;
  cursor: pointer;
  top: 8px;
}

@media (max-width: 1199px) {
  .nav_btn {
    top: 18px;
  }
}

.nav_btn .line {
  left: 0px;
  right: 0;
  width: 50px;
  height: 5px;
  margin: 0 auto;
  text-align: center;
  background: #fff;
  position: absolute;
  transition: all 0.3s linear 0s;
  backface-visibility: hidden;
}

@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop,
  body {
    /* font-family: 'メイリオ'; */
  }

  .head_img1_tb img {
    /* width: 230px; */
  }

  .nav_btn {
    width: 60px;
    height: 60px;
    background-size: contain;
    background-position: center;
    position: fixed;
    right: 0;
    top: 0;
    cursor: pointer;
  }
}


@media all and (-ms-high-contrast: none) and (min-width: 769px) and (max-width: 830px) {
  *::-ms-backdrop,
  .nav_btn .line {
    left: 0;
  }
}

.nav_btn .line.top {
  top: 17px;
}

.nav_btn.move .line.top {
  transform: rotate(135deg);
  -webkit-transform: rotate(135deg);
  top: 30px;
}

.nav_btn .line.middle {
  top: 30px;
}

.nav_btn.move .line.middle {
  width: 0;
  opacity: 0;
}

.nav_btn .line.bottom {
  top: 43px;
}

.nav_btn.move .line.bottom {
  transform: rotate(-135deg);
  -webkit-transform: rotate(-135deg);
  top: 30px;
}

@media (max-width: 768px) {
  .nav_btn {
    width: 32px;
    height: 32px;
    top: -5px;
    right: 0;
  }

  .nav_btn .line {
    width: 32px;
    height: 4px;
  }

  .nav_btn .line.top {
    top: 12px;
  }

  .nav_btn .line.middle {
    top: 22px;
  }

  .nav_btn .line.bottom {
    top: 32px;
  }

  .nav_btn.move .line.top {
    top: 22px;
  }

  .nav_btn.move .line.bottom {
    top: 22px;
  }
}

ul.head_ul_sp {
  height: 100px;
  margin: 0 auto;
  list-style: none;
  padding: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-inline: 3vw;
}

@media (max-width: 767px) {
  ul.head_ul_sp {
    height: 60px;
  }
}

@media (max-width: 500px) {
  ul.head_ul_sp {
    padding-bottom: 5px;
  }
}

.head_img1_sp {
  width: 20%;
}
.head_img1_sp a {
  display: block;
}

.head_img2_sp {
  margin-top: 0;
  width: 60%;
  max-width: 300px;
}

.head_img2_sp a {
  display: block;
}

@media all and (-ms-high-contrast: none) and (max-width: 1199px) {
  *::-ms-backdrop,
  .head_img1_tb {
    /* width: 230px; */
  }

  .head_img2_tb {
    width: 250px;
    /* margin-bottom: 10px; */
  }

  .head_img3_tb {
    /* width: 250px; */
    margin-right: 65px;
  }

  .head_img2_sp {
    width: 220px;
    margin-right: 65px;
    margin-left: 30px;
  }

  .images_three_set a {
    flex: 1;
  }
}
@media (max-width: 420px) {
  .head_img1_sp {
    max-width: 100px;
    margin-bottom: 5px;
    width: 24%;
  }
}

.nav_container_pc {
  width: 100%;
  height: 80px;
  background-size: auto;
  background-position: calc(50% + 90px) 43.5%;
  background-repeat: no-repeat;
  position: fixed;
  left: 0;
  top: 152px;
  z-index: 100;
  background-image: url(../images/main/bg_top.webp);
  background-position: center -152px;
  background-repeat: no-repeat;   
}

@media (min-width: 1920px) {
  .nav_container_pc {
      background-size: cover;
  }
}

ul.nav_ul_pc {
  list-style: none;
  padding: 0;
  margin: 0 auto;
  max-width: 1200px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
}

li.nav_ul_li_pc {
  position: relative;
  text-align: center;
  height: 80px;
  line-height: 80px;
  transform: rotate(-0.03deg);
}

@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop,
  /* IE11 */
  .nav_ul_li_pc {
    padding: 10px 0 0;
  }
}

.main_nav_title_pc {
  text-decoration: none;
  color: #fff;
  cursor: default;
  font-weight: bold;
  font-size: 18px;
  letter-spacing: 0px;
  font-weight: bold;
  font-style: normal;
  height: 55px;
  display: inline-block;
  text-align: left;
}

.nav_ul_li_pc:hover .main_nav_title_pc {
text-shadow:
  0 0 1px  #5078c7,
  0 0 3px  #5078c7,
  0 0 6px  #5078c7,
  0 0 10px #5078c7,
  0 0 20px #5078c7,
  0 0 1px  #5078c7,
  0 0 3px  #5078c7,
  0 0 6px  #5078c7,
  0 0 10px #5078c7,
  0 0 20px #5078c7;
}

.main_nav_title_pc span {
  font-weight: 700;
  font-style: normal;
}

.main_nav_title_pc span.triangle_icon {
  font-size: 10px;
  margin-left: -12px;
  vertical-align: top;
}

@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop,
  /* IE11 */
  .main_nav_title_pc span.triangle_icon {
    vertical-align: baseline;
  }
}

.main_nav_link_set {
  display: flex;
  gap: 12px;
}

.main_nav_link_set a {
  display: block;
}

.main_nav_link_set a:hover {
  filter: brightness(150%)
  drop-shadow(0 0 5px #FFFFFF);
}

ul.nav_list_pc {
  margin: 0;
  padding: 0;
  list-style: none;
  position: absolute;
  left: 0;
  top: 76px;
  z-index: 50;
  font-weight: 700;
  font-style: normal;
  visibility: hidden;
}

.nav_list_pc_space {
  position: relative;
  top: -2px;
  margin-right: 5px;
  font-size: 16px;
}

ul.nav_list_pc span {
  font-weight: 700;
  font-style: normal;
  transform: rotate(-0.03deg);
}

ul.nav_ul_pc li.nav_ul_li_pc:hover ul.nav_list_pc {
  visibility: visible;
}

@media (max-width: 767px) {
  .nav_list_pc_space {
    margin-right: 4px;
    font-size: max(2.2vw, 13px);
  }
}
@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop,
  /* IE11 */
  ul.nav_list_pc {
    top: 93px;
  }
}

ul.nav_list_pc li {
  width: 490px;
  height: 0;
  background: rgb(11 38 67 / 90%);
  font-size: 12px;
  box-sizing: content-box !important;
  -webkit-transition: opacity 0.2s, visibility 0.2s, height 0.2s;
  -o-transition: opacity 0.2s, visibility 0.2s, height 0.2s;
  transition: opacity 0.2s, visibility 0.2s, height 0.2s;
  visibility: hidden;
  opacity: 0;
  position: relative;
  z-index: 30;
}

ul.nav_list_pc.wide li {
  width: 560px;
}



ul.nav_ul_pc li.nav_ul_li_pc:hover ul.nav_list_pc li {
  opacity: 1;
  visibility: visible;
  height: 47px;
}

ul.nav_list_pc li:last-child {
  border-bottom: none;
}

@media (min-width: 1200px) {
  .underbar {
    display: inline-block;
  }
}

.nv_hover {
  position: relative;
  text-decoration: none;
  border-radius: 20px;
  transition: 0.3s all linear;
  transition: none;
  font-size: 19px;
}

/* a.main_nav_title_pc::after {
  position: absolute;
  bottom: 15px;
  left: 0;
  content: "";
  width: 100%;
  height: 3px;
  background: #fff;
  transform: scale(0, 1);
  transform-origin: left top;
  transition: transform 0.3s;
} */
/* a.main_nav_title_pc:hover::after {
  transform: scale(1, 1);
} */
/* ul.nav_list_pc:hover + a.main_nav_title_pc::after {
  transform: scale(1, 1);
} */
@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop,
  ul.nav_list_pc li a {
    padding-top: 3px;
  }
}

.nav_ul_li_pc li a {
  text-decoration: none;
  box-sizing: border-box;
  color: #fff;
  display: block;
  font-weight: bold;
  text-align: left;
  font-size: 22px;
  letter-spacing: 0.5px;
  line-height: 47px;
  padding: 0 10px 0 20px;
}
/* .nav_ul_li_pc li a::before {
  content: "";
  width: calc(100% - 12px);
  border-bottom: 2px dashed #e60012;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
} */
/* .nav_ul_li_pc li.grayout a::before {
  border-color: #000;
} */
ul.nav_list_pc li:last-child a::before {
  border-bottom: none;
}

ul.nav_list_pc li:hover a::before,
ul.nav_list_pc li:hover a {
  background: #e9ebee;
  color: #446096;
}

@media (max-width: 1199px) {
  .nav_container_pc {
    display: none;
  }

  .nav_container_sp {
    display: block;
  }
}

@media (min-width: 1200px) {
  .nav_container_pc {
    display: block;
  }

  .nav_container_sp {
    display: none;
  }
}

.nav_container_sp {
  position: fixed;
  left: 0;
  top: 100px;
  width: 100%;
  background: rgba(0, 0, 0, 0);
  color: #fff;
  visibility: hidden;
  height: 0;
  transition: all 0.5s;
  -webkit-transition: all 0.5s;
  overflow-y: auto;
  z-index: 110;
}

@media (max-width: 767px) {
  .nav_container_sp {
    top: 60px;
  }
}

.nav_container_sp.open {
  height: 100vh;
  background: rgb(68 96 150 / 95%);
  visibility: visible;
}

.nav_ul_sp {
  list-style: none;
  padding: 0;
  margin: 0;
  margin-bottom: 250px;
  padding-bottom: 55px;
  font-weight: 700;
  font-style: normal;
}

#nav_live_replay_sp {
  padding: 3vw 0 30px;
}

#nav_live_replay_sp a:hover {
  opacity: 1;
  filter: brightness(150%)
  drop-shadow(0 0 18px #FFFFFF);
}


.nav_ul_li_sp {
  margin: 0;
  margin-top: 1px;
  padding: 0 5%;
  background-size: cover;
  background-position: center;
  position: relative;
  z-index: 5;
  /* text-shadow: 0 0 20px #1c3f82, 0 0 1px #1c3f82, 0 0 2px #1c3f82, 0 0 3px #1c3f82, 0 0 4px #1c3f82, 0 0 5px #1c3f82, 0 0 6px #1c3f82, 0 0 7px #1c3f82, 0 0 8px #1c3f82, 0 0 9px #1c3f82, 0 0 10px #1c3f82, 0 0 11px #1c3f82, 0 0 12px #1c3f82, 0 0 13px #1c3f82, 0 0 14px #1c3f82, 0 0 15px #1c3f82, 0 0 20px #1c3f82, 0 0 1px #1c3f82, 0 0 2px #1c3f82, 0 0 3px #1c3f82, 0 0 4px #1c3f82, 0 0 5px #1c3f82, 0 0 6px #1c3f82, 0 0 7px #1c3f82, 0 0 8px #1c3f82, 0 0 9px #1c3f82, 0 0 10px #1c3f82, 0 0 11px #1c3f82, 0 0 12px #1c3f82, 0 0 13px #1c3f82, 0 0 14px #1c3f82, 0 0 15px #1c3f82; */
}

.nav_bg {
  max-width: unset;
  margin: 0 0 2vw;
  padding: 0;
  border-radius: 10px;
}

.nav_ul_li_sp a {
  text-decoration: none;
}

.nav_title {
  color: #fff;
  cursor: pointer;
  display: block;
  padding: 4px 0 3px 25px;
  font-size: 24px;
  position: relative;
  transform: rotate(-0.03deg);
}

/* @media (max-width: 450px) {
  .nav_title {
    font-size: 20px;
  }
  .dento_nav {
    font-size: 20px;
  }
}
@media (max-width: 380px) {
  .nav_title {
    font-size: 18px;
  }
  .dento_nav {
    font-size: 18px;
  }
}
*/
/* .nav_title.direct_link:after {
  position: absolute;
  left: 10px;
  top: 15px;
  content: "▶︎";
  font-size: 14px;
  vertical-align: middle;
} */
.nav_ul_li_sp:hover .nav_title {
  opacity: 0.7;
}

.nav_title::before {
  position: absolute;
  left: 0;
  top: 12px;
  content: "▼";
  font-size: 18px;
  vertical-align: middle;
}

.nav_title.up::before {
  position: absolute;
  left: 0;
  content: "▲";
  font-size: 18px;
  vertical-align: middle;
}

.nav_list_sp {
  display: none;
  list-style: none;
  padding: 5px 0 15px;
  margin: 0 0 12px;
  width: 100%;
}

.nav_list_sp li:hover{
  background-color: #0b2643;
}
.nav_list_sp a {
  color: #fff;
  text-decoration: none;
  display: block;
  font-weight: 500;
  padding: 13px 0 10px;
  letter-spacing: 0.5px;
  transform: rotate(-0.03deg);
}
.nav_list_sp li.grayout_sp a {
  text-shadow: none;
}

.d-flex {
  display: flex;
  align-items: center;
}
@media (max-width: 1199px) {
    .nav_title{
      font-size: 26px;
    }
}
@media (max-width: 767px) {
  #nav_live_replay_sp {
    padding: 3vw 0 8vw;
  }

  .nav_title{
        padding-left: 1.1em;
  }
  .nav_title.up::before {
    font-size: max(2.4vw, 17px);
    top: .5em;
  }

}


@media (max-width: 380px) {
  .nav_list_sp a {
    padding-left: 0px;
  }

  .nav_list_pc_li_icon {
    padding: 0px;
  }
}

@media (max-width: 350px) {
  .nav_list_sp li {
    font-size: 15px;
  }
}

.nav_list_sp a:hover .nav_list_pc_li_icon {
  color: #ffffff;
}

.nav_list_sp .nav_list_pc_li_icon {
  color: #fff;
  padding: 0 5px;
  vertical-align: middle;
}

.nav_list_sp li {
  position: relative;
  padding-left: 70px;
  font-size: 24px;
}

.nav_list_sp li::before,
.nav_list_sp li:first-child::after {
  content: "";
  width: calc(100% - 24px);
  position: absolute;
  left: 50%;

  transform: translateX(-50%);
}

@media (max-width: 767px) {
  .nav_title {
    font-size: 22px;
  }
  .nav_list_sp li {
    padding-left: 8vw;
  }
}

@media (max-width: 470px) {
  .nav_list_sp li {
    font-size: 18px;
  }
}

@media (max-width: 425px) {
  .nav_list_sp li {
    font-size: 16px;
  }

  .nav_list_pc_li_icon {
    font-size: 12px;
    padding: 0;
    top: -2px;
    position: relative;
  }
}

@media (max-width: 370px) {
  .nav_list_sp li {
    font-size: 4.3vw;
  }
}

/* .nav_list_sp li:hover {
  opacity: 0.7;
} */

.nav_list_sp li:hover .underbar {
  color: #ffffff;
}

.images_three_set {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  text-align: center;
  width: 96%;
  max-width: 690px;
  margin: 0 auto;
}

.images_three_set a:hover {
  opacity: 0.7;
}

.image_single {
  margin: 30px auto 2px;
  width: 59%;
  max-width: 690px;
  text-align: center;
}

@media (max-width: 1199px) {
  .images_three_set {
    justify-content: center;
  }
  .image_single {
    margin: 23px auto 0;
  }
}

@media (max-width: 767px) {
  .images_three_set{
    width: 100%;
    padding: 0 10%;
    gap: 5%;
  }
  .image_single {
    margin: 4% auto 0;
  width: 42.75%;
  }
}

.image_single a:hover {
  opacity: 0.7;
}

/* グレイアウト用 */
ul.nav_list_pc li.grayout {
  background: #969696;
  pointer-events: none;
}

ul.nav_list_pc li.grayout a {
  color: #000;
  /* background-color: gray; */
}

ul.nav_list_pc li.grayout:hover .nav_list_pc_li_icon {
  color: #000;
}

.nav_list_sp li.grayout_sp {
  background: #969696;
  pointer-events: none;
}

.nav_list_sp li.grayout_sp:last-of-type {
  border-radius: 0 0 15px 15px;
}

.nav_list_sp li.grayout_sp a .nav_list_pc_li_icon {
  color: #000;
}

.nav_list_sp .grayout_sp a:hover .nav_list_pc_li_icon {
  color: #000;
}

.nav_list_sp li.grayout_sp:hover {
  opacity: 0.9;
}

.nav_ul_li_sp_stay.grayout_sp {
  background: #969696;
  pointer-events: none;
}

.nav_ul_li_sp_stay.grayout_sp a {
  color: #000;
}

.nav_ul_li_sp_stay.grayout_sp:hover {
  opacity: 1;
}

.grayout_sp a {
  color: #000;
}

/* グレイアウト用 */
/* main_nav.php css end */
/* index.php css start */
main {
  /* position: relative; */
  display: block;
}

_::-webkit-full-page-media,
_:future,
:root .css_selector {
  padding-top: 0;
}

.mv_contents.bg {
  object-fit: cover;
  background-image: url(../images/main/visual/img_mv_bg_00.jpg);
  background-position: center -152px;
  background-repeat: no-repeat;   
}

@media (max-width: 1199px) {
  .mv_contents.bg {
    width: 100%;
    height: auto;
    aspect-ratio: 750 / 1061;
  }
  
}



/* トップ共通 */
.top-title {
  text-align: center;
  margin: 0;
}
.top-btn-link {
  display: block;
  margin: auto;
  text-align: center;
}
.top-btn-link.show:hover {
  opacity: 0.7;
}

/* / トップ共通 */

.pickup .inner{
  padding: 0;
  margin: 0 auto;
  max-width: 1200px;
  margin-bottom: 17px;
}
.pickup .inner .sp_none{display: block;}
.pickup .inner .pc_none{display: none;}
@media (max-width: 450px) {
  .pickup .inner .sp_none{display: none;}
  .pickup .inner .pc_none{display: block;}
}
.pickup .inner ul{
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  list-style: none;
  margin: 86px 0 0;
  padding: 0;
}
.pickup .inner ul li{
  width: calc((100% - (78px * 2)) / 3);
}
.pickup .inner ul li:nth-child(n+4){
  margin-top: 35px;
}
.pickup .inner ul li a{
  display: block;
  transition: all .1s;
}
.pickup .inner ul li a:hover{
  filter: brightness(150%)
          drop-shadow(0 0 50px #FFFFFF);
}
.pickup .inner ul li img{
  width: 100%;
}
.pickup .inner ul li.greyout{
  pointer-events: none;
}

@media (max-width: 1199px) {
  .pickup .inner{
    box-sizing: border-box;
    padding: 0 5%;
  }
  .pickup .inner ul li{
    width: calc((100% - (30px * 2)) / 3);
  }

  .pickup .inner ul li a:hover{
    filter: brightness(150%)
            drop-shadow(0 0 50px #FFFFFF);
  }

}
@media (max-width: 767px) {
  .pickup .inner ul li:nth-child(n+4){
    margin-top: unset;
  }
  .pickup .inner ul li:nth-child(n+3){
    margin-top: 4vw;
  }

  .pickup .inner ul{
    margin: 8vw 0 0;
    padding: 0 2%;
    gap: unset;
  }
  .pickup .inner ul li{
    width: 48%;
  }
}


.scroll-anime.delay1 {
  transition: opacity 0.5s, visibility 0.5s, transform 0.5s;
  transition-delay: 0.2s;
  opacity: 0;
  visibility: hidden;
}
.scroll-anime.delay2 {
  transition: opacity 0.5s, visibility 0.5s, transform 0.5s;
  transition-delay: 0.3s;
  opacity: 0;
  visibility: hidden;
}
.scroll-anime.delay3 {
  transition: opacity 0.5s, visibility 0.5s, transform 0.5s;
  transition-delay: 0.4s;
  opacity: 0;
  visibility: hidden;
}
.scroll-anime.delay4 {
  transition: opacity 0.5s, visibility 0.5s, transform 0.5s;
  transition-delay: 0.5s;
  opacity: 0;
  visibility: hidden;
}
.scroll-anime.delay5 {
  transition: opacity 0.5s, visibility 0.5s, transform 0.5s;
  transition-delay: 0.6s;
  opacity: 0;
  visibility: hidden;
}
.scroll-anime.delay6 {
  transition: opacity 0.5s, visibility 0.5s, transform 0.5s;
  transition-delay: 0.7s;
  opacity: 0;
  visibility: hidden;
}
.scroll-anime.delay7 {
  transition: opacity 0.5s, visibility 0.5s, transform 0.5s;
  transition-delay: 0.8s;
  opacity: 0;
  visibility: hidden;
}
.scroll-anime.delay8 {
  transition: opacity 0.5s, visibility 0.5s, transform 0.5s;
  transition-delay: 0.9s;
  opacity: 0;
  visibility: hidden;
}

@media (max-width: 1199px) {
  .pickup-bg {
    padding: 0 4% 0;
    position: relative;
  }
}

.pu_text {
  position: absolute;
  left: 51%;
  top: 102px;
  transform: translate(-50%, 0%);
  display: block;
  width: 100%;
  text-align: center;
  font-size: 15px;
  font-weight: bold;
  font-family: "メイリオ", "ヒラギノ角ゴ Pro", "游ゴシック体", "Yu Gothic",
    YuGothic, "Hiragino Kaku Gothic Pro", "Meiryo", sans-serif;
  color: #fff;
}

.pu_text2 {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 26px;
  text-align: center;
  font-size: 13px;
  font-weight: bold;
  color: #fff;
  background: #694d14;
  margin: auto;
  padding: 3px 0;
  pointer-events: none;
  width: 33%;
  border-radius: 50%;
  line-height: 1.1;
}
.pu_text2 .num {
  font-size: 138%;
}
.pu_text2 .bottom {
  font-size: 123%;
}

.pu_title_sp {
  width: 70%;
  margin: auto;
}

.pu_text_sp {
  position: absolute;
  left: 50%;
  top: 72%;
  transform: translate(-50%, 0%);
  display: block;
  color: #fff;
  width: 95%;
  text-align: center;
  font-size: 2.4vw;
  font-weight: bold;
  font-family: "メイリオ", "ヒラギノ角ゴ Pro", "游ゴシック体", "Yu Gothic";
}

.pu_text_sp2 {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 19%;
  text-align: center;
  font-size: 2vw;
  font-weight: bold;
  color: #fff;
  background: #694d14;
  margin: auto;
  padding: min(0.6vw, 3px) 0;
  width: 33%;
  border-radius: 50%;
  line-height: 1.1;
}
.pu_text_sp2 .num {
  font-size: 138%;
}
.pu_text_sp2 .bottom {
  font-size: 123%;
}

@media (max-width: 420px) {
  .pu_text_sp {
    transform: translate(-50%, 0%) scale(0.95);
    width: 110%;
  }
}

@media (max-width: 385px) {
  .pu_text_sp {
    transform: translate(-50%, 0%) scale(0.9);
  }
}

@media (max-width: 355px) {
  .pu_text_sp {
    transform: translate(-50%, 0%) scale(0.85);
  }
}

@media (max-width: 335px) {
  .pu_text_sp {
    transform: translate(-50%, 0%) scale(0.7);
    width: 120%;
  }
}

.pu_text_sp.tiny {
  font-size: 2.8vw;
}

.campaign{
  margin-top: 110px;
}
.campaign .inner{
  box-sizing: border-box;
  margin: auto;
  max-width: 1200px;
  text-align: center;
}
.campaign .inner a{
  display: inline-block;
  transition: all .2s;
}

.campaign .inner a:hover{
  opacity: .6;
}


.campaign .inner a + a{
  margin-top: 50px;
}


@media (max-width: 1199px) {
  .campaign{
    margin-top: 8vw;
  }

  .campaign .inner{
    padding: 0 5%;
  }
}

@media (max-width: 767px) {
  .campaign{
    margin-top: 12vw;
  }

  .campaign .inner{
    padding: 0 5%;
  }

  .campaign .inner a + a{
    margin-top: 8vw;
  }

}


.answer-contents_pc,
.answer-contents_sp {
  display: none;
}
.answer-contents_pc.block,
.answer-contents_sp.block {
  display: block;
}

.answer-contents_pc.block.show,
.answer-contents_sp.block.show {
  opacity: 0;
  animation: top-btn_anime 0.5s ease 0.5s alternate forwards;
}

.answer-contents_pc a,
.answer-contents_sp a {
  display: block;
  border: 4px solid #00b0ec;
}

.ouen_banner_pc img:hover,
.ouen_banner_sp img:hover,
.answer-contents_pc a:hover,
.answer-contents_sp a:hover {
  opacity: 0.7;
}

.ouen_banner_sp,
.answer-contents_sp {
  padding: 0 4%;
  margin-bottom: 4%;
}

.news_container {
  margin-top: 134px;
}

.news_kiji_pc{
  margin-bottom: 18px;
}
@media (min-width: 1200px) {
  .news_container {
    display: block;
    background-size: cover;
    background-position: 50%;
  }

  .news_kiji_pc {
    display: flex;
    align-items: baseline;
  }

  .news_kiji_sp {
    display: none;
  }

  #news_logo_pc {
    display: inline;
  }

  #news_logo_sp {
    display: none;
  }
}

@media (max-width: 1199px) {
  .news_kiji_pc {
    display: none;
  }

  .news_kiji_sp {
    display: block;
  }

  #news_logo_pc {
    display: none;
  }

  #news_logo_sp {
    display: inline;
  }
}

.news_wrapper {
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
}

.news_wrapper p {
  margin: 0 auto;
  text-align: center;
  position: relative;
  z-index: 5;
  width: 306px;
}

.news_list {
  max-width: 1200px;
  position: relative;
  width: 100%;
  margin-left: auto;
  background-color: #FFFFFF;
  padding: 8px;
  margin: 58px auto 200px;
}

@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop,
  .news_list {
    padding-right: 10px;
  }
}

@supports (-ms-ime-align: auto) {
  .news_list {
    padding-right: 10px;
  }
}

ul.news_list_ul {
  list-style: none;
  padding: 18px 26px;
  margin: 0;
  width: 100%;
  height: 122px;
  overflow-y: scroll;
  position: relative;
  font-weight: 500;
  background: #fff;
  border: 4px solid #274172;
}

@media (max-width: 1199px) {
  .news_container {
    padding-bottom: 0;
    margin: 0;
    padding: 15% 3% 6%;
  }

  .top-title.news_title {
    margin: auto;
  }
  .top-title.news_title img {
    width: 100%;
  }

  ul.news_list_ul {
    border-width: 4px;
    height: 190px;
    margin: 0 auto;
    padding: 20px 0px;
  }

  .news_list {
    margin: 3vw 0 12vw;
    width: 100%;
  }
}
@media (max-width: 767px) {
  .news_container {
    padding-bottom: 0;
    margin: 0;
    padding: 20% 5% 6%;
  }

  .news_list {
    margin: 5vw 0 0;
  }

}

.news_list_ul::-webkit-scrollbar {
  width: 40px;
}

.news_list_ul::-webkit-scrollbar-track {
  background: transparent;
  background-position: center;
  background-size: auto 90%;
}

.news_list_ul::-webkit-scrollbar-thumb {
  background: url("../images/news/news-scrollbar.jpg") no-repeat;
  height: 60px;
  background-position: center;
  /* background-size: auto 50%; */
}

.date {
  /* background-size: cover; */
  background-color: #274172;
  color: #FFFFFF;
  font-weight: 500;
  font-size: 18px;
  padding: .05em 10px .2em;
}

@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop,
  .date {
    padding: 5px 10px 0;
  }
}

.news_list_ul a {
  color: #c30d23;
  text-decoration: none;
  font-weight: 600;
  /* text-underline-offset: 4px; */
  transition: all .2s;
}
.news_list_ul a:hover {
  opacity: .6;
}
.text {
  color: #274172;
  margin-left: 20px;
  letter-spacing: 0.3px;
  line-height: 1.7;
  display: block;
  font-weight: 600;
  font-size: 18px;
}

@media (max-width: 1199px) {
  ul.news_list_ul li {
    margin:0 0 1.2em 8px;
  }

  .text {
    display: block;
    padding: 0;
    margin: .4em 0 0;
    font-size: 16px
    }

  .news_list_ul::-webkit-scrollbar-track {
    background-size: auto 90%;
  }

  .news_list_ul::-webkit-scrollbar-thumb {
    background-position: center;
  }

  .news_list_ul::-webkit-scrollbar {
    width: 30px;
  }

}

/* メインビジュアルここから */
.main_center {
  max-width: 1200px;
  margin: 260px auto 0;
  pointer-events: none;
}

.mv_container {
  background-image: url(../images/main/visual/img_mv_bg_00.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  box-shadow: 0 0 20px #5078c7;
  width: 100%;                 /* 1200px 固定をやめる */
  max-width: 1200px;
  aspect-ratio: 1200 / 626;    /* ← 縦横比だけ固定 */
  position: relative;
  overflow: hidden;
}

.mv_container .mv_item_chara_1{
  position: absolute;
  top: 205px;
  left: 139px;
  transform:
    translate(0,0)
    scale(0.5);
  opacity: 0;
  animation: chara_jump .3s forwards ease-out;
  animation-delay: 2.8s;
  z-index: 3;
}

.mv_container .mv_item_chara_2{
  position: absolute;
    top: -6px;
    left: 280px;
  transform:
    translate(0,0)
    scale(0.5);
  opacity: 0;
  animation: chara_jump .3s forwards ease-out;
  animation-delay: 3.2s;
  z-index: 3;
}
.mv_container .mv_item_chara_3{
  position: absolute;
  top: -8px;
  right: 0;
  left: 0;
  text-align: center;
  transform:
    translate(0,0)
    scale(0.5);
  opacity: 0;
  animation: chara_jump .3s forwards ease-out;
  animation-delay: 3.3s;
  z-index: 2;
}
.mv_container .mv_item_chara_4{
  position: absolute;
  top: 22px;
  right: 256px;
  transform:
    translate(0,0)
    scale(0.5);
  opacity: 0;
  animation: chara_jump .3s forwards ease-out;
  animation-delay: 3s;
  z-index: 3;
}
.mv_container .mv_item_chara_5{
  position: absolute;
  top: 176px;
  right: 160px;
  transform:
    translate(0,0)
    scale(0.5);
  opacity: 0;
  animation: chara_jump_boy .3s forwards ease-out;
  animation-delay: 4s;
  z-index: 3;
}
@keyframes chara_jump {
  0% {
    transform: 
      scale(4);
    opacity: 0;
  }
  70% {
    transform: 
      scale(1);
    opacity: 1;
  }
  80% {
    transform: 
    rotate(8deg)
      scale(1);
    opacity: 1;
  }
  90% {
    transform: 
    rotate(-4deg)
      scale(1);
    opacity: 1;
  }
  100% {
    transform: 
    rotate(0deg)
      scale(1);
    opacity: 1;
  }
}
@keyframes chara_jump_boy {
    0% {
    transform: 
      scale(.5)
      translate(0, 50px);
    opacity: 0;
  }
  50% {
    transform: 
      translate(0, -100px);
  }
  100% {
    transform: 
      scale(1)
      translate(0, 0);
    opacity: 1;
  }

}
.mv_container .mv_item_copy_1{
  position: absolute;
  top: 88px;
  right: 30px;
  transform: translate(0, -100px);
  opacity: 0;
  animation: copy_slidein .8s forwards ease-in-out;
  z-index: 3;
}

.mv_container .mv_item_copy_2{
  position: absolute;
  top: 88px;
  left: 30px;
  transform: translate(0, -100px);
  opacity: 0;
  animation: copy_slidein .8s forwards ease-in-out;
  animation-delay: 1.2s;
  z-index: 3;
}
@keyframes copy_slidein {
  from {
    transform: translate(0, -100px); /* ← ここ */
    opacity: 0;
  }
  to {
    transform: translate(0, 0);
    opacity: 1;
  }
}

.mv_container .mv_item_copy_3{
  position: absolute;
  bottom: 20px;
  right: 15px;
  transform: translate(20px,0);
  opacity: 0;
  animation: copy_slidein_2_left 1s forwards;
  animation-delay: 5.5s;
  z-index: 3;
}
@keyframes copy_slidein_2_left {
  from {
    transform: translate(20px,0);
    opacity: 0;
  }
  to {
    transform: translate(0, 0);
    opacity: 1;
  }
}

.mv_container .mv_item_copy_4{
  position: absolute;
  z-index: 3;
  animation: copy_slidein_3 2.2s forwards ease-in;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
@keyframes copy_slidein_3 {
  from {
    transform:
    translate(0, 50px)
    scale(4);
    opacity: 0;
  }
  to {
    transform:
    translate(0, 0)
    scale(1);
    opacity: 1;
  }
}

.mv_container .mv_item_title_1{
  position: absolute;
  bottom: 60px;
  left: 30px;
  right: 0;
  margin: 0 auto;
  text-align: center;
  transform: scale(3)
  rotate(180deg);
  opacity: 0;
  animation: title_don1 .2s forwards;
  animation-delay: 4.8s;
  z-index: 3;
}
@keyframes title_don1 {
  0% {
    transform: scale(3)
    rotate(60deg);
    opacity: 0;
  }
  100% {
    transform: scale(1)
    rotate(0deg);
    opacity: 1;
  }
}

.mv_container .mv_item_title_2{
  position: absolute;
  bottom: 12px;
  left: 0;
  right: 0;
  margin: 0 auto;
  text-align: center;
  transform: scale(0.5);
  opacity: 0;
  animation: title_don2 .3s forwards;
  animation-delay: 5s;
  z-index: 3;
}
@keyframes title_don2 {
  0% {
    transform: scale(3)
    rotate(-30deg);
    opacity: 0;
  }
  100% {
    transform: scale(1)
     rotate(0deg);
    opacity: 1;
  }
}

.mv_container .mv_item_dynamite{
  position: absolute;
  top: 18px;
  left: 14px;
  transform: translate(-20px,0);
  opacity: 0;
  animation: copy_slidein_2_right 1s forwards;
  animation-delay: 5.5s;
  z-index: 3;
}
@keyframes copy_slidein_2_right {
  from {
    transform: translate(-20px,0);
    opacity: 0;
  }
  to {
    transform: translate(0, 0);
    opacity: 1;
  }
}

.mv_container .mv_item_bg{
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
  text-align: center;
  /* transform: scale(0.5);
  opacity: 0;
  animation: scaleIn 1s forwards;
  animation-delay: .5s; */
  z-index: 2;
}


@media (max-width: 1199px) {
}
/* アニメーションする要素 */
.mv_title1 {
  position: absolute;
  top: 100px;
  left: 100px;
  transform: scale(1);
  opacity: 0;
  animation: title_don1 1s forwards;
  animation-delay: 3.5s;
}

.mv_title2 {
  position: absolute;
  top: 200px;
  left: 100px;
  transform: scale(0.5);
  opacity: 0;
  animation: scaleIn 1s forwards;
  transform-origin: bottom;
}

/* 拡縮アニメーション */
@keyframes scaleIn {
  from {
    transform: scale(0.5);
    opacity: 0;
  }
  to {
    transform: scale(2);
    opacity: 1;
  }
}

/* 1199px以下〜768px以上で、右上起点で拡縮 */
/* ここから TB 用（1199〜768px） */
@media screen and (max-width: 1199px) and (min-width: 768px) {
  .main_center {
    width: 100%;
    margin: 120px auto 0;
  }

  .mv_container {
    width: 100%;
    max-width: 1200px;  /* お好みで */
    /* height は書かない。aspect-ratio に任せる */
  }

  .mv_container .mv_item_chara_1 {
    top: 17.0833vw;
    left: 11.5833vw;
    width: 13.75vw;
  }

  .mv_container .mv_item_chara_2 {
    top: -0.5vw;
    left: 23.3333vw;
    width: 15.2vw;
  }

  .mv_container .mv_item_chara_3{
    top: -0.6667vw;
    right: 0;
    left: 0;
    margin: auto;
    width: 21.5vw;
  }

  .mv_container .mv_item_chara_4{
    top: 1.8333vw;
    right: 21.3333vw;
    width: 15.25vw;
  }

  .mv_container .mv_item_chara_5{
    top: 14.6667vw;
    right: 13.3333vw;
    width: 12.75vw;
  }

  .mv_container .mv_item_copy_1{
    top: 7.3333vw;
    right: 2.5vw;
    width: 9vw;
  }

  .mv_container .mv_item_copy_2{
    top: 7.3333vw;
    left: 2.5vw;
    width: 11vw;
  }

 .mv_container .mv_item_copy_3{
    bottom: 1.6667vw;
    right: 1.25vw;
    width: 19vw;
    z-index: 3;
  }

  .mv_container .mv_item_title_1{
    bottom: 5vw;
    left: 2.5vw;
    right: 0;
    margin: 0 auto;
    text-align: center;
    width: 55vw;
  }

  .mv_container .mv_item_title_2{
    bottom: 1vw;
    left: 0;
    right: 0;
    margin: 0 auto;
    text-align: center;
    width: 56.5vw;
  }

  .mv_container .mv_item_dynamite{
    position: absolute;
    top: 1.5vw;
    left: 1.1667vw;
    width: 15vw;
  }

  .mv_container .mv_item_bg{
    width: 100%;
    left: unset;
    right: 0;
  }
  .mv_container .mv_item_bg img{
    width: 100%;
  }
  
}


@media (max-width: 767px) {
  .main_center {
    width: 100%;
    margin: 60px auto 0;
  }

  .mv_container {
    background-image: url(../images/main/visual/sp/img_mv_bg_01.png);
    background-repeat: no-repeat;
    background-size: cover;
    box-shadow: none;
    position: relative;
    overflow: hidden;

    width: 100%;
    max-width: 1200px;     /* お好みで */
    aspect-ratio: 750 / 1061; /* ここは元のSPデザイン比率に合わせて */
  }

  .mv_container .mv_item_chara_1 {
    top: 42vw;
    left: 0;
    width: 31.75vw;
  }

  .mv_container .mv_item_chara_2 {
    top: 11vw;
    left: 3vw;
    width: 30vw;
  }

  .mv_container .mv_item_chara_3{
    top: 2vw;
    right: 0;
    left: 0;
    margin: auto;
    width: 39vw;
  }

  .mv_container .mv_item_chara_4{
    top: 13.75vw;
    right: 5.25vw;
    width: 24.5vw;
  }

  .mv_container .mv_item_chara_5{
      top: 36vw;
      right: 0;
      width: 30.75vw;
  }

  .mv_container .mv_item_copy_1,
  .mv_container .mv_item_copy_2{
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
  }

 .mv_container .mv_item_copy_3{
    bottom: 1.75vw;
    width: 42vw;
    left: 0;
    right: 0;
    margin: 0 auto;
    z-index: 3;
  }
 .mv_container .mv_item_copy_4{
    position: absolute;
    top: 33vw;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 64vw;
    z-index: 5;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .mv_container .mv_item_title_1{
    bottom: 20vw;
    left: 2.5vw;
    right: 0;
    margin: 0 auto;
    width: 95vw;
  }

  .mv_container .mv_item_title_2{
    bottom: 6.75vw;
    width: 85vw;
  }

  .mv_container .mv_item_dynamite{
    position: absolute;
    top: 1.5vw;
    left: 1.1667vw;
    width: 15vw;
  }

  .mv_container .mv_item_bg{
    display: none;
  }

}


/* / ビジュアルアニメーション */

/* スクロールアニメーション共通 */
.scroll-anime {
  transition: opacity 0.5s, visibility 0.5s, transform 0.5s;
  opacity: 0;
  visibility: hidden;
}
.scroll-anime.show {
  opacity: 1;
  visibility: visible;
}
/* / スクロールアニメーション共通 */

.flip-in.show {
  opacity: 0;
  animation: flip-in 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards 0.3s;
}

@keyframes flip-in {
  0% {
    transform: rotateX(540deg);
    opacity: 0;
  }

  100% {
    transform: rotateX(0deg);
    opacity: 1;
  }
}

.fadein_contents {
  transform: translate(0, 40px);
  transition: all 0.6s;
}
.fadein_contents.show {
  transform: translate(0, 0);
}

.news_container .fadein_contents {
  transition-delay: 0.4s;
}

.top-btn-link.show {
  animation: top-btn_anime 0.5s ease 0s alternate;
  transition: none;
}


/* アニメーション */
.pickup ul li.scroll-anime {
  transform: translate(0, 0px);
  -webkit-transform: translate(0, 0px);
  transition-delay: 0.2s;
}

.pickup .scroll-anime.show {
  transform: translate(0, 0);
  -webkit-transform: translate(0, 0);
}

.campaign .inner a.scroll-anime {
  transform: translate(0, 100px);
  -webkit-transform: translate(0, 100px);
  transition-delay: 0.1s;
}

.campaign .inner a.scroll-anime.show {
  transform: translate(0, 0);
  -webkit-transform: translate(0, 0);
}
@media (max-width: 767px) {
  .pickup .scroll-anime {
  transform: translate(0, 100px);
  -webkit-transform: translate(0, 100px);
  transition-delay: 0.3s;
}
.pickup .scroll-anime.show {
  transform: translate(0, 0);
  -webkit-transform: translate(0, 0);
}

}
/* / アニメーション */


@keyframes top-btn_anime {
  0% {
    opacity: 0;
    transform: scale(0.9, 0.9);
  }
  50% {
    transform: scale(1.1, 1.1);
  }
  100% {
    transform: scale(1, 1);
  }

  50%,
  100% {
    opacity: 1;
  }
}

@media (max-width: 1199px) {
  .mv_container {
    margin-top: 0;
    padding-bottom: 3%;
  }
  .mv_container::before,
  .mv_container::after {
    display: none;
  }

  .mv_contents {
    position: static;
    display: block;
  }
  .mv_contents.machigai-left,
  .mv_contents.machigai-right {
    width: 100%;
  }
  .mv_contents.machigai-left {
    margin-bottom: 1.5%;
  }
  .mv_contents.subtitle01 {
    margin-bottom: 1%;
    width: 11%;
  }
  .mv_contents.subtitle02 {
    width: 27%;
    margin: auto;
    margin-bottom: 1%;
  }
  .mv_contents.machigai-right {
    margin-bottom: 2%;
  }
  .mv-bottom-flex {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
  .mv_contents.title {
    width: 69%;
    bottom: 7%;
  }
  .mv_contents.dynamite {
    width: 9%;
  }
}

/* メインビジュアルここまで */
/* index.php css end */
/* footer.php css start */
footer {
  position: relative;
  z-index: 1;
}

.footer_container {
  padding: 0;
  position: relative;
}

#footer_center_moya {
  position: absolute;
  top: -35px;
  z-index: -1;
  left: 0;
  right: 0;
  margin: auto;
}

#to_top_btn_pc {
  position: fixed;
  right: 30px;
  bottom: 116px;
  cursor: pointer;
  width: 63px;
  opacity: 0;
  visibility: hidden;
  transition: opacity 1s, visibility 1s;
}

@media (max-width: 1199px) {
  #to_top_btn_sp {
    position: fixed;
    right: 20px;
    bottom: 45px;
    width: 45px;
    cursor: pointer;
    opacity: 0;
    visibility: hidden;
    transition: opacity 1s, visibility 1s;
    z-index: 1;
  }
}

@media (min-width: 1500px) {
  #to_top_btn_pc {
    right: 50px;
  }
}

@media (min-width: 1900px) {
  #to_top_btn_pc {
    right: 250px;
  }
}

@media (min-width: 2500px) {
  #to_top_btn_pc {
    right: 550px;
  }
}

@media (min-width: 3800px) {
  #to_top_btn_pc {
    right: 1150px;
  }
}

#to_top_btn_pc.show,
#to_top_btn_sp.show {
  opacity: 1;
  visibility: visible;
}

#to_top_btn_pc:hover {
  opacity: 0.8;
}

img.slide-arrow.prev-arrow.slick-arrow {
  display: none !important;
}

@media (max-width: 1199px) {
  img.slide-arrow.prev-arrow.slick-arrow {
    position: absolute;
    top: 10px;
    left: -30px;
    width: 20px;
    display: block !important;
    cursor: pointer;
  }
}

img.slide-arrow.next-arrow.slick-arrow {
  display: none !important;
}

@media (max-width: 1199px) {
  img.slide-arrow.next-arrow.slick-arrow {
    position: absolute;
    top: 10px;
    right: -30px;
    width: 20px;
    display: block !important;
    cursor: pointer;
  }
}

@media (max-width: 1199px) {
  #footer_center_moya {
    display: none;
  }
}

.footer_banner_pc,
.footer_banner_sp {
  max-width: 1200px;
  margin: 0 auto;
}

@media (max-width: 1199px) {
  .footer_banner_pc {
    display: none;
  }

  .footer_banner_sp {
    display: block;
    margin: 40px 0 24px;
  }

  .footer_container {
    padding-top: 0;
  }
}

@media (min-width: 1200px) {
  .footer_banner_pc {
    display: block;
  }

  .footer_banner_sp {
    display: none;
  }
}

ul.slider {
  padding: 0px;
  margin: 0;
  list-style: none;
  width: 80%;
  margin: 0 auto;
}

@media (max-width: 1199px) {
  ul.slider {
    background: none;
    box-shadow: none;
  }
}

.ouen_message_list {
  display: none;
}

.ouen_message_list.slick-initialized {
  display: block;
}

ul.slider li a img {
  width: 100%;
}

ul.slider li a img:hover {
  opacity: 0.7;
}

/* slickデファクト左右ボタン用 */

_::-webkit-full-page-media,
_:future,
:root .slick-prev {
  width: auto !important;
}

_::-webkit-full-page-media,
_:future,
:root .slick-next {
  /* right: -20px!important; */
  width: auto !important;
}

@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop,
  .slick-prev {
    width: auto !important;
  }

  .slick-next {
    width: auto !important;
    /* right: -20px!important; */
  }
}

.footer_container p {
  text-align: center;
  /* color: #ffde65; */
  color: #FFFFFF;
  margin: 0 auto 0;
  padding: 30px 0;
}

@media (max-width: 767px) {
  .footer_container p {
    font-size: 2.75vw;
    margin: 0 auto;  
    padding: 22vw 0 8vw;
  }
}
/* footer.php css end */
/* 下層ページ共通 css start */
.page-bi {
  background-size: cover;
  background-attachment: fixed;
  position: relative;
  background-position-y: 50px;
  padding-bottom: 72px;
}

@media (max-width: 1199px) {
  .page-bi {
    padding-bottom: 0;
  }
}
.contain {
  max-width: 1200px;
  margin: auto;
  padding-top: 200px;
  position: relative;
  animation: slideIn 0.5s forwards ease;
  width: 96%;
}

@media (max-width: 1199px) {
  .contain {
    width: 100%;
    width: 96%;
    padding-top: 150px;
  }
}
@media (max-width: 768px) {
  .contain {
    /* padding-top: calc(8vw + 60px); */
    padding-top: 80px;
  }
}

h2.pc {
  font-size: 30px;
  text-align: center;
  font-weight: 900;
  margin: -52px auto auto;
  padding: 15px 0px;
  color: #fff;
  letter-spacing: 0;
  position: relative;
  z-index: 1;
}

@media all and (-ms-high-contrast: none) {
  *::-ms-backdrop,
  h2.pc {
    padding-bottom: 8px;
  }
}

h2.sp {
  font-size: 28px;
  text-align: center;
  font-weight: 900;
  padding: 15px 0px;
  color: #fff;
  letter-spacing: 3px;
  position: relative;
  overflow: hidden;
  margin: -60px 0 0;
  z-index: 1;
}

@media screen and (max-width: 768px) {
  h2.sp {
    font-size: 16px;
    margin-top: -50px;
  }
}

@media (max-width: 1199px) {
  h2.pc {
    display: none;
  }

  .movie_wrap {
    overflow-x: hidden;
  }

  h2.sp {
    display: block;
  }
}

@media (min-width: 1200px) {
  h2.pc {
    display: block;
  }

  h2.sp {
    display: none;
  }
}

.bc-white {
  background-color: #FFFFFF;
  position: relative;
}


#a1 .h4_u {
  background: linear-gradient(transparent 70%, #00b0ec 70%);
}

li {
  list-style: none;
}

.main-slider {
  margin: auto;
  padding: 0;
}

@media (max-width: 1199px) {
  .bc-white::before,
  .bc-white::after {
    display: none;
  }
  .bc-white {
    margin-top: 0;
    box-shadow: none;
    border-width: 4px;
  }

  .clear_box_w.pc-none {
    height: 100px;
  }
}
@media (max-width: 768px) {
  .bc-white {
    border-radius: 0;
  }
}

.page-inner {
  /* padding: 2% 2% 3% 2%; */
  padding: 84px 55px 76px;
  margin: auto;
}
@media (max-width: 1199px) {
  .page-inner {
    padding: 84px 2% 76px;
  }
}
@media (max-width: 767px) {
  .page-inner {
    padding: 12vw 0 15vw 0;
    border-radius: 0;
  }
}

/* movie_~.php css start */
.jstream-eqPlayer {
  display: block !important;
}

.jstplayer {
  width: 640px;
}

.jstlistcrtl {
  width: 640px;
}

.jstlist {
  width: 600px;
}

.jstream-eqPlayer {
  display: block !important;
}

/* movie_~.php css end */
/* dream.php css start */
.saturday {
  color: #01a0e9;
}

.sunday {
  color: #e60a12;
}

.kousin {
  text-align: center;
  font-weight: bold;
  font-size: 28px;
  padding: 150px 0;
  color: #446096;
}

@media (max-width: 700px) {
  .kousin {
    font-size: 20px !important;
    padding: 100px 0 !important;
  }
}

/* dream.php css end */
/* tv_schedule.php css start */
.tv_padding {
  padding: 20px;
}

.tv_padding a {
  color: #c30d23;
  text-decoration: none;
  transition: all .2s;
}
.tv_padding a:hover {
  opacity: .6;
}

.tv_padding p {
  margin: 0;
  margin-top: 10px;
  color: #000;
}

.tv_padding tr {
  background: #fff;
}

#tv {
  width: 100%;
  text-align: center;
  border: 1px solid #000;
  border-collapse: collapse;
  margin-top: 20px;
}

th,
td {
  border: 1px solid #000;
  padding: 5px;
}

th {
  background: #c4d5e5;
  color: #000;
}
/* tv_schedule.php css end */

/*下層ページタイトルパターン2*/
.second_title_img {
  position: relative;
  text-align: center;
}

.second_title_txt {
  color: #fff;
  font-size: min(3.6vw, 36px);
  text-align: center;
  margin: 30px 0 0 0 ;
  padding-inline: 139px;
  text-shadow: 0 0 20px #1c3f82, 0 0 1px #1c3f82, 0 0 2px #1c3f82, 0 0 3px #1c3f82, 0 0 4px #1c3f82, 0 0 5px #1c3f82, 0 0 6px #1c3f82, 0 0 7px #1c3f82, 0 0 8px #1c3f82, 0 0 9px #1c3f82, 0 0 10px #1c3f82, 0 0 11px #1c3f82, 0 0 12px #1c3f82, 0 0 13px #1c3f82, 0 0 14px #1c3f82, 0 0 15px #1c3f82, 0 0 20px #1c3f82, 0 0 1px #1c3f82, 0 0 2px #1c3f82, 0 0 3px #1c3f82, 0 0 4px #1c3f82, 0 0 5px #1c3f82, 0 0 6px #1c3f82, 0 0 7px #1c3f82, 0 0 8px #1c3f82, 0 0 9px #1c3f82, 0 0 10px #1c3f82, 0 0 11px #1c3f82, 0 0 12px #1c3f82, 0 0 13px #1c3f82, 0 0 14px #1c3f82, 0 0 15px #1c3f82;
  font-weight: bold;
}


.second_title_txt .title {
  position: relative;
  z-index: 1;
  background-repeat: no-repeat;
  background-size: cover;
  display: block;
  padding-block: 30px;
  background-position: center 35%;
  
}

_:-ms-lang(x)::-ms-backdrop,
.second_title_txt {
  top: 50%;
}

#main .s-tbl th {
  background: #c4d5e5;
  color: #000;
}

#main .s-tbl tr:nth-child(2n + 1) {
  background: #e8ebee;
}

.sunday {
  color: red;
}

/*レスポンシブ*/

@media (max-width: 1199px) {
  h2.second_title_txt {
    /* font-size: min(4.5vw, 42px); */
    margin: 0 auto;
    letter-spacing: 2px;
    /* top: max(-4.2vw, -36px); */
    padding-inline: 0;
    font-size: 4vw;
  }

  .second_title_img img {
    width: 98%;
    top: 5px;
  }
}

@media (max-width: 768px) {
  h2.second_title_txt {
    font-size: 4.2vw;
    letter-spacing: 1px;
    width: 100%;
  }
}

/******表示・非表示*******/
@media (min-width: 1200px) {
  /*PCの時非表示にします*/
  .pc-none {
    display: none !important;
  }
}

@media (max-width: 1199px) {
  /*TBとSPの時非表示にします*/
  .tb-none {
    display: none !important;
  }
}

@media (max-width: 768px) {
  /*SPの時非表示にします*/
  .sp-none {
    display: none !important;
  }

  .sp-only {
    display: block !important;
  }
}

@keyframes slideIn {
  0% {
    opacity: 0;
    transform: translatex(-200px);
  }

  100% {
    opacity: 1;
    transform: translatex(0);
  }
}

@keyframes slideIn2 {
  0% {
    opacity: 0;
    transform: translatex(500px);
  }

  100% {
    opacity: 1;
    transform: translatex(0);
  }
}

@keyframes slideIn3 {
  0% {
    opacity: 0;
    transform: translatex(-500px);
  }

  100% {
    opacity: 1;
    transform: translatex(0);
  }
}

.ouen_message_pc_container {
  position: relative;
  background-color: #00b0ec;
  background-image: url(../images/header/header-nami.png);
  background-size: auto;
  background-position: calc(50% + 90px) 61.5%;
  background-repeat: no-repeat;
  display: flex;
  align-items: flex-end;
  padding-bottom: 24px;
  height: 150px;
  z-index: 30;

  /* 応援メッセージ非表示 */
  /* display: none; */
}



@media (max-width: 1199px) {
  .fadeUpAni {
    animation-delay: 1.9s;
  }
}

/* 下から出現 */
@keyframes fadeUpAni {
  from {
    opacity: 0;
    transform: translateY(5px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.ouen_message_pc_wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  overflow: hidden;
}

.ouen_icon {
  display: none;
}

@media (max-width: 1499px) {
  .ouen_message_pc_wrapper .ouen_img_box::before {
    height: 34px;
  }
}

.ouen_message_pc_wrapper ul {
  margin: 0;
  padding: 0;
  list-style: none;
  width: 1182px;
  height: 56px;
  padding-left: 16px;
}

.ouen_message_list_li {
  margin-top: 3px;
  text-align: left;
  background: #fff;
  border-radius: 10px;
  border: 4px solid #e60012;
  height: 45px;
  display: flex !important;
  font-weight: bold;
  align-items: center;
}

.to_racer {
  color: #d33414;
  font-size: 16px;
  margin-left: 140px;
  margin-right: 20px;
  white-space: nowrap;
}
.to_racer::before {
  content: "";
  background-image: url(../images/main/name-before.svg);
  background-size: contain;
  background-repeat: no-repeat;
  display: inline-block;
  vertical-align: bottom;
  margin-right: 8px;
  width: 26px;
  height: 23px;
}

.ouen_honbun_index {
  font-size: 16px;
}

.racer_name_inex {
  font-size: 15px;
  white-space: nowrap;
  margin-right: 10px;
}

.ouen_honbun_index {
  margin-right: 13px;
}

.ouen_message_list_li span {
  margin: 0 10px;
  font-weight: bold;
}
.ouen_message_list_li span.name {
  margin: 0;
  font-size: 115%;
}

.br_on {
  display: none;
}

@media (max-width: 1199px) {
  .br_on {
    display: block;
  }

  .ouen_message_wrapper {
    display: flex;
    justify-content: left;
    align-items: center;
    max-width: 1200px;
  }
}

.ouen_li_index {
  color: #d33414;
}

.flag .head_container_tb,
.flag .head_container_sp {
  border-bottom-color: #d33414;
}

@media (max-width: 1199px) {
  .ouen_message_sp_container {
    display: block;
    text-align: center;
    /* padding: 0 10px; */
    background-color: #00b0ec;
    background-image: url(../images/header/header-nami_sp.png);
    background-size: auto;
    background-position: center;
    background-repeat: no-repeat;
    padding: 20px 0;
    z-index: 5;
    position: relative;
    transition: opacity 0.2s;

    /* 応援メッセージ非表示 */
    /* display: none; */
  }

  .ouen_message_sp_container.show {
    opacity: 1;
    visibility: visible;
  }

  .ouen_message_sp_wrapper {
    overflow: hidden;
  }

  .ouen_message_title_sp {
    position: relative;
    list-style: none;
  }

  .ouen_message_title_sp > img {
    max-width: 95px;
    max-height: 61px;
    position: relative;
    z-index: 2;
  }

  .ouen_message_text_sp {
    background: #fff;
    border: 3px solid #e60012;
    border-radius: 10px;
    width: 97%;
    height: 40px;
    font-weight: bold;
    margin: 0 auto;
  }

  #text_sp {
    list-style-type: none;
  }
}

@media (max-width: 768px) {
  /* .ouen_message_sp_container {
    top: 22px;
  } */
  .ouen_message_text_sp {
    width: 95%;
  }

  .ouen_message_sp_container {
    padding: 15px 0;
  }

  .ouen_message_text_sp {
    height: 34px;
  }
}
@media (max-width: 420px) {
  .ouen_message_sp_container {
    background-size: 140%;
    background-position-x: 15%;
  }
}

#to_top_btn {
  box-sizing: border-box;
  text-decoration: none;
  position: fixed;
  bottom: 32px;
  right: 30px;
  z-index: 10000;
  cursor: pointer;
  opacity: 0;
  transition: 1s;
  visibility: hidden;
}

#to_top_btn.show {
  opacity: 1;
  visibility: visible;
}


#to_top_btn:hover {
  opacity: 0.8;
}

@media (max-width: 1199px) {
  #to_top_btn {
    width: 100px;
    right: 40px;
    bottom: 60px;
  }
}

@media (max-width: 767px) {
  #to_top_btn {
    width: 50px;
    right: 5vw;
    bottom: 8vw;
  }
}

@media (min-width: 769px) and (max-width: 790px) {
  .grid {
    max-width: 740px !important;
    width: 100% !important;
    margin-left: 0 !important;
  }

  .player_img {
    margin-left: 0 !important;
  }

  
}

/* ヘッダースクロール固定用 */
.head_container_pc,
.nav_container_pc{
  transition: 0.5s;
}

.fade-out {
  transition: 0.5s;
}

/* 正解バナー */

/* / 正解バナー */

/* photo gallery */

.photo_gallery_swiper_wrapper {
  text-align: center;
  background-size: cover;
  overflow: hidden;
  margin: 100px auto 0;
  max-width: 1200px;
}
.photo_gallery_swiper_wrapper h3 {
  margin: 0;
  margin-top: 0;
  margin-bottom: 65px;
}

.photo_gallery_swiper_wrapper .swiper {
  overflow: visible;
}
.photo_gallery_swiper_wrapper .swiper-wrapper {
  transition-timing-function: linear;
}

.photo_gallery_swiper_wrapper .swiper-slide img {
  width: 100%;
  height: auto;
}

.swiper:hover .swiper-slide {
  opacity: 1; /* ホバーしている要素には通常の状態を適用 */
  transition: opacity .2s;
}

.swiper:hover .swiper-slide:not(:hover) {
  opacity: 0.3; /* ホバーしていない要素に薄くする効果を適用 */
}

.photo_gallery_swiper_wrapper .top-btn-link {
  display: inline-block;
  margin-top: 54px;
}

@media (max-width: 1199px) {
  .photo_gallery_swiper_wrapper {
    padding-bottom: min(20vw, 17px);
  }
  .photo_gallery_swiper_wrapper h3 {
    margin: 0;
    margin-bottom: min(11vw, 56px);
  }

  .photo_gallery_swiper_wrapper .top-btn-link {
    width: 30%;
  }
}
@media (max-width: 767px) {
  .photo_gallery_swiper_wrapper {
    margin: 15vw 0 0;
    padding-bottom: min(10vw, 150px);
  }
  .photo_gallery_swiper_wrapper h3 {
    margin-bottom: min(6vw, 80px);
  }
  #photo_gallery_swiper {
    padding: 0 0 10vw;
  }
  .photo_gallery_swiper_wrapper .top-btn-link {
    margin-top: 0;
    width: 45vw;
  }
}

@media (max-width: 767px) {
  .second_title_txt .title {
        background-size: contain;
        background-position: center 0.4vw;
        background-size: 100% 110%;
        padding: 0 2% 5vw;
  }
}

.drean_caution {
  color: #fff;
  font-size: 16px;
}

@media (max-width: 1199px) {
  .drean_caution {
    font-size: 16px;
}
}
@media (max-width: 767px) {
  .drean_caution {
    font-size: 13px;
}
}
@media (max-width: 450px) {
  .drean_caution {
    font-size: 11px;
  
}
}