@charset "UTF-8";

/*------------------------------------------------------------------------
.header
------------------------------------------------------------------------*/
.header {

  .header__content {
    background: rgba(255, 255, 255, 0);
  }

  .header-menu__link {
    /*color: #fff;*/
  }
}



/*------------------------------------------------------------------------
.kv
------------------------------------------------------------------------*/
.kv {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: -1;
  picture {
    height: 100vh;
  }
}

.kv__slide {
  /*
  position: absolute;
  width: 100%;
  height: 100vh;
  top: 0;
  left: 0;
  transition: .5s;
  z-index: 1;
  &.is-active {
    z-index: 10;
  }
  */
}

.kv__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.swiper-slide-active .kv__img,
.swiper-slide-duplicate-active .kv__img,
.swiper-slide-prev .kv__img {
  animation: zoomanime 8s linear 0s normal both;
}

@keyframes zoomanime {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.08);
  }
}



  /*------------------------------------------------------------------------
  .kv-progressbar
  ------------------------------------------------------------------------*/
  .kv-progressbar {
    position: absolute;
    right: 5%;
    bottom: 5%;
    width: 100%;
    max-width: 280px;
    height: 1px;
    background: rgba(255,255,255,0.5);
    overflow: hidden;
    z-index: 10;
    @media screen and (max-width: 736px) {
      width: 140px;
      right: 3%;
      bottom: 3%;
    }
  }

  .kv-progressbar__in {
    display: inline-block;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    background: #fff;
    border-radius: 7px;
    transform: scaleX(0);
    transform-origin: left center;
    transition-timing-function: linear;
  }



/*------------------------------------------------------------------------
.kv-read
------------------------------------------------------------------------*/
.kv-read {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  height: 100vh;
  width: var(--site-width);
  margin: 0 auto 0;
  padding: 0 16px 50px;
  @media screen and (max-width: 736px) {
    width: 100%;
    margin-bottom: 0;
  }
}

.kv-read__midashi {
  margin-bottom: 30px;
  color: #fff;
  font-size: 8.8rem;
  font-weight: bold;
  line-height: 1;
  text-shadow: 0 0 20px rgba(0,0,0,0.2);

  width: 0%;

  animation: AnimationTitle 1.2s ease both;
  animation-delay: .5s;
  background: #ffffff;
  background: linear-gradient(90deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 1) 40%, rgba(73, 14, 75, 1) 55%, rgba(180, 225, 20, 1) 80%, rgba(255, 255, 255, 1) 100%);  background-size: 300% 100%;
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  font-feature-settings: initial;
  background-position: 100% 50%;

  overflow: hidden;
  white-space: nowrap;

  @media screen and (max-width: 736px) {
    margin-bottom: min(var(--vw, 1vw) * 30/768 * 100, 30px);
    font-size: calc( var( --vw ) * 12 );
    font-size: clamp(1.4rem, var(--vw, 1vw) * 88/768 * 100, 8.8rem);
  }
}

@keyframes AnimationTitle {
  0% {
    width: 0%;
    background-position: 100% 50%;
  }
  100%{
    width: 100%;
    background-position: 0% 50%
  }
}

.kv-read__txt {
  color: #fff;
  font-size: 1.8rem;
  text-shadow: 0 0 10px rgba(0,0,0,0.15);
  @media screen and (max-width: 736px) {
    font-size: clamp(1.6rem, var(--vw, 1vw) * 18/768 * 100, 1.8rem)
  }
}



/*------------------------------------------------------------------------
.intro-message-bg
------------------------------------------------------------------------*/
.intro-message-bg {
  background-image: linear-gradient(180deg,rgba(242, 242, 242, 0) 0%, rgba(242, 242, 242, 0.5) 10%, rgba(242, 242, 242, 1) 25%, rgba(242, 242, 242, 1) 100%);
  @media screen and (max-width: 736px) {
  }
}



/*------------------------------------------------------------------------
.intro
------------------------------------------------------------------------*/
.intro {
  padding-top: 400px;
  padding-bottom: 200px;
  text-align: center;
  @media screen and (max-width: 736px) {
    position: relative;
    padding-top: min(var(--vw, 1vw) * 200/768 * 100, 200px);
    padding-bottom: min(var(--vw, 1vw) * 126/768 * 100, 126px);
  }
}

.intro__inner {
  position: relative;
  width: var(--site-width);
  margin: 0 auto;
  @media screen and (max-width: 736px) {
    position: static;
    width: 100%;
    padding: 0 24px;
  }
}

.intro__txt1 {
  font-size: 2rem;
  @media screen and (max-width: 736px) {
    font-size: clamp(1.7rem, var(--vw, 1vw) * 24/768 * 100, 2.4rem)
  }
}

.intro__txt2 {
  font-size: 2rem;
  @media screen and (max-width: 736px) {
    font-size: clamp(1.7rem, var(--vw, 1vw) * 24/768 * 100, 2.4rem)
  }
}

.intro__link {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  max-width: 345px;
  width: 100%;
  height: 44px;
  margin: 20px auto 0;
  color: #fff;
  background-color: #000;
  &::after {
    display: block;
    content: "";
    width: 12px;
    height: 12px;
    background-image: url(/static/img/icon/icon_target_blank_white.svg);
  }
}


  /*------------------------------------------------------------------------
  .intro-box
  ------------------------------------------------------------------------*/
  .intro-box {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 16px;
    align-items: center;
    justify-content: center;
    margin: 24px 0;
    @media screen and (max-width: 736px) {
      width: 100%;
    }
  }

  .intro-box__word {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: 462px;
    height: 52px;
    padding: 0 12px;
    color: #fff;
    font-size: 2.8rem;
    font-weight: bold;
    background-color: var(--purple);
    @media screen and (max-width: 736px) {
      justify-content: center;
      font-size: clamp(2rem, var(--vw, 1vw) * 24/768 * 100, 2.8rem);
      line-height: 1.3;
      text-align: center;
    }
  }



/*------------------------------------------------------------------------
.topmessage
------------------------------------------------------------------------*/
.topmessage {
  padding-bottom: 120px;
  @media screen and (max-width: 736px) {}
}

.topmessage__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: var(--site-width);
  margin: 0 auto;
  @media screen and (max-width: 736px) {
    width: 100%;
    display: block;
    padding: 0 24px;
  }
}

.topmessage__left {
  @media screen and (max-width: 736px) {
    margin-bottom: min(var(--vw, 1vw) * 72/768 * 100, 72px);
  }
}

.topmessage__right {
  margin-right: -48px;
  @media screen and (max-width: 736px) {
    margin-right: 0;
  }
}

.topmessage__midashi {
  margin-bottom: 24px;
  font-size: 7.2rem;
  font-weight: bold;
  line-height: 1.1;
  color: #333;
  @media screen and (max-width: 736px) {
    font-size: min(var(--vw, 1vw) * 64/768 * 100, 6.4rem);
  }
}

.topmessage__txt {
  margin-bottom: 48px;
  line-height: 2;
  letter-spacing: 1.5px;
  @media screen and (max-width: 736px) {
    margin-bottom: min(var(--vw, 1vw) * 48/768 * 100, 48px);
  }
}

.topmessage__box {
  @media screen and (max-width: 736px) {}
}

.topmessage__box-link {
  display: flex;
  align-items: center;
  justify-content: center;
  @media screen and (max-width: 736px) {}
}

.topmessage__img {
  @media screen and (max-width: 736px) {
    width: 100%;
  }
}



/*------------------------------------------------------------------------
.ourbusiness
------------------------------------------------------------------------*/
.ourbusiness {
  position: relative;
}

.ourbusiness__inner {
  position: absolute;
  width: var(--site-width);
  height: 100%;
  left: 0;
  right: 0;
  margin: auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  @media screen and (max-width: 736px) {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 100%;
    padding: 0 24px;
  }
}

.ourbusiness__midashi {
  margin-bottom: 70px;
  font-size: 7.2rem;
  line-height: 1.1;
  font-weight: bold;
  @media screen and (max-width: 736px) {
    margin-bottom: min(var(--vw, 1vw) * 36/768 * 100, 36px);
    font-size: min(var(--vw, 1vw) * 64/768 * 100, 6.4rem);
  }
}

.ourbusiness__txt {
  margin-bottom: 120px;
  line-height: 2;
  letter-spacing: 1.5px;
}

.ourbusiness__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  max-height: 800px;
  min-height: 550px;
  @media screen and (max-width: 736px) {
    height: min(var(--vw, 1vw) * 768/768 * 100, 768px);
  }
}



/*------------------------------------------------------------------------
.interview-faq-bg
------------------------------------------------------------------------*/
.interview-faq-bg {
  padding-top: 85px;
  background-color: #a9a2a9;
  background-image: url(/static/img/top/interview_faq_bg.png);
  background-position: center bottom;
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-blend-mode: multiply;
  @media screen and (max-width: 736px) {
    padding-top: min(var(--vw, 1vw) * 128/768 * 100, 128px);
  }
}



/*------------------------------------------------------------------------
.interview
------------------------------------------------------------------------*/
.interview {
  margin-bottom: 120px;
  @media screen and (max-width: 736px) {
    margin-bottom: min(var(--vw, 1vw) * 120/768 * 100, 120px);
  }
  .box-link__txt {
    width: 374px;
    @media screen and (max-width: 736px) {
      width: auto;
      padding: 0 40px 0 20px;
    }
  }
}

.interview__inner {
  min-width: var(--site-width);
  margin: 0 auto;
  overflow: hidden;
  @media screen and (max-width: 736px) {
    min-width: 100%;
    padding: 0 24px;
  }
}

.interview__top {
  width: var(--site-width);
  display: flex;
  justify-content: space-between;
  margin: 0 auto 50px;
  @media screen and (max-width: 736px) {
    display: block;
    width: 100%;
  }
}

.interview__midashi {
  margin-right: 56px;
  font-size: 7.2rem;
  font-weight: bold;
  color: #fff;
  line-height: 1.1;
  @media screen and (max-width: 736px) {
    margin-bottom: min(var(--vw, 1vw) * 34/768 * 100, 34px);
    font-size: min(var(--vw, 1vw) * 72/768 * 100, 7.2rem);
  }
}

.interview-slide {
  overflow: visible !important;
}

.interview-slide-wrapper {}

.interview-slide__block {
  width: 332px;
  opacity: .4;
  transition: .5s;
  &.swiper-slide-active {
    opacity: 1;
    .interview-slide__img {
      display: inline-block;
      transform: rotateY(0deg) scale(1);
    }
    .interview-slide__title,
    .interview-slide__meta {
      opacity: 1;
      @media screen and (max-width: 736px) {
        opacity: 1;
      }
    }
  }
  &.swiper-slide-prev {
    opacity: 1;
    @media screen and (max-width: 736px) {
      opacity: .4;
    }
    .interview-slide__img {
      display: inline-block;
      transform: perspective(400px) rotateY(3deg) scale(1.02);
    }
    .interview-slide__title,
    .interview-slide__meta {
      opacity: 1;
      @media screen and (max-width: 736px) {
        opacity: 0;
      }
    }
  }
  &.swiper-slide-next {
    opacity: 1;
    @media screen and (max-width: 736px) {
      opacity: .4;
    }
    .interview-slide__img {
      display: inline-block;
      transform: perspective(400px) rotateY(-3deg) scale(1.02);
    }
    .interview-slide__title,
    .interview-slide__meta {
      opacity: 1;
      @media screen and (max-width: 736px) {
        opacity: 0;
      }
    }
  }
}

.interview-slide__link {
  display: block;
}

.interview-slide__img-wrapper {
  position: relative;
  &::after {
    position: absolute;
    right: 26px;
    bottom: 26px;
    content: "";
    display: block;
    width: 14px;
    height: 14px;
    background-repeat: no-repeat;
    background-image: url(/static/img/icon/icon_arrow1.svg);

  }
}

.interview-slide__img {
  width: 100%;
  border-radius: 20px;
  transform: rotateY(0deg) scale(1.04);
  transition: .5s;
}

.interview-slide__title {
  opacity: 0;
  margin-top: 20px;
  margin-bottom: 12px;
  font-size: 1.8rem;
  font-weight: bold;
  transition: .5s;
  @media screen and (max-width: 736px) {
    font-size: clamp(1.6rem, var(--vw, 1vw) * 18/768 * 100, 1.8rem);
  }
}

.interview-slide__meta {
  opacity: 0;
  transition: .5s;
}


.swiper-button-next, .swiper-button-prev {
  width: 56px;
  height: 56px;
  background-color: #fff;
  border-radius: 50%;
  margin-top: -76px;
  @media screen and (max-width: 736px) {
    top: auto;
    bottom: min(var(--vw, 1vw) * 100/768 * 100, 100px);
    width: min(var(--vw, 1vw) * 70/768 * 100, 70px);
    height: min(var(--vw, 1vw) * 70/768 * 100, 70px);
  }
  &::after {
    display: block;
    width: 15px;
    height: 15px;
    content: "";
    background-image: url(/static/img/icon/icon_arrow3.svg);
    background-repeat: no-repeat;
  }
}

.swiper-button-next {
  right: 32px;
  @media screen and (max-width: 736px) {
    right: 0;
  }
}

.swiper-button-prev {
  left: 32px;
  @media screen and (max-width: 736px) {
    left: 0;
  }
  &::after {
  transform: rotate(180deg);
}}

/*------------------------------------------------------------------------
.faq
------------------------------------------------------------------------*/
.faq {
  padding-bottom: 120px;
  @media screen and (max-width: 736px) {
    padding-bottom: min(var(--vw, 1vw) * 120/768 * 100, 120px);
  }
  .box-link {
    float: right;
    clear: both;
  }
}

.faq__inner {
  display: flex;
  width: var(--site-width);
  margin: 0 auto;
  @media screen and (max-width: 736px) {
    width: 100%;
    display: block;
    padding: 0 24px;
  }
}

.faq__midashi {
  margin-right: 56px;
  font-size: 7.2rem;
  font-weight: bold;
  color: #fff;
  line-height: 1.1;
  @media screen and (max-width: 736px) {
    margin-bottom: min(var(--vw, 1vw) * 56/768 * 100, 56px);
    font-size: min(var(--vw, 1vw) * 72/768 * 100, 7.2rem);
  }
}

.faq__right {
  width: 100%;
}

.faq__ul {
  margin-bottom: 32px;
}

.faq__li {
  position: relative;
  padding: 24px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.8);
  cursor: pointer;
  &:last-child {
    border-bottom: 1px solid rgba(255, 255, 255, 0.8);
  }
  &.is-open {
    &::after {
      transform: rotate(0deg);
    }
    .faq__a {
      display: block;

    }
  }
  &::before {
    position: absolute;
    top: 50%;
    right: 12px;
    display: block;
    content: "";
    width: 20px;
    height: 1px;
    background-color: rgba(255, 255, 255, 0.8);
    @media screen and (max-width: 736px) {
    }
  }
  &::after {
    position: absolute;
    top: 50%;
    right: 12px;
    display: block;
    content: "";
    width: 20px;
    height: 1px;
    background-color: rgba(255, 255, 255, 0.8);
    transform: rotate(90deg);
    transition: .5s;
    @media screen and (max-width: 736px) {
    }
  }
}

.faq__q {
  position: relative;
  padding-left: 60px;
  color: #fff;
  line-height: 2.4;
  @media screen and (max-width: 736px) {
    padding-right: 45px;
    line-height: 1.8;
  }
}

.faq__a {
  display: none;
  position: relative;
  margin-top: 12px;
  padding: 0 60px 0;
  color: #fff;
  a {
    color: #fff;
    text-decoration: underline;
    text-underline-offset: 3px;
  }
  @media screen and (max-width: 736px) {
    padding-right: 45px;
  }
}

.faq__mark {
  position: absolute;
  left: 0;
  top: 0;
  margin-left: 12px;
  margin-right: 12px;
  font-size: 4rem;
  color: #fff;
  opacity: 0.8;
  line-height: 1;
  @media screen and (max-width: 736px) {
    top: 2px;
    font-size: clamp(2.8rem, var(--vw, 1vw) * 40/768 * 100, 4rem);
  }
}



