@charset "UTF-8";
/*========= テキストを滑らかに出現させるためのCSS ===============*/
.smoothText {
  overflow: hidden;
  display: block;
}

/* アニメーションで傾斜がついている文字列を水平に戻す*/
.smoothTextTrigger {
  transition: 2s ease-in-out;
  transform: translate3d(0, 100%, 0) skewY(12deg);
  transform-origin: left;
  display: block;
}

.smoothTextTrigger.smoothTextAppear {
  transform: translate3d(0, 0, 0) skewY(0);
}

/* fadeUp */
.fadeUp {
  -webkit-animation-name: fadeUpAnime;
          animation-name: fadeUpAnime;
  -webkit-animation-duration: 2s;
          animation-duration: 2s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  opacity: 0;
}

@-webkit-keyframes fadeUpAnime {
  from {
    opacity: 0;
    transform: translateY(100px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeUpAnime {
  from {
    opacity: 0;
    transform: translateY(100px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.fadeUpTrigger, .fadeinTrigger {
  opacity: 0;
}

.fadein {
  -webkit-animation-name: fadeinAnime;
          animation-name: fadeinAnime;
  -webkit-animation-duration: 1.5s;
          animation-duration: 1.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  opacity: 0;
}

@-webkit-keyframes fadeinAnime {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes fadeinAnime {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.ani_d01 {
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
}

.ani_d02 {
  -webkit-animation-delay: 0.4s;
          animation-delay: 0.4s;
}

.ani_d03 {
  -webkit-animation-delay: 0.6s;
          animation-delay: 0.6s;
}

.ani_d04 {
  -webkit-animation-delay: 0.8s;
          animation-delay: 0.8s;
}

.ani_d05 {
  -webkit-animation-delay: 1s;
          animation-delay: 1s;
}

.ani_d06 {
  -webkit-animation-delay: 1.2s;
          animation-delay: 1.2s;
}

.company_box.active .crs_img::before, .reserch_box.active .crs_img::before, .sustainability_box.active .crs_img::before {
  transform: translateX(0);
}

.crs_img {
  overflow: hidden;
  position: relative;
}
.crs_img::before {
  background: #fff;
  bottom: 0;
  content: "";
  left: 0;
  pointer-events: none;
  position: absolute;
  right: 0;
  top: 0;
  width: 100%;
  transform: translateX(-100%);
  transition: 0.3s ease-in-out;
  z-index: 4;
}

.eachTextAnime span, .eachTextAnime02 span {
  opacity: 0;
}

.eachTextAnime.appeartext span {
  -webkit-animation: text_anime_on 0.4s ease-out forwards;
          animation: text_anime_on 0.4s ease-out forwards;
}
@media screen and (max-width: 768px) {
  .eachTextAnime.appeartext span {
    -webkit-animation: text_anime_on02 0.4s ease-out forwards;
            animation: text_anime_on02 0.4s ease-out forwards;
  }
}

@-webkit-keyframes text_anime_on {
  0% {
    opacity: 0;
    margin-left: 10px;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 1;
    margin-left: 0px;
  }
}

@keyframes text_anime_on {
  0% {
    opacity: 0;
    margin-left: 10px;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 1;
    margin-left: 0px;
  }
}
.eachTextAnime02.appeartext span {
  -webkit-animation: text_anime_on02 0.4s ease-out forwards;
          animation: text_anime_on02 0.4s ease-out forwards;
}

@-webkit-keyframes text_anime_on02 {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes text_anime_on02 {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.block__pic {
  width: 100%;
}

.scroll_down {
  display: none;
}
@media screen and (max-width: 768px) {
  .scroll_down {
    display: inline-block;
  }
}
.scroll_down a {
  padding-top: 70px;
  position: absolute;
  bottom: 30px;
  z-index: 2;
  display: inline-block;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  text-decoration: none;
  font-size: 1.2rem;
}
.scroll_down a span {
  position: absolute;
  top: 0;
  left: 50%;
  width: 24px;
  height: 24px;
  margin-left: -12px;
  border-left: 1px solid #000;
  border-bottom: 1px solid #000;
  transform: rotate(-45deg);
  -webkit-animation: sdb 1.5s infinite;
  animation: sdb 1.5s infinite;
  box-sizing: border-box;
}
@-webkit-keyframes sdb {
  0% {
    -webkit-transform: rotate(-45deg) translate(0, 0);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    -webkit-transform: rotate(-45deg) translate(-20px, 20px);
    opacity: 0;
  }
}
@keyframes sdb {
  0% {
    transform: rotate(-45deg) translate(0, 0);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    transform: rotate(-45deg) translate(-20px, 20px);
    opacity: 0;
  }
}/*# sourceMappingURL=movement.css.map */