@charset "UTF-8";
/* フェーズ1 */
.site_content_wrap.hidden,
.header_logo.hidden {
  opacity: 0;
  transform: translateY(40px);
  visibility: hidden;
}

.site_content_wrap.visible {
  visibility: visible;
  position: relative;
  animation: contentFadeIn 0.6s ease-out forwards;
}

.header_logo.visible {
  position: absolute;
  animation: contentFadeIn 0.6s ease-out forwards;
}

@keyframes contentFadeIn {
  0% {
    opacity: 0;
    transform: translateY(24px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

.loading_wrap {
  width: 100%;
  height: 100%;
  background-color: var(--base-white);
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10000;
  transition: background-color 0.6s, width 0.6s ease-in;
}

.loading_wrap .loading_logo {
  width: 205px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -40%);
  opacity: 0;
  animation: fadeIn 600ms forwards;
  transition: opacity 600ms;
}

@keyframes fadeIn {
  0% {
    transform: translate(-50%, -40%);
    opacity: 0;
  }
  100% {
    transform: translate(-50%, -50%);
    opacity: 1;
  }
}

.loading_wrap .loading_logo img:last-child {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
}

/* フェーズ2 */

.loading_wrap.color {
  background-color: var(--main-primary);
}

.loading_wrap.color .loading_logo img:first-child {
  opacity: 0;
}

.loading_wrap.color .loading_logo img:last-child {
  opacity: 1;
}

/* フェーズ3 */

.loading_wrap.color .loading_logo.dn {
  animation: fadeOut 0.8s ease forwards;
  transition: opacity 600ms;
}

@keyframes fadeOut {
  0% {
    transform: translate(-50%, -50%);
    opacity: 1;
  }
  100% {
    transform: translate(-50%, -60%);
    opacity: 0;
  }
}

.loading_wrap.small {
  width: 40%;
}

/* ローディング中は本文のスクロールを防ぐ */
body.non_scroll .site_content_wrap {
  position: fixed;
  width: 100%;
}

/* フェーズ4 */

.loading_wrap.hidden {
  opacity: 0;
  transition: opacity 0.6s;
}

@media (max-width: 1023px) {

  .loading_wrap {
    transition: all 0.6s;
  }
  
  .loading_wrap.small {
    width: 100%;
    height: 0;
  }

  .loading_wrap.sp_small {
    width: 100%;
    height: 500px;
  }

  .loading_wrap .loading_logo.sp_dn {
    display: none;
  }
}
