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

@keyframes blink_animation {
  0% {
    opacity: 0;
  }
  10% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

.box1 {
  margin-bottom: 11.55vw;
}

.box-para-pic {
  width: 100%;
  height: 50vw;
  margin: 0 auto 11.6vw;
  background-color: #000;
  overflow: hidden;
  -webkit-transition: opacity 1s ease-out;
  -o-transition: opacity 1s ease-out;
  transition: opacity 1s ease-out;
  opacity: 0;
}

.box-para-pic img {
  position: relative;
  display: block;
}

.box-para-pic.show {
  opacity: 1;
}

.box1-title {
  font-size: 5vw;
  text-align: center;
  font-weight: bold;
  color: #01b577;
  line-height: 1.25;
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
}

.box1-title span {
  color: transparent;
  line-height: inherit;
  background-image: -webkit-gradient(linear, left top, right top, color-stop(50%, #01b577), color-stop(50%, #d4d4d4));
  background-image: -o-linear-gradient(left, #01b577 50%, #d4d4d4 50%);
  background-image: linear-gradient(90deg, #01b577 50%, #d4d4d4 50%);
  background-size: 201% 100%;
  background-position: right center;
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-transition: background-position var(--time) linear;
  -o-transition: background-position var(--time) linear;
  transition: background-position var(--time) linear;
}

.box1-title.show span {
  background-position: left center;
}

.box-content {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  border-top: 1px solid #cccccc;
  padding: 3.36vw 0 0;
  margin-bottom: 34.93vw;
  margin-bottom: 25.93vw;
}

.box-content__left {
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 35%;
      -ms-flex: 0 0 35%;
          flex: 0 0 35%;
}

.box-content__title {
  font-size: 2.5vw;
  font-weight: bold;
  color: #333333;
  margin-top: 0.2vw;
  line-height: 1.35;
  letter-spacing: 0.01em;
}

.box-content__right {
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 65%;
      -ms-flex: 0 0 65%;
          flex: 0 0 65%;
  padding-top: 0.3vw;
}

.box-content__right .box-textarea {
  margin-bottom: 6.86vw;
  margin-bottom: 12.86vw;
}

.box-content__right .box-textarea p {
  line-height: 1.87;
  text-align: justify;
  margin-bottom: 1.88vw;
}

.box-content__right .box-textarea p:last-child {
  margin-bottom: 0;
}

.box-content__right .box-pic {
  margin-bottom: 3.45vw;
}

.box-content__subtitle {
  font-size: 1.75vw;
  color: #333333;
  font-weight: bold;
  margin-bottom: 2.4vw;
}

.box2 {
  margin-bottom: 12.6vw;
}

.box2-link {
  width: 100%;
  height: 9.38vw;
  background-color: #01b577;
  border-radius: 1.2vw;
  overflow: hidden;
}

.box2-link:after {
  content: " ";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background-color: #333333;
  -webkit-transition: -webkit-transform 0.5s cubic-bezier(0.63, 0, 0.45, 1);
  transition: -webkit-transform 0.5s cubic-bezier(0.63, 0, 0.45, 1);
  -o-transition: transform 0.5s cubic-bezier(0.63, 0, 0.45, 1);
  transition: transform 0.5s cubic-bezier(0.63, 0, 0.45, 1);
  transition: transform 0.5s cubic-bezier(0.63, 0, 0.45, 1), -webkit-transform 0.5s cubic-bezier(0.63, 0, 0.45, 1);
  -webkit-transform: translateY(102%);
      -ms-transform: translateY(102%);
          transform: translateY(102%);
}

.box2-link a, .box2-link a:link, .box2-link a:visited {
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  width: 100%;
  height: 100%;
  color: #fff;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  z-index: 1;
}

.box2-link-title {
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 15.54%;
      -ms-flex: 0 0 15.54%;
          flex: 0 0 15.54%;
  text-align: center;
}

.box2-link-title__sub {
  font-size: 0.875vw;
  padding-left: 3.68vw;
  text-align: left;
}

.box2-link-title__main {
  font-size: 1.62vw;
  font-weight: bold;
  letter-spacing: 0.05em;
}

.box2-link-text {
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 84.24%;
      -ms-flex: 0 0 84.24%;
          flex: 0 0 84.24%;
  font-size: 1.25vw;
  letter-spacing: 0.05em;
}

.box2-link-arrow {
  width: 1.88vw;
  position: absolute;
  right: 2.5vw;
  bottom: 2.47vw;
  overflow: hidden;
}

.box2-link-arrow img {
  display: block;
}

.box-pic-area > div {
  width: 72.63%;
  height: 27.5vw;
  border-radius: 3.5vw;
  overflow: hidden;
  -webkit-overflow-scrolling: touch;
  z-index: 1;
}

.box-pic-area > div:nth-child(2) {
  width: 48.42%;
  height: 33.13vw;
  position: absolute;
  right: 0;
  top: 16.8vw;
  margin-top: 28vw;
}

.box-pic-area > div:nth-child(2) img {
  background-color: red;
}

.box-pic-area img {
  position: relative;
  display: block;
  -webkit-transition: top 0.2s ease-out;
  -o-transition: top 0.2s ease-out;
  transition: top 0.2s ease-out;
  -webkit-transform: translate3d(0, 0, 0);
          transform: translate3d(0, 0, 0);
}

@media screen and (min-width: 769px) {
  .box2-link:hover:after {
    -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
            transform: translateY(0);
  }
}

@media screen and (max-width: 768px) {
  .box1 {
    margin-bottom: 24.5vw;
  }
  .box-para-pic {
    width: 112%;
    height: 93.3vw;
    left: -6%;
    margin-bottom: 30.1vw;
  }
  .box1-title {
    font-size: 7.2vw;
    line-height: 1.48;
  }
  .box-content {
    border-top: 0.3vw solid #cccccc;
    padding: 13.4vw 0 0;
    margin-bottom: 68.1vw;
    margin-bottom: 56.1vw;
  }
  .box-content__left {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 100%;
        -ms-flex: 0 0 100%;
            flex: 0 0 100%;
    margin-bottom: 11.2vw;
  }
  .box-content__title {
    font-size: 8vw;
    margin-top: 0;
    line-height: 1.33;
  }
  .box-content__right {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 100%;
        -ms-flex: 0 0 100%;
            flex: 0 0 100%;
    padding: 0;
  }
  .box-content__right .box-textarea {
    margin-bottom: 22.7vw;
  }
  .box-content__right .box-textarea p {
    line-height: 1.61;
    margin-bottom: 5.6vw;
  }
  .box-content__right .box-pic {
    margin-bottom: 6.5vw;
  }
  .box-content__subtitle {
    font-size: 5.06vw;
    margin-bottom: 6.4vw;
  }
  .box2 {
    margin-bottom: 26.6vw;
  }
  .box2-link {
    border-radius: 3vw;
    height: auto;
  }
  .box2-link a, .box2-link a:link, .box2-link a:visited {
    padding-left: 9.6%;
    padding-top: 7vw;
    padding-bottom: 6.7vw;
  }
  .box2-link-title {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 100%;
        -ms-flex: 0 0 100%;
            flex: 0 0 100%;
    text-align: left;
    margin-bottom: 5.2vw;
  }
  .box2-link-title__sub {
    font-size: 3.2vw;
    margin-bottom: 0.7vw;
    padding-left: 0;
  }
  .box2-link-title__main {
    font-size: 4.8vw;
  }
  .box2-link-text {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 100%;
        -ms-flex: 0 0 100%;
            flex: 0 0 100%;
    font-size: 4vw;
    line-height: 1.46;
  }
  .box2-link-arrow {
    width: 4vw;
    right: 8.8%;
    bottom: 8vw;
  }
  .box-pic-area > div {
    width: 82%;
    height: 46.67vw;
    border-radius: 5.8vw;
  }
  .box-pic-area > div:nth-child(2) {
    width: 54.92%;
    height: 56.54vw;
    padding: 0;
    top: 31.1vw;
    margin-top: 40vw;
  }
}
/*# sourceMappingURL=recruit.css.map */
