@charset "utf-8";

.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;
  }
}


.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;
  }
  .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;
    @media screen and (max-width: 768px) {
      border-radius: 48px;
    }

    img {
      position: relative;
      left: 50%;
      translate: -50% 0;
      scale: 1;
      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: 34px;
    }
    .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;
      }
    }
  }
}

/* -- インタビューページ下層 -- */
.interview-lowerPage {

  .fv {
    container-type: inline-size;
  }

  .fv-wrap{
    @media screen and (max-width: 560px) {
      display: grid;
      grid-template-columns: 1fr;
      grid-template-rows: 1fr;
    }
  }

  .fv-cont {
    position: absolute;
    top: 58.5%;
    translate: 0 -50%;
    left: 6.25cqw;
    z-index: 5;
    z-index: 3;
    @media screen and (max-width: 560px) {
      top: initial;
      bottom: calc(4.4cqw + 4.4445cqw + 24px);
      /* bottom: 4.4cqw; */
      /* bottom: 0; */
      left: 6.5cqw;
      translate: initial;
      position: relative;
      margin-top: auto;
      margin-bottom: 4.4cqw;
      padding: 4.4445cqw;
      border-radius: 0 16px 16px 0;
      grid-column: 1/1;
      grid-row: 1/1;
      height: fit-content;
      &::before {
        content: "" ;
        position: absolute;
        background: rgb(255 255 255 / .6);
        border-radius: 0 32px 32px 0;
        z-index: -1;
        inset: 0;
        width: 100%;
        height: 100%;
        @media screen and (max-width: 560px) {
          left: -11cqw;
        }
      }
    }

    .fv-copy {
      /* font-size: 2.529645cqw; */
      font-size: clamp(1.8rem, 3vw, 3.2rem);
      line-height: 1.5;
      margin-bottom: 32px;
      @media screen and (max-width: 560px) {
        font-size: 3.2cqw;
        margin-bottom: 2cqw;
      }
    }
    .num {
      font-family: var(--font-roboto);
      /* font-size: 6.319115cqw; */
      font-size: clamp(3.6rem, 7vw, 7.2rem);
      font-weight: 500;
      color: var(--black);
      line-height: 1;
      @media screen and (max-width: 560px) {
        font-size: 12.33334cqw;
      }
    }
    .name {
      /* font-size: 1.57978cqw; */
      font-size: clamp(1.2rem, 2.5vw, 2.4rem);
      font-weight: 700;
      @media screen and (max-width: 560px) {
        font-size: 5cqw;
      }
    }
    .text {
      /* font-size: 1.26382cqw; */
      font-size: clamp(1.2rem, 1.75vw, 1.6rem);
      @media screen and (max-width: 560px) {
        font-size: 2.8cqw;
        line-height: 1.6;
      }
    }
    .note {
      margin-top: 8px;
      /* font-size: .94787cqw; */
      font-size: 1.2rem;
      @media screen and (max-width: 560px) {
        font-size: 2.4cqw;
      }
    }
  }

  @media screen and (max-width: 560px) {
    .fv-img {
      grid-column: 1/1;
      grid-row: 1/1;
    }
  }


  .timeline {
    border-radius: 64px;
    padding-block: 60px;
    overflow: hidden;
    max-width: 1040px;
    margin-inline: auto;
    margin-bottom: 112px;
    @media screen and (max-width: 768px) {
      padding-block: 36px;
      border-radius: 32px;
      margin-bottom: 36px;
    }

    .timeline-inner {
      padding-inline: 80px;
      @media screen and (max-width: 768px) {
        padding-inline: 24px;
      }
    }

    .time-line-title {
      position: relative;
      display: flex;
      align-items: center;
      gap: 16px;
      margin-bottom: 48px;
      @media screen and (max-width: 768px) {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
        margin-bottom: 24px;
      }

      &::before {
        content: "";
        position: absolute;
        width: 50px;
        height: 1px;
        background: var(--black);
        bottom: -24px;
        left: 0;
        translate: 0 -50%;
        z-index: 1;
        @media screen and (max-width: 768px) {
          display: none;
        }
      }

      .en {
        font-family: var(--font-roboto);
        font-weight: 500;
        font-size: 4rem;
        line-height: 1;
        @media screen and (max-width: 768px) {
          font-size: 3.2rem;
        }
      }
      .caption {
        font-size: 2rem;
        font-weight: 700;
        @media screen and (max-width: 768px) {
          font-size: 1.6rem;
        }
      }
    }

    .timeline-list {
      display: flex;
      flex-direction: column;
      gap: 16px;
    }

    .timeline-item {
      display: flex;
      gap: 16px;
      @media screen and (max-width: 768px) {
        flex-direction: column;
      }
    }

    .timeline-term {
      position: relative;
      font-size: 2rem;
      font-weight: 700;
      min-width: 240px;
      height: fit-content;
      border-radius: 0 8px 8px 0;
      background: var(--white);
      @media screen and (max-width: 768px) {
        font-size: 1.6rem;
        width: fit-content;
        min-width: 150px;
      };
      &::before {
        content: "";
        position: absolute;
        top: 0;
        left: -100%;
        background: var(--white);
        width: 100%;
        height: 100%;
        z-index: 0;
      }
    }

    .timeline-text {
      font-size: 1.6rem;
      text-align: justify;
      line-height: 1.6;
      @media screen and (max-width: 768px) {
        font-size: 1.4rem;
      }
    }


    &.career {
      background: var(--gray-light);
      .time-line-title .en {
        color: #abb6c8;
      }
    }
    &.schedule {
      background: var(--lime);
      .time-line-title .en {
        color: #abb6c8;
      }
      .timeline-term {
        min-width: 100px;
      }
    }
  }

  .content-outer {
    @media screen and (max-width: 768px) {
      margin-bottom: 0;
    }
  }

  .interview-wrap {
    position: relative;
  }

  .interview-block {
    max-width: 880px;
    padding-inline: 104px;
    @media screen and (max-width: 768px) {
      padding-inline: 0;
      margin-bottom: 54px;
    }
    .head-text__unit {
      gap: 52px;
      @media screen and (max-width: 768px) {
        gap: 32px;
      }
      .head {
        font-size: 3.2rem;
        @media screen and (max-width: 768px) {
          font-size: 1.8rem;
        }
      }
    }

    +  .interview-block,
    + .interview-img  {
      margin-top: 120px;
      @media screen and (max-width: 768px) {
        margin-top: 0;
      }
    }
  }

  .interview-img {
    position: relative;
    display: block;
    right: -104px;
    @media screen and (max-width: 768px) {
      right: initial;
      left: 4px;
      border-radius: 16px;
      width: calc(100vw - 8px);
      margin-inline: calc(50% - 50vw);
    }

    + .interview-block  {
      margin-top: 120px;
      @media screen and (max-width: 768px) {
        margin-top: 48px;
      }
    }
  }

  .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;
      }
    }
  }

  .sibling-links.slider-links .js-slider .swiper {
    @media screen and (max-width: 768px) {
        padding-inline: 0;
      .head-text__unit {
        text-align: center;
      }
    }
  }

  .prev-btn {
    margin-bottom: 128px;
    @media screen and (max-width: 768px) {
      margin-block: 64px;
    }
  }
}

.womens-interview-lowerPage {

    @media screen and (max-width: 560px) {
      .fv-cont {
        bottom: 4.4cqw;
      }
    }

  @media screen and (max-width: 560px) {
    .fv .square::before {
      width: 88%;
      height: 40%;
    }
  }

  .fv-head {
    font-size: clamp(1.2rem, 2vw, 2rem);
    font-weight: 700;
    margin-bottom: 16px;
    span {
      padding-right: 32px;
    }
    @media screen and (max-width: 560px) {
      font-size: 1.8rem;
    }
  }

 .timeline.schedule {
  background: linear-gradient(180deg, rgb(251, 235, 249) 40%, rgb(255, 246, 217) 100%);
 }
}

.lowerPage .sibling-links .heading-unit {
  flex-direction: column;
  align-items: flex-start;
  gap: 64px;
  @media screen and (max-width: 768px) {
    gap: 24px;
  }
}

.heading-unit .heading-category {
  padding-bottom: 10px;
}

.lowerPage .fv .fv-img::before {
  background-image: initial;
}

@media screen and (max-width: 768px) {
  .lowerPage .sibling-links .heading-unit .heading-category {
    font-size: 12cqw;
  }
}