@import url("https://fonts.googleapis.com/css2?family=Oswald:wght@200..700&family=Noto+Sans+JP:wght@100..900&display=swap");
/* override */
/* page style */
.p-home {
  position: relative;
  width: 100vw;
}
.p-home > * {
  position: relative;
  z-index: 2;
}
.p-home .p-video {
  height: 100%;
  left: 0;
  position: absolute;
  top: 44.2967884828vh;
  width: 100vw;
  z-index: 1;
}
@media screen and (max-width: 640px) {
  .p-home .p-video {
    top: 53.6vw;
  }
}
.p-home .p-video > div {
  height: 100vh;
  position: -webkit-sticky;
  position: sticky;
  left: 0;
  top: 0;
  overflow: hidden;
  width: 100vw;
}
.p-home .p-video > div video {
  height: calc(100% + 50px);
  object-fit: cover;
  left: -25px;
  position: relative;
  top: -25px;
  width: calc(100% + 50px);
}
.p-home .p-video-overlay {
  background-color: #1A1A1A;
  height: 100vh;
  left: 0;
  opacity: 0;
  position: absolute;
  top: 0;
  width: 100vw;
}
.p-home .p-mv {
  height: 100vh;
  overflow: hidden;
  margin-bottom: 19.4729136164vw;
  position: relative;
  left: 0;
  top: 0;
  width: 100vw;
}
@media screen and (max-width: 640px) {
  .p-home .p-mv {
    height: calc(100vh - 16vw);
    margin-bottom: 0;
    max-height: 177.7777777778vw;
  }
}
.p-home .p-mv-txt-1 {
  align-items: center;
  background-color: #1A1A1A;
  display: flex;
  height: 44.2967884828vh;
  justify-content: center;
  line-height: 1;
  padding-top: 7.1010248902vw;
  position: relative;
  text-align: center;
  width: 100vw;
}
@media screen and (max-width: 640px) {
  .p-home .p-mv-txt-1 {
    height: 53.6vw;
  }
}
.p-home .p-mv-txt-1:before {
  background: linear-gradient(280.28deg, #1A1A1A 7.63%, #253C6A 83.52%);
  -webkit-mask-image: url('data:image/svg+xml;utf8,<svg width="858" height="400" viewBox="0 0 858 400" fill="%23fff" xmlns="http://www.w3.org/2000/svg"><path d="M204 0L858 0V400H0L204 0Z" /></svg>');
          mask-image: url('data:image/svg+xml;utf8,<svg width="858" height="400" viewBox="0 0 858 400" fill="%23fff" xmlns="http://www.w3.org/2000/svg"><path d="M204 0L858 0V400H0L204 0Z" /></svg>');
  -webkit-mask-size: cover;
          mask-size: cover;
  content: " ";
  display: block;
  height: 100%;
  position: absolute;
  right: 0;
  top: 0;
  width: 62.8111273792vw;
}
@keyframes loopText {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(max(-1566px, -114.6412884334vw));
  }
}
@keyframes loopTextSP {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(max(-739px, -197.0666666667vw));
  }
}
.p-home .p-mv-txt-1 span {
  background: url("../img/home/mv_txt.svg") repeat-x top left/min(1566px, 114.6412884334vw) min(106px, 7.7598828697vw);
  display: block;
  height: min(106px, 7.7598828697vw);
  overflow: hidden;
  position: absolute;
  text-indent: -9999px;
  left: min(-10px, -0.7320644217vw);
  top: 50%;
  width: min(4698px, 343.9238653001vw);
}
.p-home .p-mv-txt-1 span.is-inview {
  animation: loopText 20s linear infinite 1s;
}
@media screen and (max-width: 640px) {
  .p-home .p-mv-txt-1 span {
    background-size: min(739px, 197.0666666667vw) min(50px, 13.3333333333vw);
    height: min(50px, 13.3333333333vw);
    width: min(2217px, 591.2vw);
    top: 25%;
  }
  .p-home .p-mv-txt-1 span.is-inview {
    animation: loopTextSP 20s linear infinite 1s;
  }
}
.p-home .p-mv-txt-2 {
  color: #fff;
  font-size: min(106px, 7.7598828697vw);
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.0732064422vw;
  position: relative;
  text-align: center;
  top: max(-60px, -4.39238653vw);
}
@media screen and (max-width: 640px) {
  .p-home .p-mv-txt-2 {
    font-size: 16vw;
    line-height: 1.1666666667;
    top: max(-80px, -21.3333333333vw);
  }
}
.p-home .p-mv video {
  bottom: 0;
  height: 100%;
  object-fit: cover;
  position: absolute;
  width: 100vw;
}
.p-home .p-business {
  background-color: rgba(26, 26, 26, 0.8);
  color: #fff;
  height: 49.0483162518vw;
  padding-top: 7.6866764275vw;
  position: relative;
  text-align: center;
}
@media screen and (max-width: 640px) {
  .p-home .p-business {
    height: auto;
    margin-bottom: 0;
    padding-bottom: 18.6666666667vw;
    padding-top: 16.5333333333vw;
  }
}
.p-home .p-business:before {
  background: linear-gradient(281.77deg, #1A1A1A 0.66%, #253C6A 85.92%);
  content: " ";
  display: block;
  height: 100%;
  -webkit-mask-image: url('data:image/svg+xml;utf8,<svg width="1250" height="670" viewBox="0 0 1250 670" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M326.684 0H1250V670H0L326.684 0Z" fill="%23000"/></svg>');
          mask-image: url('data:image/svg+xml;utf8,<svg width="1250" height="670" viewBox="0 0 1250 670" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M326.684 0H1250V670H0L326.684 0Z" fill="%23000"/></svg>');
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
          mask-size: 100% 100%;
  opacity: 0.5;
  position: absolute;
  right: 0;
  top: 0;
  width: 91.5080527086vw;
}
@media screen and (max-width: 640px) {
  .p-home .p-business:before {
    -webkit-mask-position: -26.6666666667vw 0;
            mask-position: -26.6666666667vw 0;
    -webkit-mask-size: auto 100%;
            mask-size: auto 100%;
    width: 100vw;
  }
}
.p-home .p-business-ttl {
  font-size: 2.3426061493vw;
  letter-spacing: 0.2342606149vw;
  padding-bottom: 3.074670571vw;
  padding-top: 2.196193265vw;
}
@media screen and (max-width: 640px) {
  .p-home .p-business-ttl {
    font-size: 6.1333333333vw;
    padding-bottom: 6.1333333333vw;
    padding-top: 6.6666666667vw;
    white-space: nowrap;
  }
}
.p-home .p-business-btns {
  display: flex;
  justify-content: center;
  gap: 6.149341142vw;
  padding-top: 4.6120058565vw;
}
@media screen and (max-width: 640px) {
  .p-home .p-business-btns {
    flex-direction: column;
    gap: 5.3333333333vw;
    padding-top: 8.5333333333vw;
  }
}
.p-home .p-business-btns li .c-btn-2 {
  width: 28.5505124451vw;
}
@media screen and (max-width: 640px) {
  .p-home .p-business-btns li .c-btn-2 {
    width: 100%;
  }
}
.p-home .p-company {
  background: url(../img/home/company_bg.jpg) no-repeat 0 0/contain;
  border-radius: 0.7320644217vw;
  height: 39.6046852123vw;
  padding-top: 3.8799414348vw;
}
@media screen and (max-width: 640px) {
  .p-home .p-company {
    background: url(../img/home/company_bg_sp.jpg) no-repeat 0 0/contain;
    height: 144.5333333333vw;
    padding: 16.8vw 6.4vw 0;
    width: 100%;
  }
}
.p-home .p-company-head {
  align-items: center;
  display: flex;
  gap: 1.8301610542vw;
  margin-bottom: 1.317715959vw;
}
@media screen and (max-width: 640px) {
  .p-home .p-company-head {
    flex-direction: column;
  }
}
.p-home .p-company-head p {
  color: #fff;
  line-height: 1.625;
}
@media screen and (max-width: 640px) {
  .p-home .p-company-head p {
    padding-bottom: 5.3333333333vw;
    padding-top: 3.2vw;
  }
}
.p-home .p-case {
  min-height: 49.560761347vw;
  padding-bottom: 6.0761346999vw;
  padding-top: 8.0527086384vw;
  position: relative;
}
@media screen and (max-width: 640px) {
  .p-home .p-case {
    min-height: unset;
    padding-bottom: 17.3333333333vw;
    padding-top: 17.3333333333vw;
  }
}
.p-home .p-case-head p {
  padding-bottom: 1.4641288433vw;
  padding-top: 1.6837481698vw;
  width: 27.0131771596vw;
}
@media screen and (max-width: 640px) {
  .p-home .p-case-head p {
    padding-bottom: 7.4666666667vw;
    padding-top: 5.3333333333vw;
    width: 100%;
  }
}
.p-home .p-case-carousel {
  position: absolute;
  right: 0;
  top: 12.0058565154vw;
  width: 60.2489019034vw;
}
@media screen and (max-width: 640px) {
  .p-home .p-case-carousel {
    left: 0;
    padding-bottom: 8vw;
    position: relative;
    top: unset;
    width: 100vw;
  }
}
.p-home .p-case-carousel .c-cases {
  left: 0;
  position: absolute;
  top: 0;
}
@media screen and (max-width: 640px) {
  .p-home .p-case-carousel .c-cases {
    position: relative;
  }
}
@media screen and (max-width: 640px) {
  .p-home .p-case-carousel .c-case {
    opacity: 1;
    transform: translateY(0);
    width: 74.4vw;
  }
}
@media screen and (max-width: 640px) {
  .p-home .p-case-carousel .slick-track {
    margin-left: 6.4vw;
  }
}
.p-home .p-case-carousel .slick-slider .c-case {
  margin-right: 1.756954612vw;
}
@media screen and (max-width: 640px) {
  .p-home .p-case-carousel .slick-slider .c-case {
    margin-right: 6.4vw;
  }
}
.p-home .p-case-carousel .slick-slider .slick-dots {
  background: rgba(0, 0, 0, 0.2);
  height: 1px;
  display: flex;
  justify-content: space-between;
  margin-top: 6.2225475842vw;
  position: relative;
  width: 51.2445095168vw;
}
@media screen and (max-width: 640px) {
  .p-home .p-case-carousel .slick-slider .slick-dots {
    margin: 9.3333333333vw 6.4vw 0;
    width: unset;
  }
}
.p-home .p-case-carousel .slick-slider .slick-dots li {
  height: 100%;
  position: relative;
  width: 20%;
}
.p-home .p-case-carousel .slick-slider .slick-dots li button {
  height: 100%;
  text-indent: -9999px;
  width: 100%;
}
.p-home .p-case-carousel .slick-slider .slick-dots li.slick-active button {
  background: #5081E8;
}
.p-home .p-recruit {
  background: url(../img/home/recruit_bg.jpg) no-repeat 50% 50%/cover;
  height: 58.1991215227vw;
  padding: 9.663250366vw 0 11.2005856515vw;
  position: relative;
  width: 100%;
}
@media screen and (max-width: 640px) {
  .p-home .p-recruit {
    padding: 16.5333333333vw 0 18.6666666667vw;
    height: unset;
  }
}
.p-home .p-recruit > * {
  position: relative;
}
.p-home .p-recruit:before {
  background: #1A1A1A;
  content: " ";
  display: block;
  height: 100%;
  left: 0;
  opacity: 0.85;
  position: absolute;
  top: 0;
  width: 100%;
}
.p-home .p-recruit p {
  color: #fff;
  padding-top: 2.4158125915vw;
  text-align: center;
}
@media screen and (max-width: 640px) {
  .p-home .p-recruit p {
    padding-top: 5.3333333333vw;
    text-align: left;
  }
}
.p-home .p-recruit-btns {
  display: flex;
  flex-wrap: wrap;
  gap: 2.5622254758vw;
  padding-top: 5.1976573939vw;
}
@media screen and (max-width: 640px) {
  .p-home .p-recruit-btns {
    flex-direction: column;
    gap: 5.3333333333vw;
    padding-top: 8vw;
  }
}
.p-home .p-recruit-btns li {
  width: 25.6222547584vw;
}
@media screen and (max-width: 640px) {
  .p-home .p-recruit-btns li {
    width: 100%;
  }
}
.p-home .p-recruit-btns li a {
  width: 100%;
}/*# sourceMappingURL=home.css.map */