@charset "utf-8";
:root {
  --vc-purple: #b478aa;
  --vc-orange: #f0786e;
  --vc-blue: #0d64b0;
  --vc-pink: #e38aa7;
  --vc-gray: #788296;
  --vc-brown: #a58c78;
}

.content-outer {
  max-width: 1080px;
  margin-top: 128px;
  margin-inline: auto;
  margin-bottom: 128px;
  padding-inline: 40px;
  @media screen and (max-width: 768px) {
    padding-inline: 16px;
    margin-top: 64px;
    margin-bottom: 80px;
  }
}

.sec-intro {
  max-width: 900px;
  margin-inline: auto;
  margin-bottom: 128px;
  @media screen and (max-width: 768px) {
    margin-bottom: 56px;
  }
  
  .head-text__unit {
    margin-bottom: 0;
    .head {
      position: relative;
      font-size: 3.2rem;
      @media screen and (max-width: 768px) {
        font-size: 1.8rem;
      }
      &::before {
        top: initial;
        bottom: -16px;
      }
    }
  }
}

.intro-head {
  position: relative;
  width: fit-content;
  font-size: 3.2rem;
  font-weight: 700;
  text-align: center;
  margin-inline: auto;
}

.link-list {
  max-width: 1040px;
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
}

.link-item {
  display: flex;
  flex-direction: column;
  gap: 30px;
  width: calc(calc(100% - 80px) / 3);
  @media screen and (max-width: 768px) {
    width: auto;
    gap: 24px;
  }
  .item-link {
    position: relative;
    
    @media (any-hover: hover) {
      &:hover{
        a { opacity: 1; }
        .arrow {
          right: 16px;
        }
        img {
          scale: 1.1;
        }
      }
    }
  }
  .item-img {
    display: block;
    position: relative;
    background: var(--white);
    box-shadow: 2px 0px 6px rgba(0, 0, 0, 0.15);
    border-radius: 64px;
    overflow: hidden;

    img {
      position: relative;
      left: 50%;
      translate: -50% 0;
      scale: 1;
      top: 4px;
      transition: ease 300ms scale;
    }
  }
  .arrow {
    position: absolute;
    width: 50px;
    height: 40px;
    line-height: 1;
    display: grid;
    place-content: center;
    background-color: var(--lime);
    border-radius: 50vmax;
    border: 1px solid var(--black);
    right: 32px;
    bottom: -16px;
    transition: ease 300ms right;

    &::before {
      content: "";
      position: absolute;
      width: 6px;
      aspect-ratio: 1;
      border-right: 2px solid var(--black);
      border-bottom: 2px solid var(--black);
      rotate: -45deg;
      top: 50%;
      right: 16px;
      translate: 0 -50%;
      z-index: 1;
    }
    &::after {
      content: "";
      position: absolute;
      width: 12px;
      height: 2px;
      top: 50%;
      translate: 0 -50%;
      background: var(--black);
      right: 22px;
      z-index: 1;
    }
  }
  .item-prof {
    display: flex;
    flex-direction: column;
    gap: 50px;
    @media screen and (max-width: 768px) {
      gap: 36px;
    }
    .name {
      position: relative;
      font-size: 2.4rem;
      font-weight: 700;
      @media screen and (max-width: 768px) {
        font-size: 1.8rem;
      }
      &::before {
        content: "";
        position: absolute;
        width: 50px;
        height: 1px;
        background: var(--black);
        bottom: -20px;
        left: 0;
        translate: 0 -50%;
        z-index: 1;
      }
    }
  }

  &.purple .item-img {
    border: 2px solid var(--vc-purple);
  }
  &.orange .item-img {
    border: 2px solid var(--vc-orange);
  }
  &.blue .item-img {
    border: 2px solid var(--vc-blue);
  }
  &.pink .item-img {
    border: 2px solid var(--vc-pink);
  }
  &.gray .item-img {
    border: 2px solid var(--vc-gray);
  }
  &.brown .item-img {
    border: 2px solid var(--vc-brown);
  }
}


/* -- インタビューページ下層 -- */
.voice-lowerPage {

  .fv {
    container-type: inline-size;
  }

  .fv-cont {
    position: absolute;
    top: 58.5%;
    translate: 0 -50%;
    left: 9.25cqw;
    z-index: 5;
    @media screen and (max-width: 560px) {
      /* top: 34.5%; */
      top: 40.5%;
      left: 5.25cqw;
    }

    .fv-info {
      display: flex;
      flex-direction: column;
    }

    .fv-head {
      position: relative;
      font-size: clamp(1.3rem, 3vw, 2rem);
      font-weight: 700;
      line-height: 1.5;
      margin-bottom: 16px;
      @media screen and (max-width: 560px) {
        font-size: 4.26666cqw;
      }

      span {
        display: block;
      }
    }

    .en {
      position: relative;
      width: fit-content;
      font-family: var(--font-roboto);
      font-size: clamp(1.4rem, 3.5vw, 2.4rem);
      font-weight: 500;
      @media screen and (max-width: 560px) {
        font-size: 5.33334cqw;
      }
      &::before {
        content: "";
        position: absolute;
        border: 0.4cqw var(--lime) solid;
        width: 102%;
        height: 32%;
        top: 1cqw;
        left: -2.5%;
        z-index: -1;
        transition: ease 300ms opacity;
        @media screen and (max-width: 560px) {
          border: 1cqw var(--lime) solid;
          width: 100%;
          height: 32%;
          top: 2.75cqw;
          left: -2.5%;
        }
      }
    }

    .num {
      font-family: var(--font-roboto);
      font-size: clamp(3.6rem, 10vw, 7.2rem);
      font-weight: 500;
      color: var(--black);
      line-height: 1;
      @media screen and (max-width: 560px) {
        font-size: 18.6cqw;
      }
    }
    .name {
      font-size: clamp(1.2rem, 3vw, 2.4rem);
      font-weight: 700;
      @media screen and (max-width: 560px) {
        font-size: 4.26667cqw;
      }
    }
    .text {
      font-size: clamp(1.2rem, 2vw, 1.6rem);
      @media screen and (max-width: 560px) {
        font-size: 3.2cqw;
      }
    }
    .note {
      margin-top: 8px;
      font-size: 1rem;
      @media screen and (max-width: 560px) {
        font-size: 2.66667cqw;
      }
    }
  }

  .interview-list {
    display: grid;
    grid-auto-columns: 1fr;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows:repeat(2, 1fr);
    gap: 24px;
    padding-inline: 20px;
    @media screen and (max-width: 768px) {
      grid-auto-columns: 1fr;
      grid-template-columns: repeat(1, 1fr);
      grid-template-rows:repeat(1, 1fr);
      padding-inline: 0;
    }
  }

  .interview-item {
    border-radius: 64px;
    padding: 48px 40px;
    @media screen and (max-width: 768px) {
      padding: 32px 24px;
      border-radius: 32px;
    }

    .head-text__unit {
      gap: 56px;
      margin-bottom: 0;
      @media screen and (max-width: 768px) {
        gap: 32px;
      }
      @media screen and (max-width: 768px) {
        .head::before {
          bottom: -16px;
        }
      }
    }

    &.purple {
      background: rgb(180 120 170 / .2);
      .head::before {
        background-color: var(--purple);
      }
    }
    &.pink {
      background: rgb(240 120 110 / .2);
      .head::before {
        background-color: #f0786e;
      }
    }
    &.blue {
      background: rgb(13 100 176 / .2);
      .head::before {
        background-color: var(--blue);
      }
    }
    &.gray {
      background: rgb(165 140 120 / .2);
      .head::before {
        background-color: var(--gray);
      }
    }
  }

    .sibling-links {
    @media screen and (max-width: 768px) {
      padding-inline: 0;
    }
    .sibling-outer .block-list__item .img-outer {
      @media screen and (max-width: 768px) {
        filter: none;
        border-radius: 48px;
      }
    }
  }

  .sibling-links.slider-links .js-slider .swiper {
    @media screen and (max-width: 768px) {
        padding-inline: 0;
      .head-text__unit {
        text-align: center;
      }
    }
  }

}


.lowerPage .fv .fv-img::before {
  background-image: initial;
}

@media screen and (max-width: 550px) {
  .lowerPage .fv .fv-heading {
    top: 50%;
    left: 50%;
    translate: -50% -50%;
    width: max-content;
  }
}

@media screen and (min-width: 769px) {
  #voice .fv-deco .triangle[data-num=tri03] {
    top: 8%;
  }

  #voice .fv .fv-deco .triangle[data-num=tri07] {
    right: 17%;
  }
  #voice .fv .fv-deco .triangle.-show[data-num=tri07] {
    right: 16%;
  }
}