@charset "UTF-8";
/* **************************************


     追加


***************************************/
/*最小値:$value+0.2 → 可変（$value + 0.625vw（画面幅320px:2px, 800px:5px, 1200px:7.5px,2560px:12px））→ 最大値:$value + 1.2*/
/*最小値:$value+0.2 → 可変（$value + 0.625vw（画面幅320px:2px, 800px:5px, 1200px:7.5px,2560px:12px））→ 最大値:$value + 1.2*/
/* =============================================================================


     index


============================================================================= */
.index-nav {
  background: #fff;
}

.index-navbox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 230px;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-right: 200px;
}

.index-nav-logo {
  margin: auto 0;
  width: 160px;
}

.index-nav-list {
  gap: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.index-nav-item {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.index-nav-link {
  font-weight: normal;
  padding: 80px 10px 0;
  position: relative;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
}

.index-nav-link:hover {
  color: #00afec;
}

.index-nav-link:hover:before {
  opacity: 1;
}

.index-nav-link:before {
  background: #00afec;
  content: "";
  height: 80px;
  left: 50%;
  opacity: 0;
  position: absolute;
  top: 0;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  -webkit-transition: 0.2s;
  transition: 0.2s;
  width: 1px;
}

.index-nav-contact {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background: #00afec;
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  font-size: 1rem;
  height: 100%;
  height: 230px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: absolute;
  right: 0;
  text-align: center;
  top: 0;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  width: 145px;
}

.index-nav-contact img {
  width: 60px;
}

.index-nav-contact:hover {
  opacity: 0.7;
}

.mv {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background: transparent url(../asset/images/index/mv.jpg) no-repeat top center/cover;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 50vw;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
  position: relative;
}

.mv-en {
  color: #8dd2d9;
  font-family: "Bebas-Regular", sans-serif;
  font-size: clamp(14.4rem, calc(14.2rem + (0.625vw * 1)), 15.4rem);
  left: 0;
  line-height: 0.8;
  mix-blend-mode: hard-light;
  opacity: 0.6;
  position: absolute;
  top: 0;
}

.mv-en.en02 {
  bottom: 0.05em;
  left: auto;
  right: 0;
  top: auto;
}

.mv-ttl {
  color: #fff;
  font-size: clamp(4.4rem, calc(4.2rem + (0.625vw * 1)), 5.4rem);
  font-weight: bold;
  letter-spacing: 0.3em;
  text-align: center;
  text-shadow: 4px 4px 4px #000000bf;
}

.mv-ttl span {
  margin-left: 1em;
}

.recruit {
  overflow: hidden;
  padding: 40px 0;
  position: relative;
  text-align: right;
}

.recruit-bg-en {
  color: #8dd2d9;
  font-family: "Bebas-Regular", sans-serif;
  font-size: clamp(39.4rem, calc(39.2rem + (0.625vw * 1)), 40.4rem);
  line-height: 0.8;
  margin-left: auto;
  mix-blend-mode: multiply;
  opacity: 0.15;
  position: absolute;
  right: -1em;
  top: 0;
}

.recruit-btn {
  background: transparent url(../asset/images/index/recruit-btn.svg) no-repeat top center/contain;
  display: inline-block;
  height: 180px;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  width: 180px;
}

.recruit-btn:hover {
  background: transparent url(../asset/images/index/recruit-btn_ac.svg) no-repeat top center/contain;
}

/* =============================================================================


     .concept


============================================================================= */
.concept {
  background: transparent url(../asset/images/index/concept_bg.svg) no-repeat top center/cover;
  color: #fff;
  padding: 60px 0;
}

.concept-txt {
  margin-top: 60px;
}

/* =============================================================================


     .works


============================================================================= */
.works {
  background: transparent url(../asset/images/index/works-bg.jpg) no-repeat top center/cover;
  margin: 60px 0;
  overflow: hidden;
  padding: 80px 0;
}

.works-content-btnbox {
  margin-top: 60px;
  text-align: center;
}

.index-btn {
  gap: 20px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  font-size: 1.8rem;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}

.index-btn:hover {
  opacity: 0.7;
}

.index-btn:hover span:before {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}

.index-btn span {
  height: 70px;
  position: relative;
  width: 70px;
}

.index-btn span:after {
  content: "→";
  font-size: 2.4rem;
  left: 50%;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

.index-btn span:before {
  background: transparent url(../asset/images/common/btn-ball_bk.svg) no-repeat top center/contain;
  content: "";
  height: 100%;
  left: 0%;
  position: absolute;
  top: 0%;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  width: 100%;
}

.index-btn.wh span:before {
  background: transparent url(../asset/images/common/btn-ball_wh.svg) no-repeat top center/contain;
}

.works-content {
  gap: 110px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 20px 0;
  max-width: 720px;
  padding: 40px 0;
  position: relative;
}

.works-content:before {
  background: #0a59a8;
  -webkit-clip-path: polygon(0 0, calc(100% - 100px) 0%, 100% 100%, 0% 100%);
          clip-path: polygon(0 0, calc(100% - 100px) 0%, 100% 100%, 0% 100%);
  content: "";
  height: 100%;
  left: calc(590px - 50vw);
  mix-blend-mode: multiply;
  position: absolute;
  top: 0;
  width: calc(50vw - 590px + 100% + 140px);
}

.works-content:nth-of-type(2) {
  margin-left: auto;
}

.works-content:nth-of-type(2):before {
  background: #418eb0;
  -webkit-clip-path: polygon(100px 0%, 100% 0%, 100% 100%, 0% 100%);
          clip-path: polygon(100px 0%, 100% 0%, 100% 100%, 0% 100%);
  left: auto;
  right: calc(590px - 50vw);
}

.works-content:nth-of-type(3):before {
  background: #6fc3ac;
}

.works-bg {
  height: 100%;
  left: calc(590px - 50vw);
  position: absolute;
  top: 0;
  width: calc(50vw - 590px + 100% + 140px);
}

.works-content:nth-of-type(2) .works-bg {
  left: auto;
  right: calc(590px - 50vw);
}

.works-bg:before, .works-bg:after {
  background: #0a59a8;
  -webkit-clip-path: polygon(0 0, calc(100% - 100px) 0%, 100% 100%, 100px 100%);
          clip-path: polygon(0 0, calc(100% - 100px) 0%, 100% 100%, 100px 100%);
  content: "";
  height: 100%;
  left: auto;
  mix-blend-mode: multiply;
  position: absolute;
  width: 120px;
}

.works-content:nth-of-type(2) .works-bg:before,
.works-content:nth-of-type(2) .works-bg:after {
  background: #418eb0;
  -webkit-clip-path: polygon(100px 0%, 100% 0, calc(100% - 100px) 100%, 0% 100%);
          clip-path: polygon(100px 0%, 100% 0, calc(100% - 100px) 100%, 0% 100%);
}

.works-content:nth-of-type(3) .works-bg:before,
.works-content:nth-of-type(3) .works-bg:after {
  background: #6fc3ac;
}

.works-bg:before {
  right: -40px;
}

.works-content:nth-of-type(2) .works-bg:before {
  left: -40px;
  right: auto;
}

.works-bg:after {
  right: -80px;
}

.works-content:nth-of-type(2) .works-bg:after {
  left: -80px;
  right: auto;
}

.works-content-ttlbox,
.works-cotnent-txtbox {
  position: relative;
  z-index: 1;
}

.works-content-ttlimg {
  width: 260px;
}

.works-content-img {
  mix-blend-mode: multiply;
  opacity: 0.9;
  position: absolute;
  width: 70%;
  z-index: 1;
}

@media (max-width: 1228px){
  .mv-en {
    font-size: clamp(9.4rem, calc(9.2rem + (0.625vw * 1)), 10.4rem);
  }
  .mv-ttl {
    font-size: clamp(3.4rem, calc(3.2rem + (0.625vw * 1)), 4.4rem);
  }
  .recruit-bg-en {
    font-size: clamp(29.4rem, calc(29.2rem + (0.625vw * 1)), 30.4rem);
  }
  .works-content {
    gap: 60px;
    max-width: 85%;
  }
  .works-content:before {
    left: -24px;
    width: 95vw;
  }
  .works-content:nth-of-type(2):before {
    right: -24px;
  }
  .works-bg {
    left: -24px;
    width: 95vw;
  }
  .works-content:nth-of-type(2) .works-bg {
    right: -24px;
  }
  .works-content-ttlimg {
    margin: auto;
    width: 200px;
  }
}

@media (max-width: 767px){
  .mv {
    height: 60vw;
    margin-top: 80px;
  }
  .mv-en {
    font-size: clamp(5.4rem, calc(5.2rem + (0.625vw * 1)), 6.4rem);
  }
  .mv-ttl span {
    margin-left: 0;
  }
  .mv-ttl {
    font-size: clamp(2.4rem, calc(2.2rem + (0.625vw * 1)), 3.4rem);
  }
  .recruit {
    padding: 20px 0;
  }
  .recruit-bg-en {
    font-size: clamp(14.4rem, calc(14.2rem + (0.625vw * 1)), 15.4rem);
    right: -1em;
  }
  .recruit-btn {
    height: 100px;
    width: 100px;
  }
  .works-content {
    gap: 30px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    max-width: 100%;
    padding: 40px 0;
    width: 100%;
  }
  .works-content:before {
    -webkit-clip-path: none;
            clip-path: none;
    left: -16px;
    width: 100vw;
  }
  .works-content:nth-of-type(2):before {
    -webkit-clip-path: none;
            clip-path: none;
    right: -16px;
    width: 100vw;
  }
  .works-bg {
    display: none;
  }
}


/*# sourceMappingURL=index.css.map*/