@charset "UTF-8";

/* =====================
  animation
===================== */
@keyframes marquee {
  100% {
    translate: -100%;
  }
}

@keyframes scroll-down {
  0% {
    opacity: 0;
    transform: translateX(0);
  }

  50% {
    opacity: 1;
    transform: translateX(25%);
  }

  90% {
    opacity: 1;
    transform: translateX(25%);
  }

  95% {
    opacity: 0;
    transform: translateX(25%);
  }

  100% {
    opacity: 0;
    transform: translateX(25%);
  }
}

/* =====================
  c-others
===================== */
.c-others {
  .swiper-slide a {
    display: block grid;
    grid-template-columns: auto 1fr;
    gap: 0 21px;
    align-items: baseline;

    @media (width <= 768px) {
      gap: 0 5vw;
    }

    @media (any-hover: hover) {
      &:hover {
        .picture {
          transform: scale(1.05);
        }
      }
    }

    /* ==== picture ==== */
    .picture {
      grid-area: 1 / 1 / 2 / 3;
      transition: all 250ms ease 0s;
    }

    /* ==== year ==== */
    .year {
      grid-area: 2 / 1 / 3 / 3;
      margin-block-start: 16px;
      font-size: 14px;

      @media (width <= 768px) {
        margin-block-start: calc((100 / 390) * 12 * 1vw);
        font-size: calc((100 / 390) * 14 * 1vw);
      }
    }

    /* ==== title ==== */
    .title {
      grid-area: 3 / 1 / 4 / 2;
      margin-block-start: 12px;
      font-family: var(--title);
      font-size: 40px;
      font-weight: 500;
      line-height: 1;
      color: var(--green);

      @media (width <= 768px) {
        margin-block-start: calc((100 / 390) * 12 * 1vw);
        font-size: calc((100 / 390) * 36 * 1vw);
      }
    }

    /* ==== position ==== */
    .position {
      grid-area: 3 / 2 / 4 / 3;
    }
  }
}

/* =====================
  mv
===================== */
.mv {
  position: relative;
  block-size: 884px;
  overflow: hidden;
  background: linear-gradient(
    90deg,
    rgb(215 233 228 / 100%) 0%,
    rgb(215 233 228 / 100%) 33%,
    rgb(236 244 242 / 100%) 33%,
    rgb(236 244 242 / 100%) 66%,
    rgb(215 233 228 / 100%) 66%,
    rgb(215 233 228 / 100%) 100%
  );

  @media (width <= 768px) {
    block-size: calc((100 / 390) * 800 * 1vw);
    background: #d7e9e4;
  }

  /* ==== swiper ==== */
  .swiper {
    z-index: 2;
    block-size: 100%;

    @media only screen and (width <= 768px) {
      block-size: auto;

      .swiper-wrapper {
        block-size: auto;
      }
    }

    .swiper-slide {
      block-size: inherit;

      @media only screen and (width <= 768px) {
        padding-inline: calc((100 / 390) * 16 * 1vw);
      }

      & a {
        display: block grid;
        justify-content: center;
        block-size: inherit;
        padding-block-start: 115px;

        @media (width <= 768px) {
          padding-block-start: calc((100 / 390) * 95 * 1vw);

          & img {
            block-size: calc((100 / 390) * 484 * 1vw);
            object-fit: cover;
            border-radius: calc((100 / 390) * 10 * 1vw);
          }
        }
      }
    }
  }

  /* ==== catch ==== */
  .catch {
    position: absolute;
    inset-block-end: 76px;
    inset-inline-start: 85px;
    z-index: 2;
    font-family: var(--jp);
    font-size: 40px;
    font-weight: 500;
    line-height: 2;
    color: var(--gray400);
    pointer-events: none;

    @media (width <= 768px) {
      position: relative;
      inset: unset;
      padding-block: calc((100 / 390) * 17 * 1vw) 0;
      padding-inline: calc((100 / 390) * 32 * 1vw);
      font-size: calc((100 / 390) * 30 * 1vw);
      line-height: 1.6;
    }
  }

  /* ==== en ==== */
  .en {
    position: absolute;
    inset-block-end: 45px;
    inset-inline-start: 85px;
    z-index: 2;
    font-family: var(--title);
    font-size: 20px;
    font-weight: 400;
    color: var(--green);
    letter-spacing: 0.8px;
    pointer-events: none;

    @media (width <= 768px) {
      position: relative;
      inset: unset;
      display: block flow;
      padding-block-start: calc((100 / 390) * 15 * 1vw);
      padding-inline-start: calc((100 / 390) * 32 * 1vw);
      font-size: calc((100 / 390) * 18 * 1vw);
      line-height: 1.5;
      letter-spacing: calc((100 / 390) * 0.72 * 1vw);
    }
  }

  /* ==== text ==== */
  .text {
    position: absolute;
    inset-block-start: 190px;
    display: flex;
    gap: 38px;
    inline-size: 100vw;
    block-size: 66px;
    margin-inline: calc(50% - 50vw);
    pointer-events: none;

    @media (width <= 768px) {
      inset-block-start: 40vw;
      gap: calc((100 / 390) * 28 * 1vw);
      block-size: calc((100 / 390) * 51 * 1vw);
    }

    &::before,
    &::after {
      display: block;
      flex-shrink: 0;
      inline-size: 1458px;
      block-size: 66px;
      content: '';
      background-image: url('../img/recruit/text.svg');
      background-repeat: no-repeat;
      background-position: center bottom;
      background-size: 1485px 66px;
      animation: marquee 150s linear infinite;
    }

    @media (width <= 768px) {
      &::before,
      &::after {
        inline-size: calc((100 / 390) * 613 * 1vw);
        block-size: calc((100 / 390) * 51 * 1vw);
        background-image: url('../img/recruit/text_sp.svg');
        background-size: calc((100 / 390) * 613 * 1vw) calc((100 / 390) * 51 * 1vw);
      }
    }
  }

  /* ==== scroll ==== */
  .scroll {
    position: absolute;
    inset-block-end: 41px;
    inset-inline-end: 76px;
    display: block grid;
    gap: 20px;
    justify-content: center;
    inline-size: 104px;
    aspect-ratio: 1 / 1;
    border: 1px solid var(--green);
    border-radius: calc(infinity * 1px);

    @media (width <= 768px) {
      inset-block-end: 12.2vw;
      inset-inline-end: calc((100 / 390) * 16 * 1vw);
      gap: calc((100 / 390) * 20 * 1vw);
      inline-size: calc((100 / 390) * 80 * 1vw);
    }

    &::before {
      display: block flow;
      align-self: flex-end;
      inline-size: 37px;
      aspect-ratio: 37 / 12;
      content: '';
      background-image: url('../img/recruit/scroll.svg');
      background-repeat: no-repeat;
      background-position: center;
      background-size: contain;
    }

    @media (width <= 768px) {
      &::before {
        inline-size: calc((100 / 390) * 33 * 1vw);
      }
    }

    &::after {
      align-items: flex-start;
      inline-size: 21px;
      aspect-ratio: 21 / 10;
      margin-inline: auto;
      content: '';
      background-color: var(--green);
      mask-image: var(--icon-arrow);
      mask-repeat: no-repeat;
      mask-position: center;
      mask-size: contain;
      rotate: 0 0 1 90deg;
      animation: scroll-down 2500ms ease 0ms infinite normal none running;
    }

    @media (width <= 768px) {
      &::after {
        inline-size: calc((100 / 390) * 17 * 1vw);
        translate: 0 -1.9vw;
      }
    }
  }
}

/* =====================
  message
===================== */
.message {
  padding-block: 0;
  overflow: hidden;
  background-image: url('../img/recruit/bg.webp');
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;

  @media (width <= 768px) {
    background-image: url('../img/recruit/bg_sp.webp');
  }

  .u-inner {
    padding-block: 35px 52px;

    @media (width <= 768px) {
      padding-block: calc((100 / 390) * 27 * 1vw) calc((100 / 390) * 64 * 1vw);
    }

    /* ==== breadcrumb ==== */
    .breadcrumb {
      position: unset;
      inset: unset;
      margin-inline: auto 0;

      @media (width <= 768px) {
        padding-inline-end: 0;
        margin-block-start: 0;
      }
    }

    /* ==== contents ==== */
    .contents {
      display: block grid;
      grid-template-columns: 448px auto;
      gap: 58px 80px;
      align-items: flex-start;
      padding-block-start: 53px;

      @media (width <= 768px) {
        display: block flex;
        flex-direction: column;
        gap: calc((100 / 390) * 39 * 1vw);
      }

      /* ==== u-head ==== */
      .u-head {
        grid-area: 1 / 2 / 2 / 3;
        gap: 51px;
        padding-block-start: 63px;

        @media (width <= 768px) {
          gap: calc((100 / 390) * 44 * 1vw);
          padding-block-start: calc((100 / 390) * 0 * 1vw);
          text-align: center;
          translate: 1vw 0;
        }

        .title {
          font-size: 32px;
          color: transparent;
          background: linear-gradient(99deg, #274827 15.76%, #aad59a 97.34%);
          background-clip: text;
          -webkit-text-fill-color: transparent;

          @media (width <= 768px) {
            font-size: calc((100 / 390) * 23 * 1vw);
            font-feature-settings: 'palt' on;
          }
        }
      }

      /* ==== text ==== */
      .text {
        grid-area: 2 / 2 / 3 / 3;
        font-size: 18px;

        @media (width <= 768px) {
          font-size: calc((100 / 390) * 15 * 1vw);
        }

        & p {
          line-height: 2;

          & + p {
            margin-block-start: 36px;

            @media (width <= 768px) {
              margin-block-start: calc((100 / 390) * 30 * 1vw);
            }
          }
        }
      }

      /* ==== img ==== */
      .img {
        position: relative;
        display: block grid;
        grid-area: 1 / 1 / 4 / 2;
        gap: 64px;

        @media (width <= 768px) {
          gap: 0;
          inline-size: 100%;
          margin-block-start: calc((100 / 390) * 9 * 1vw);
        }

        .unit[data-id='1'] {
          @media (width <= 768px) {
            inline-size: calc((100 / 390) * 178 * 1vw);
            block-size: auto;
          }
        }

        .unit[data-id='2'] {
          margin-inline: auto 0;

          @media (width <= 768px) {
            inline-size: calc((100 / 390) * 124 * 1vw);
            block-size: auto;
            margin-block-start: calc((100 / 390) * 85 * -1 * 1vw);
          }
        }
      }
    }
  }
}

/* =====================
  requirement
===================== */
.requirement {
  padding-block: 63px 118px;

  @media (width <= 768px) {
    padding-block: calc((100 / 390) * 48 * 1vw) calc((100 / 390) * 65 * 1vw);
  }

  /* ==== u-head ==== */
  .u-head {
    margin-block-end: 67px;

    @media (width <= 768px) {
      margin-block-end: calc((100 / 390) * 42 * 1vw);
    }
  }

  /* ==== no-data ==== */
  .no-data {
    margin-block: 40px;
    font-size: 18px;
    font-weight: 500;
    color: var(--gray400);
    text-align: center;

    @media (width <= 768px) {
      margin-block: calc((100 / 390) * 32 * 1vw);
      font-size: calc((100 / 390) * 18 * 1vw);
    }
  }
}

/* =====================
  interview
===================== */
.interview {
  padding-block: 103px 109px;
  background: var(--gray100);

  @media (width <= 768px) {
    padding-block: calc((100 / 390) * 48 * 1vw) calc((100 / 390) * 34 * 1vw);
  }

  /* ==== u-head ==== */
  .u-head {
    margin-block-end: 47px;

    @media (width <= 768px) {
      margin-block-end: 6vw;
    }
  }

  /* ==== swiper-slide ==== */
  .swiper-slide {
    padding-block: 20px;

    @media (width <= 768px) {
      padding-block: calc((100 / 390) * 18 * 1vw);
    }
  }
}

/* =====================
  number
===================== */
.number {
  padding-block: 84px 119px;
  background: var(--bg-grid);
  background-repeat: repeat;
  background-position: center center;
  background-size: 29px 29px;

  @media (width <= 768px) {
    padding-block: calc((100 / 390) * 49 * 1vw) calc((100 / 390) * 70 * 1vw);
    background-size: calc((100 / 390) * 29 * 1vw) calc((100 / 390) * 29 * 1vw);
  }

  /* ==== list ==== */
  .list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 61px 64px;
    max-inline-size: 1151px;
    margin-block: 72px 0;
    margin-inline: auto;
    color: white;

    @media (width <= 768px) {
      display: block flex;
      flex-direction: column;
      gap: 11vw;
      margin-block: 12vw 0;
    }

    /* ==== li ==== */
    & li {
      display: block grid;
      gap: 40px;
      padding-block: 24px 27px;
      padding-inline: 24px;
      margin-block: calc((1em - 1lh) / 2);
      background: linear-gradient(102deg, #274827 15.2%, #aad59a 135.62%);
      border-radius: 10px;

      @media (width <= 768px) {
        gap: 6.3vw;
        padding-block: calc((100 / 390) * 24 * 1vw) calc((100 / 390) * 20 * 1vw);
        padding-inline: calc((100 / 390) * 24 * 1vw);
        border-radius: calc((100 / 390) * 10 * 1vw);
      }

      /* ==== h3 ==== */
      & h3 {
        inline-size: fit-content;
        padding-block: 5px;
        padding-inline: 16px;
        margin-block: calc((1em - 1lh) / 2);
        margin-inline: auto;
        line-height: 1;
        border: 1px solid white;
        border-radius: calc(infinity * 1px);

        @media (width <= 768px) {
          padding-block: calc((100 / 390) * 7 * 1vw);
          padding-inline: calc((100 / 390) * 23 * 1vw);
          font-size: calc((100 / 390) * 14 * 1vw);
        }
      }

      /* ==== value ==== */
      .value {
        display: block grid;
        grid-auto-flow: column;
        align-items: baseline;
        justify-content: center;

        /* ==== img ==== */
        .img {
          margin-inline-end: 20px;

          @media (width <= 768px) {
            margin-inline-end: calc((100 / 390) * 22 * 1vw);
          }
        }

        /* ==== countup ==== */
        .countup {
          font-family: var(--title);
          font-size: 81px;
          line-height: 1;
          translate: 0 -4px;
          font-variant: tabular-nums;
          font-feature-settings: "tnum";
          

          @media (width <= 768px) {
            font-size: calc((100 / 390) * 72 * 1vw);
            translate: 0 -1.7vw;
          }
        }

        /* ==== unit ==== */
        .unit {
          padding-inline-start: 8px;
          font-size: 38px;
          font-weight: 700;
          translate: 0 -4px;

          @media (width <= 768px) {
            padding-inline-start: calc((100 / 390) * 8 * 1vw);
            font-size: calc((100 / 390) * 38 * 1vw);
            translate: 0 -1.8vw;
          }
        }
      }
    }
  }
}

/* =====================
  banner
===================== */
.banner {
  padding-block: 111px 120px;

  @media (width <= 768px) {
    padding-block: calc((100 / 390) * 48 * 1vw) calc((100 / 390) * 51 * 1vw);
  }

  /* ==== u-inner ==== */
  .u-inner {
    background-image: url('../img/recruit/entry.webp');
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    border-radius: 10px;

    @media (width <= 768px) {
      background-image: url('../img/recruit/entry_sp.webp');
      border-radius: calc((100 / 390) * 10 * 1vw);
    }

    & a {
      display: block grid;
      grid-auto-flow: column;
      gap: 20px;
      place-content: center;
      block-size: 100%;
      padding-block: 80px;
      margin-block: calc((1em - 1lh) / 2);
      font-family: var(--title);
      font-size: 72px;
      font-weight: 500;
      line-height: 1;
      color: transparent;
      background: linear-gradient(102deg, #274827 15.2%, #aad59a 135.62%);
      background-clip: text;
      translate: 2px 3px;
      -webkit-text-fill-color: transparent;

      @media (width <= 768px) {
        gap: calc((100 / 390) * 20 * 1vw);
        padding-block: calc((100 / 390) * 74 * 1vw);
        font-size: calc((100 / 390) * 56 * 1vw);
        translate: calc((100 / 390) * 4.8 * 1vw) calc((100 / 390) * 7 * -1 * 1vw);
      }

      &::after {
        inline-size: 56px;
        aspect-ratio: 1 / 1;
        content: '';
        background-image: url('../img/recruit/anchor.svg');
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
        translate: -4px 5px;
      }

      @media (width <= 768px) {
        &::after {
          inline-size: calc((100 / 390) * 48 * 1vw);
          translate: calc((100 / 390) * -10 * 1vw) calc((100 / 390) * 4 * 1vw);
        }
      }
    }
  }
}

/* =====================
  staff
===================== */
.staff {
  min-block-size: 615px;
  padding-block: 115px 80px;
  background: var(--lightgreen);

  @media (width <= 768px) {
    min-block-size: calc((100 / 390) * 615 * 1vw);
    padding-block: calc((100 / 390) * 96 * 1vw) calc((100 / 390) * 37 * 1vw);
  }

  /* ==== u-inner ==== */
  .u-inner {
    --_gap: 129px;

    display: block grid;
    grid-template-rows: auto auto auto 1fr;
    grid-template-columns: auto 1fr 668px;
    gap: 0;
    align-items: flex-start;
    padding-inline-start: 40px;

    @media (width <= 768px) {
      --_gap: 0;

      grid-template-rows: auto;
      grid-template-columns: auto 1fr;
      padding-inline: calc((100 / 390) * 16 * 1vw);
    }

    /* ==== catch ==== */
    .catch {
      grid-area: 1 / 1 / 3 / 3;
      padding-block: 70px 26px;
      margin-inline-end: var(--_gap);
      font-family: var(--jp);
      font-size: 32px;
      font-weight: 500;
      line-height: 2.15;
      color: var(--gray400);
      border-block-end: 1px solid #929292;

      @media (width <= 768px) {
        grid-area: 2 / 1 / 3 / 3;
        padding-block: 5vw 3.6vw;
        margin-inline: calc((100 / 390) * 16 * 1vw);
        font-size: calc((100 / 390) * 24 * 1vw);

        /* line-height: 2; */
      }
    }

    /* ==== picture ==== */
    .picture {
      grid-area: 1 / 3 / 5 / 4;

      @media (width <= 768px) {
        display: block flow;
        grid-area: 1 / 1 / 2 / 3;
        margin-inline: auto;
      }
    }

    /* ==== year ==== */
    .year {
      grid-area: 3 / 1 / 4 / 3;
      margin-block-start: 24px;
      font-size: 14px;

      @media (width <= 768px) {
        grid-area: 3 / 1 / 4 / 3;
        margin-block-start: calc((100 / 390) * 16 * 1vw);
        margin-inline: calc((100 / 390) * 16 * 1vw);
        font-size: calc((100 / 390) * 14 * 1vw);
      }
    }

    /* ==== title ==== */
    .title {
      grid-area: 4 / 1 / 5 / 2;
      margin-block-start: 12px;
      font-family: var(--title);
      font-size: 40px;
      font-weight: 500;
      line-height: 1;
      color: var(--green);

      @media (width <= 768px) {
        grid-area: 4 / 1 / 5 / 2;
        margin-block-start: 3vw;
        margin-inline: calc((100 / 390) * 16 * 1vw);
        font-size: calc((100 / 390) * 40 * 1vw);
      }
    }

    /* ==== position ==== */
    .position {
      display: block grid;
      grid-area: 4 / 2 / 5 / 3;
      block-size: 100%;
      padding-block: 20px 0;
      margin-inline-start: 20px;
      font-size: 16px;

      @media (width <= 768px) {
        grid-area: 4 / 2 / 5 / 3;
        padding-block: 5.1vw 0;
        margin-inline-start: 1vw;
        font-size: calc((100 / 390) * 16 * 1vw);
      }
    }
  }
}

/* =====================
  qa
===================== */
.qa {
  padding-block: 34px 120px;

  @media (width <= 768px) {
    padding-block: calc((100 / 390) * 27 * 1vw) calc((100 / 390) * 60 * 1vw);
  }

  /* ==== breadcrumb ==== */
  .breadcrumb {
    position: unset;
    inset: unset;
    margin-inline: auto 0;

    @media (width <= 768px) {
      padding-inline: unset;
      margin-block-start: unset;
    }
  }

  /* ==== list ==== */
  .list {
    display: block grid;
    gap: 64px;
    padding-inline: 40px;
    margin-block: 87px 0;
    counter-reset: number;

    @media (width <= 768px) {
      gap: calc((100 / 390) * 40 * 1vw);
      padding-inline: 0;
      margin-block: calc((100 / 390) * 52 * 1vw) 0;
    }

    /* ==== item ==== */
    .item {
      display: block grid;
      gap: 30px;

      @media (width <= 768px) {
        gap: calc((100 / 390) * 21 * 1vw);
      }

      /* ==== question ==== */
      .question {
        position: relative;
        display: block flex;
        align-items: center;
        inline-size: fit-content;
        padding-block: 7px;
        padding-inline: 64px 27px;
        font-size: 20px;
        font-weight: 500;
        line-height: 2;
        color: var(--green);
        background: var(--lightgreen);
        border-radius: 9px;

        @media (width <= 768px) {
          inline-size: unset;
          padding-block: calc((100 / 390) * 8.5 * 1vw);
          padding-inline: calc((100 / 390) * 55.6 * 1vw) calc((100 / 390) * 13 * 1vw);
          font-size: calc((100 / 390) * 17 * 1vw);
          border-radius: calc((100 / 390) * 9 * 1vw);
        }

        &::before {
          position: absolute;
          inset-block-start: 5px;
          inset-inline-start: 24px;
          font-family: var(--title);
          font-size: 24px;
          content: 'Q' counter(number);
          counter-increment: number;
        }

        @media (width <= 768px) {
          &::before {
            inset-block-start: calc((100 / 390) * 6 * 1vw);
            inset-inline-start: calc((100 / 390) * 19.4 * 1vw);
            font-size: calc((100 / 390) * 22 * 1vw);
          }
        }
      }

      /* ==== answer ==== */
      .answer {
        margin-block: calc((1em - 1lh) / 2);
        line-height: 2;
      }
    }
  }
}

/* =====================
  others
===================== */
.others {
  padding-block: 104px 108px;
  background: var(--gray100);

  @media (width <= 768px) {
    padding-block: calc((100 / 390) * 48 * 1vw) calc((100 / 390) * 34 * 1vw);
  }
}
