:root {
  --color-black: #333;
  --color-light-black: #575757;
  --color-dark-black: #090909;
  --color-pure-black: #000;
  --color-white: #fff;
  --color-gray: #c9c9c9;
  --color-light-gray: #efefef;
  --color-dark-gray: #909090;
  --color-dark-gray-2: #8e8e8e;
}

.news .parts-btn, .lab .parts-btn, .works .parts-btn, .service .parts-btn, .solution .parts-btn {
  margin: 0 auto;
  transition: 0.3s;
}
@media (hover: hover) {
  .news .parts-btn:where(:-moz-any-link, :enabled, summary):hover, .lab .parts-btn:where(:-moz-any-link, :enabled, summary):hover, .works .parts-btn:where(:-moz-any-link, :enabled, summary):hover, .service .parts-btn:where(:-moz-any-link, :enabled, summary):hover, .solution .parts-btn:where(:-moz-any-link, :enabled, summary):hover {
    opacity: 0.8;
    transform: initial;
  }
  .news .parts-btn:where(:any-link, :enabled, summary):hover, .lab .parts-btn:where(:any-link, :enabled, summary):hover, .works .parts-btn:where(:any-link, :enabled, summary):hover, .service .parts-btn:where(:any-link, :enabled, summary):hover, .solution .parts-btn:where(:any-link, :enabled, summary):hover {
    opacity: 0.8;
    transform: initial;
  }
}

.fv__inner {
  height: -moz-fit-content;
  height: fit-content;
  margin: 0 auto;
  max-width: 1100px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .fv__inner {
    width: 82.98%;
  }
}
.fv__inner.--wide {
  max-width: 1180px;
}
@media screen and (max-width: 767px) {
  .fv__inner.--wide {
    width: 100%;
  }
}
.fv__inner.--full {
  max-width: none;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .fv__inner.--full {
    width: 100%;
  }
}
.fv__video {
  width: 100%;
  height: 100dvh;
  -o-object-fit: cover;
     object-fit: cover;
  position: sticky;
  top: 0;
  left: 0;
  z-index: -1;
}
.fv__video-mask {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--color-black);
  opacity: 0;
}
@media screen and (max-width: 767px) {
  .fv__video.--pc {
    display: none;
  }
}
.fv__video.--sp {
  display: none;
}
@media screen and (max-width: 767px) {
  .fv__video.--sp {
    display: block;
  }
}

.intro {
  background: #020202;
  color: var(--color-white);
  padding: 120px 0 360px;
  text-align: center;
  position: relative;
}
@media screen and (max-width: 767px) {
  .intro {
    padding: 50px 0 360px;
  }
}
.intro::after {
  content: "";
  position: absolute;
  bottom: -100px;
  left: 0;
  width: 100%;
  height: 460px;
  background: linear-gradient(180deg, #020202 0, var(--color-light-gray) 100%);
}
.intro.--animate .textanimation span {
  display: inline-block;
}
.intro.--animate .textanimation > span {
  overflow: hidden;
}
.intro.--animate .textanimation > span > span {
  animation: showTextFromBottom 0.5s backwards;
}
.intro.--animate .intro__text {
  opacity: 1;
}
@keyframes showTextFromBottom {
  0% {
    opacity: 0;
    transform: translateY(100%);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}
.intro__inner {
  height: -moz-fit-content;
  height: fit-content;
  margin: 0 auto;
  max-width: 1100px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .intro__inner {
    width: 82.98%;
  }
}
.intro__inner.--wide {
  max-width: 1180px;
}
@media screen and (max-width: 767px) {
  .intro__inner.--wide {
    width: 100%;
  }
}
.intro__inner.--full {
  max-width: none;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .intro__inner.--full {
    width: 100%;
  }
}
.intro__title {
  font: 500 23px/1.2173913043 "Noto Sans JP", "sans-serif";
  letter-spacing: 1.15px;
  margin-bottom: 8px;
}
@media screen and (max-width: 767px) {
  .intro__title {
    font: 500 15px/1.6666666667 "Noto Sans JP", "sans-serif";
    letter-spacing: 0.75px;
    margin-bottom: 15px;
  }
}
.intro__title br {
  display: none;
}
@media screen and (max-width: 767px) {
  .intro__title br {
    display: block;
  }
}
.intro__text {
  font: 500 15px/1.8666666667 "Noto Sans JP", "sans-serif";
  letter-spacing: 0.75px;
  opacity: 0;
  transition: 0.5s;
  transition-delay: 0.7s;
}
@media screen and (max-width: 767px) {
  .intro__text {
    font: 500 11px/1.6363636364 "Noto Sans JP", "sans-serif";
    letter-spacing: 0;
  }
}
.intro__text.--sm {
  font: 500 13px/2.1538461538 "Noto Sans JP", "sans-serif";
  letter-spacing: 0.65px;
}
@media screen and (max-width: 767px) {
  .intro__text.--sm {
    font: 500 10px/1.8 "Noto Sans JP", "sans-serif";
    letter-spacing: 0.2px;
    margin-top: 10px;
  }
}

.solution {
  position: relative;
  overflow: hidden;
}
.solution__inner {
  height: -moz-fit-content;
  height: fit-content;
  margin: 0 auto;
  max-width: 1100px;
  width: 100%;
  padding: 105px 0 120px;
}
@media screen and (max-width: 767px) {
  .solution__inner {
    width: 82.98%;
  }
}
.solution__inner.--wide {
  max-width: 1180px;
}
@media screen and (max-width: 767px) {
  .solution__inner.--wide {
    width: 100%;
  }
}
.solution__inner.--full {
  max-width: none;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .solution__inner.--full {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .solution__inner {
    padding: 105px 0 60px;
  }
}
.solution__contents {
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 767px) {
  .solution .parts-solution-image {
    order: 2;
    margin-bottom: 86px;
  }
}
.solution__text {
  text-align: center;
  margin: 80px 0;
}
@media screen and (max-width: 767px) {
  .solution__text {
    order: 1;
    margin: 0 0 60px;
  }
}

.service {
  position: relative;
  height: 400dvh;
}
@media screen and (max-width: 767px) {
  .service {
    height: initial;
  }
}
.service .parts-title-sec-top {
  margin: 0 auto 80px;
}
.service__video {
  width: 100%;
  height: 100dvh;
  -o-object-fit: cover;
     object-fit: cover;
  position: sticky;
  top: 0;
  left: 0;
  z-index: -1;
}
.service__video-mask {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #030303;
  opacity: 0.69;
}
.service__inner-wrap {
  margin: -100dvh auto 0;
  padding: 105px 0 120px;
  position: sticky;
  top: 0;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .service__inner-wrap {
    position: relative;
  }
}
.service__inner {
  height: -moz-fit-content;
  height: fit-content;
  margin: 0 auto;
  max-width: 1100px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .service__inner {
    width: 82.98%;
  }
}
.service__inner.--wide {
  max-width: 1180px;
}
@media screen and (max-width: 767px) {
  .service__inner.--wide {
    width: 100%;
  }
}
.service__inner.--full {
  max-width: none;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .service__inner.--full {
    width: 100%;
  }
}
.service__contents {
  position: relative;
  color: var(--color-white);
  height: 404px;
  transform: skewY(-5deg);
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  .service__contents {
    height: initial;
    display: flex;
    flex-direction: column;
    gap: 80px;
  }
}
@media screen and (max-width: 767px) {
  .service__parts-btn-wrap {
    display: none;
  }
}
.service__parts-btn-wrap .parts-btn {
  display: none;
}
.service__parts-btn-wrap .parts-btn.--active {
  display: flex;
}
.service__item {
  display: flex;
  gap: 54px;
  opacity: 0;
  position: absolute;
  transition: 0.3s;
}
@media screen and (max-width: 767px) {
  .service__item {
    flex-direction: column;
    position: relative;
    opacity: 1;
    transition: none;
  }
}
.service__item .parts-btn {
  display: none;
  transition: 0.3s;
}
@media screen and (max-width: 767px) {
  .service__item .parts-btn {
    display: flex;
  }
}
@media (hover: hover) {
  .service__item .parts-btn:where(:-moz-any-link, :enabled, summary):hover {
    opacity: 0.8;
    transform: skewY(5deg);
  }
  .service__item .parts-btn:where(:any-link, :enabled, summary):hover {
    opacity: 0.8;
    transform: skewY(5deg);
  }
}
.service__item.--active {
  opacity: 1;
  transform: translateX(0);
}
.service__item.--prev {
  transform: translateX(-100%);
}
@media screen and (max-width: 767px) {
  .service__item.--prev {
    transform: translateX(0);
  }
}
.service__item.--next {
  transform: translateX(100%);
}
@media screen and (max-width: 767px) {
  .service__item.--next {
    transform: translateX(0);
  }
}
.service__item-num {
  font: 400 44px/1.2954545455 "Caudex", "sans-serif";
  letter-spacing: 0;
}
@media screen and (max-width: 767px) {
  .service__item-num {
    font: 400 34px/1.2941176471 "Caudex", "sans-serif";
  }
}
.service__item-title {
  font: 500 24px/2.0833333333 "Noto Sans JP", "sans-serif";
  letter-spacing: 1.92px;
  margin-bottom: 12px;
}
@media screen and (max-width: 767px) {
  .service__item-title {
    font: 500 18px/2.7777777778 "Noto Sans JP", "sans-serif";
    letter-spacing: 1.44px;
    margin-bottom: 8px;
  }
}

.works {
  min-height: 100dvh;
  position: relative;
}
.works .parts-title-sec-top {
  margin: 0 auto 200px;
}
@media screen and (max-width: 767px) {
  .works .parts-title-sec-top {
    margin: 0 auto 80px;
  }
}
.works__video {
  width: 100%;
  height: 100dvh;
  -o-object-fit: cover;
     object-fit: cover;
  position: sticky;
  top: 0;
  left: 0;
  z-index: -1;
}
.works__video-mask {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--color-black);
  opacity: 0;
}
.works__inner {
  height: -moz-fit-content;
  height: fit-content;
  margin: 0 auto;
  max-width: 1100px;
  width: 100%;
  margin: -100dvh auto 0;
  padding: 105px 0 120px;
}
@media screen and (max-width: 767px) {
  .works__inner {
    width: 82.98%;
  }
}
.works__inner.--wide {
  max-width: 1180px;
}
@media screen and (max-width: 767px) {
  .works__inner.--wide {
    width: 100%;
  }
}
.works__inner.--full {
  max-width: none;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .works__inner.--full {
    width: 100%;
  }
}
.works__contents {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 121px;
  transform: skewY(-5deg);
  transform-origin: left top;
  margin-bottom: 90px;
}
@media screen and (max-width: 767px) {
  .works__contents {
    grid-template-columns: 1fr;
    gap: 40px;
    margin-bottom: 40px;
  }
}
.works__link {
  color: var(--color-white);
  opacity: 0;
  transition: 0.5s;
}
.works__link .hover-has-img__wrap {
  width: 100%;
  height: auto;
  overflow: hidden;
  position: relative;
}
.works__link .hover-has-img__wrap::after {
  content: "";
  background: var(--color-black);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  transition: 0.3s;
}
.works__link .hover-has-img__img {
  transition: 0.3s;
  width: 100%;
}
@media (hover: hover) {
  .works__link:where(:-moz-any-link, :enabled, summary):hover .hover-has-img__wrap::after {
    opacity: 0.2;
  }
  .works__link:where(:any-link, :enabled, summary):hover .hover-has-img__wrap::after {
    opacity: 0.2;
  }
  .works__link:where(:-moz-any-link, :enabled, summary):hover .hover-has-img__img {
    transform: scale(1.1);
  }
  .works__link:where(:any-link, :enabled, summary):hover .hover-has-img__img {
    transform: scale(1.1);
  }
}
@media screen and (max-width: 767px) {
  .works__link.--animate {
    opacity: 1;
  }
}
.works__link.--animate:nth-child(even) {
  opacity: 1;
}
.works__link:nth-child(odd):has(+ .works__link.--animate) {
  opacity: 1;
}
@media screen and (max-width: 767px) {
  .works__link:nth-child(odd):has(+ .works__link.--animate) {
    opacity: initial;
  }
}
.works .hover-has-img__wrap {
  margin-bottom: 4px;
}
.works__title {
  font: 500 16px/1.75 "Noto Sans JP", "sans-serif";
  letter-spacing: 0;
}
@media screen and (max-width: 767px) {
  .works__title {
    font: 500 14px/1.7857142857 "Noto Sans JP", "sans-serif";
    letter-spacing: 1.12px;
  }
}

.lab {
  min-height: 100dvh;
  position: relative;
}
.lab .parts-title-sec-top {
  margin: 0 auto 40px;
}
@media screen and (max-width: 767px) {
  .lab .parts-title-sec-top {
    margin: 0 auto 20px;
  }
}
.lab__video {
  width: 100%;
  height: 100dvh;
  -o-object-fit: cover;
     object-fit: cover;
  position: sticky;
  top: 0;
  left: 0;
  z-index: -1;
}
.lab__video-mask {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #020202;
  opacity: 0.51;
}
.lab__inner {
  height: -moz-fit-content;
  height: fit-content;
  margin: 0 auto;
  max-width: 1100px;
  width: 100%;
  margin: -100dvh auto 0;
  padding: 105px 0 120px;
}
@media screen and (max-width: 767px) {
  .lab__inner {
    width: 82.98%;
  }
}
.lab__inner.--wide {
  max-width: 1180px;
}
@media screen and (max-width: 767px) {
  .lab__inner.--wide {
    width: 100%;
  }
}
.lab__inner.--full {
  max-width: none;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .lab__inner.--full {
    width: 100%;
  }
}
.lab__text {
  color: var(--color-white);
  transform: skewY(-5deg);
}
.lab__contents {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px;
  transform: skewY(-5deg);
  margin: 80px 0;
}
@media screen and (max-width: 767px) {
  .lab__contents {
    grid-template-columns: 1fr;
    margin: 40px 0 20px;
  }
}
.lab__link {
  display: flex;
  flex-direction: column;
  opacity: 0;
  transition: 0.5s;
}
.lab__link .hover-has-img__wrap {
  width: 100%;
  height: auto;
  overflow: hidden;
  position: relative;
}
.lab__link .hover-has-img__wrap::after {
  content: "";
  background: var(--color-black);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  transition: 0.3s;
}
.lab__link .hover-has-img__img {
  transition: 0.3s;
  width: 100%;
}
@media (hover: hover) {
  .lab__link:where(:-moz-any-link, :enabled, summary):hover .hover-has-img__wrap::after {
    opacity: 0.2;
  }
  .lab__link:where(:any-link, :enabled, summary):hover .hover-has-img__wrap::after {
    opacity: 0.2;
  }
  .lab__link:where(:-moz-any-link, :enabled, summary):hover .hover-has-img__img {
    transform: scale(1.1);
  }
  .lab__link:where(:any-link, :enabled, summary):hover .hover-has-img__img {
    transform: scale(1.1);
  }
}
@media screen and (max-width: 767px) {
  .lab__link.--animate {
    opacity: 1;
  }
}
.lab__link:nth-child(1):has(~ .lab__link:nth-child(4).--animate), .lab__link:nth-child(1):has(~ .lab__link:nth-child(8).--animate), .lab__link:nth-child(2):has(~ .lab__link:nth-child(4).--animate), .lab__link:nth-child(2):has(~ .lab__link:nth-child(8).--animate), .lab__link:nth-child(3):has(~ .lab__link:nth-child(4).--animate), .lab__link:nth-child(3):has(~ .lab__link:nth-child(8).--animate), .lab__link:nth-child(5):has(~ .lab__link:nth-child(4).--animate), .lab__link:nth-child(5):has(~ .lab__link:nth-child(8).--animate), .lab__link:nth-child(6):has(~ .lab__link:nth-child(4).--animate), .lab__link:nth-child(6):has(~ .lab__link:nth-child(8).--animate), .lab__link:nth-child(7):has(~ .lab__link:nth-child(4).--animate), .lab__link:nth-child(7):has(~ .lab__link:nth-child(8).--animate) {
  opacity: 1;
}
@media screen and (max-width: 767px) {
  .lab__link:nth-child(1):has(~ .lab__link:nth-child(4).--animate), .lab__link:nth-child(1):has(~ .lab__link:nth-child(8).--animate), .lab__link:nth-child(2):has(~ .lab__link:nth-child(4).--animate), .lab__link:nth-child(2):has(~ .lab__link:nth-child(8).--animate), .lab__link:nth-child(3):has(~ .lab__link:nth-child(4).--animate), .lab__link:nth-child(3):has(~ .lab__link:nth-child(8).--animate), .lab__link:nth-child(5):has(~ .lab__link:nth-child(4).--animate), .lab__link:nth-child(5):has(~ .lab__link:nth-child(8).--animate), .lab__link:nth-child(6):has(~ .lab__link:nth-child(4).--animate), .lab__link:nth-child(6):has(~ .lab__link:nth-child(8).--animate), .lab__link:nth-child(7):has(~ .lab__link:nth-child(4).--animate), .lab__link:nth-child(7):has(~ .lab__link:nth-child(8).--animate) {
    opacity: initial;
  }
}
.lab__link:nth-child(4).--animate, .lab__link:nth-child(8).--animate {
  opacity: 1;
}
.lab__link .hover-has-img__wrap {
  height: 251px;
}
@media screen and (max-width: 767px) {
  .lab__link .hover-has-img__wrap {
    height: auto;
  }
}
.lab__link .hover-has-img__img {
  -o-object-fit: cover;
     object-fit: cover;
  width: auto;
  height: 100%;
}
@media screen and (max-width: 767px) {
  .lab__link .hover-has-img__img {
    width: 100%;
    height: auto;
  }
}
.lab__link-data {
  background: rgba(255, 255, 255, 0.2);
  padding: 15px 21px 21px;
  display: flex;
  flex-direction: column;
  gap: 5px;
  color: var(--color-white);
  flex: 1;
}
@media screen and (max-width: 767px) {
  .lab__link-data {
    background: rgba(0, 0, 0, 0.5);
  }
}
.lab__link-data-date {
  font: 500 11px/2.1818181818 "Noto Sans JP", "sans-serif";
  text-align: right;
  letter-spacing: 0;
}
.lab__link-data-title {
  font: 500 14px/1.7142857143 "Noto Sans JP", "sans-serif";
  letter-spacing: 0.56px;
}

.news {
  min-height: 100dvh;
  position: relative;
}
.news__video {
  width: 100%;
  height: 100dvh;
  -o-object-fit: cover;
     object-fit: cover;
  position: sticky;
  top: 0;
  left: 0;
  z-index: -1;
}
.news__video-mask {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #070707;
  opacity: 0.83;
}
.news__inner {
  height: -moz-fit-content;
  height: fit-content;
  margin: 0 auto;
  max-width: 1100px;
  width: 100%;
  margin: -100dvh auto 0;
  padding: 176px 0 200px;
}
@media screen and (max-width: 767px) {
  .news__inner {
    width: 82.98%;
  }
}
.news__inner.--wide {
  max-width: 1180px;
}
@media screen and (max-width: 767px) {
  .news__inner.--wide {
    width: 100%;
  }
}
.news__inner.--full {
  max-width: none;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .news__inner.--full {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .news__inner {
    padding: 112px 0 100px;
  }
}
.news__contents {
  transform: skewY(-5deg);
  transform-origin: left top;
  display: flex;
  flex-direction: column;
  margin-bottom: 60px;
}
@media screen and (max-width: 767px) {
  .news__contents {
    margin-bottom: 30px;
  }
}
.news__link {
  align-items: center;
  display: flex;
  gap: 10.5px;
  color: var(--color-white);
  padding: 30px 0;
  border-bottom: 1px solid var(--color-white);
  position: relative;
  transition: 0.3s;
}
.news__link .hover-has-img__wrap {
  width: 100%;
  height: auto;
  overflow: hidden;
  position: relative;
}
.news__link .hover-has-img__wrap::after {
  content: "";
  background: var(--color-black);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  transition: 0.3s;
}
.news__link .hover-has-img__img {
  transition: 0.3s;
  width: 100%;
}
@media (hover: hover) {
  .news__link:where(:-moz-any-link, :enabled, summary):hover .hover-has-img__wrap::after {
    opacity: 0.2;
  }
  .news__link:where(:any-link, :enabled, summary):hover .hover-has-img__wrap::after {
    opacity: 0.2;
  }
  .news__link:where(:-moz-any-link, :enabled, summary):hover .hover-has-img__img {
    transform: scale(1.1);
  }
  .news__link:where(:any-link, :enabled, summary):hover .hover-has-img__img {
    transform: scale(1.1);
  }
}
@media screen and (max-width: 767px) {
  .news__link {
    align-items: flex-start;
    flex-direction: column;
    padding: 27px 12px;
  }
}
.news__link:first-child {
  border-top: 1px solid var(--color-white);
}
.news__link .hover-has-img__wrap {
  opacity: 0;
  position: absolute;
  right: clamp(-100px, (100vw - 1180px) / 2 * -1, -40px);
  top: -30px;
  width: 498px;
}
@media screen and (max-width: 767px) {
  .news__link .hover-has-img__wrap {
    position: relative;
    opacity: 1;
    width: 100%;
    right: initial;
    top: initial;
  }
}
@media (hover: hover) {
  .news__link:where(:-moz-any-link, :enabled, summary):hover {
    opacity: 0.8;
    opacity: 1 !important;
  }
  .news__link:where(:any-link, :enabled, summary):hover {
    opacity: 0.8;
    opacity: 1 !important;
  }
  .news__link:where(:-moz-any-link, :enabled, summary):hover .hover-has-img__wrap {
    opacity: 1;
    z-index: 2;
  }
  .news__link:where(:any-link, :enabled, summary):hover .hover-has-img__wrap {
    opacity: 1;
    z-index: 2;
  }
}
.news__link-date {
  font: 500 11px/1.4545454545 "Noto Sans JP", "sans-serif";
  letter-spacing: 0;
}
.news__link-title {
  font: 500 16px/1.5 "Noto Sans JP", "sans-serif";
  letter-spacing: 0;
}
@media screen and (max-width: 767px) {
  .news__link-title {
    font: 500 15px/1.4 "Noto Sans JP", "sans-serif";
    letter-spacing: 0.6px;
  }
}

.parts-contact {
  margin-top: 0;
}/*# sourceMappingURL=style.css.map */