/*****************************************************************************
CSS only for top page christmas ver
*****************************************************************************/

/* Header
-----------------------------------------*/
.Header--christmas,
.Header--christmas .Nav {
  background: linear-gradient(180deg, #7e0900, #af1a18);
}
.Header--christmas .Nav::after {
  content: '';
  display: inline-block;
  position: absolute;
  top: max(calc(100% - 26px), calc(100% - 1.36482vw));
  right: .57742%;
  z-index: 2;
  width: min(397px, 20.83989vw);
  aspect-ratio: 397 / 104;
  background: url(/index/img/theme_christmas/bg_header_01.png);
  background-repeat: no-repeat;
  background-position: right top;
  background-size: contain;
}
@media screen and (max-width: 1200px) {
  .Header--christmas .Nav::after {
    top: max(-42px, calc(-26px - 1.86666vw));
    width: min(240px, 30vw);
  }
}
.Header--christmas .Nav.Nav--fixed::after {
  top: 77.41935%;
  width: 10vw;
}

/* Mv
-----------------------------------------*/
@media screen and (max-width: 1200px) {
  .Mv {
    padding-top: 100px;
  }
}
.Mv__inner {
  overflow: visible;
}
.Mv .swiper-slide-active::after {
  content: '';
  display: inline-block;
  position: absolute;
  top: max(-57px, calc(-9.08136vw * .84971 + 7.88381%));
  left: -.859375%;
  z-index: 2;
  width: min(173px, 9.08136vw);
  aspect-ratio: 173 / 147;
  background-image: url(/index/img/theme_christmas/bg_mv_01.png);
  background-repeat: no-repeat;
  background-position: left top;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  .Mv .swiper-slide-active::after {
    top: max(-27px, calc(-20vw * .84971 + 8.30769%));
    left: -1.79104%;
    width: 20vw;
  }
}

/* Pickup
-----------------------------------------*/
.Pickup {
  background-image: url(/index/img/theme_christmas/bg_pickup_01.png);
  background-repeat: no-repeat;
  background-position: right 6.29921vw top 5.35433vw;
  background-size: 11.07611vw auto;
}
@media screen and (max-width: 767px) {
  .Pickup {
    background-size: 24vw auto;
  }
}
.Pickup__wrapper {
  overflow: visible;
}
.Pickup__list li {
  position: relative;
}
.Pickup__list li::after {
  content: '';
  display: inline-block;
  position: absolute;
  top: -7.61904%;
  left: -7.61904%;
  width: min(147px, 35%);
  aspect-ratio: 147 / 146;
  background-repeat: no-repeat;
  background-position: left top;
  background-size: contain;
}
.Pickup__list li:nth-child(odd)::after {
  background-image: url(/index/img/theme_christmas/bg_pickup_02.png);
}
.Pickup__list li:nth-child(even)::after {
  background-image: url(/index/img/theme_christmas/bg_pickup_03.png);
}

/* Match
-----------------------------------------*/
.GameRank::before,
.GameRank::after {
  content: '';
  display: inline-block;
  position: absolute;
  background-repeat: no-repeat;
  background-position: left top;
  background-size: contain;
}
.GameRank::before {
  top: -7.08446%;
  left: -4.2328%;
  width: min(147px, 7.71653vw);
  aspect-ratio: 147 / 66;
  background-image: url(/index/img/theme_christmas/bg_match_01.png);
}
@media screen and (max-width: 767px) {
  .GameRank::before {
    width: 20vw;
  }
}
.GameRank::after {
  top: -10.08174%;
  right: -1.0582%;
  width: min(213px, 11.1811vw);
  aspect-ratio: 213 / 59;
  background-image: url(/index/img/theme_christmas/bg_match_02.png);
}
@media screen and (max-width: 767px) {
  .GameRank::after {
    width: 29vw;
  }
}

/* News
-----------------------------------------*/
.News__list {
  position: relative;
}
.News__list::after {
  content: '';
  display: inline-block;
  position: absolute;
  top: max(-103px, calc(-24.93438vw * .27578 + 1.41732vw));
  right: max(-290px, -15.22309vw);
  width: min(475px, 24.93438vw);
  aspect-ratio: 475 / 131;
  background-image: url(/index/img/theme_christmas/bg_news_01.png);
  background-repeat: no-repeat;
  background-position: left top;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  .News__list::after {
    top: max(-42px, calc(-46vw * .27578 + 1.6vw));
    right: -14.13333vw;
    width: 46vw;
  }
}

/* Ranking
-----------------------------------------*/
.Ranking {
  overflow: visible;
}
.Ranking::after {
  content: '';
  display: inline-block;
  position: absolute;
  top: max(calc(-58px), calc(-52.33595vw * .1364 + 4.09448vw));
  right: -2.3622vw;
  z-index: 2;
  width: min(997px, 52.33595vw);
  aspect-ratio: 997 / 136;
  background-image: url(/index/img/theme_christmas/bg_ranking_01.png);
  background-repeat: no-repeat;
  background-position: left top;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  .Ranking::after {
    top: max(calc(-16px), calc(-97vw * .1364 + 9.06666vw));
    right: -12.26666vw;
    width: 97vw;
  }
}

/* Classes
-----------------------------------------*/
.Classes {
  position: relative;
}
.Classes::after {
  content: '';
  display: inline-block;
  position: absolute;
  top: max(calc(-45px), calc(-20.99737vw * .3025 + 3.9895vw));
  right: calc((100% - 71.14583vw) / 2 + 8.34645vw);
  z-index: 2;
  width: min(400px, 20.99737vw);
  aspect-ratio: 400 / 121;
  background-image: url(/index/img/theme_christmas/bg_classes_01.png);
  background-repeat: no-repeat;
  background-position: left top;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  .Classes::after {
    top: max(calc(-17px), calc(-38vw * .3025 + 6.93333vw));
    right: 12vw;
    width: 38vw;
  }
}
.Classes__wrapper::before {
  background-color: #7e0900;
  background-image:
    linear-gradient(-90deg, #92130e 1px, transparent 1px),
    linear-gradient(#92130e 1px, transparent 1px);
}
.Classes__wrapper::after {
  content: '';
  display: block;
  position: absolute;
  top: 5.46875vw;
  left: 50%;
  z-index: -1;
  transform: translateX(-50%);
  width: 50vw;
  max-height: 374px;
  aspect-ratio: 2.492 / 1;
  filter: blur(30px);
  background   : linear-gradient(to bottom, transparent, #af1a18);
  border-radius: 50%/100% 100% 0 0;
}
@media screen and (max-width: 767px) {
  .Classes__wrapper::after {
    width: 62.78184vw;
    height: 60%;
    aspect-ratio: auto;
  }
}

/* Footer
-----------------------------------------*/
.Footer {
  position: relative;
  overflow: visible;
}
.Footer::after {
  content: '';
  display: inline-block;
  position: absolute;
  top: max(calc(-32px), calc(-32.38845vw * .5867 + 330px));
  left: calc((100% - 976px) / 2 * .29924);
  z-index: 2;
  width: min(617px, 32.38845vw);
  aspect-ratio: 617 / 362;
  background-image: url(/index/img/theme_christmas/bg_pappiness_01.png);
  background-repeat: no-repeat;
  background-position: left bottom;
  background-size: contain;
}
@media screen and (max-width: 767px) {
  .Footer::after {
    top: max(calc(-165px), calc(-52vw * .5867 + 81px));
    left: 15px;
    width: 52vw;
  }
}

/* Snow
-----------------------------------------*/
#Snow {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9;
  pointer-events: none;
  overflow: hidden;
}
.Snowflake {
  position: absolute;
  top: -10px;
  color: transparent;
  font-size: 1em;
  text-shadow: 0 0 0 #fff;
  opacity: .8;
  user-select: none;
  animation: fall linear forwards;
}
@keyframes fall {
  to {
    transform: translateY(100vh);
  }
}