@charset "UTF-8";
/*
// グラデだけ使いたい場合
.gradient-section {
  @include gradient-bg(45deg, #ff8a00, #e52e71, 10%, 90%);
}

// グラデ＋画像
.hero {
  @include bg-with-gradient(
    135deg,
    rgba(0,0,0,0.5),
    rgba(0,0,0,0.2),
    0%,
    100%,
    '/images/bg.jpg'
  );
}

// 背景画像のみ
.bg-image-only {
  @include bg-image('/images/bg.jpg', center top, contain, repeat);
}

*/
/* responsive */
/*@include mq() { }*/
.wrapper {
  opacity: 0;
  position: relative;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
.wrapper.fadein {
  opacity: 1;
  -webkit-transition-delay: 0.5s;
          transition-delay: 0.5s;
}

.is-fade-in-up {
  -webkit-animation-name: fade-in-up-sm;
          animation-name: fade-in-up-sm;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-fill-mode: both;
          animation-fill-mode: both;
  opacity: 0;
}

@-webkit-keyframes fade-in-up-sm {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}

@keyframes fade-in-up-sm {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
a, .faq_block h4:not(.active) {
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
a:hover, .faq_block h4:not(.active):hover {
  opacity: 0.5;
}

.faq_block h4 {
  cursor: pointer;
}

.ani_fade_up {
  opacity: 0;
  -webkit-transform: translate(0, 5rem);
          transform: translate(0, 5rem);
  -webkit-transition: 0.8s ease;
  transition: 0.8s ease;
  will-change: transform;
}
.load_complete .ani_fade_up.ani {
  opacity: 1;
  -webkit-transform: translate(0, 0);
          transform: translate(0, 0);
}

.loop-container_w {
  overflow: hidden;
  width: 100%;
  position: absolute;
  left: 0;
  bottom: 0.5rem;
}

.loop-track_w {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  -webkit-animation: scrollLoop_w 100s linear infinite;
          animation: scrollLoop_w 100s linear infinite;
}

.loop-track_w img {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin: 0 0.375rem;
  width: auto;
  height: 4.375rem; /* 必要に応じて調整 */
}

@-webkit-keyframes scrollLoop_w {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}

@keyframes scrollLoop_w {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.loop-fixed {
  position: fixed;
  top: 0;
  bottom: 0;
  width: 9.4375rem; /* 画像幅に応じて調整 */
  overflow: hidden;
  z-index: 5; /* 装飾としては高めに */
  pointer-events: none; /* 装飾だけなら操作を無効に */
}

.loop-fixed.left {
  left: 0rem;
}

.loop-fixed.right {
  right: 0;
}

.loop-track {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-animation: verticalScrollReverse 100s linear infinite;
          animation: verticalScrollReverse 100s linear infinite;
}

.loop-fixed.left .loop-track {
  -webkit-animation: verticalScroll 100s linear infinite;
          animation: verticalScroll 100s linear infinite;
}

.loop-track img {
  width: 100%;
  height: auto;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  margin: 0.8125rem 0;
  -o-object-fit: contain;
     object-fit: contain;
}

@-webkit-keyframes verticalScroll {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  100% {
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}

@keyframes verticalScroll {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  100% {
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}
@-webkit-keyframes verticalScrollReverse {
  0% {
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes verticalScrollReverse {
  0% {
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}