@charset "UTF-8";

/* home-mv
------------------------------------------- */
.home-mv {
  position: relative;
  height: calc(100vh - 90px);
}
@media only screen and (min-width: 768px) {
  .home-mv {
    height: calc(100vh - 90px) !important;
  }
  }
.home-mv::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background: rgba(0, 0, 0, 0.3);
}
.home-mv__img {
  width: 100%;
  height: 100%;
}
.home-mv__catch {
  width: 700px;
  padding: 0 20px;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
}
.home-mv__catch-text {
  color: #fff;
  text-align: center;
}
.home-mv__catch-en {
  font-size: 2.5rem;
  font-style: italic;
  letter-spacing: 0.5em;
  text-indent: 0.5em;
  display: block;
  margin-bottom: 20px;
}
.home-mv__catch-en .md {
  font-size: 2.8rem;
}
.home-mv__catch-ja {
  display: block;
}



.home-mv__scroll {
  height: 85px;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
}
.home-mv__scroll a {
  display: block;
}
.home-mv__scroll .text {
  position: absolute;
  left: 0;
  top: -15px;
  color: #fff;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  white-space: nowrap;
  transform: translate(-50%, -100%);
}

.home-mv__scroll:before {
  content: "";
  position: absolute;
  bottom: 0;
  left: -4px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background:#fff;
  animation:
    circlemove 2s ease-in-out infinite,
    cirlemovehide 2s ease-out infinite;
}

@keyframes circlemove {
  0%   { bottom: 80px; }
  100% { bottom: -5px; }
}

@keyframes cirlemovehide {
  0%   { opacity: 0 }
  50%  { opacity: 1; }
  80%  { opacity: 0.9; }
  100% { opacity: 0; }
}

.home-mv__scroll:after {
  content:"";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 1px;
  height: 100%;
  background:#fff;
}


/* home-section
------------------------------------------- */
.home-section__title .title-icon {
  display: block;
  width: 20px;
  height: 20px;
  background: url("../img/icon_title.png") no-repeat center center / 100% auto;
  margin: 0 auto 10px;
}
.home-section__title-wh .title-icon {
  background-image: url("../img/icon_title_wh.png");
}
.home-section__title-wh {
  color: #fff;
}
.home-section__title .title-en {
  display: block;
  font-size: 3.2rem;
  letter-spacing: 0.5em;
  text-indent: 0.5em;
  line-height: 1.4;
}
.home-section__title .title-ja {
  display: block;
  line-height: 1.4;
}


/* home-service
------------------------------------------- */
.home-service__list {
  padding: 0 15px;
}
.home-service__list .item {
  width: 33.33%;
  padding: 0 15px;
}
.home-service__list .item-img {
  position: relative;
  overflow: hidden;
}
.home-service__list .item-img::after {
  content: "";
  display: inline-block;
  width: 60px;
  height: 60px;
  background: url("../img/icon_bnr_arw.png") no-repeat left top / 100% auto;
  position: absolute;
  right: 0;
  bottom: 0;
}
.home-service__list .item img {
  transform: scale(1);
  transition: transform .6s;
}
.home-service__list .item a:hover img {
  transform: scale(1.2);
}
.home-service__list .item-text {
  text-align: center;
  margin-top: 10px;
  font-size: 2.2rem;
  line-height: 1.4;
}
.home-service__list .item-text .sm {
  display: block;
  font-size: 1.6rem;
  line-height: 1.4;
  margin-top: 3px;
}


/* home-works
------------------------------------------- */
.home-works__list .slick-list {
  max-width: 1150px;
  margin: auto;
  overflow: visible;
}
.home-works__list .slick-arrow {
  border: none;
}
.home-works__list .item {
  padding: 0 15px;
}
.home-works__list .item-img {
  position: relative;
  overflow: hidden;
  height: 220px;
}
.home-works__list .item img {
  transform: scale(1);
  transition: transform .6s;
}
.home-works__list .item a:hover img {
  transform: scale(1.2);
}
.home-works__list .item-info {
  margin-top: 10px;
}
.home-works__list .item-date {
  line-height: 1.2;
}
.home-works__list .item-date::after {
  content: "";
  display: inline-block;
  background: #B1B1B1;
  width: 1px;
  height: 15px;
  margin: 0 10px;
  vertical-align: middle;
  position: relative;
  top: -2px;
}
.home-works__list .item-cat {
  font-size: 1.3rem;
  line-height: 1.4;
}
.home-works__list .item-text {
  margin-top: 5px;
}


/* home-reasons
------------------------------------------- */
.home-reasons {
  background: url("../img/home_reasons_bg.jpg") no-repeat center center / cover;
  position: relative;
}
.home-reasons::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background: rgba(0, 0, 0, 0.3);
}
.home-reasons__inner {
  position: relative;
  z-index: 1;
}

.home-reasons__list {
  margin-left: -20px;
  margin-right: -20px;
}
.home-reasons__list .box {
  width: 33.33%;
  padding: 20px;
  color: #fff;
}
.home-reasons__list .box-dt,
.home-reasons__list .box-title {
  text-align: center;
}
.home-reasons__list .box-title {
  font-size: 1.8rem;
  margin-top: 15px;
}
.home-reasons__list .box-dt {
  line-height: 1;
}
.home-reasons__list .box-dt .en {
  display: block;
  letter-spacing: 0.25em;
}
.home-reasons__list .box-dt .num {
  display: block;
  letter-spacing: 0.1em;
  font-size: 5rem;
  margin-top: 5px;
}
.home-reasons__list .box-dd {
  line-height: 1.6;
}
.home-reasons__list .box-text {
  margin-top: 20px;
}





/* home-recruit
------------------------------------------- */
.home-recruit {
  background: url("../img/home_recruit_bg.jpg") no-repeat center center / cover;
  position: relative;
}
.home-recruit::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background: rgba(0, 0, 0, 0.3);
}
.home-recruit__inner {
  position: relative;
  z-index: 1;
}


/* bottom-bnr
------------------------------------------- */
.bottom-bnr__list {
  padding: 0 60px;
}
.bottom-bnr__list .item {
  padding: 0 10px;
}
.bottom-bnr__list .item-text {
  font-size: 1.2rem;
  margin-top: 5px;
}
.bottom-bnr__list .item img {
  transition: opacity .2s;
}
.bottom-bnr__list .item a:hover img {
  opacity: 0.7;
}


/* @media max-767
------------------------------------------- */
@media only screen and (max-width: 767px) {

  .home-mv {
    height: calc(100vh - 70px);
    min-height: 600px;
  }
  .home-mv__catch {
    max-width: 450px;
    width: 100%;
  }
  .home-mv__catch-en {
    font-size: 1.8rem;
  }


  .home-section__title .title-en {
    font-size: 2.6rem;
  }

  .home-service__contents {
    margin-top: 30px;
  }
  .home-service__list {
    padding: 0;
  }
  .home-service__list .item {
    width: 100%;
    padding: 15px 20px;
  }
  .home-service__list .item-text {
    font-size: 1.8rem;
  }
  .home-service__list .item-text .sm {
    font-size: 1.4rem;
  }

  .home-works__list .item {
    padding: 0 10px;
  }
  .home-works__list .item-img {
  }

  .home-reasons {
    background-size: 500em;
  }
  .home-reasons__list {
    margin-left: 0;
    margin-right: 0;
  }
  .home-reasons__list .box {
    width: 100%;
    padding: 20px 0;
  }
  .home-reasons__list .box:last-child {
    padding-bottom: 0;
  }
  .home-reasons__list .box-title {
    font-size: 1.6rem;
  }



  .home-recruit {
    background-image: url("../img/home_recruit_bg_sp.jpg");
  }

  .bottom-bnr__inner {
    padding: 0;
  }
  .bottom-bnr__list {
    padding: 0;
    padding-bottom: 30px;
  }
  .bottom-bnr__list.slick-dotted.slick-slider {
    padding-bottom: 30px;
    margin-top: 20px;
    margin-bottom: 20px;
  }

}