@layer pages {

  /* ---------------------------------------------
  .section-404
------------------------------------------------ */
  .section-404 {
    text-align: center;

    @media (max-width: 896px) {
      text-align: left;
    }

    & .text-box {
      margin-top: 40px;

      @media (max-width: 896px) {
        margin-top: 30px;
      }
    }

    & .button-box {
      display: flex;
      justify-content: center;
      margin-top: 40px;

      @media (max-width: 896px) {
        margin-top: 30px;
      }
    }
  }
}

@layer pages {
  :root {
    --color-black-100: #000;
    --color-black-90: rgb(0 0 0 / 90%);
    --color-gray-100: #fff;
    --color-gray-90: #f9f9f9;
    --color-gray-80: #efefef;
    --color-gray-70: #ccc;
    --color-gray-60: #aaa;
    --color-gray-50: #999;
    --color-gray-40: #797979;
    --color-gray-30: #626262;
    --color-gray-20: #4c4c4c;
    --color-gray-10: #222;
    --color-gray-5: #111;
    --color-red-95: #fcebee;
    --color-red-90: #fae6ea;
    --color-red-80: #eccad1;
    --color-red-70: #e5a6b2;
    --color-red-60: #db8294;
    --color-red-50: #ca596e;
    --color-red-40: #b82f49;
    --color-red-30: #a70524;
    --color-red-25: #8a0720;
    --color-red-20: #86041d;
    --color-red-10: #640316;
    --color-red-5: #43020e;
    --color-primary-90: var(--color-red-90);
    --color-primary-80: var(--color-red-80);
    --color-primary-70: var(--color-red-70);
    --color-primary-60: var(--color-red-60);
    --color-primary-50: var(--color-red-50);
    --color-primary-40: var(--color-red-40);
    --color-primary-30: var(--color-red-30);
    --color-primary-20: var(--color-red-20);
    --color-primary-10: var(--color-red-10);
    --color-primary-5: var(--color-red-5);
    --color-neutral-100: var(--color-gray-100);
    --color-neutral-90: var(--color-gray-90);
    --color-neutral-80: var(--color-gray-80);
    --color-neutral-70: var(--color-gray-70);
    --color-neutral-60: var(--color-gray-60);
    --color-neutral-50: var(--color-gray-50);
    --color-neutral-40: var(--color-gray-40);
    --color-neutral-30: var(--color-gray-30);
    --color-neutral-20: var(--color-gray-20);
    --color-neutral-10: var(--color-gray-10);
    --color-neutral-5: var(--color-gray-5);
    --color-category-blue: var(--color-blue-30);
    --color-category-green: var(--color-green-30);
    --color-category-purple: var(--color-purple-30);
    --color-blue-30: #0564a7;
    --color-green-30: #1e8e38;
    --color-purple-30: #83408a;
    --color-text-black: var(--color-black-100);
    --color-text-default: var(--color-neutral-5);
    --color-text-subtle: var(--color-neutral-40);
    --color-fill-default: var(--color-neutral-100);
    --color-fill-subtle: var(--color-neutral-80);
    --color-fill-dark: var(--color-neutral-10);
    --color-stroke-default: var(--color-gray-75);
    --color-stroke-dark: var(--color-gray-20);
    --color-stroke-brandsubtle: var(--color-primary-50);
    --color-text-brand: var(--color-primary-30);
    --color-fill-brand: var(--color-primary-30);
    --color-tag-blue: var(--color-blue-30);
    --color-tag-green: var(--color-green-30);
    --color-tag-purple: var(--color-purple-30);
    --color-text-light: var(--color-neutral-100);
    --color-fill-subtler: var(--color-neutral-80);
    --color-stroke-light: var(--color-gray-100);
    --color-stroke-subtler: var(--color-gray-50);
    --color-stroke-brand: var(--color-primary-30);
    --color-stroke-subtle: var(--color-gray-70);
    --color-stroke-subtle-2: var(--color-gray-50);
    --color-bluegreen-30: #39809c;
    --color-brown-30: #866431;
    --color-tag-bluegreen: var(--color-bluegreen-30);
    --color-tag-brown: var(--color-brown-30);
    --color-category-bluegreen: var(--color-bluegreen-30);
    --color-category-brown: var(--color-brown-30);
    --color-blue-30-2: #0564a7;
    --color-text-danger: #d00;
    --color-gray-75: #e0e0e0;
    --color-voice-green: #d1eace;
    --color-voice-blue: #d1e6f6;
    --color-voice-purple: #eeddf1;
    --color-voice-pink-01: #fbe0e5;
    --color-voice-pink-02: #f9d8eb;
    --color-voice-blue-02: #c4eaef;
    --color-voice-yellow-01: #f4ebdd;
    --color-voice-yellow-02: #ffdf87;
  }
}

@layer pages {
  :root {
    --font-family: "Noto Sans JP", "YuGothic", "Hiragino Kaku Gothic Pro", "Meiryo", sans-serif;
    --second-family: "Rajdhani", sans-serif;
    --font-noto-serif: "Noto Serif JP", sans-serif;
    --font-size-base: 1rem;
  }
}

@layer pages {
  :root {
    --max-width-xxl: 1512px;
    --max-width-xl: 1210px;
    --max-width-lg: 870px;
  }
}

@layer pages {

  /* ---------------------------------------------
  .about-hero
------------------------------------------------ */
  .about-hero {
    background: var(--color-stroke-brand);

    >.wrap {
      display: flex;
      width: 100%;
      max-width: 1417px;
      justify-content: flex-end;
      margin-inline: auto;
      padding-block: 90px 71px;
      padding-inline: 20px;

      @media (max-width: 896px) {
        padding-block: 30px 60px;
      }
    }

    >.wrap>.inner {
      display: flex;
      max-width: 1294px;
      gap: 20px 1.46832%;

      @media (max-width: 896px) {
        flex-direction: column-reverse;
      }
    }

    >.wrap>.inner>.content {
      @media (min-width: 897px) {
        width: 53.25825%;
      }
    }

    >.wrap>.inner>.content>.subheading {
      position: relative;
      padding-left: 50px;
      color: var(--color-text-light);
      font-family: var(--second-family);
      font-size: 1.375rem;
      font-weight: 700;
      line-height: 1.27273;

      &::before {
        position: absolute;
        top: 50%;
        left: 0;
        display: flex;
        width: 40px;
        height: 1px;
        background-color: var(--color-stroke-light);
        content: "";
        transform: translateY(-50%);
      }
    }

    >.wrap>.inner>.content>.heading {
      margin-top: 20px;

      img {
        width: 100%;
        max-width: 507px;
        height: auto;
      }
    }

    >.wrap>.inner>.content>.text {
      margin-top: 70px;
      color: var(--color-text-light);
      font-size: 1.125rem;
      font-weight: 400;
      line-height: 1.88889;

      @media (max-width: 896px) {
        margin-top: 22px;
        font-size: 1.0625rem;
      }

      &+& {
        margin-top: 20px;
      }
    }

    >.wrap>.inner>.slider {
      width: 49.23572%;

      @media (max-width: 896px) {
        width: 56.8vw;
        margin-inline: auto;
      }

      img {
        width: 100%;
        height: auto;
      }
    }
  }

  /* ---------------------------------------------
  .about-solutions
------------------------------------------------ */

  @keyframes solutions-pc {
    0% {
      background-position: 0 0;
    }

    100% {
      background-position: -840px 0;
    }
  }

  @keyframes solutions-sp {
    0% {
      background-position: 0 0;
    }

    100% {
      background-position: -423px 0;
    }
  }

  .about-solutions {
    background-color: var(--color-neutral-80);

    >.inner {
      position: relative;
      max-width: 1110px;
      margin-inline: auto;
      padding-block: 235px 80px;
      padding-inline: 20px;

      @media (max-width: 896px) {
        padding-block: 129px 40px;
      }

      &::before {
        position: absolute;
        top: 137px;
        left: 50%;
        width: 100vw;
        height: 129px;
        animation: solutions-pc 16s linear infinite;
        background-image: url("/assets/images/about/text-solution.png");
        background-position: top;
        background-repeat: repeat-x;
        background-size: 840px 129px;
        content: "";
        pointer-events: none;
        transform: translateX(-50%);

        @media (max-width: 896px) {
          top: 79px;
          height: 65px;
          animation-name: solutions-sp;
          background-size: 423px 65px;
        }
      }
    }

    >.inner>.title {
      position: relative;
      padding-bottom: 70px;
      color: var(--color-text-default);
      font-size: 2.625rem;
      font-weight: 700;
      line-height: 1.33333;
      text-align: center;

      @media (max-width: 896px) {
        padding-bottom: 60px;
        font-size: 1.75rem;
        line-height: 1.28571;
      }

      &::after {
        position: absolute;
        bottom: 35px;
        left: 50%;
        width: 70px;
        height: 4px;
        border-radius: 4px;
        background-color: var(--color-stroke-brand);
        content: "";
        transform: translateX(-50%);

        @media (max-width: 896px) {
          bottom: 30px;
        }
      }
    }

    >.inner>.text {
      color: var(--color-text-default);
      font-size: 1.25rem;
      font-weight: 500;
      line-height: 1.7;
      text-align: center;

      @media (max-width: 896px) {
        font-size: 1.125rem;
        line-height: 1.77778;
        text-align: left;
      }
    }

    .list {
      display: grid;
      background: var(--color-black-100);
      grid-template-columns: repeat(4, 1fr);

      @media (max-width: 896px) {
        grid-template-columns: repeat(2, 1fr);
      }
    }

    .list>li {
      position: relative;
      display: flex;
      overflow: hidden;
      width: 100%;
      align-items: flex-end;
      justify-content: center;
      aspect-ratio: 400 / 370;

      @media (max-width: 896px) {
        aspect-ratio: 187.5 / 188;
      }
    }

    .list>li>.image {
      position: absolute;
      width: 100%;

      img {
        width: 100%;
        height: auto;
        -o-object-fit: cover;
        object-fit: cover;
      }
    }

    .list>li>.content {
      position: relative;
      display: flex;
      flex-direction: column;
      padding: 20px 20px 31px;
      gap: 8px;
      text-align: center;

      @media (max-width: 896px) {
        padding-bottom: 14px;
      }
    }

    .list>li>.content>.title {
      color: var(--color-text-light);
      font-size: 1.75rem;
      font-weight: 700;
      line-height: 1.35714;

      @media (max-width: 896px) {
        font-size: 1rem;
        line-height: 1.375;
      }
    }
  }

  /* ---------------------------------------------
  .about-expansion
------------------------------------------------ */

  @keyframes expansion-pc {
    0% {
      background-position: 0 0;
    }

    100% {
      background-position: -1236px 0;
    }
  }

  @keyframes expansion-sp {
    0% {
      background-position: 0 0;
    }

    100% {
      background-position: -670px 0;
    }
  }

  .about-expansion {
    background: var(--color-fill-brand);

    >.inner {
      position: relative;
      max-width: 1110px;
      margin-inline: auto;
      padding-block: 235px 60px;
      padding-inline: 20px;

      @media (max-width: 896px) {
        padding-block: 129px 40px;
      }

      &::before {
        position: absolute;
        top: 137px;
        left: 50%;
        width: 100vw;
        height: 129px;
        animation: expansion-pc 28s linear infinite;
        background-image: url("/assets/images/about/text-various-fields.png");
        background-position: top;
        background-repeat: repeat-x;
        background-size: 1324px 129px;
        content: "";
        pointer-events: none;
        transform: translateX(-50%);

        @media (max-width: 896px) {
          top: 79px;
          height: 65px;
          animation-name: expansion-sp;
          background-size: 670px 65px;
        }
      }
    }

    >.inner>.title {
      position: relative;
      padding-bottom: 70px;
      color: var(--color-text-light);
      font-size: 2.625rem;
      font-weight: 700;
      line-height: 1.33333;
      text-align: center;

      @media (max-width: 896px) {
        padding-bottom: 60px;
        font-size: 1.75rem;
        line-height: 1.28571;
      }

      &::after {
        position: absolute;
        bottom: 35px;
        left: 50%;
        width: 70px;
        height: 4px;
        border-radius: 4px;
        background-color: var(--color-fill-default);
        content: "";
        transform: translateX(-50%);

        @media (max-width: 896px) {
          bottom: 30px;
        }
      }
    }

    >.inner>.text {
      color: var(--color-text-light);
      font-size: 1.25rem;
      font-weight: 500;
      line-height: 1.7;
      text-align: center;

      @media (max-width: 896px) {
        font-size: 1.125rem;
        line-height: 1.77778;
        text-align: left;
      }
    }

    >.list {
      display: grid;
      max-width: 1210px;
      padding-bottom: 150px;
      gap: 2px;
      grid-template-columns: repeat(4, 1fr);
      margin-inline: auto;
      padding-inline: 20px;

      @media (max-width: 896px) {
        padding-bottom: 50px;
        gap: 3px;
        grid-template-columns: repeat(2, 1fr);
      }
    }

    >.list>li {
      display: flex;
      flex: 1 1 0;
      flex-direction: column;
      padding: 10px 10px 18px;
      border-radius: 5px;
      background: var(--color-fill-default);
      gap: 18px;

      @media (max-width: 896px) {
        padding-bottom: 10px;
        gap: 10px;
      }
    }

    >.list>li>.image {
      overflow: hidden;
      flex-shrink: 0;
      border-radius: 3px;

      @media (max-width: 896px) {
        border-radius: 2px;
      }

      img {
        width: 100%;
        height: auto;
        aspect-ratio: 271 / 144;

        @media (max-width: 896px) {
          aspect-ratio: 146 / 87;
        }
      }
    }

    >.list>li>.wrap {
      display: flex;
      justify-content: center;
    }

    >.list>li>.wrap>.title {
      position: relative;
      color: var(--color-text-default);
      font-size: 1rem;
      font-weight: 500;
      line-height: 1.5;
      text-align: center;

      @media (max-width: 896px) {
        font-size: 0.6875rem;
        font-weight: 400;
        line-height: 1.45455;
      }
    }
  }

  /* ---------------------------------------------
  .about-human
------------------------------------------------ */

  @keyframes human-pc {
    0% {
      background-position: 0 0;
    }

    100% {
      background-position: -1996px 0;
    }
  }

  @keyframes human-sp {
    0% {
      background-position: 0 0;
    }

    100% {
      background-position: -1005px 0;
    }
  }

  .about-human {
    background: var(--color-fill-brand);

    >.inner {
      position: relative;
      max-width: 1110px;
      margin-inline: auto;
      padding-block: 235px 80px;
      padding-inline: 20px;

      @media (max-width: 896px) {
        padding-block: 131px 40px;
      }

      &::before {
        position: absolute;
        top: 137px;
        left: 50%;
        width: 100vw;
        height: 129px;
        animation: human-pc 38s linear infinite;
        background-image: url("/assets/images/about/text-human.png");
        background-position: top;
        background-repeat: repeat-x;
        background-size: 1996px 129px;
        content: "";
        pointer-events: none;
        transform: translateX(-50%);

        @media (max-width: 896px) {
          top: 79px;
          height: 65px;
          animation-name: human-sp;
          background-size: 1005px 65px;
        }
      }
    }

    >.inner>.title {
      position: relative;
      padding-bottom: 70px;
      color: var(--color-text-light);
      font-size: 2.625rem;
      font-weight: 700;
      line-height: 1.33333;
      text-align: center;

      @media (max-width: 896px) {
        padding-bottom: 60px;
        font-size: 1.75rem;
        line-height: 1.28571;
      }

      &::after {
        position: absolute;
        bottom: 35px;
        left: 50%;
        width: 70px;
        height: 4px;
        border-radius: 4px;
        background-color: var(--color-stroke-light);
        content: "";
        transform: translateX(-50%);

        @media (max-width: 896px) {
          bottom: 30px;
        }
      }
    }

    >.inner>.text {
      color: var(--color-text-light);
      font-size: 1.25rem;
      font-weight: 500;
      line-height: 1.7;
      text-align: center;

      @media (max-width: 896px) {
        font-size: 1.125rem;
        line-height: 1.77778;
        text-align: left;
      }
    }

    >.bottom {
      display: grid;
      max-width: 1210px;
      padding-bottom: 150px;
      gap: 30px 3.4188%;
      grid-template-columns: 52.99145% 1fr;
      margin-inline: auto;
      padding-inline: 20px;

      @media (max-width: 896px) {
        padding-bottom: 50px;
        grid-template-columns: 100%;
      }
    }

    >.bottom>.layout>.box {
      padding: 10px 10px 20px;
      border-radius: 5px;
      background: var(--color-fill-default);

      @media (min-width: 897px) {
        max-width: 650px;
      }

      @media (max-width: 896px) {
        padding: 5px 5.5px 10px;
        border-radius: 3px;
      }
    }

    >.bottom>.layout>.box>.list {
      display: grid;
      overflow: hidden;
      border-radius: 3px;
    }

    >.bottom>.layout>.box>.list>.image {
      img {
        width: 100%;
        height: auto;
        aspect-ratio: 600 / 169;

        @media (max-width: 896px) {
          aspect-ratio: 324 / 96;
        }
      }
    }

    >.bottom>.layout>.box>.title {
      margin-top: 15px;
      color: var(--color-text-brand);
      font-size: 1.875rem;
      font-weight: 700;
      line-height: 1.16667;
      text-align: center;

      @media (max-width: 896px) {
        margin-top: 8px;
        font-size: 1rem;
        line-height: 1.125;
      }
    }

    >.bottom>.layout>.service {
      position: relative;

      &::before {
        display: block;
        width: 20px;
        height: 20px;
        background: url("/assets/images/about/icon-plus.svg") 50% / contain no-repeat;
        content: "";
        margin-block: 15px;
        margin-inline: auto;

        @media (max-width: 896px) {
          width: 14px;
          height: 14px;
          margin-block: 7px 8px;
        }
      }

      &::after {
        position: absolute;
        bottom: -26px;
        width: 100%;
        height: 96px;
        background: url("/assets/images/about/bg-polygon.png") 50% / 278px 72px no-repeat;
        content: "";
        margin-inline: auto;

        @media (max-width: 896px) {
          bottom: 0;
          height: 34px;
          background-size: 131px 34px;
        }
      }
    }

    >.bottom>.layout>.service>.inner {
      display: flex;
      width: 100%;
      justify-content: space-between;
      padding: 26px 20px;
      border-radius: 5px;
      background: var(--color-fill-default);
      gap: 5px;

      @media (max-width: 896px) {
        padding: 10px;
        border-radius: 3px;
      }
    }

    >.bottom>.layout>.service>.inner>.list {
      display: grid;
      width: 100%;
      max-width: 200px;
      gap: 6px;

      @media (max-width: 896px) {
        max-width: 29.33333vw;
        gap: 0.8vw;
      }

      li {
        grid-template-columns: 32px 1fr;

        @media (max-width: 896px) {
          grid-template-columns: 4.53333vw 1fr;
        }
      }

      &:first-child li {
        grid-template-columns: 32px auto;

        @media (max-width: 896px) {
          grid-template-columns: 4.53333vw auto;
        }
      }
    }

    >.bottom>.layout>.service>.inner>.list>li {
      position: relative;
      display: grid;
      min-height: 44px;
      align-items: center;
      justify-content: center;
      border-radius: 5px;
      background: var(--color-red-90);
      color: var(--color-text-brand);
      font-size: 0.875rem;
      font-weight: 700;
      gap: 5px;
      line-height: 1.5;
      padding-block: 6px;

      @media (max-width: 896px) {
        min-height: 22px;
        color: var(--color-text-brand);
        font-size: 2.4vw;
        font-weight: 700;
        gap: 0.53333vw;
        line-height: 1.6;
        padding-block: 0.8vw;
      }

      &[data-icon]::before {
        display: block;
        width: 32px;
        height: 32px;
        content: "";

        @media (max-width: 896px) {
          width: 4.53333vw;
          height: 4.53333vw;
        }
      }

      &[data-icon="hardware"]::before {
        background: url("/assets/images/about/icon-hardware.svg") 50% / contain no-repeat;
      }

      &[data-icon="software"]::before {
        background: url("/assets/images/about/icon-software.svg") 50% / contain no-repeat;
      }

      &[data-icon="network"]::before {
        background: url("/assets/images/about/icon-network.svg") 50% / contain no-repeat;
      }

      &[data-icon="support"] {
        padding-inline: 20px 17px;

        @media (max-width: 896px) {
          padding-inline: 1.06667vw 1.33333vw;
        }

        &::before {
          background: url("/assets/images/about/icon-support.svg") 50% / contain no-repeat;
        }
      }

      &[data-icon="logistics"] {
        padding-inline: 20px 17px;

        @media (max-width: 896px) {
          padding-inline: 1.06667vw 1.33333vw;
        }

        &::before {
          background: url("/assets/images/about/icon-logistics.svg") 50% / contain no-repeat;
        }
      }

      &[data-icon="document"] {
        padding-inline: 20px 17px;

        @media (max-width: 896px) {
          padding-inline: 1.06667vw 1.33333vw;
        }

        &::before {
          background: url("/assets/images/about/icon-document.svg") 50% / contain no-repeat;
        }
      }
    }

    >.bottom>.layout>.service>.inner>.wrap {
      width: 108px;
      flex-shrink: 0;

      @media (max-width: 896px) {
        width: 14.4vw;
      }
    }

    >.bottom>.layout>.service>.inner>.wrap>.image {
      display: flex;
      flex-direction: column;
      align-items: center;
      margin-top: 10px;

      @media (max-width: 896px) {
        margin-top: 0.8vw;
      }
    }

    >.bottom>.layout>.service>.inner>.wrap>.image img {
      width: 100%;
      max-width: 59px;
      height: auto;

      @media (max-width: 896px) {
        max-width: 8.26667vw;
      }
    }

    >.bottom>.layout>.service>.inner>.wrap>.image>figcaption {
      margin-top: 8.5px;
      color: var(--color-text-brand);
      font-size: 1.375rem;
      font-weight: 700;
      letter-spacing: -0.03em;
      line-height: 1.22727;
      text-align: center;

      @media (max-width: 896px) {
        margin-top: 1.06667vw;
        font-size: 2.93333vw;
        letter-spacing: -0.03em;
        line-height: 1.36;
      }
    }

    >.bottom>.layout>.service>.text {
      position: relative;
      z-index: 2;
      margin-top: 25px;
      color: var(--color-text-light);
      font-size: 1.375rem;
      font-weight: 700;
      line-height: 1.54545;
      text-align: center;

      @media (max-width: 896px) {
        margin-top: 2px;
        font-size: 0.9375rem;
        line-height: 2.27;
        text-align: center;
      }
    }

    >.bottom>.layout>.customers {
      display: flex;
      width: 100%;
      min-height: 70px;
      align-items: center;
      justify-content: center;
      padding: 10px 20px;
      border-radius: 5px;
      margin-top: 31px;
      background: var(--color-voice-yellow-02);
      color: var(--color-text-brand);
      font-size: 1.375rem;
      font-weight: 700;
      line-height: 1.27273;

      @media (max-width: 896px) {
        min-height: 34px;
        padding: 9px;
        margin-top: 6px;
        font-size: 0.9375rem;
        line-height: 0.96;
      }
    }

    >.bottom>.box>.wrap {
      position: relative;

      &::before {
        position: absolute;
        z-index: 1;
        top: 0;
        left: 0;
        width: 15px;
        height: 15px;
        background: url("/assets/images/about/icon-corner-white.svg") 50% / contain no-repeat;
        content: "";

        @media (max-width: 896px) {
          width: 15px;
          height: 15px;
        }
      }

      &::after {
        position: absolute;
        z-index: 1;
        top: 0;
        right: 0;
        width: 15px;
        height: 15px;
        background: url("/assets/images/about/icon-corner-white.svg") 50% / contain no-repeat;
        content: "";
        transform: rotate(90deg);

        @media (max-width: 896px) {
          width: 15px;
          height: 15px;
        }
      }
    }

    >.bottom>.box>.wrap>.content {
      position: relative;
      display: flex;
      align-items: center;
      padding: 39px;
      border: 1px solid var(--color-red-50);

      @media (max-width: 896px) {
        padding: 19px;
      }

      &::before {
        position: absolute;
        z-index: 1;
        bottom: -1px;
        left: -1px;
        width: 15px;
        height: 15px;
        background: url("/assets/images/about/icon-corner-white.svg") 50% / contain no-repeat;
        content: "";
        transform: rotate(270deg);

        @media (max-width: 896px) {
          width: 15px;
          height: 15px;
        }
      }

      &::after {
        position: absolute;
        z-index: 1;
        right: -1px;
        bottom: -1px;
        width: 15px;
        height: 15px;
        background: url("/assets/images/about/icon-corner-white.svg") 50% / contain no-repeat;
        content: "";
        transform: rotate(180deg);

        @media (max-width: 896px) {
          width: 15px;
          height: 15px;
        }
      }
    }

    >.bottom>.box>.wrap>.content>.inner>p {
      color: var(--color-text-light);
      font-size: 1.125rem;
      font-weight: 500;
      line-height: 1.77778;

      @media (max-width: 896px) {
        font-size: 0.875rem;
        line-height: 1.71429;
      }

      &+& {
        margin-top: 12px;
      }
    }
  }

  /* ---------------------------------------------
  .about-features
------------------------------------------------ */

  @keyframes features-pc {
    0% {
      background-position: 0 0;
    }

    100% {
      background-position: -1810px 0;
    }
  }

  @keyframes features-sp {
    0% {
      background-position: 0 0;
    }

    100% {
      background-position: -911px 0;
    }
  }

  .about-features {
    --width-map-pc: 1600;
    --width-map-sp: 375;
    --height-map-pc: 784;
    --height-map-sp: 232;

    background-color: var(--color-neutral-80);

    >.inner {
      position: relative;
      max-width: 1110px;
      padding-top: 235px;
      margin-inline: auto;
      padding-inline: 20px;

      @media (max-width: 896px) {
        padding-top: 129px;
      }

      &::before {
        position: absolute;
        top: 137px;
        left: 50%;
        width: 100vw;
        height: 129px;
        animation: features-pc 34s linear infinite;
        background-image: url("/assets/images/about/text-features.png");
        background-position: top;
        background-repeat: repeat-x;
        background-size: 1810px 129px;
        content: "";
        pointer-events: none;
        transform: translateX(-50%);

        @media (max-width: 896px) {
          top: 79px;
          height: 65px;
          animation-name: features-sp;
          background-size: 911px 65px;
        }
      }
    }

    >.inner>.title {
      position: relative;
      padding-bottom: 70px;
      color: var(--color-text-default);
      font-size: 2.625rem;
      font-weight: 700;
      line-height: 1.33333;
      text-align: center;

      @media (max-width: 896px) {
        padding-bottom: 60px;
        font-size: 1.75rem;
        line-height: 1.28571;
      }

      &::after {
        position: absolute;
        bottom: 35px;
        left: 50%;
        width: 70px;
        height: 4px;
        border-radius: 4px;
        background-color: var(--color-stroke-brand);
        content: "";
        transform: translateX(-50%);

        @media (max-width: 896px) {
          bottom: 30px;
        }
      }
    }

    >.inner>.text {
      color: var(--color-text-default);
      font-size: 1.25rem;
      font-weight: 500;
      line-height: 1.7;
      text-align: center;

      @media (max-width: 896px) {
        font-size: 1.125rem;
        line-height: 1.77778;
        text-align: left;
      }
    }

    >.map {
      position: relative;
      margin-top: 40px;
      aspect-ratio: var(--width-map-pc) / var(--height-map-pc);
      background: url("/assets/images/about/bg-map-pc.png") 50% / contain no-repeat;

      @media (max-width: 896px) {
        margin-top: 10px;
        aspect-ratio: var(--width-map-sp) / var(--height-map-sp);
        background-image: url("/assets/images/about/bg-map-sp.png");
      }
    }

    >.map>.card {
      position: absolute;
      overflow: hidden;
      width: 100%;
      max-width: calc(189/var(--width-map-pc)*100%);
      padding: calc(7/var(--width-map-pc)*100%) calc(7/var(--width-map-pc)*100%) calc(18/var(--width-map-pc)*100%);
      border-radius: calc(5/var(--width-map-pc)*100vw);
      background: var(--color-fill-brand);
      box-shadow: 0 calc(5/var(--width-map-pc)*100vw) calc(20/var(--width-map-pc)*100vw) 0 rgb(0 0 0 / 10%);

      @media (max-width: 896px) {
        max-width: calc(59/var(--width-map-sp)*100%);
        padding: calc(2/var(--width-map-sp)*100%) calc(2/var(--width-map-sp)*100%) calc(5.5/var(--width-map-sp)*100%);
        border-radius: calc(2/var(--width-map-sp)*100vw);
      }

      &:nth-child(1) {
        top: calc(228/var(--height-map-pc)*100%);
        left: calc(186/var(--width-map-pc)*100%);

        @media (max-width: 896px) {
          top: calc(59/var(--height-map-sp)*100%);
          left: calc(14/var(--width-map-sp)*100%);
        }
      }

      &:nth-child(2) {
        top: calc(187/var(--height-map-pc)*100%);
        left: calc(444/var(--width-map-pc)*100%);

        @media (max-width: 896px) {
          top: calc(46/var(--height-map-sp)*100%);
          left: calc(85/var(--width-map-sp)*100%);
        }
      }

      &:nth-child(3) {
        top: calc(137/var(--height-map-pc)*100%);
        left: calc(698/var(--width-map-pc)*100%);

        @media (max-width: 896px) {
          top: calc(30/var(--height-map-sp)*100%);
          left: calc(155/var(--width-map-sp)*100%);
        }
      }

      &:nth-child(4) {
        top: calc(371/var(--height-map-pc)*100%);
        left: calc(1065/var(--width-map-pc)*100%);
        max-width: calc(266/var(--width-map-pc)*100%);

        @media (max-width: 896px) {
          top: calc(99/var(--height-map-sp)*100%);
          left: calc(258/var(--width-map-sp)*100%);
          max-width: calc(83.5/var(--width-map-sp)*100%);
        }

        >.image img {
          @media (max-width: 896px) {
            aspect-ratio: 79 / 41;
          }
        }
      }
    }

    >.map>.card>.image {
      overflow: hidden;
      border-radius: calc(3/var(--width-map-pc)*100vw);

      @media (max-width: 896px) {
        border-radius: calc(1/var(--width-map-sp)*100vw);
      }

      img {
        width: 100%;
        height: auto;

        @media (max-width: 896px) {
          aspect-ratio: 54 / 51;
        }
      }
    }

    >.map>.card>.text {
      margin-top: calc(18/var(--width-map-pc)*100vw);
      color: var(--color-text-light);
      font-size: calc(24/var(--width-map-pc)*100vw);
      font-weight: 700;
      line-height: 1;
      text-align: center;

      @media (max-width: 896px) {
        margin-top: calc(5.5/var(--width-map-sp)*100vw);
        font-size: calc(10/var(--width-map-sp)*100vw);
      }
    }
  }

  /* ---------------------------------------------
  .about-various
------------------------------------------------ */

  @keyframes various-pc {
    0% {
      background-position: 0 0;
    }

    100% {
      background-position: -1897px 0;
    }
  }

  @keyframes various-sp {
    0% {
      background-position: 0 0;
    }

    100% {
      background-position: -955px 0;
    }
  }

  .about-various {
    background: url("/assets/images/about/bg-various.jpg") 50% / cover no-repeat;

    >.inner {
      position: relative;
      max-width: 1210px;
      margin-inline: auto;
      padding-block: 235px 145px;
      padding-inline: 20px;

      @media (max-width: 896px) {
        padding-block: 129px 70px;
      }

      &::before {
        position: absolute;
        top: 137px;
        left: 50%;
        width: 100vw;
        height: 129px;
        animation: various-pc 36s linear infinite;
        background-image: url("/assets/images/about/text-various.png");
        background-position: top;
        background-repeat: repeat-x;
        background-size: 1897px 129px;
        content: "";
        pointer-events: none;
        transform: translateX(-50%);

        @media (max-width: 896px) {
          top: 79px;
          height: 65px;
          animation-name: various-sp;
          background-size: 955px 65px;
        }
      }
    }

    >.inner>.title {
      position: relative;
      padding-bottom: 70px;
      color: var(--color-text-light);
      font-size: 2.625rem;
      font-weight: 700;
      line-height: 1.33333;
      text-align: center;

      @media (max-width: 896px) {
        padding-bottom: 60px;
        font-size: 1.75rem;
        line-height: 1.28571;
      }

      &::after {
        position: absolute;
        bottom: 35px;
        left: 50%;
        width: 70px;
        height: 4px;
        border-radius: 4px;
        background-color: var(--color-stroke-light);
        content: "";
        transform: translateX(-50%);

        @media (max-width: 896px) {
          bottom: 30px;
        }
      }
    }

    >.inner>.text {
      color: var(--color-text-light);
      font-size: 1.25rem;
      font-weight: 500;
      line-height: 1.7;
      text-align: center;

      @media (max-width: 896px) {
        font-size: 1.125rem;
        line-height: 1.77778;
        text-align: left;
      }
    }

    >.inner>.business-partners {
      margin-block-start: 114px;

      @media (max-width: 896px) {
        margin-block-start: 39px;
      }
    }

    >.inner>.business-partners>.title {
      color: var(--color-text-light);
      font-size: 1.75rem;
      font-weight: 700;
      line-height: 1.28571;
      margin-block-end: 30px;

      @media (max-width: 896px) {
        font-size: 1.375rem;
        line-height: 1.36364;
        margin-block-end: 20px;
        text-align: center;
      }
    }

    >.inner>.business-partners>.image {
      display: block;
      width: 100%;
      margin-top: -67px;

      @media (max-width: 896px) {
        margin-top: 0;
      }

      >img {
        width: 100%;
        height: auto;
      }
    }

    >.inner>.sales-trends {
      margin-block-start: 90px;

      @media (max-width: 896px) {
        margin-block-start: 50px;
      }
    }

    >.inner>.sales-trends>.title {
      display: flex;
      align-items: baseline;
      gap: 30px;
      margin-block-end: 39px;

      @media (max-width: 896px) {
        flex-direction: column;
        align-items: center;
        gap: 11px;
        margin-block-end: 21px;
      }

      >h3 {
        color: var(--color-text-light);
        font-size: 1.75rem;
        font-weight: 700;
        line-height: 1.28571;

        @media (max-width: 896px) {
          font-size: 1.375rem;
          line-height: 1.36364;
        }
      }

      >span {
        color: var(--color-text-light);
        font-size: 0.875rem;
        font-weight: 700;
        line-height: 1.85714;

        @media (max-width: 896px) {
          font-size: 0.75rem;
          line-height: 1.83333;
        }
      }
    }

    >.inner>.sales-trends>.image {
      display: block;
      width: 100%;

      >img {
        width: 100%;
        height: auto;
      }
    }
  }
}

@layer pages {

  /* ---------------------------------------------
  .company-list-card
------------------------------------------------ */
  .company-list-card {
    display: grid;
    grid-gap: 50px 30px;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: 1fr;
    padding-block: 20px;

    @media (max-width: 896px) {
      grid-gap: 60px;
      grid-template-columns: repeat(1, 1fr);
      padding-block: 20px 40px;
    }
  }

  /* ---------------------------------------------
  .company-list-qualified
------------------------------------------------ */
  .company-list-qualified {
    display: flex;
    border-bottom: 1px solid var(--color-stroke-default);
    color: var(--color-text-default);
    font-size: 1rem;
    gap: 10px;
    line-height: 1.75;
    padding-block: 16px;

    @media (max-width: 896px) {
      flex-direction: column;
      gap: 20px;
      padding-block: 20px 27px;
    }

    &:first-of-type {
      @media (min-width: 897px) {
        padding-top: 0;
      }
    }

    >dt {
      width: 150px;
      flex: 1 0 auto;
      font-weight: 700;
    }

    >dd {
      width: 100%;
    }

    >dd>ul {
      display: flex;
      flex-direction: column;
      gap: 18px;

      @media (max-width: 896px) {
        gap: 10px;
      }
    }

    >dd>ul>li {
      display: flex;
      justify-content: space-between;
    }

    >dd>ul>li>.text {
      width: 100%;
    }

    >dd>ul>li>.person {
      width: 50px;
      flex: 1 0 auto;
      text-align: right;
    }
  }

  /* ---------------------------------------------
  .company-philosophy-box
------------------------------------------------ */
  .company-philosophy-box {
    border-top: 1px solid var(--color-stroke-default);
  }

  /* ---------------------------------------------
  .company-message-intro
------------------------------------------------ */
  .company-message-intro {
    padding: 50px 20px 60px;
    border-radius: 5px;
    margin-top: 50px;
    background-color: var(--color-fill-subtle);

    @media (max-width: 896px) {
      margin-top: 30px;
    }

    &:first-child {
      margin-top: 0;
    }

    >.speech {
      font-size: 1.25rem;
      font-weight: 500;
      line-height: 2.2;
      text-align: center;

      @media (max-width: 896px) {
        font-size: 1rem;
        line-height: 2.25;
      }
    }

    >.logo {
      width: 206px;
      margin: 40px auto 0;
    }

    >.logo>img {
      display: block;
      width: 100%;
      height: auto;
    }
  }

  /* ---------------------------------------------
  .company-message-ceo
------------------------------------------------ */
  .company-message-ceo {
    display: grid;
    margin-top: 50px;
    gap: 30px;
    grid-template-columns: repeat(2, 1fr);

    @media (max-width: 896px) {
      margin-top: 30px;
      gap: 40px;
      grid-template-columns: repeat(1, 1fr);
    }

    &:first-child {
      margin-top: 0;
    }

    >.box {
      @media (max-width: 896px) {
        &:nth-child(1) {
          order: 2;
        }

        &:nth-child(2) {
          order: 1;
        }
      }
    }

    >.box>.sign {
      width: 224px;
      margin-top: 40px;
    }

    >.box>.sign>img {
      display: block;
      width: 100%;
      height: auto;
    }

    figure {
      margin: 0;
    }
  }

  /* ---------------------------------------------
  .company-sustainability-large
------------------------------------------------ */
  .company-sustainability-large {
    position: relative;
    margin-top: 30px;

    &::after {
      position: absolute;
      display: block;
      border: 1px solid var(--color-stroke-default);
      content: "";
      inset: 0;
      pointer-events: none;
    }

    &:first-child {
      margin-top: 0;
    }

    >.image {
      position: relative;
      z-index: 2;
    }

    >.image>picture>img {
      display: block;
      width: 100%;
      height: auto;
    }

    figure {
      margin: 0;
    }

    >.box {
      display: flex;
      padding: 29px 30px;
      gap: 30px;

      @media (max-width: 896px) {
        flex-direction: column;
        padding: 19px 20px;
      }
    }

    >.box>.detail {
      width: 100%;
    }

    >.box>.detail>.heading {
      display: flex;
      flex-direction: column;

      +* {
        margin-top: 20px;
      }
    }

    >.box>.detail>.heading>.sub {
      color: var(--color-text-brand);
      font-family: var(--second-family);
      font-size: 1.5rem;
      font-weight: 700;
      line-height: 1.5;

      @media (max-width: 896px) {
        font-size: 1.25rem;
      }
    }

    >.box>.detail>.heading>.title {
      font-size: 1.5rem;
      font-weight: 700;
      line-height: 1.5;

      @media (max-width: 896px) {
        font-size: 1.25rem;
      }
    }

    >.box>.list {
      display: flex;
      width: 100px;
      flex: 1 0 auto;
      flex-flow: column wrap;
      gap: 4px;

      @media (max-width: 896px) {
        width: 100%;
        flex-direction: row;
      }
    }

    >.box>.list>figure {
      @media (max-width: 896px) {
        width: 95px;
      }
    }

    >.box>.list>figure>img {
      display: block;
      width: 100%;
      height: auto;
    }
  }

  /* ---------------------------------------------
  .company-sustainability-normal
------------------------------------------------ */
  .company-sustainability-normal {
    position: relative;

    &::after {
      position: absolute;
      display: block;
      border: 1px solid var(--color-stroke-default);
      content: "";
      inset: 0;
      pointer-events: none;
    }

    >.image {
      position: relative;
      z-index: 2;
    }

    >.image>picture>img {
      display: block;
      width: 100%;
      height: auto;
    }

    figure {
      margin: 0;
    }

    >.box {
      padding: 29px 30px 33px;

      @media (max-width: 896px) {
        padding: 19px 20px;
      }
    }

    >.box>.title {
      display: flex;
      flex-direction: column;
      font-size: 1.25rem;
      font-weight: 700;
      line-height: 1.5;

      +* {
        margin-top: 11px;
      }
    }

    >.box>.link {
      margin-top: 7px;
    }
  }

  .company-box-access {
    display: flex;
    gap: 30px;

    @media (max-width: 896px) {
      flex-direction: column;
    }

    >.box {
      width: min(345px, 39.65517vw);
      flex: 1 0 auto;

      @media (max-width: 896px) {
        width: 100%;
      }
    }

    >.box>.text-small {
      margin-top: 10px;
    }

    >.image {
      width: 100%;
    }
  }
}

@layer pages {

  .temp-contact-details {
    padding-bottom: 49px;
    border-bottom: 1px solid var(--color-stroke-default);
    margin-bottom: 51px;

    @media (max-width: 896px) {
      margin-bottom: 33px;
    }
  }

  .temp-contact-information {
    margin-top: 50px;

    @media (max-width: 896px) {
      margin-top: 30px;
    }

    >.box {
      width: 100%;
      height: 270px;
      padding: 28px 30px;
      border: 1px solid var(--color-stroke-default);
      overflow-y: auto;

      @media (max-width: 896px) {
        height: 480px;
      }
    }
  }

  .temp-thanks {
    text-align: center;
  }

  .contact-catalog-panel {
    display: grid;
    gap: 30px;
    grid-template-columns: repeat(2, 1fr);

    @media (max-width: 896px) {
      gap: 10px;
      grid-template-columns: repeat(1, 1fr);
    }

    >.panel {
      display: flex;
      flex-direction: column;
      justify-content: center;
      padding: 70px 40px;
      border-radius: 5px;
      background-color: var(--color-fill-subtle);

      @media (min-width: 897px) {
        align-items: center;
      }

      @media (max-width: 896px) {
        padding: 30px 17.5px;
      }
    }

    >.panel>.icon {
      width: 36px;
      height: 36px;
    }

    >.panel>.icon>img {
      width: 100%;
      height: 100%;
      -o-object-fit: contain;
      object-fit: contain;
    }

    >.panel>.content {
      display: flex;
      flex-direction: column;
      align-items: center;
      margin-block-start: 15px;
    }

    >.panel>.content>.title {
      font-size: 1.75rem;
      font-weight: 700;
      line-height: 1.42857;

      @media (max-width: 896px) {
        font-size: 1.625rem;
        line-height: 1.30769;
      }
    }

    >.panel>.content>.text {
      font-size: 1.375rem;
      font-weight: 700;
      line-height: 1.81818;

      @media (max-width: 896px) {
        font-size: 1rem;
        line-height: 2.125;
      }
    }

    >.panel>.button {
      margin-block-start: 30px;
    }
  }

  .temp-contact-container {
    .heading-02> :not(span) {
      @media (min-width: 897px) {
        font-size: 2.25rem;
      }
    }
  }
}

@layer pages {
  .temp-diary-related {
    padding: 0 20px 48px;
    border-bottom: 1px solid var(--color-stroke-default);
    margin: 100px -20px 0;

    @media (max-width: 896px) {
      padding-bottom: 30px;
      margin-inline: 0;
      padding-inline: 0;
    }
  }
}

@layer pages {

  .temp-introduction-container {
    background-color: var(--color-fill-subtle);
    padding-block: 50px 0;
  }

  .temp-introduction-box {
    @media (max-width: 896px) {
      padding-bottom: 77px;
    }
  }

  /* Load more items - hidden by default, JS will handle fade-in */
  [data-load-more-item] {
    display: none;
  }

  /* Load more button - hidden by default */
  [data-load-more-button] {
    display: none;
  }

  .introduction-list-filter {
    display: flex;
    width: 100%;
    max-width: var(--max-width-xl);
    flex-direction: column;
    gap: 40px;
    margin-block-end: 50px;
    margin-inline: auto;
    padding-inline: 20px;

    @media (max-width: 896px) {
      max-width: 100%;
      gap: 30px;
      margin-block-end: 30px;
    }

    >.box-filter {
      display: flex;
      flex-direction: column;
      gap: 10px;
    }

    >.box-filter>.label {
      color: var(--color-text-black);
      font-size: 1.125rem;
      font-weight: 700;
      line-height: 1.5;

      @media (max-width: 896px) {
        font-size: 1rem;
        line-height: 1.5;
      }
    }

    >.box-filter>.radio-group {
      display: flex;
      gap: 15px 25px;

      @media (max-width: 896px) {
        gap: 16px;
      }
    }

    >.box-filter>.radio-group>.radio-form>.text {
      padding: 1px 0 1px 30px;
      font-size: 0.9375rem;
      line-height: 1.46667;

      @media (max-width: 896px) {
        font-size: 0.75rem;
        line-height: 1.83333;
      }
    }

    >.box-filter>.radio-group>.radio-form>.input {

      &:checked+.text::before,
      &:not(:checked)+.text::before {
        width: 24px;
        height: 24px;
        border: 2px solid var(--color-stroke-subtle);
        background: transparent;
      }

      &:checked+.text::after,
      &:not(:checked)+.text::after {
        top: 6px;
        left: 6px;
        width: 12px;
        height: 12px;
      }
    }
  }

  .introduction-filter-result {
    width: 100%;
    background-color: var(--color-fill-subtle);
    padding-block-start: 50px;

    >.container>.text-result {
      color: var(--color-text-black);
      font-size: 0.875rem;
      line-height: 1.5;
      margin-block-end: 12px;
    }

    >.container>.text-result>span {
      font-feature-settings: "tnum";
      font-variant-numeric: tabular-nums;
    }

    >.container>.introduction-box>.button {
      display: flex;
      justify-content: center;
    }
  }
}

@layer pages {

  .base-office-box {
    display: grid;
    margin-top: 30px;
    gap: 30px;
    grid-template-columns: repeat(2, 1fr);

    @media (max-width: 896px) {
      margin-top: 30px;
      gap: 20px;
      grid-template-columns: repeat(1, 1fr);
    }

    >.card>.text {
      margin-top: 10px;
      color: var(--color-text-default);
      font-size: 0.875rem;
      font-weight: 400;
      line-height: 1.86;
    }
  }

  .base-building-box {
    display: grid;
    margin-top: 30px;
    gap: 50px;
    grid-template-columns: repeat(2, 1fr);

    @media (max-width: 896px) {
      margin-top: 30px;
      gap: 80px;
      grid-template-columns: repeat(1, 1fr);
    }

    >.card {
      display: flex;
      flex-direction: column;
    }

    >.card>.box-image {
      display: flex;
      margin-top: 30px;
      gap: 5px;
    }

    >.card>.box-image>figure {
      margin-top: 0;
    }

    >.card>.box-image[data-variant-grid="half"] {
      >figure {
        flex: 1;

        >img {
          height: 225px;
          -o-object-fit: cover;
          object-fit: cover;
          -o-object-position: center center;
          object-position: center center;
        }
      }
    }

    >.card>.text-normal {
      flex-grow: 1;
    }
  }
}

@layer pages {

  /* ---------------------------------------------
  .career-training-step
------------------------------------------------ */
  .career-training-step {
    >.step {
      display: flex;
      flex-direction: column;
    }

    >.step+.step {
      position: relative;
      margin-top: 64px;

      &::before {
        position: absolute;
        top: -64px;
        left: 50%;
        display: block;
        width: 210px;
        height: 64px;
        background: url("/assets/images/recruit/career_training/icon-arrow-down-01.svg") center / contain no-repeat;
        content: "";
        transform: translateX(-50%);
      }
    }

    >.step>.heading {
      padding: 10px 20px 12px;
      border-radius: 5px 5px 0 0;
      background-color: var(--color-red-30);
      color: var(--color-gray-100);
      font-size: 1.25rem;
      font-weight: 700;
      line-height: 1.4;
      text-align: center;

      @media (max-width: 896px) {
        font-size: 1.125rem;
        line-height: 1.55556;
      }
    }

    >.step>.content {
      padding: 30px 35px 35px;
      border-radius: 0 0 5px 5px;
      background-color: var(--color-gray-100);

      @media (max-width: 896px) {
        padding: 20px;
      }
    }
  }

  /* ---------------------------------------------
  .career-training-career-vision
------------------------------------------------ */
  .career-training-career-vision {
    @media (max-width: 896px) {
      padding-top: 10px;
    }

    >.heading {
      margin-bottom: 30px;
      color: var(--color-red-30);
      font-size: 1.5rem;
      font-weight: 700;
      line-height: 1.375;
      text-align: center;

      @media (max-width: 896px) {
        font-size: 1.25rem;
        line-height: 1.4;
      }
    }

    >.list {
      display: grid;
      gap: 25px;
      grid-template-columns: repeat(3, minmax(0, 1fr));

      @media (max-width: 896px) {
        gap: 25px;
        grid-template-columns: 1fr;
      }
    }

    >.list>li {
      position: relative;

      @media (max-width: 896px) {
        width: 100%;
      }

      &+li::before {
        position: absolute;
        top: 50%;
        left: -13px;
        display: block;
        width: 15px;
        height: 15px;
        background: url("/assets/images/recruit/career_training/icon-x.svg") center / contain no-repeat;
        content: "";
        transform: translate(-50%, -50%);

        @media (max-width: 896px) {
          top: -13px;
          left: 50%;
          transform: translate(-50%, -50%);
        }
      }
    }

    .card {
      display: flex;
      height: 100%;
      flex-direction: column;
      justify-content: center;
      padding: 22px 20px;
      border-radius: 8px;
      background-color: var(--color-red-95);
      gap: 10px;
      text-align: center;

      @media (max-width: 896px) {
        min-height: auto;
        padding: 25px 10px;
      }
    }

    .card>.title {
      color: var(--color-red-30);
      font-size: 1.0625rem;
      font-weight: 700;
      line-height: 1.47059;

      @media (max-width: 896px) {
        font-size: 0.9375rem;
        line-height: 1.46667;
      }
    }

    .card>.text {
      font-size: 0.875rem;
      line-height: 1.57143;

      @media (max-width: 896px) {
        font-size: 0.75rem;
        line-height: 1.66667;
      }
    }
  }

  /* ---------------------------------------------
  .career-training-system
------------------------------------------------ */
  .career-training-system {
    @media (min-width: 897px) {
      padding-top: 5px;
    }

    .list-course,
    .list-occupation {
      display: grid;
      padding: 0;
      margin: 0;
      gap: 0 10px;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      list-style: none;

      @media (max-width: 896px) {
        gap: 0 3px;
      }
    }

    .list-course::after {
      display: block;
      aspect-ratio: 800 / 84;
      background: url("/assets/images/recruit/career_training/bg-line-01-pc.svg") center / 100% 100% no-repeat;
      content: "";
      grid-column: 1 / -1;

      @media (max-width: 896px) {
        aspect-ratio: 268 / 28;
        background: url("/assets/images/recruit/career_training/bg-line-01-sp.svg") center / 100% 100% no-repeat;
      }
    }

    .list-course>li>.card {
      height: 100%;
      padding: 20px 15px 35px;
      border-radius: 5px;
      text-align: center;

      @media (max-width: 896px) {
        padding: 10px 5px 14px;
      }
    }

    .list-course>li[data-theme-variant="management"]>.card {
      background-color: var(--color-voice-green);
    }

    .list-course>li[data-theme-variant="specialist"]>.card {
      background-color: var(--color-voice-blue);
    }

    .list-course>li[data-theme-variant="expert"]>.card {
      background-color: var(--color-voice-purple);
    }

    .list-course>li>.card>.icon {
      width: 78px;
      margin: 0 auto;

      @media (max-width: 896px) {
        width: 40px;
      }
    }

    .list-course>li>.card>.icon>img {
      width: 100%;
      height: auto;
    }

    .list-course>li>.card>.title {
      font-size: 1.25rem;
      font-weight: 700;
      line-height: 1.4;

      *+& {
        margin-top: 10px;

        @media (max-width: 896px) {
          margin-top: 6px;
        }
      }

      @media (max-width: 896px) {
        font-size: 0.625rem;
        line-height: 1.3;
      }
    }

    .list-course>li[data-theme-variant="management"]>.card>.title {
      color: var(--color-green-30);
    }

    .list-course>li[data-theme-variant="specialist"]>.card>.title {
      color: var(--color-blue-30);
    }

    .list-course>li[data-theme-variant="expert"]>.card>.title {
      color: var(--color-purple-30);
    }

    .list-course>li>.card>.text {
      font-size: 0.875rem;
      line-height: 1.57143;

      *+& {
        margin-top: 5px;

        @media (max-width: 896px) {
          margin-top: 6px;
        }
      }

      @media (max-width: 896px) {
        font-size: 0.5625rem;
        line-height: 1.33333;
      }
    }

    .list-occupation>li>.card {
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 13px 10px;
      border-radius: 5px;
      background-color: var(--color-red-95);
      gap: 6px;

      @media (max-width: 896px) {
        flex-direction: column;
        padding: 7px 5px;
        gap: 0;
      }
    }

    .list-occupation>li>.card>.icon {
      width: 24px;
      flex-shrink: 0;
    }

    .list-occupation>li>.card>.title {
      color: var(--color-red-30);
      font-size: 1rem;
      font-weight: 700;
      line-height: 1.75;

      @media (max-width: 896px) {
        font-size: 0.625rem;
        line-height: 2.2;
        text-align: center;
      }
    }
  }

  /* ---------------------------------------------
  .career-training-path
------------------------------------------------ */
  .career-training-path {
    border-radius: 5px;
    background-color: var(--color-gray-100);

    *+& {
      margin-top: 20px;
    }

    >li {
      &+li {
        border-top: 2px solid var(--color-red-95);
      }
    }

    >li>.card {
      display: flex;
      align-items: center;
      padding: 23px 40px 23px 28px;
      gap: 18px;

      @media (max-width: 896px) {
        flex-direction: column;
        align-items: center;
        padding: 18px 20px 20px;
        gap: 16px;
      }
    }

    >li>.card>.icon {
      width: 94px;
      flex-shrink: 0;
    }

    >li>.card>.icon>img {
      width: 100%;
      height: auto;
      border-radius: 90px;
    }

    >li>.card[data-theme-variant="specialist"]>.icon>img {
      border: 4px solid var(--color-voice-blue);
    }

    >li>.card[data-theme-variant="management"]>.icon>img {
      border: 4px solid var(--color-voice-green);
    }

    >li>.card[data-theme-variant="expert"]>.icon>img {
      border: 4px solid var(--color-voice-purple);
    }

    >li>.card>.content {
      flex: 1;
      padding-top: 2px;
    }

    >li>.card>.content>.title {
      font-size: 1.25rem;
      font-weight: 700;
      line-height: 1.4;
    }

    >li>.card[data-theme-variant="specialist"]>.content>.title {
      color: var(--color-blue-30);
    }

    >li>.card[data-theme-variant="management"]>.content>.title {
      color: var(--color-green-30);
    }

    >li>.card[data-theme-variant="expert"]>.content>.title {
      color: var(--color-purple-30);
    }

    >li>.card>.content>.text {
      font-size: 0.875rem;
      line-height: 1.85714;

      *+& {
        margin-top: 6px;
      }
    }
  }

  /* ---------------------------------------------
  .career-training-box-white
------------------------------------------------ */
  .career-training-box-white {
    padding: 30px;
    border-radius: 5px;
    background-color: var(--color-gray-100);

    @media (max-width: 896px) {
      padding: 20px;
    }

    *+& {
      margin-top: 20px;
    }

    >.heading-05 {
      +.text-normal {
        margin-top: 10px;
      }

      &:not(:first-child) {
        margin-top: 25px;

        @media (max-width: 896px) {
          margin-top: 21px;
        }
      }
    }

    >.heading {
      color: var(--color-text-default);
      font-size: 1rem;
      font-weight: 700;
      line-height: 1.75;

      +* {
        margin-top: 4px;
      }

      &:not(:first-child) {
        margin-top: 24px;
      }
    }

    >.text-normal+.text-norma {
      margin-top: 10px;
    }

    >.list-dots {
      gap: 0;
    }

    >.list-dots>li {
      line-height: 1.75;

      &::before {
        top: 16px;
      }
    }

    >.container>.list-dots>li::before {
      top: calc(14px + var(--dot-size)/3);
    }

    .note {
      font-size: 0.875rem;
      line-height: 1.9;
    }
  }

  /* ---------------------------------------------
  .career-training-text-lead
------------------------------------------------ */
  .career-training-text-lead {
    padding-bottom: 30px;
    border-bottom: 1px solid var(--color-gray-70);
    font-size: 1.125rem;
    line-height: 1.67;

    @media (max-width: 896px) {
      font-size: 1rem;
      line-height: 1.75;
    }

    &+* {
      margin-top: 60px;

      @media (max-width: 896px) {
        margin-top: 30px;
      }
    }
  }

  /* ---------------------------------------------
  .career-training-section
------------------------------------------------ */
  .career-training-section {
    +& {
      margin-top: 60px;

      @media (max-width: 896px) {
        margin-top: 50px;
      }
    }
  }
}

@layer pages {

  /* ---------------------------------------------
  .cross-talk-detail
------------------------------------------------ */
  .cross-talk-detail {
    .lead {
      display: flex;
      flex-direction: column;
      gap: 50px;

      @media (max-width: 896px) {
        gap: 30px;
      }
    }

    .heading {
      display: flex;
      flex-direction: column;
      gap: 10px;
    }

    .heading>.subtitle {
      font-size: 1.375rem;
      font-weight: 700;
      line-height: 1;

      @media (max-width: 896px) {
        font-size: 1.125rem;
      }
    }

    .heading .heading-02>h2 {
      font-size: 2.625rem;
      line-break: strict;
      line-height: 1.42857;

      @media (max-width: 896px) {
        font-size: 1.5rem;
        line-height: 1.5;
      }
    }

    .heading>.caption {
      font-size: 1.375rem;
      font-weight: 700;
      line-height: 1.81818;

      @media (max-width: 896px) {
        font-size: 1rem;
        line-height: 1.8125;
      }
    }

    .hero-image,
    .section-image,
    .participant-card .avatar>.image,
    .answer-card>.box>.avatar {
      margin: 0;
    }

    .hero-image {
      overflow: hidden;
      border-radius: 5px;
      aspect-ratio: 1170 / 570;

      @media (max-width: 896px) {
        aspect-ratio: 335 / 163;
      }
    }

    .hero-image>img,
    .section-image>img,
    .participant-card .avatar>.image>img,
    .answer-card>.box>.avatar>img,
    .cross-talk-card>.image>img {
      display: block;
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
      object-fit: cover;
    }

    .intro .intro-text {
      color: var(--color-text-default);
      font-size: 1.125rem;
      line-height: 1.75;

      @media (max-width: 896px) {
        font-size: 1rem;
      }
    }

    .answer-card .text .text-normal+.text-normal,
    .editor-note .text .text-normal+.text-normal {
      margin-top: 10px;
    }

    .participants {
      display: grid;
      gap: 30px;
      grid-template-columns: repeat(2, minmax(0, 1fr));

      @media (max-width: 896px) {
        margin-top: 20px;
        gap: 10px;
        grid-template-columns: 1fr;
      }
    }

    .participant-card {
      display: grid;
      align-items: center;
      padding: 30px 30px 30px 25px;
      border-radius: 5px;
      border-left: 5px solid var(--color-stroke-brand);
      background-color: var(--color-fill-subtle);
      gap: 0 30px;
      grid-template-areas: "avatar content";
      grid-template-columns: 119px minmax(0, 1fr);

      @media (max-width: 896px) {
        padding: 20px 20px 20px 15px;
        gap: 0 20px;
        grid-template-columns: 87px minmax(0, 1fr);
        grid-template-rows: auto auto;
      }
    }

    .participant-card .avatar {
      grid-area: avatar;
      place-self: center;

      @media (max-width: 896px) {
        place-self: start center;
      }
    }

    .participant-card .content {
      display: flex;
      min-width: 0;
      flex-direction: column;
      gap: 10px;
      grid-area: content;

      @media (max-width: 896px) {
        display: grid;
        gap: 0;
        grid-column: 1 / -1;
        grid-row: 1 / 3;
        grid-template-columns: subgrid;
        grid-template-rows: subgrid;
      }
    }

    .participant-card .avatar>.image {
      overflow: hidden;
      width: 119px;
      border-radius: 999px;
      aspect-ratio: 1;

      @media (max-width: 896px) {
        width: 87px;
        aspect-ratio: 87 / 88;
      }
    }

    .participant-card .name {
      color: var(--color-text-default);
      font-size: 1.25rem;
      font-weight: 700;
      line-height: 1.4;

      @media (max-width: 896px) {
        font-size: 0.875rem;
        grid-column: 1;
        grid-row: 2;
        line-height: 1.71429;
        place-self: start center;
        text-align: center;
      }
    }

    .participant-card .info {
      display: flex;
      min-width: 0;
      flex-direction: column;
      gap: 10px;

      @media (max-width: 896px) {
        align-self: center;
        gap: 7px;
        grid-column: 2;
        grid-row: 1 / 3;
      }
    }

    .participant-card .group {
      display: flex;
      flex-direction: column;

      @media (max-width: 896px) {
        gap: 6px;
      }
    }

    .participant-card .group>div {
      display: flex;
      align-items: flex-start;
      gap: 14px;

      @media (max-width: 896px) {
        flex-direction: column;
        gap: 0;
      }
    }

    .participant-card .group .label {
      flex-shrink: 0;
      font-size: 0.875rem;
      font-weight: 700;
      line-height: 1.85714;

      @media (max-width: 896px) {
        font-size: 0.75rem;
        line-height: 1.66667;
      }
    }

    .participant-card .group .text {
      min-width: 0;

      @media (max-width: 896px) {
        margin-top: 2px;
      }
    }

    .participant-card .group .text>.line {
      display: inline;
      font-size: 0.875rem;
      line-height: 1.85714;

      @media (max-width: 896px) {
        display: block;
        font-size: 0.75rem;
        line-height: 1.66667;
      }
    }

    .participant-card .group .text>.line+.line::before {
      content: " ";

      @media (max-width: 896px) {
        content: none;
      }
    }

    .body {
      width: 100%;
      max-width: var(--max-width-lg);
      padding-top: 120px;
      margin: 0 auto;
    }

    .cross-talk-section+.cross-talk-section,
    .editor-note {
      margin-top: 80px;
    }

    .cross-talk-section>.question {
      display: flex;
      align-items: center;
      margin-bottom: 20px;
      gap: 8px;
    }

    .cross-talk-section>.question>.line {
      width: 25px;
      height: 2px;
      flex-shrink: 0;
      background-color: var(--color-fill-brand);
    }

    .cross-talk-section>.question>.label {
      flex: 1;
      font-size: 1.375rem;
      font-weight: 700;
      line-height: 1.5;

      @media (max-width: 896px) {
        font-size: 1.25rem;
        line-height: 1.5;
      }
    }

    .answers {
      display: flex;
      flex-direction: column;
      gap: 20px;
    }

    .answer-card {
      --answer-avatar-size-pc: 90px;
      --answer-avatar-size-sp: 70px;
    }

    .answer-card[data-avatar-size="large"] {
      --answer-avatar-size-sp: 90px;
    }

    .answer-card>.box {
      display: grid;
      width: 100%;
      min-width: 0;
      align-items: start;
      gap: 0 20px;
      grid-template-areas:
        "avatar name"
        "avatar text";
      grid-template-columns: var(--answer-avatar-size-pc) minmax(0, 1fr);

      @media (max-width: 896px) {
        align-items: center;
        gap: 10px 20px;
        grid-template-areas:
          "avatar name"
          "text text";
        grid-template-columns: var(--answer-avatar-size-sp) minmax(0, 1fr);
      }
    }

    .answer-card>.box>.avatar {
      overflow: hidden;
      width: var(--answer-avatar-size-pc);
      border-radius: 999px;
      aspect-ratio: 1;
      grid-area: avatar;

      @media (max-width: 896px) {
        width: var(--answer-avatar-size-sp);
        align-self: center;
      }
    }

    .answer-card>.box>.name {
      color: var(--color-text-brand);
      font-size: 1rem;
      font-weight: 700;
      grid-area: name;
      line-height: 1.75;

      @media (max-width: 896px) {
        align-self: center;
      }
    }

    .answer-card>.box>.text {
      min-width: 0;
      grid-area: text;
    }

    .section-image {
      overflow: hidden;
      border-radius: 5px;
      margin-top: 80px;
      aspect-ratio: 870 / 490;

      @media (max-width: 896px) {
        aspect-ratio: 335 / 189;
      }
    }

    .editor-note>.box {
      padding: 51px 60px 60px;
      border-radius: 5px;
      background-color: var(--color-red-95);

      @media (max-width: 896px) {
        padding: 30px 20px;
      }
    }

    .editor-note .head {
      margin-bottom: 22px;

      @media (max-width: 896px) {
        margin-bottom: 24px;
      }
    }

    .editor-note .head>.title {
      position: relative;
      width: -moz-fit-content;
      width: fit-content;
    }

    .editor-note .head>.title>h3 {
      color: var(--color-text-brand);
      font-size: 1.625rem;
      font-weight: 700;
      line-height: 1.30769;

      @media (max-width: 896px) {
        font-size: 1.375rem;
        line-height: 1.54545;
      }
    }

    .editor-note .head>.title>.line {
      display: block;
      width: calc(100% + 12px);
      height: 2px;
      border-radius: 2px;
      margin-top: 11px;
      background-color: var(--color-fill-brand);

      @media (max-width: 896px) {
        width: calc(100% + 9px);
        margin-top: 10px;
      }
    }

    .editor-note .head>.title>.icon {
      position: absolute;
      top: -11px;
      left: calc(100% + 8px);
      width: 64px;
      height: 60px;

      @media (max-width: 896px) {
        top: -11px;
        left: calc(100% + 8px);
      }
    }

    .editor-note .text>.text-normal {
      margin-top: 10px;
    }

    .editor-note .text>.text-normal:first-child {
      margin-top: 0;
    }

    .related {
      width: 100%;
      max-width: var(--max-width-lg);
      padding-top: 100px;
      margin: 0 auto;

      @media (max-width: 896px) {
        padding-top: 80px;
      }
    }

    .related>.cards {
      display: grid;
      gap: 30px;
    }

    .cross-talk-card {
      display: grid;
      gap: 20px;
      grid-template-columns: minmax(0, 420fr) minmax(0, 430fr);
      text-decoration: none;

      @media (max-width: 896px) {
        gap: 20px;
        grid-template-columns: 1fr;
      }
    }

    .cross-talk-card>.image {
      overflow: hidden;
      border-radius: 5px;
      margin: 0;
      aspect-ratio: 420 / 225;

      @media (max-width: 896px) {
        aspect-ratio: 335 / 200;
      }
    }

    .cross-talk-card>.image>img {
      transition: transform 300ms ease-out;
    }

    .cross-talk-card>.detail {
      display: flex;
      flex-direction: column;
      gap: 10px;

      @media (max-width: 896px) {
        gap: 6px;
      }
    }

    .cross-talk-card:is(a):hover>.image>img {
      @media (min-width: 897px) {
        transform: scale(1.1);
      }
    }

    .cross-talk-card .detail>.label {
      display: flex;
      align-items: center;
      gap: 10px;
    }

    .cross-talk-card .detail>.label>.line {
      width: 40px;
      height: 1px;
      flex-shrink: 0;
      background-color: var(--color-fill-brand);
    }

    .cross-talk-card .detail>.label>.text {
      color: var(--color-text-brand);
      font-size: 0.875rem;
      font-weight: 700;
      line-height: 1.71429;
    }

    .cross-talk-card .detail>.title {
      font-size: 1.625rem;
      font-weight: 700;
      line-height: 1.46154;

      @media (max-width: 896px) {
        margin-top: 4px;
        font-size: 1.375rem;
        line-height: 1.5;
      }
    }

    .cross-talk-card .detail>.text>p {
      color: var(--color-text-default);
      font-size: 1rem;
      line-height: 1.75;
    }

    .button-primary {
      margin-top: 50px;
      margin-inline: auto;

      @media (max-width: 896px) {
        margin-top: 70px;
      }
    }
  }
}

@layer pages {

  /* ---------------------------------------------
  .graduates-recruitment
------------------------------------------------ */
  .graduates-recruitment,
  .careers-recruitment {
    .inner {
      width: 100%;
      max-width: var(--max-width-lg);
      margin: 0 auto;
    }

    .section+.section {
      margin-top: 100px;

      @media (max-width: 896px) {
        margin-top: 80px;
      }
    }

    .lead {
      margin-bottom: 30px;

      @media (max-width: 896px) {
        margin-bottom: 30px;
      }
    }

    .lead>.text-normal+.text-normal {
      margin-top: 0;
    }

    .lead>.text-normal>a {
      color: var(--color-text-brand);
      text-decoration: underline;
      text-decoration-color: var(--color-text-brand);

      &:hover {
        @media (min-width: 897px) {
          text-decoration: none;
        }
      }
    }

    .group-list {
      display: flex;
      flex-direction: column;
      gap: 30px;

      @media (max-width: 896px) {
        gap: 20px;
      }
    }

    .group-list>.group {
      margin-top: 0;
    }

    .group>.heading-04 {
      @media (max-width: 896px) {
        padding-left: 16px;
      }
    }

    .group>.group-text {
      margin-bottom: 20px;
    }

    .group>.group-text>.text-normal+.text-normal {
      margin-top: 0;
    }

    .group>.group-text>.text-normal>a {
      color: var(--color-text-brand);
      text-decoration: underline;
      text-decoration-color: var(--color-text-brand);

      &:hover {
        @media (min-width: 897px) {
          text-decoration: none;
        }
      }
    }

    .group-list:not([data-group-type="faq"]) .list-accordion-faq>.faq>.question,
    .group-list:not([data-group-type="faq"]) .list-recruitment-items>.faq>.question {
      font-weight: 700;
    }

    .group-list:not([data-group-type="faq"]) .list-accordion-faq>.faq>.question>.note,
    .group-list:not([data-group-type="faq"]) .list-recruitment-items>.faq>.question>.note {
      display: block;
      margin-top: 5px;
      font-size: 0.875rem;
      font-weight: 400;
      line-height: 1.85714;

      @media (max-width: 896px) {
        margin-top: 4px;
      }
    }

    .detail>table {
      width: calc(100% + 20px);
      margin: -15px -10px;
      border-collapse: separate;
      border-spacing: 10px 15px;
    }

    .detail tr {
      -moz-column-break-inside: avoid;
      break-inside: avoid;
    }

    .detail th,
    .detail td {
      padding: 0 0 18px;
      border-bottom: 1px solid var(--color-stroke-subtle);
      text-align: left;
      vertical-align: top;
    }

    .box.no-entry-button .detail tr:last-child>* {
      padding-bottom: 0;
      border-bottom: 0;
    }

    .detail th {
      width: 110px;
      font-weight: 400;
    }

    .detail th>p {
      font-size: 1rem;
      font-weight: 700;
      line-height: 1.75;
    }

    .detail td>p,
    .detail td li {
      font-size: 1rem;
      font-weight: 400;
      line-height: 1.75;
    }

    .detail td>p+p,
    .detail td .paragraphs>p+p {
      margin-top: 0;
    }

    .detail td .definition-list {
      margin: 0;
    }

    .detail td .definition-list>div+div {
      margin-top: 28px;
    }

    .detail td .definition-list dt,
    .detail td .definition-list dd {
      margin: 0;
    }

    .detail td .definition-list dt {
      font-size: 1rem;
      font-weight: 700;
      line-height: 1.75;
    }

    .detail td .definition-list dt:empty {
      display: none;
    }

    .detail td .definition-list dt:not(:empty)+dd {
      margin-top: 0;
    }

    .detail td .definition-list dd>p+p {
      margin-top: 0;
    }

    .detail td>.list {
      padding-left: 24px;
      margin: 0;
      list-style-position: outside;
      list-style-type: disc;
    }

    .detail td>.list>li {
      display: list-item;
    }

    .detail td>.list>li+li {
      margin-top: 0;
    }

    @media (max-width: 896px) {

      .detail>table,
      .detail tr,
      .detail th,
      .detail td {
        display: block;
        width: 100%;
      }

      .detail>table>tbody {
        display: flex;
        flex-direction: column;
        gap: 15px;
      }

      .detail>table {
        width: 100%;
        margin: 0;
        border-spacing: 0;
      }

      .detail tr {
        padding-bottom: 18px;
        border-bottom: 1px solid var(--color-stroke-subtle);
      }

      .detail th,
      .detail td {
        padding: 0;
        border-bottom: 0;
      }

      .detail th {
        margin-bottom: 8px;
      }

      .box.no-entry-button .detail tr:last-child {
        padding-bottom: 0;
        border-bottom: 0;
      }
    }

    .detail+.button {
      display: flex;
      justify-content: center;
      padding-block: 50px 30px;
    }

    .detail+.button>.button-primary {
      margin-top: 0;
    }

    .group-list[data-group-type="faq"] {
      gap: 30px;
    }

    .group-list[data-group-type="faq"] .group+.group {
      margin-top: 0;
    }

    .button-primary {
      margin-top: 50px;
      margin-inline: auto;

      @media (max-width: 896px) {
        margin-top: 30px;
      }
    }
  }
}

@layer pages {

  /* ---------------------------------------------
  .recruit-interview
------------------------------------------------ */
  .recruit-interview {
    .text-normal+section {
      margin-top: 50px;
    }

    >section {
      @media (max-width: 896px) {
        margin-top: 71px;
      }
    }

    >section>.box-grid-2 {
      row-gap: 50px;

      @media (min-width: 897px) {
        grid-template-rows: auto auto auto;
      }

      @media (max-width: 896px) {
        row-gap: 40px;
      }
    }
  }

  /* ---------------------------------------------
  .recruit-interview-card
------------------------------------------------ */
  .recruit-interview-card {
    display: grid;
    row-gap: 20px;

    @media (min-width: 897px) {
      grid-row: span 3;
      grid-template-rows: subgrid;
    }

    >.detail {
      display: grid;
      align-content: start;
      gap: 6px;

      @media (min-width: 897px) {
        grid-row: span 2;
        grid-template-rows: subgrid;
      }
    }

    >figure {
      overflow: hidden;
      border-radius: 5px;
      aspect-ratio: 570 / 339;

      @media (max-width: 896px) {
        aspect-ratio: 335 / 200;
      }
    }

    >figure>img {
      display: block;
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
      object-fit: cover;
      transition: all 300ms ease-out;
    }

    >.detail>.title {
      font-size: 1.5rem;
      font-weight: 700;
      line-height: 1.5;

      @media (max-width: 896px) {
        font-size: 1.375rem;
        line-height: 1.5;
      }
    }

    >.detail>.text {
      font-size: 1rem;
      line-height: 1.625;
    }

    &:hover {
      >figure>img {
        @media (min-width: 897px) {
          transform: scale(1.1);
        }
      }
    }
  }
}

@layer pages {

  /* ---------------------------------------------
  .interview-detail
------------------------------------------------ */
  .interview-detail {
    .lead {
      display: flex;
      flex-direction: column;
      padding-bottom: 60px;
      border-bottom: 1px solid var(--color-stroke-default);
      gap: 50px;

      @media (max-width: 896px) {
        padding-bottom: 20px;
        gap: 30px;
      }

      .heading .subtitle {
        margin-bottom: 10px;
        font-size: 1.375rem;
        font-weight: 700;
        line-height: 1;

        @media (max-width: 896px) {
          margin-bottom: 12px;
          font-size: 1.125rem;
          line-height: 1;
        }
      }

      .heading .heading-02>h2 {
        font-size: 2.625rem;
        line-height: 1.42857;

        @media (max-width: 896px) {
          font-size: 1.5rem;
          line-height: 1.5;
        }
      }

      .profile {
        display: grid;
        align-items: start;
        gap: 30px;
        grid-template-columns: 590fr 550fr;

        @media (max-width: 896px) {
          grid-template-columns: 1fr;
        }
      }

      .profile .image {
        overflow: hidden;
        border-radius: 5px;
        margin: 0;
        aspect-ratio: 590 / 351;

        @media (max-width: 896px) {
          aspect-ratio: 335 / 199;
        }
      }

      .profile .image>img {
        display: block;
        width: 100%;
        height: 100%;
        -o-object-fit: cover;
        object-fit: cover;
      }

      .profile .box {
        padding-top: 2px;
      }

      .profile .profile-head>.joined {
        margin-bottom: 5px;
        font-size: 0.875rem;
        line-height: 1.85714;
      }

      .profile .profile-head>.name,
      .profile .profile-head>.department {
        font-size: 1.375rem;
        font-weight: 700;
        line-height: 1.45455;

        @media (max-width: 896px) {
          font-size: 1.25rem;
          line-height: 1.3;
        }
      }

      .profile .lead-text {
        margin-top: 20px;
      }

      .profile .lead-text>.badge {
        display: inline-flex;
        width: auto;
        min-height: 34px;
        align-items: center;
        padding: 5px 15px;
        border-radius: 5px;
        background-color: var(--color-fill-brand);
        color: var(--color-text-light);
        font-size: 0.875rem;
        font-weight: 500;
        line-height: 1.71429;
      }

      .profile .lead-text>.text {
        margin-top: 10px;
      }

      .text-normal+.text-normal {
        margin-top: 0;
      }
    }

    .body {
      width: 100%;
      max-width: var(--max-width-lg);
      padding-top: 100px;
      margin: 0 auto;

      @media (max-width: 896px) {
        padding-top: 70px;
      }

      .qa+.qa {
        margin-top: 80px;
      }

      .qa .box .question {
        display: flex;
        align-items: center;
        margin-bottom: 20px;
        gap: 8px;
      }

      .qa .box .question>.line {
        width: 25px;
        height: 2px;
        flex-shrink: 0;
        background-color: var(--color-fill-brand);
      }

      .qa .box .question>.label {
        flex: 1;
        font-size: 1.375rem;
        font-weight: 700;
        line-height: 1.5;

        @media (max-width: 896px) {
          font-size: 1.25rem;
          line-height: 1.5;
        }
      }

      .qa.has-image {
        display: grid;
        align-items: start;
        gap: 30px;
        grid-template-columns: 380px 1fr;

        @media (max-width: 896px) {
          display: flex;
          flex-direction: column;
        }
      }

      .qa.has-image>.image {
        overflow: hidden;
        border-radius: 5px;
        margin: 0;
        aspect-ratio: 380 / 284;

        @media (max-width: 896px) {
          width: 100%;
          aspect-ratio: 335 / 250;
        }
      }

      .qa.has-image>.image>img {
        display: block;
        width: 100%;
        height: 100%;
        -o-object-fit: cover;
        object-fit: cover;
      }

      .qa.has-image[data-desktop-layout="text-image"] {
        grid-template-columns: 1fr 380px;
      }

      .qa.has-image[data-desktop-layout="text-image"]>.image {
        order: 2;
      }

      .qa.has-image[data-desktop-layout="text-image"]>.box {
        order: 1;
      }

      .qa.has-image[data-mobile-layout="text-image"]>.image {
        @media (max-width: 896px) {
          order: 2;
        }
      }

      .qa.has-image[data-mobile-layout="text-image"]>.box {
        @media (max-width: 896px) {
          order: 1;
        }
      }

      .text-normal+.text-normal {
        margin-top: 0;
      }
    }

    .related {
      width: 100%;
      max-width: var(--max-width-lg);
      padding-top: 100px;
      margin: 0 auto;

      @media (max-width: 896px) {
        padding-top: 120px;
      }

      .box-recruit-job-slider>.splide:not(.is-initialized.is-active)>.splide__track>.splide__list {
        @media (min-width: 897px) {
          grid-template-columns: repeat(2, 1fr);
        }
      }

      .card-blog .image-card>figure {
        height: 250px;

        @media (max-width: 896px) {
          height: auto;
          aspect-ratio: 335 / 199;
        }
      }

      .card-blog>.box {
        padding-top: 20px;
      }

      .card-blog .info {
        margin-bottom: 6px;
        gap: 40px;
      }

      .card-blog .info>.tag {
        line-height: 1.71429;
      }

      .button-primary {
        margin-top: 50px;

        @media (max-width: 896px) {
          margin-top: 30px;
        }
      }
    }
  }
}

@layer pages {

  /* ---------------------------------------------
  .job-introduction-box
------------------------------------------------ */
  .job-introduction-box {
    display: flex;
    flex-wrap: wrap;
    gap: 30px 50px;

    @media (max-width: 896px) {
      flex-direction: column;
    }

    >.detail {
      @media (min-width: 897px) {
        flex: 1;
      }
    }

    >.detail>.text-normal {
      &+& {
        margin-top: 12px;
      }
    }

    >picture {
      display: block;
      width: 100%;

      @media (min-width: 897px) {
        width: 48.291%;
      }
    }

    >picture>img {
      width: 100%;
      height: auto;
    }
  }

  /* ---------------------------------------------
  .job-introduction-list
------------------------------------------------ */
  .job-introduction-list {
    display: grid;
    margin-top: 50px;
    row-gap: 10px;

    @media (min-width: 897px) {
      margin-top: 120px;
      gap: 15px;
      grid-template-columns: repeat(2, 1fr);
    }

    >li>a {
      position: relative;
      display: flex;
      overflow: hidden;
      height: 100%;
      flex-wrap: wrap;
      align-items: center;
      border-radius: 5px;
      background-color: var(--color-gray-80);

      &::before {
        position: absolute;
        top: 0;
        right: 0;
        width: 30px;
        height: 100%;
        border-radius: 0 5px 5px 0;
        background-color: var(--color-red-30);
        content: "";
      }

      &::after {
        position: absolute;
        top: 50%;
        right: 11px;
        width: 0;
        height: 0;
        border-width: 4px 0 4px 7px;
        border-style: solid;
        border-color: transparent transparent transparent var(--color-gray-100);
        content: "";
        transform: translateY(-50%);
      }

      &:hover>picture>img {
        @media (min-width: 897px) {
          transform: scale(1.1);
        }
      }
    }

    >li>a>picture {
      display: block;
      overflow: hidden;
      width: 35.526%;
      height: 100%;
      aspect-ratio: 119 / 89.5;

      @media (min-width: 897px) {
        width: 38.097%;
        aspect-ratio: 220 / 150;
      }
    }

    >li>a>picture>img {
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
      object-fit: cover;
      transition: all 300ms ease-out;
    }

    >li>a>.detail {
      flex: 1;
      padding: 10px 40px 10px 10px;

      @media (min-width: 897px) {
        padding-inline: 25px 50px;
      }
    }

    >li>a>.detail>.title {
      margin-bottom: 3px;
      font-weight: 500;

      @media (min-width: 897px) {
        margin-bottom: 6px;
        font-size: 1.5625rem;
        line-height: 1.44;
      }
    }

    >li>a>.detail>.text {
      color: var(--color-gray-40);
      font-size: 0.75rem;

      @media (min-width: 897px) {
        font-size: 1rem;
      }
    }
  }
}

@layer pages {

  /* ---------------------------------------------
  recruit-learn-keyword
------------------------------------------------ */
  .recruit-learn-keyword-box {
    display: grid;
    grid-template-columns: 44.44444% 1fr;

    @media (max-width: 896px) {
      grid-template-columns: 1fr;
    }

    &[data-box-size-variant="medium"] {
      grid-template-columns: 45.29915% 1fr;

      @media (max-width: 896px) {
        grid-template-columns: 1fr;
      }
    }

    &[data-box-size-variant="large"] {
      grid-template-columns: 46.92308% 1fr;

      @media (max-width: 896px) {
        grid-template-columns: 1fr;
      }
    }

    &[data-box-size-variant="small"] {
      grid-template-columns: 41.45299% 1fr;

      @media (max-width: 896px) {
        grid-template-columns: 1fr;
      }
    }

    &[data-box-size-variant="full"] {
      grid-template-columns: 1fr;

      >.content,
      >.content:first-child {
        padding-right: 0;
        border-right: none;
      }

      >.content:last-child {
        padding-left: 0;
      }
    }

    &+& {
      @media (min-width: 897px) {
        padding-top: 50px;
        border-top: 1px solid var(--color-stroke-default);
        margin-top: 50px;
      }

      >.content:first-child {
        @media (max-width: 896px) {
          padding-top: 30px;
        }
      }
    }

    >.content {
      @media (max-width: 896px) {
        padding-bottom: 30px;
        border-bottom: 1px solid var(--color-stroke-default);
      }
    }

    >.content+.content {
      @media (max-width: 896px) {
        padding-top: 30px;
      }
    }

    >.content:first-child {
      padding-right: 40px;
      border-right: 1px solid var(--color-stroke-default);

      @media (max-width: 896px) {
        padding-right: 0;
        border-right: none;
        border-bottom: 1px solid var(--color-stroke-default);
      }
    }

    >.content:last-child {
      padding-left: 40px;

      @media (max-width: 896px) {
        padding-left: 0;
        border-bottom: none;
      }
    }

    >.content .heading-row {
      --mb-pc: 50px;
      --mb-sp: 20px;

      display: flex;
      flex-wrap: wrap;
      align-items: center;
      margin-bottom: var(--mb-pc);
      gap: 30px;

      @media (max-width: 896px) {
        flex-direction: column;
        align-items: flex-start;
        margin-bottom: var(--mb-sp);
        gap: 20px;
      }

      .heading,
      .subheading {
        margin-bottom: 0;
      }
    }

    >.content .heading {
      margin-bottom: 30px;

      @media (max-width: 896px) {
        margin-bottom: 20px;
      }
    }

    >.content .heading:has(.u-d-md-none) {
      @media (min-width: 897px) {
        display: flex;
        flex-wrap: wrap;

        >span:first-child {
          padding-right: 0;
        }

        >span:last-child {
          padding-left: 0;
        }
      }
    }

    >.content .heading>span {
      display: inline-flex;
      padding: 2px 10px 4px;
      background-color: var(--color-fill-brand);
      color: var(--color-text-light);
      font-family: var(--font-noto-serif);
      font-size: 3.375rem;
      font-weight: 700;
      letter-spacing: -0.03em;
      line-height: 1;

      @media (max-width: 896px) {
        padding: 4px 10px 6px;
        font-size: 2.375rem;
      }
    }

    >.content .subheading {
      margin-bottom: 10px;
      font-family: var(--font-noto-serif);
      font-size: 1.625rem;
      font-weight: 900;
      line-height: 1.31;

      @media (max-width: 896px) {
        font-size: 1.375rem;
        line-height: 1.36;
      }

      &+* {
        margin-top: 0;
      }
    }

    >.content>.detail-box {
      /* style */
    }

    >.content>.detail-box+.detail-box {
      padding-top: 40px;
      border-top: 1px solid var(--color-stroke-default);
      margin-top: 40px;

      @media (max-width: 896px) {
        padding-top: 30px;
        margin-top: 30px;
      }
    }

    >.content .info-box {
      display: grid;
      gap: 40px;
      grid-template-columns: 1fr 45.24207%;

      @media (max-width: 896px) {
        gap: 20px;
        grid-template-columns: 1fr;
      }

      &[data-size-variant="medium"] {
        grid-template-columns: 1fr 48.75776%;

        @media (max-width: 896px) {
          grid-template-columns: 1fr;
        }
      }
    }

    >.content>picture {
      display: block;
    }

    >.content .image img {
      display: block;
      width: 100%;
      max-width: 100%;
      height: auto;
      border-radius: 5px;
    }

    >.content .text-normal+.image {
      margin-top: 30px;

      @media (max-width: 896px) {
        margin-top: 20px;
      }
    }

    >.content>.list-order+.text-normal {
      margin-top: 10px;

      @media (max-width: 896px) {
        margin-top: 10px;
      }
    }
  }

  .recruit-learn-keyword-bar {
    --mt-pc: 14px;
    --mt-sp: 10px;

    display: table;
    margin-top: var(--mt-pc);
    border-spacing: 0;

    @media (max-width: 896px) {
      margin-top: var(--mt-sp);
    }

    >.bar-row {
      display: table-row;

      >.label,
      >.value {
        display: table-cell;
        color: var(--color-fill-brand);
        font-weight: 700;
        vertical-align: middle;
      }

      >.label {
        width: auto;
        padding-right: 10px;
        font-size: 1.375rem;

        >.inner {
          display: flex;
          align-items: center;
        }

        >.inner>.text {
          padding-right: 10px;
          line-height: 1.2;
        }

        >.inner>.text[data-size-variant="medium"] {
          font-size: 2rem;

          @media (max-width: 896px) {
            font-size: 1.375rem;
          }
        }

        >.inner>.dots {
          min-width: 25px;
          height: 1em;
          flex: 1;
          background-image: radial-gradient(circle, var(--color-fill-brand) 1.5px, transparent 1.5px);
          background-position: left center;
          background-repeat: repeat-x;
          background-size: 8px;
        }
      }

      >.value {
        white-space: nowrap;

        >.number {
          font-family: var(--second-family);
          font-feature-settings: "tnum";
          font-size: 3.125rem;
          font-variant-numeric: tabular-nums;
          font-weight: 900;
          letter-spacing: 0.03em;
          line-height: 1.08;

          @media (max-width: 896px) {
            font-size: 3rem;
          }
        }

        >.number[data-size-variant="medium"] {
          font-size: 5rem;
          line-height: 0.86;

          @media (max-width: 896px) {
            font-size: 3.125rem;
            line-height: 1.08;
          }
        }

        >.number[data-spacing-variant="medium"] {
          @media (max-width: 896px) {
            letter-spacing: 0.1em;
          }
        }

        >.number>.unit {
          font-family: var(--font-family);
          font-size: 1.875rem;
          font-weight: 700;
          letter-spacing: 0.03em;
          line-height: 1.08;
        }

        >.number>.unit[data-size-variant="medium"] {
          font-size: 1.875rem;

          @media (max-width: 896px) {
            font-size: 1.875rem;
          }
        }
      }
    }
  }

  .recruit-learn-keyword-location {
    display: flex;
    flex-direction: column;
    gap: 9px;

    @media (max-width: 896px) {
      flex-flow: row wrap;
      padding-left: 5px;
      gap: 20px;
    }

    >.number {
      display: flex;
      align-items: baseline;
      justify-content: center;
      color: var(--color-text-brand);
      font-family: var(--second-family);
      font-size: 5rem;
      font-weight: 700;
      gap: 5px;
      line-height: 0.68;
      text-align: center;

      @media (max-width: 896px) {
        position: relative;
        top: -3px;
        flex-direction: column;
        align-items: center;
        font-size: 3.125rem;
        line-height: 0.68;
      }
    }

    >.number>.unit {
      font-family: var(--font-family);
      font-size: 1.875rem;
    }

    >.city {
      position: relative;
      padding: 0 16px;
      color: var(--color-text-brand);
      font-size: 1.375rem;
      font-weight: 700;
      line-height: 1.45;
      text-align: center;
    }

    >.city span {
      font-size: 1rem;
    }

    >.city::before,
    >.city::after {
      position: absolute;
      top: 50%;
      width: 10px;
      height: 96px;
      content: "";
      transform: translateY(-50%);
    }

    >.city::before {
      left: 0;
      background-image: url("/assets/images/recruit/learn_keyword/icon-bracket-left-01.svg");
      background-position: 0 0;
      background-repeat: no-repeat;
      background-size: contain;
    }

    >.city::after {
      right: 0;
      background-image: url("/assets/images/recruit/learn_keyword/icon-bracket-right-01.svg");
      background-position: 0 0;
      background-repeat: no-repeat;
      background-size: contain;
    }
  }

  .recruit-learn-keyword-bar-container {
    display: flex;
    flex-wrap: wrap;
    gap: 40px 68px;

    @media (max-width: 896px) {
      flex-direction: column;
      gap: 20px;
    }

    >.content-pc {
      display: flex;
      flex-wrap: wrap;
      margin-top: -20px;
      margin-bottom: -20px;
      gap: 40px 80px;

      @media (max-width: 896px) {
        display: none;
      }
    }

    >.content-pc>* {
      margin-top: 0;
    }

    >.content-pc>.recruit-learn-keyword-bar>.bar-row>* {
      padding-top: 10px;
      padding-bottom: 10px;
    }

    >.content-sp {
      display: none;

      @media (max-width: 896px) {
        display: block;
        margin-top: -9px;
      }
    }
  }
}

@layer pages {

  /* ---------------------------------------------
  .message-manager
------------------------------------------------ */
  .message-manager {
    overflow: hidden;

    .lead {
      margin-bottom: 40px;
      font-weight: 700;
      line-height: 1.75;

      @media (min-width: 897px) {
        margin-bottom: 60px;
        font-size: 1.5rem;
        line-height: 1.66667;
      }
    }

    .text-normal {
      &+& {
        margin-top: 28px;
      }
    }

    .tab-content>.tabs {
      @media (min-width: 897px) {
        margin-bottom: 80px;
      }
    }
  }

  /* ---------------------------------------------
  .box-content-label
------------------------------------------------ */
  .box-content-label {
    &[data-style-variant="slide"] {
      >.container {
        padding-inline: 0;

        @media (min-width: 897px) {
          padding-bottom: 80px;
        }
      }

      >.container>.inner {
        padding-inline: 20px;

        @media (min-width: 897px) {
          max-width: 910px;
        }
      }
    }
  }

  /* ---------------------------------------------
  .message-manager-slider
------------------------------------------------ */
  .message-manager-slider {
    margin-inline: calc(50% - 50dvw);

    @media (min-width: 897px) {
      padding-inline: 105px;
    }

    >.splide {
      position: relative;

      &::before,
      &::after {
        @media (min-width: 897px) {
          position: absolute;
          z-index: 1;
          top: 0;
          width: 70px;
          height: 100%;
          background: linear-gradient(90deg,
              var(--color-gray-100) 0%,
              rgb(from var(--color-gray-100) r g b / 0%) 100%);
          content: "";
        }
      }

      &::before {
        @media (min-width: 897px) {
          left: 0;
        }
      }

      &::after {
        @media (min-width: 897px) {
          right: 0;
          transform: rotate(180deg);
        }
      }
    }

    >.splide>.splide__track>.splide__list>.splide__slide>figure {
      height: 100%;
    }

    >.splide>.splide__track>.splide__list>.splide__slide>figure>img {
      overflow: hidden;
      width: 100%;
      height: 100%;
      border-radius: 5px;
      -o-object-fit: cover;
      object-fit: cover;
    }
  }
}

@layer pages {
  .message-president-heading {
    font-family: var(--font-noto-serif);
    font-size: 2.625rem;
    font-weight: 900;
    line-height: 1.28571;
    margin-block-end: 30px;

    @media (max-width: 896px) {
      font-size: 1.75rem;
      line-height: 1.5;
    }

    &+.text-normal {
      margin-block-start: 0;
    }
  }

  .message-president-subheading {
    font-family: var(--font-noto-serif);
    font-size: 1.75rem;
    font-weight: 900;
    line-height: 1.28571;
    margin-block-end: 30px;

    @media (max-width: 896px) {
      font-size: 1.375rem;
      line-height: 1.36364;
    }

    &+.text-normal {
      margin-block-start: 0;
    }
  }

  .message-president-name {
    display: flex;
    align-items: center;
    gap: 30px;
    margin-block-start: 52px;

    @media (max-width: 896px) {
      margin-block-start: 50px;
    }

    >.position {
      font-family: var(--font-noto-serif);
      font-size: 1.125rem;
      line-height: 2;
    }

    >.signature {
      display: block;
      width: auto;
      height: 40px;
    }
  }
}

@layer pages {

  /* ---------------------------------------------
  .one-week-detail
------------------------------------------------ */
  .one-week-detail {

    /* ---------------------------------------------
    Intro
  ------------------------------------------------ */
    .intro {
      padding-bottom: 80px;
      border-bottom: 1px solid var(--color-stroke-default);

      @media (max-width: 896px) {
        padding-bottom: 60px;
      }
    }

    .intro>.heading {
      margin-bottom: 50px;

      @media (max-width: 896px) {
        margin-bottom: 30px;
      }
    }

    .intro>.heading>.subtitle {
      margin-bottom: 10px;
      font-size: 1.375rem;
      font-weight: 700;
      line-height: 1;

      @media (max-width: 896px) {
        margin-bottom: 12px;
        font-size: 1.375rem;
        line-height: 1;
      }
    }

    .intro>.heading>.title {
      font-size: 2.875rem;
      font-weight: 700;
      line-height: 1.52174;

      @media (max-width: 896px) {
        font-size: 1.75rem;
        line-height: 1.5;
      }
    }

    .intro+.day {
      margin-top: 70px;
    }

    .profile {
      display: flex;
      align-items: flex-start;
      gap: 30px;

      @media (max-width: 896px) {
        flex-direction: column;
      }
    }

    .profile>.image {
      overflow: hidden;
      flex: 420;
      flex-shrink: 0;
      border-radius: 5px;
      aspect-ratio: 420 / 250;

      @media (max-width: 896px) {
        width: 100%;
        flex: 1;
      }
    }

    .profile>.image>img {
      display: block;
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
      object-fit: cover;
    }

    .profile>.box {
      flex: 420;

      @media (max-width: 896px) {
        width: 100%;
        flex: 1;
      }
    }

    .profile>.box>.joined {
      margin-bottom: 10px;
      font-size: 0.875rem;
      line-height: 1.85714;
    }

    .profile>.box>.department {
      margin-bottom: 20px;
      font-size: 1.375rem;
      font-weight: 700;
      line-height: 1.5;
    }

    .profile>.box>.text {
      >.text-normal+.text-normal {
        margin-top: 0;
      }
    }

    /* ---------------------------------------------
    Day section
  ------------------------------------------------ */
    .day {
      margin-top: 120px;

      @media (max-width: 896px) {
        margin-top: 70px;
      }
    }

    .day>.head {
      display: flex;
      align-items: center;
      margin-bottom: 40px;
      gap: 20px;

      @media (max-width: 896px) {
        margin-bottom: 40px;
      }
    }

    .day>.head>.icon {
      width: 60px;
      flex-shrink: 0;
      margin: 0;
    }

    .day>.head>.icon>img {
      display: block;
      width: 100%;
      height: auto;
    }

    .day>.head>.title {
      font-size: 1.75rem;
      font-weight: 700;
      line-height: 1.5;

      @media (max-width: 896px) {
        flex: 1;
        font-size: 1.375rem;
        line-height: 1.5;
      }
    }

    .summary {
      display: flex;
      align-items: flex-start;
      margin-bottom: 30px;
      gap: 30px;

      @media (max-width: 896px) {
        flex-direction: column;
      }
    }

    .summary>.image {
      overflow: hidden;
      width: 270px;
      flex-shrink: 0;
      border-radius: 5px;
      aspect-ratio: 270 / 165;

      @media (max-width: 896px) {
        width: 100%;
        aspect-ratio: 335 / 205;
      }
    }

    .summary>.image>img {
      display: block;
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
      object-fit: cover;
    }

    .summary>.text {
      flex: 1;

      >.text-normal+.text-normal {
        margin-top: 0;
      }
    }

    /* ---------------------------------------------
    Schedule
  ------------------------------------------------ */
    .schedule>.heading {
      display: flex;
      align-items: center;
      padding: 12px 15px;
      border-radius: 5px;
      margin-bottom: 20px;
      background-color: var(--color-fill-subtle);
      font-size: 1.125rem;
      font-weight: 700;
      gap: 8px;
      line-height: 1.5;
    }

    .schedule>.heading>.icon {
      width: 24px;
      height: 24px;
      flex-shrink: 0;
      background: url("/assets/images/recruit/one_week/icon-alarm.svg") no-repeat center / contain;
    }

    .schedule>.table {
      width: 100%;
      border-collapse: separate;
      border-spacing: 10px 0;

      th,
      td {
        padding-bottom: 18px;
        border-bottom: 1px solid var(--color-stroke-default);
        font-size: 1rem;
        font-weight: 400;
        line-height: 1.75;
        text-align: left;
        vertical-align: top;
      }

      tr+tr>* {
        padding-top: 15px;
      }

      th {
        width: 110px;
        font-weight: 400;
        white-space: nowrap;

        @media (max-width: 896px) {
          width: 102px;
        }
      }

      td>p+p {
        margin-top: 6px;
      }
    }

    /* ---------------------------------------------
    Related
  ------------------------------------------------ */
    .related {
      margin-top: 80px;

      .button-primary {
        margin-top: 50px;

        @media (max-width: 896px) {
          margin-top: 30px;
        }
      }
    }

    .related .box-recruit-job-slider>.splide:not(.is-initialized.is-active)>.splide__track>.splide__list {
      @media (min-width: 897px) {
        grid-template-columns: repeat(2, 1fr);
      }
    }

    .related .one-week-card {
      display: block;
      text-decoration: none;
    }

    .related .one-week-card>.image {
      overflow: hidden;
      border-radius: 5px;
      margin: 0;
      aspect-ratio: 420 / 250;
    }

    .related .one-week-card>.image>img {
      display: block;
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
      object-fit: cover;
      transition: transform 300ms ease-out;
    }

    .related .one-week-card>.box {
      display: flex;
      flex-direction: column;
      padding-top: 20px;
      gap: 6px;
    }

    .related .one-week-card>.box>.meta {
      display: flex;
      align-items: center;
      color: var(--color-text-subtle);
      font-size: 0.875rem;
      gap: 20px;
      line-height: 1.71429;
    }

    .related .one-week-card>.box>.meta>span {
      position: relative;
      white-space: nowrap;
    }

    .related .one-week-card>.box>.meta>.joined::before {
      position: absolute;
      top: 50%;
      left: -10px;
      display: block;
      width: 1px;
      height: 15px;
      background-color: var(--color-text-subtle);
      content: "";
      transform: translateY(-50%);
    }

    .related .one-week-card>.box>.title {
      font-size: 1.25rem;
      font-weight: 500;
      line-height: 1.7;
    }

    .related .one-week-card>.box>.info {
      color: var(--color-text-subtle);
      font-size: 0.875rem;
      line-height: 1.85714;
    }

    .related .one-week-card:is(a):hover>.image>img {
      @media (min-width: 897px) {
        transform: scale(1.1);
      }
    }
  }
}

@layer pages {

  /* ---------------------------------------------
  recruit-philosophy
------------------------------------------------ */
  .philosophy-image-box {
    width: 100%;
    max-width: 100%;
    margin-top: 50px;

    >img {
      display: block;
      width: 100%;
      height: auto;
    }
  }

  .philosophy-action-box {
    display: grid;
    margin-top: 30px;
    gap: 15px;
    grid-template-columns: repeat(2, 1fr);

    @media (max-width: 896px) {
      gap: 10px;
      grid-template-columns: 1fr;
    }

    >.item {
      display: grid;
      padding: 30px 20px;
      border-radius: 5px;
      background: var(--color-gray-100);
      grid-row: span 2;
      grid-template-rows: subgrid;

      @media (max-width: 896px) {
        padding: 20px 15px;
      }
    }

    >.item>.title {
      color: var(--color-text-brand);
      font-size: 1.75rem;
      font-weight: 700;
      line-height: 1.21;
      text-align: center;

      @media (max-width: 896px) {
        font-size: 1.25rem;
        line-height: 1.5;
        text-align: left;
      }
    }

    >.item>.text-normal {
      margin-top: 0;
      text-align: center;

      @media (max-width: 896px) {
        text-align: left;
      }
    }
  }
}

@layer pages {
  .recruit-top-mv {
    position: relative;
    height: 723px;
    padding-inline: 20px;

    @media (width <=1154px) {
      height: 62.65165vw;
    }

    @media (max-width: 896px) {
      height: auto;
      padding-inline: 0;
    }

    >.bg {
      position: absolute;
      z-index: 0;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;

      @media (max-width: 896px) {
        top: auto;
        bottom: 0;
        height: 241px;
      }
    }

    >.bg>img {
      position: absolute;
      top: 0;
      left: 0;
      display: block;
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
      object-fit: cover;
    }

    >.inner {
      position: relative;
      z-index: 1;
      max-width: 1114px;
      margin-inline: auto;

      @media (max-width: 896px) {
        max-width: none;
        padding-bottom: 241px;
      }
    }

    >.inner>.person {
      position: relative;
      z-index: 1;
      display: block;
      width: 661px;

      @media (width <=1154px) {
        width: 57.27903vw;
      }

      @media (max-width: 896px) {
        position: absolute;
        bottom: 0;
        left: 50%;
        width: 280px;
        transform: translateX(-50%);
      }
    }

    >.inner>.person>img {
      display: block;
      width: 100%;
      height: auto;
    }

    >.inner>.content {
      position: absolute;
      z-index: 0;
      top: 50%;
      right: 0;
      width: 534px;
      border-radius: 5px;
      background-color: var(--color-red-30);
      transform: translateY(-50%);

      @media (width <=1154px) {
        width: 46.27383vw;
      }

      @media (max-width: 896px) {
        position: relative;
        top: auto;
        right: auto;
        width: 100%;
        border-radius: 0;
        transform: none;
      }

      &::after {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: url("/assets/images/recruit/top/bg-recruit-mv-content-pc.png");
        background-size: cover;
        content: "";

        @media (max-width: 896px) {
          width: auto;
          height: 100%;
          aspect-ratio: 262 / 403;
          background-image: url("/assets/images/recruit/top/bg-recruit-mv-content-sp.png");
        }
      }
    }

    >.inner>.content>.content-inner {
      position: relative;
      z-index: 1;
      padding: 60px 70px;

      @media (width <=1154px) {
        padding: 5.19931vw 6.06586vw;
      }

      @media (max-width: 896px) {
        padding: 50px 20px;
      }
    }

    >.inner>.content>.content-inner>.title-sub {
      position: relative;
      padding-left: 50px;
      color: var(--color-gray-100);
      font-family: var(--second-family);
      font-size: 1.375rem;
      font-weight: 700;
      line-height: 1.27273;

      @media (width <=1154px) {
        padding-left: 4.33276vw;
        font-size: 1.90641vw;
      }

      @media (max-width: 896px) {
        padding-left: 50px;
        font-size: 1.375rem;
      }

      &::before {
        position: absolute;
        top: 50%;
        left: 0;
        width: 40px;
        height: 1px;
        background-color: var(--color-red-50);
        content: "";

        @media (width <=1154px) {
          width: 3.4662vw;
        }

        @media (max-width: 896px) {
          width: 40px;
        }
      }
    }

    >.inner>.content>.content-inner>.title-main {
      display: block;
      max-width: 394px;
      margin-top: 20px;

      @media (width <=1154px) {
        max-width: 34.14211vw;
        margin-top: 1.7331vw;
      }

      @media (max-width: 896px) {
        max-width: 329px;
        margin-top: 19px;
      }
    }

    >.inner>.content>.content-inner>.title-main>img {
      display: block;
      width: 100%;
      height: auto;
    }

    >.inner>.content>.content-inner>.text {
      margin-top: 40px;
      color: var(--color-gray-100);
      font-size: 1rem;
      line-height: 1.75;

      @media (width <=1154px) {
        margin-top: 3.4662vw;
        font-size: 1.38648vw;
      }

      @media (max-width: 896px) {
        margin-top: 30px;
        font-size: 0.875rem;
        line-height: 1.71429;
      }
    }
  }

  .recruit-top-float-buttons {
    position: fixed;
    z-index: 10;
    right: 0;
    bottom: 0;
    display: flex;
    flex-direction: column;
    padding: 10px 9px;
    background-color: var(--color-gray-100);
    border-top-left-radius: 5px;
    gap: 2px;
    transition: opacity 200ms ease-out;

    @media (max-width: 896px) {
      right: 15px;
      bottom: 15px;
      left: 15px;
      overflow: hidden;
      flex-direction: row;
      padding: 0;
      border: 1px solid var(--color-red-40);
      border-radius: 5px;
      gap: 0;
    }

    &[aria-hidden="true"] {
      opacity: 0;
      pointer-events: none;
    }

    >a {
      position: relative;
      display: flex;
      width: 185px;
      align-items: center;
      padding: 15px 20px 15px 15px;
      border-radius: 5px;
      background-color: var(--color-red-30);
      color: var(--color-gray-100);
      font-size: 1rem;
      font-weight: 500;
      transition: background-color 300ms ease-out;

      @media (max-width: 896px) {
        width: auto;
        flex: 1;
        justify-content: center;
        padding: 15px 10px;
        border-radius: 0;
        font-size: 0.75rem;
        text-align: center;
      }

      &:hover {
        @media (min-width: 897px) {
          background-color: var(--color-primary-50);
        }
      }

      &::after {
        position: absolute;
        top: 50%;
        right: 15px;
        display: block;
        width: 0;
        height: 0;
        border-width: 4px 0 4px 8px;
        border-style: solid;
        border-color: transparent transparent transparent var(--color-gray-100);
        content: "";
        transform: translateY(-50%);

        @media (max-width: 896px) {
          display: none;
        }
      }

      &[data-button="careers"] {
        background-color: var(--color-red-25);

        &:hover {
          @media (min-width: 897px) {
            background-color: var(--color-primary-40);
          }
        }
      }

      &[data-button="entry"] {
        background-color: var(--color-gray-10);

        &:hover {
          @media (min-width: 897px) {
            background-color: var(--color-gray-20);
          }
        }
      }
    }
  }

  .recruit-top-wrapper {
    position: relative;
    overflow: hidden;
    background-color: var(--color-red-30);
    padding-block: 200px 506px;

    @media (width <=1600px) {
      padding-block-end: 460px;
    }

    @media (max-width: 896px) {
      padding-block: 100px max(277px, 41.29464vw);
    }

    &::before {
      position: absolute;
      z-index: 0;
      top: 0;
      right: 0;
      width: 608px;
      height: 802px;
      background: url("/assets/images/recruit/top/bg-recruit-content-top-pc.png") no-repeat;
      background-size: contain;
      content: "";

      @media (width <=1600px) {
        width: 38vw;
        height: 50.125vw;
      }

      @media (max-width: 896px) {
        width: 276px;
        height: 306px;
        background-image: url("/assets/images/recruit/top/bg-recruit-content-top-sp.png");
      }
    }

    &::after {
      position: absolute;
      z-index: 0;
      right: 0;
      bottom: 0;
      width: 697px;
      height: 919px;
      background: url("/assets/images/recruit/top/bg-recruit-content-bottom-pc.png") no-repeat;
      background-size: contain;
      content: "";

      @media (width <=1600px) {
        width: 43.5625vw;
        height: 57.4375vw;
      }

      @media (max-width: 896px) {
        width: 293px;
        height: 386px;
        background-image: url("/assets/images/recruit/top/bg-recruit-content-bottom-sp.png");
      }
    }
  }

  .recruit-top-section {
    position: relative;
    z-index: 1;
    max-width: 2000px;
    color: var(--color-gray-100);
    font-size: 1rem;
    line-height: 1.75;
    margin-inline: auto;
    padding-inline: 20px;

    &:not(:first-child) {
      margin-block-start: 280px;

      @media (max-width: 896px) {
        margin-block-start: 112px;
      }
    }

    >.inner {
      max-width: 1170px;
      margin-inline: auto;
    }
  }

  .recruit-top-heading {
    position: relative;
    margin-block-end: 30px;

    @media (max-width: 896px) {
      margin-block-end: 22px;
    }

    >span {
      display: inline-block;
      background: linear-gradient(180deg, #8a0720 20.11%, #a70524 83.68%);
      -webkit-background-clip: text;
      background-clip: text;
      font-family: var(--second-family);
      font-size: 10rem;
      font-weight: 700;
      letter-spacing: -0.02em;
      line-height: 1;
      -webkit-text-fill-color: transparent;
      white-space: nowrap;

      @media (max-width: 896px) {
        font-size: 5.3125rem;
      }
    }

    >img,
    >picture>img {
      --height-pc: 82px;
      --height-sp: 52px;

      position: relative;
      z-index: 1;
      display: block;
      width: auto;
      height: var(--height-pc);
      margin-block-start: -77px;

      @media (max-width: 896px) {
        height: var(--height-sp);
        margin-block-start: -38px;
      }
    }
  }

  .recruit-top-company-grid {
    display: grid;
    gap: 10px;
    grid-template-areas:
      "first first second second"
      "first first third fourth";
    grid-template-columns: repeat(4, 1fr);
    margin-block-start: 50px;

    @media (max-width: 896px) {
      gap: 20px;
      grid-template-areas:
        "first"
        "second"
        "third"
        "fourth";
      grid-template-columns: 1fr;
      margin-block-start: 30px;
    }

    >a {
      position: relative;
      display: block;
      overflow: hidden;
      border-radius: 6px;

      &:hover>picture>img {
        @media (min-width: 897px) {
          transform: scale(1.1);
        }
      }
    }

    >a>picture>img {
      position: absolute;
      z-index: 0;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      border-radius: 5px;
      -o-object-fit: cover;
      object-fit: cover;
      transition: transform 300ms ease-out;

      @media (max-width: 896px) {
        position: static;
        height: auto;
        -o-object-fit: fill;
        object-fit: fill;
      }
    }

    >a>.text {
      position: absolute;
      z-index: 1;
      bottom: 10px;
      left: 10px;
      display: flex;
      overflow: hidden;
      min-height: 56px;
      align-items: center;
      padding: 5px 45px 5px 20px;
      border-radius: 5px;
      background-color: var(--color-gray-100);
      font-size: 1.375rem;
      font-weight: 700;
      line-height: 1.18182;

      @media (width <=1600px) {
        min-height: 3.5vw;
        padding: 0.3125vw 45px 0.3125vw 1.25vw;
        font-size: 1.375vw;
      }

      @media (max-width: 896px) {
        bottom: 0;
        left: 0;
        width: 100%;
        min-height: 48px;
        padding: 5px 45px 5px 20px;
        border-top-left-radius: 0;
        border-top-right-radius: 0;
        font-size: 1.125rem;
        line-height: 1.33333;
      }

      &[data-font-size="small"] {
        font-size: 1.0625rem;
        line-height: 1.41176;

        @media (width <=1600px) {
          font-size: 1.0625vw;
        }

        @media (max-width: 896px) {
          font-size: 1.125rem;
          line-height: 1.33333;
        }
      }

      &::before {
        position: absolute;
        z-index: 0;
        top: 0;
        right: 0;
        width: 25px;
        height: 100%;
        background-color: var(--color-gray-10);
        content: "";
      }

      &::after {
        position: absolute;
        z-index: 1;
        top: 50%;
        right: 9px;
        width: 0;
        height: 0;
        border-width: 4px 0 4px 7px;
        border-style: solid;
        border-color: transparent transparent transparent var(--color-gray-100);
        content: "";
        transform: translateY(-50%);
      }
    }

    >.box-first {
      grid-area: first;
    }

    >.box-second {
      aspect-ratio: 975 / 496;
      grid-area: second;

      @media (max-width: 896px) {
        aspect-ratio: auto;
      }
    }

    >.box-third {
      aspect-ratio: 482.5 / 308.5;
      grid-area: third;

      @media (max-width: 896px) {
        aspect-ratio: auto;
      }
    }

    >.box-fourth {
      aspect-ratio: 482.5 / 308.5;
      grid-area: fourth;

      @media (max-width: 896px) {
        aspect-ratio: auto;
      }
    }
  }

  .recruit-top-column {
    display: flex;

    @media (width <=1200px) {
      flex-direction: column;
      gap: 30px;
    }

    &[data-row="reverse"] {
      @media (width > 1200px) {
        flex-direction: row-reverse;
      }
    }

    >.content {
      display: flex;
      width: 51.27551%;
      margin-block-start: -20px;

      @media (width <=1200px) {
        display: block;
        width: 100%;
        margin-block-start: 0;
      }
    }

    >.content>.inner {
      max-width: min(600px, 30dvw);
      margin-inline: auto;

      @media (width <=1200px) {
        max-width: none;
      }
    }

    >.image {
      position: relative;
      display: block;
      overflow: hidden;
      flex: 1;
    }

    >.image>img {
      position: absolute;
      z-index: 0;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      border-radius: 5px;
      -o-object-fit: cover;
      object-fit: cover;

      @media (width <=1200px) {
        position: static;
        height: auto;
        -o-object-fit: fill;
        object-fit: fill;
      }
    }
  }

  .recruit-top-list-links {
    display: grid;
    border-top: 1px solid var(--color-red-50);
    -moz-column-gap: 20px;
    column-gap: 20px;
    margin-block-start: 50px;

    @media (max-width: 896px) {
      margin-block-start: 30px;
    }

    >li {
      border-bottom: 1px solid var(--color-red-50);
    }

    &[data-list="works"] {
      grid-template-columns: 1fr 1fr;

      >li:first-child {
        grid-column: 1 / -1;
      }
    }

    >li>.button {
      position: relative;
      display: flex;
      min-height: 117px;
      flex-direction: column;
      align-items: flex-start;
      justify-content: center;
      padding: 20px 40px 20px 20px;
      padding-bottom: 3px;
      background-image: linear-gradient(90deg, var(--color-gray-100), var(--color-gray-100));
      background-position: 100% 100%;
      background-repeat: no-repeat;
      background-size: 0 1px;
      color: var(--color-gray-100);
      transition: opacity 300ms ease-out, background-size cubic-bezier(0.215, 0.61, 0.355, 1) 0.3s;

      @media (max-width: 896px) {
        min-height: 91px;
        padding: 10px 30px 10px 10px;
      }

      &:hover {
        @media (min-width: 897px) {
          background-position: 0 100%;
          background-size: 100% 1px;
        }
      }

      &::after {
        position: absolute;
        top: 50%;
        right: 20px;
        display: block;
        width: 0;
        height: 0;
        border-width: 4px 0 4px 7px;
        border-style: solid;
        border-color: transparent transparent transparent var(--color-gray-100);
        content: "";
        transform: translateY(-50%);

        @media (max-width: 896px) {
          right: 10px;
        }
      }

      &[data-font-size="small"] {
        min-height: 114px;

        @media (max-width: 896px) {
          min-height: 64px;
        }

        >.title {
          font-size: 1.125rem;
          font-weight: 700;
          line-height: 1.55556;

          @media (max-width: 896px) {
            font-size: 0.8125rem;
            line-height: 2.15385;
          }
        }
      }
    }

    >li>.button>.sub {
      margin-bottom: 5px;
      font-family: var(--second-family);
      font-size: 1rem;
      font-weight: 500;
      line-height: 1.125;
      opacity: 0.7;
    }

    >li>.button>.title {
      font-size: 1.5rem;
      font-weight: 700;
      line-height: 1.5;

      @media (max-width: 896px) {
        font-size: 1.25rem;
        line-height: 1.5;
      }
    }
  }

  .recruit-top-list-env {
    display: grid;
    gap: 30px;
    grid-template-columns: repeat(3, 1fr);
    margin-block-start: 50px;

    @media (max-width: 896px) {
      gap: 10px;
      grid-template-columns: 1fr;
    }

    >li>a {
      position: relative;
      display: flex;
      overflow: hidden;
      height: 100%;
      padding: 20px 30px 20px 20px;
      border-radius: 5px;
      background-color: var(--color-gray-100);
      gap: 10px;
      transition: background-color 300ms ease-out;

      &:hover {
        @media (min-width: 897px) {
          background-color: var(--color-neutral-80);
        }
      }

      &::before {
        position: absolute;
        z-index: 0;
        top: 0;
        right: 0;
        width: 30px;
        height: 100%;
        background-color: var(--color-gray-10);
        content: "";
      }

      &::after {
        position: absolute;
        z-index: 1;
        top: 50%;
        right: 11px;
        width: 0;
        height: 0;
        border-width: 4px 0 4px 7px;
        border-style: solid;
        border-color: transparent transparent transparent var(--color-gray-100);
        content: "";
        transform: translateY(-50%);
      }
    }

    >li>a>img {
      display: block;
      width: min(80px, 5.71429vw);
      height: auto;
      flex-shrink: 0;

      @media (max-width: 896px) {
        width: 80px;
      }
    }

    >li>a>.info {
      display: flex;
      flex: 1;
      flex-direction: column;
      justify-content: center;
      padding-inline-end: 10px;
    }

    >li>a>.info>.sub {
      color: var(--color-red-30);
      font-family: var(--second-family);
      font-size: min(1rem, 1.14286vw);
      font-weight: 600;
      line-height: 1.125;
      margin-block-end: 5px;

      @media (max-width: 896px) {
        font-size: 1rem;
      }
    }

    >li>a>.info>.title {
      color: var(--color-gray-5);
      font-size: min(1.375rem, 1.57143vw);
      font-weight: 700;
      line-height: 1.36364;

      @media (max-width: 896px) {
        font-size: 1.25rem;
        line-height: 1.4;
      }
    }
  }

  .recruit-top-philosophy {
    >.heading {
      max-width: 100%;

      @media (min-width: 897px) {
        padding-inline: 96px;
      }
    }

    >.heading>picture {
      position: relative;
      display: block;
      max-width: calc(100% - 40px);
      margin-inline: auto;

      @media (min-width: 897px) {
        max-width: 2000px;
      }
    }

    >.heading>picture>img {
      position: absolute;
      bottom: 100%;
      display: block;
      width: 100%;
      height: auto;
    }

    >.splide {
      .splide__slide {
        @media (min-width: 897px) {
          width: 400px;
        }
      }

      .splide__slide>img {
        display: block;
        width: 100%;
        height: auto;
        aspect-ratio: 400 / 248;
        -o-object-fit: cover;
        object-fit: cover;
      }

      &:not(.is-initialized.is-active) {
        display: block;
        visibility: visible;

        >.splide__track>.splide__list {
          @media (min-width: 897px) {
            display: flex;
          }
        }

        >.splide__track>.splide__list>.splide__slide {
          flex: 1;
        }
      }
    }
  }
}

@layer pages {

  /* ---------------------------------------------
  .recruit-voice
------------------------------------------------ */
  .recruit-voice {
    position: relative;

    @media (max-width: 896px) {
      overflow: hidden;
    }
  }

  /* ---------------------------------------------
  .recruit-voice-heading
------------------------------------------------ */
  .recruit-voice-heading {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    margin-bottom: 40px;
    font-size: 1.875rem;
    font-weight: 700;
    gap: 9px 10px;
    line-height: 1.2;

    @media (max-width: 896px) {
      flex-direction: column;
      margin-bottom: 21px;
      font-size: 1.375rem;
      line-height: 1.36364;
    }

    >p {
      color: var(--color-red-30);
      font-family: var(--second-family);
      font-size: 3.125rem;
      line-height: 1;

      @media (min-width: 897px) {
        position: relative;
        padding-right: 51px;
      }

      @media (max-width: 896px) {
        width: 100%;
      }

      &::after {
        @media (min-width: 897px) {
          position: absolute;
          top: calc(50% - 1px);
          right: 0;
          width: 40px;
          height: 2px;
          background-color: var(--color-red-30);
          content: "";
          transform: translateY(-50%);
        }
      }
    }

    >.title {
      @media (min-width: 897px) {
        flex: 1;
        padding-top: 7px;
      }
    }
  }

  /* ---------------------------------------------
  .recruit-voice-card
------------------------------------------------ */
  .recruit-voice-card {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    padding: 35px 30px;
    border-radius: 5px;
    background-color: var(--color-voice-pink-01);
    gap: 10px 20px;

    @media (max-width: 896px) {
      height: 100%;
      flex-direction: column;
      padding: 20px 15px;
    }

    >.image {
      overflow: hidden;
      width: 110px;
      height: 110px;
      border-radius: 50%;

      @media (max-width: 896px) {
        width: 90px;
        height: 90px;
        margin: 0 auto;
      }
    }

    >.image>img {
      width: 100%;
      height: auto;
    }

    >.detail {
      @media (min-width: 897px) {
        flex: 1;
      }
    }

    >.detail>.lead {
      font-size: 1.125rem;
      font-weight: 700;
      line-height: 1.66667;

      @media (max-width: 896px) {
        font-size: 0.875rem;
        line-height: 1.57143;
      }
    }

    >.detail>.lead>span {
      color: var(--color-red-30);
    }

    >.detail>.heading {
      color: var(--color-red-30);
      font-size: 1.875rem;
      font-weight: 700;
      line-height: 1.26667;

      @media (max-width: 896px) {
        font-size: 1.5rem;
        line-height: 1.3334;
      }
    }

    >.detail>.title {
      font-size: 1.5rem;
      font-weight: 700;
      line-height: 1.3334;

      @media (max-width: 896px) {
        font-size: 1.125rem;
        line-height: 1.33333;
      }
    }

    >.detail>.text {
      margin-top: 8px;
      line-height: 1.75;

      @media (max-width: 896px) {
        margin-top: 10px;
        font-size: 0.75rem;
        line-height: 1.66667;
      }
    }

    >.detail>.tags {
      display: flex;
      flex-wrap: wrap;
      margin-top: 20px;
      gap: 5px;

      @media (max-width: 896px) {
        margin-top: 10px;
      }
    }

    >.detail>.tags>li {
      padding: 5px 12px;
      border-radius: 100px;
      background-color: var(--color-gray-100);
      color: var(--color-red-30);
      font-size: 0.8125rem;
      line-height: 1.46154;
      text-align: center;

      @media (max-width: 896px) {
        font-size: 0.625rem;
        line-height: 1.4;
      }
    }

    &[data-color-variant="yellow"] {
      background-color: var(--color-voice-yellow-01);
    }

    &[data-color-variant="baby-pink"] {
      background-color: var(--color-voice-pink-02);
    }

    &[data-color-variant="cyan"] {
      background-color: var(--color-voice-blue-02);
    }

    &[data-color-variant="blue"] {
      background-color: var(--color-voice-blue);

      >.detail>.heading {
        color: var(--color-blue-30);
      }
    }

    &[data-color-variant="green"] {
      background-color: var(--color-voice-green);
    }

    &[data-color-variant="purple"] {
      background-color: var(--color-voice-purple);
    }
  }

  /* ---------------------------------------------
  .recruit-voice-content
------------------------------------------------ */
  .recruit-voice-content {
    display: flex;
    flex-wrap: wrap;
    gap: 20px 30px;

    @media (max-width: 896px) {
      flex-direction: column;
    }

    >.image-box {
      width: 39.317%;

      @media (max-width: 896px) {
        width: 100%;
        max-width: 290px;
        margin: 0 auto;
      }
    }

    >.image-box>.image {
      display: block;
    }

    >.image-box>.image>img {
      width: 100%;
      height: auto;
    }

    >.content {
      @media (min-width: 897px) {
        flex: 1;
      }

      @media (max-width: 896px) {
        width: 100%;
      }
    }

    &[data-reverse-variant="true"] {
      @media (min-width: 897px) {
        flex-direction: row-reverse;
      }
    }

    &[data-voice-figure-sticky="true"] {
      @media (min-width: 897px) {
        >.image-box>.image {
          position: sticky;
          top: 50vh;
        }
      }
    }
  }

  /* ---------------------------------------------
  .recruit-voice-slider
------------------------------------------------ */
  .recruit-voice-slider {
    @media (max-width: 896px) {
      margin-inline: -20px;
    }

    >.splide {
      @media (max-width: 896px) {
        padding-bottom: 90px;
      }

      &:not(.is-initialized.is-active) {
        @media (min-width: 897px) {
          display: block;
          visibility: visible;
        }
      }

      .splide__arrow {
        @media (max-width: 896px) {
          top: inherit;
          bottom: 0;
          left: 20px;
          width: 60px;
          height: 60px;
          border: 1px solid var(--color-gray-20);
          border-radius: 5px;
          background-color: var(--color-gray-100);
          opacity: 1;
          transform: none;
        }
      }

      .splide__arrow::after {
        @media (max-width: 896px) {
          position: absolute;
          top: 50%;
          left: 50%;
          display: block;
          width: 0;
          height: 0;
          border-width: 4px 7px 4px 0;
          border-style: solid;
          border-color: transparent var(--color-gray-5) transparent transparent;
          content: "";
          transform: rotate(0deg) translate(-50%, -50%);
        }
      }

      .splide__arrow--next {
        @media (max-width: 896px) {
          right: 20px;
          left: inherit;
        }
      }

      .splide__arrow--next::after {
        @media (max-width: 896px) {
          border-width: 4px 0 4px 7px;
          border-color: transparent transparent transparent var(--color-gray-5);
        }
      }

      .splide__arrow>svg {
        display: none;
      }

      .splide__pagination {
        @media (max-width: 896px) {
          bottom: 25px;
          justify-content: center;
          gap: 5px;
          padding-inline: 90px;
        }
      }

      .splide__pagination__page {
        @media (max-width: 896px) {
          width: 15px;
          height: 2px;
          border-radius: 0;
          margin: 0;
          background-color: var(--color-gray-70);
          opacity: 1;
          transform: none;
          transition-property: all;
        }
      }

      .splide__pagination__page.is-active {
        @media (max-width: 896px) {
          background-color: var(--color-red-30);
        }
      }
    }

    >.splide>.splide__track>.splide__list {
      @media (min-width: 897px) {
        display: grid;
        row-gap: 10px;
      }
    }

    &[data-column-variant="two"] {
      >.splide>.splide__track>.splide__list {
        @media (min-width: 897px) {
          display: block;
          -moz-column-gap: 10px;
          column-gap: 10px;
          -moz-columns: 2;
          columns: 2;
        }
      }

      >.splide>.splide__track>.splide__list>.splide__slide {
        @media (min-width: 897px) {
          margin-bottom: 10px;
          -moz-column-break-inside: avoid;
          break-inside: avoid;
        }
      }

      >.splide>.splide__track>.splide__list>.splide__slide:last-child {
        @media (min-width: 897px) {
          margin-bottom: 0;
        }
      }
    }

    &[data-break-variant="four"] {
      >.splide>.splide__track>.splide__list>.splide__slide:nth-child(3) {
        @media (min-width: 897px) {
          margin-bottom: 0;
        }
      }

      >.splide>.splide__track>.splide__list>.splide__slide:nth-child(4) {
        @media (min-width: 897px) {
          -moz-column-break-before: column;
          break-before: column;
        }
      }
    }

    &[data-break-variant="five"] {
      >.splide>.splide__track>.splide__list>.splide__slide:nth-child(4) {
        @media (min-width: 897px) {
          margin-bottom: 0;
        }
      }

      >.splide>.splide__track>.splide__list>.splide__slide:nth-child(5) {
        @media (min-width: 897px) {
          -moz-column-break-before: column;
          break-before: column;
        }
      }
    }
  }

  /* ---------------------------------------------
  .recruit-voice-list
------------------------------------------------ */
  .recruit-voice-list {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 10px;

    @media (max-width: 896px) {
      gap: 5px;
    }

    >li {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      padding: 7px 30px 7px 7px;
      border-radius: 1000px;
      background-color: var(--color-voice-pink-01);
      -moz-column-gap: 15px;
      column-gap: 15px;

      @media (max-width: 896px) {
        padding: 3px 13px 3px 3px;
        -moz-column-gap: 3px;
        column-gap: 3px;
      }

      &[data-color-variant="yellow"] {
        background-color: var(--color-voice-yellow-01);
      }

      &[data-color-variant="baby-pink"] {
        background-color: var(--color-voice-pink-02);
      }

      &[data-color-variant="cyan"] {
        background-color: var(--color-voice-blue-02);
      }

      &[data-color-variant="blue"] {
        background-color: var(--color-voice-blue);
      }

      &[data-color-variant="green"] {
        background-color: var(--color-voice-green);
      }

      &[data-color-variant="purple"] {
        background-color: var(--color-voice-purple);
      }
    }

    >li>figure {
      width: 54px;
      height: 54px;
      border-radius: 50%;

      @media (max-width: 896px) {
        width: 28px;
        height: 28px;
      }
    }

    >li>figure>img {
      width: 100%;
      height: auto;
    }

    >li>.text {
      flex: 1;
      font-size: 1.5rem;
      font-weight: 700;
      line-height: 1.25;

      @media (max-width: 896px) {
        font-size: 0.9375rem;
        line-height: 1.46667;
      }
    }
  }
}

@layer pages {

  /* ---------------------------------------------
  recruit-work-support
------------------------------------------------ */
  .recruit-work-support-intro-box {
    display: flex;
    flex-wrap: wrap;
    border-radius: 5px;
    background-color: var(--color-red-95);

    @media (max-width: 896px) {
      flex-direction: column-reverse;
      padding: 20px 20px 40px;
      gap: 20px;
    }

    >.detail {
      display: flex;
      flex: 1;
      align-items: center;
      padding-top: 40px;
      padding-bottom: 40px;
      padding-left: 70px;
      margin-right: -10px;

      @media (max-width: 896px) {
        padding: 0;
        margin-right: 0;
      }
    }

    >.image {
      width: 49.74359%;

      @media (max-width: 896px) {
        width: 100%;
      }
    }

    >.image img {
      display: block;
      width: 100%;
      max-width: 100%;
      height: auto;

      @media (min-width: 897px) {
        height: 100%;
        border-bottom-right-radius: 5px;
        border-top-right-radius: 5px;
        -o-object-fit: cover;
        object-fit: cover;
        -o-object-position: left;
        object-position: left;
      }
    }
  }

  .recruit-work-support-anchor-box {
    --mt-pc: 50px;
    --mt-sp: 0;

    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: var(--mt-pc);
    gap: 40px;
    padding-block-start: 20px;

    @media (max-width: 896px) {
      margin-top: var(--mt-sp);
      margin-right: -20px;
      margin-left: -20px;
      gap: 13px;
    }

    >.item {
      &:first-child {
        @media (max-width: 896px) {
          position: relative;
          right: -3px;
        }
      }
    }

    >.item>a {
      display: inline-flex;
      flex-direction: column;
      gap: 10px;
      transition: all 300ms ease-out;

      @media (max-width: 896px) {
        gap: 8px;
      }
    }

    >.item>a:hover {
      @media (min-width: 897px) {
        opacity: 0.7;
      }
    }

    >.item>a>img {
      display: block;
      overflow: hidden;
      width: 114px;
      height: 114px;
      border-radius: 20px;
      margin: 0 auto;

      @media (max-width: 896px) {
        width: 74px;
        height: 74px;
      }
    }

    >.item>a>span {
      display: block;
      color: var(--color-red-30);
      font-size: 0.875rem;
      line-height: 1.43;
      text-align: center;

      @media (max-width: 896px) {
        font-size: 0.625rem;
        line-height: 1.4;
      }
    }
  }

  .recruit-work-support-info-box {
    display: grid;
    gap: 30px;
    grid-template-columns: 1fr 41.95402%;

    @media (max-width: 896px) {
      gap: 29px;
      grid-template-columns: 1fr;
    }

    &+& {
      margin-top: 60px;

      @media (max-width: 896px) {
        margin-top: 50px;
      }
    }

    >.image img {
      display: block;
      width: 100%;
      max-width: 100%;
      height: auto;
      border-radius: 5px;
    }

    >.image figcaption {
      margin-top: 10px;
      color: var(--color-text-subtle);
      font-size: 0.75rem;
      line-height: 1.83;
    }
  }

  .recruit-work-support-content-box {
    padding: 30px;
    border-radius: 5px;
    margin-top: 30px;
    background-color: var(--color-gray-100);

    @media (max-width: 896px) {
      padding: 20px;
    }

    >.heading {
      margin-bottom: 10px;
      font-size: 1.125rem;
      font-weight: 700;
      line-height: 1.5;
    }
  }

  .box-content-label>.container>.inner {
    >*+.heading-04 {
      margin-top: 60px;

      @media (max-width: 896px) {
        margin-top: 50px;
      }
    }
  }
}

@layer pages {

  /* ---------------------------------------------
  .sitemap-box
------------------------------------------------ */
  .sitemap-box {
    display: grid;
    row-gap: 120px;

    @media (max-width: 896px) {
      row-gap: 80px;
    }
  }

  /* ---------------------------------------------
  .sitemap-main-list
------------------------------------------------ */
  .sitemap-main-list {
    display: grid;
    gap: 15px 30px;
    grid-template-columns: repeat(3, 1fr);

    @media (max-width: 896px) {
      gap: 10px 15px;
      grid-template-columns: repeat(2, 1fr);
    }

    >li>a,
    >li>p {
      color: var(--color-red-30);
      font-size: 1.625rem;
      font-weight: bold;
      line-height: 1.46154;

      @media (max-width: 896px) {
        font-size: 1.375rem;
        line-height: 1.5;
      }
    }

    >li>a {
      position: relative;
      text-decoration: none;
    }

    >li>a::after {
      position: relative;
      top: -3px;
      display: inline-block;
      width: 0;
      height: 0;
      border-width: 4px 0 4px 7px;
      border-style: solid;
      border-color: transparent transparent transparent var(--color-red-30);
      margin-left: 2px;
      content: "";
      transform: translateY(-50%);

      @media (max-width: 896px) {
        top: -1px;
      }
    }

    >li>a>span {
      padding-bottom: 3px;
      background-image: linear-gradient(90deg, var(--color-red-30), var(--color-red-30));
      background-position: 100% 100%;
      background-repeat: no-repeat;
      background-size: 0 1px;
      transition: background-size cubic-bezier(0.215, 0.61, 0.355, 1) 0.3s;
    }

    >li>a:hover>span {
      @media (min-width: 897px) {
        background-position: 0 100%;
        background-size: 100% 1px;
      }
    }

    &[data-column-variant="sp-1"] {
      @media (max-width: 896px) {
        grid-template-columns: repeat(1, 1fr);
      }
    }
  }

  /* ---------------------------------------------
  .sitemap-sub-list
------------------------------------------------ */
  .sitemap-sub-list {
    display: grid;
    -moz-column-gap: 30px;
    column-gap: 30px;
    grid-template-columns: repeat(3, 1fr);

    @media (max-width: 896px) {
      -moz-column-gap: 15px;
      column-gap: 15px;
      grid-template-columns: repeat(2, 1fr);
    }

    >li {
      flex: 1 0 auto;
      padding-bottom: 1px;
      background-image: linear-gradient(90deg, var(--color-gray-60), var(--color-gray-60)),
        linear-gradient(90deg, var(--color-stroke-subtle), var(--color-stroke-subtle));
      background-position: 100% 100%, 0 100%;
      background-repeat: no-repeat;
      background-size: 0 1px, 100% 1px;
      transition: background-size cubic-bezier(0.215, 0.61, 0.355, 1) 0.3s;
    }

    >li:hover {
      @media (min-width: 897px) {
        background-position: 0 100%, 0 100%;
        background-size: 100% 1px, 100% 1px;
      }
    }

    >li>a {
      position: relative;
      display: flex;
      height: 100%;
      align-items: center;
      padding: 19px 30px 17px 10px;
      color: var(--color-text-default);
      font-size: 0.9375rem;
      font-weight: 400;
      line-height: 1.6;
      text-decoration: none;

      @media (max-width: 896px) {
        padding: 14px 24px 12px 10px;
        color: var(--color-text-default);
        font-size: 0.75rem;
        line-height: 1.66667;
      }
    }

    >li>a::after {
      position: absolute;
      top: calc(50% + 1px);
      right: 10px;
      display: block;
      width: 0;
      height: 0;
      border-width: 4px 0 4px 7px;
      border-style: solid;
      border-color: transparent transparent transparent var(--color-text-brand);
      content: "";
      transform: translateY(-50%);
    }

    &:not(:first-child) {
      margin-top: 19px;
    }

    >li.is-category-title {
      padding-top: 30px;
      border-bottom: none;
      background-image: none;
      grid-column: 1 / -1;
      transition: none;

      @media (min-width: 897px) {
        margin-top: 20px;
      }

      &:first-child {
        padding-top: 0;
      }

      &:hover {
        background-image: none;
        background-size: 0 1px;
      }

      >p {
        padding-bottom: 8px;
        color: var(--color-red-30);
        font-size: 1.25rem;
        font-weight: bold;
        line-height: 1.5;

        @media (max-width: 896px) {
          font-size: 1rem;
          line-height: 1.5;
        }
      }
    }
  }
}

@layer pages {

  /* ---------------------------------------------
  software-development-catch
------------------------------------------------ */
  .software-development-catch {
    padding: 60px 20px 71px;
    border-radius: 5px;
    background: var(--color-red-30) url("/assets/images/solution/software_development/bg-catch-pc.png") center left calc(50% + 9px) / 777px auto no-repeat;
    color: var(--color-gray-100);
    text-align: center;

    @media (max-width: 896px) {
      padding: 30px 15px 40px;
      background: var(--color-red-30) url("/assets/images/solution/software_development/bg-catch-sp.png") center / cover no-repeat;
    }

    >.logo {
      width: 45px;
      margin: 0 auto;
    }

    >.logo>img {
      width: 100%;
      height: auto;
    }

    >.text {
      margin-top: 14px;
      font-size: 2rem;
      font-weight: 500;
      line-height: 1.625;

      @media (max-width: 896px) {
        margin-top: 15px;
        font-size: 1.125rem;
        line-height: 2;
      }
    }
  }

  /* ---------------------------------------------
  software-development-check
------------------------------------------------ */
  .software-development-check {
    *+& {
      margin-top: 30px;
    }

    >.content {
      display: flex;
      align-items: center;
      padding: 40px 30px 20px 50px;
      border-radius: 5px 5px 0 0;
      background-color: var(--color-gray-80);
      box-shadow: 0 4px 4px 0 var(--color-black-25);
      gap: min(2.47934vw, 30px);

      @media (max-width: 896px) {
        flex-direction: column;
        align-items: flex-start;
        padding: 30px 20px 20px;
      }
    }

    >.content>.detail {
      width: 100%;
    }

    >.content>.detail>.list-check>li:last-child {
      @media (max-width: 896px) {
        border-bottom: none;
      }
    }

    >.content>.image {
      width: min(31.40496vw, 380px);

      @media (min-width: 897px) {
        position: relative;
        top: -10px;
        flex: 1 0 auto;
      }

      @media (max-width: 896px) {
        width: 100%;
      }
    }

    >.content>.image>img {
      width: 100%;
      height: auto;
      border-radius: 5px;
    }

    >.lead {
      border-radius: 0 0 5px 5px;
      background-color: var(--color-red-30);
      padding-block: 14px;
      text-align: center;

      @media (max-width: 896px) {
        padding: 15px 20px;
        text-align: left;
      }
    }

    >.lead>.text {
      color: var(--color-gray-100);
      font-size: 1.25rem;
      font-weight: 700;
      line-height: 1.5;

      @media (max-width: 896px) {
        font-size: 1.125rem;
        line-height: 1.55556;
      }
    }
  }
}

@layer pages {

  /* ---------------------------------------------
  .solution-box-info
------------------------------------------------ */
  .solution-box-info {
    display: flex;
    gap: min(50px, 4.13223vw);

    @media (max-width: 896px) {
      flex-direction: column;
      gap: 30px;
    }

    >.box {
      width: min(670px, 55.3719vw);
      flex: 1 0 auto;

      @media (max-width: 896px) {
        width: 100%;
      }
    }

    >.box>.heading-02 {
      margin-bottom: 20px;
    }

    >.box>.detail {
      padding-top: 30px;
      border-top: 1px solid var(--color-stroke-default);
    }

    >.image {
      width: 100%;
    }

    figure {
      margin: 0;
    }

    &[data-size-variant="medium"] {
      >.box {
        @media (min-width: 897px) {
          width: min(690px, 57.02479vw);
        }
      }
    }
  }

  /* ---------------------------------------------
  .solution-list-contact
------------------------------------------------ */
  .solution-list-contact {
    display: grid;
    gap: 30px;
    grid-template-columns: repeat(2, 1fr);

    &[data-card-variant="full"] {
      grid-template-columns: 1fr;
    }

    @media (max-width: 896px) {
      gap: 10px;
      grid-template-columns: repeat(1, 1fr);
    }

    >.card {
      display: flex;
      flex-direction: column;
      padding: 40px;
      border-radius: 5px;
      gap: 15px;
      text-align: center;

      &[data-card-variant="download"] {
        background-color: var(--color-fill-dark);
      }

      &[data-card-variant="inquiry"] {
        background-color: var(--color-fill-brand);
      }
    }

    >.card>.icon {
      display: block;
    }

    >.card>.title {
      color: var(--color-text-light);
      font-size: 1.375rem;
      font-weight: 500;
    }

    >.card>.text {
      color: var(--color-text-light);
      font-size: 0.875rem;
    }

    >.card>.button {
      display: flex;
      justify-content: center;
      margin-top: 15px;
    }
  }

  /* ---------------------------------------------
  .solution-image-info
------------------------------------------------ */
  .solution-image-info {
    display: flex;
    margin-top: 50px;
    gap: 30px;

    @media (max-width: 896px) {
      flex-direction: column;
      margin-top: 30px;
    }

    &:first-child {
      margin-top: 0;
    }

    >figure {
      width: 250px;
      flex: 1 0 auto;
      margin: 0;

      @media (max-width: 896px) {
        width: 100%;
      }
    }

    >.box {
      width: 100%;
    }

    >.box>.title {
      margin-bottom: 10px;
      font-size: 1.5rem;
      font-weight: 700;

      @media (max-width: 896px) {
        font-size: 1.25rem;
      }
    }
  }

  /* ---------------------------------------------
  .solution-content
------------------------------------------------ */
  .solution-content {
    padding-top: 50px;
    background-color: var(--color-fill-subtle);
  }

  /* ---------------------------------------------
  .solution-section
------------------------------------------------ */
  .solution-section {
    &+& {
      margin-top: 50px;

      @media (max-width: 896px) {
        margin-top: 30px;
      }
    }
  }

  /* ---------------------------------------------
  .solution-list-application
------------------------------------------------ */
  .solution-list-application {
    display: grid;
    gap: 3px;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: 1fr;

    >.link {
      display: flex;
      width: 100%;
      align-items: center;
      justify-content: center;
      padding: 12px 20px 10px;
      border-radius: 5px;
      -webkit-backdrop-filter: blur(10px);
      backdrop-filter: blur(10px);
      background: var(--color-fill-default);
      gap: 10px;
      text-decoration: none;
      transition: all 300ms ease-out;

      @media (max-width: 896px) {
        padding: 4px 15px;
      }
    }

    >.link>i {
      display: block;
      width: 66px;
      height: 66px;
      flex: 0 0 66px;
      background-color: var(--color-fill-brand);
      -webkit-mask-position: center;
      mask-position: center;
      -webkit-mask-repeat: no-repeat;
      mask-repeat: no-repeat;
      -webkit-mask-size: contain;
      mask-size: contain;
      transition: all 300ms ease-out;

      @media (max-width: 896px) {
        width: 50px;
        height: 50px;
        flex: 0 0 50px;
      }
    }

    >.link>i>img {
      display: block;
      width: 100%;
      height: auto;
    }

    >.link>span {
      color: var(--color-text-default);
      font-size: 1.375rem;
      transition: all 300ms ease-out;

      @media (max-width: 896px) {
        font-size: 1rem;
      }
    }

    >.link:hover {
      @media (min-width: 897px) {
        -webkit-backdrop-filter: blur(10px);
        backdrop-filter: blur(10px);
        background-color: var(--color-fill-brand);
        color: var(--color-text-light);
      }
    }

    >.link:hover>i {
      @media (min-width: 897px) {
        background-color: var(--color-text-light);
      }
    }

    >.link:hover>span {
      @media (min-width: 897px) {
        color: var(--color-text-light);
      }
    }
  }

  /* ---------------------------------------------
  .solution-list-office
------------------------------------------------ */
  .solution-list-office {
    display: grid;
    gap: 3px;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: 1fr;

    @media (width <=1100px) {
      grid-template-columns: repeat(3, 1fr);
    }

    >.link {
      display: flex;
      width: 100%;
      min-height: 58px;
      align-items: center;
      padding: 11px 15px 10px;
      border-radius: 5px;
      -webkit-backdrop-filter: blur(10px);
      backdrop-filter: blur(10px);
      background: var(--color-fill-default);
      gap: 8px;
      text-decoration: none;
      transition: all 300ms ease-out;

      @media (max-width: 896px) {
        padding: 4px 10px;
      }
    }

    >.link>i {
      display: block;
      width: 24px;
      height: 24px;
      flex: 0 0 24px;
      background-color: var(--color-fill-brand);
      -webkit-mask-position: center;
      mask-position: center;
      -webkit-mask-repeat: no-repeat;
      mask-repeat: no-repeat;
      -webkit-mask-size: contain;
      mask-size: contain;
      transition: all 300ms ease-out;
    }

    >.link>i>img {
      display: block;
      width: 100%;
      height: auto;
    }

    >.link>span {
      color: var(--color-text-default);
      font-size: 0.9375rem;
      line-height: 1.2;
      transition: all 300ms ease-out;

      @media (max-width: 896px) {
        font-size: 0.8125rem;
      }
    }

    >.link:hover {
      @media (min-width: 897px) {
        -webkit-backdrop-filter: blur(10px);
        backdrop-filter: blur(10px);
        background-color: var(--color-fill-brand);
        color: var(--color-text-light);
      }
    }

    >.link:hover>i {
      @media (min-width: 897px) {
        background-color: var(--color-text-light);
      }
    }

    >.link:hover>span {
      @media (min-width: 897px) {
        color: var(--color-text-light);
      }
    }
  }

  /* ---------------------------------------------
  .solution-list-keyword
------------------------------------------------ */
  .solution-list-keyword {
    display: flex;
    flex-wrap: wrap;
    gap: 3px;

    >a {
      display: block;
      padding: 12px 20px 14px;
      border-radius: 5px;
      -webkit-backdrop-filter: blur(10px);
      backdrop-filter: blur(10px);
      background-color: var(--color-fill-default);
      color: #000;
      color: initial;
      text-decoration: none;
      transition: all 300ms ease-out;

      @media (max-width: 896px) {
        padding: 7px 10px 9px;
      }
    }

    >a[data-load-more-item] {
      display: none;
    }

    >a>span {
      font-size: 0.9375rem;

      @media (max-width: 896px) {
        font-size: 0.8125rem;
      }
    }

    >a:hover {
      @media (min-width: 897px) {
        -webkit-backdrop-filter: blur(10px);
        backdrop-filter: blur(10px);
        background-color: var(--color-fill-brand);
        color: var(--color-text-light);
      }
    }
  }

  /* ---------------------------------------------
  .solution-keyword-more
------------------------------------------------ */
  .solution-keyword-more {
    >.button-more {
      margin-top: 7px;
      text-align: left;
    }
  }

  /* ---------------------------------------------
  .solution-list-category
------------------------------------------------ */
  .solution-list-category {
    display: grid;
    gap: 3px;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: 1fr;

    @media (max-width: 896px) {
      grid-template-columns: repeat(2, 1fr);
    }

    >.card {
      display: flex;
      align-items: center;
      padding: 10px;
      border-radius: 5px;
      -webkit-backdrop-filter: blur(10px);
      backdrop-filter: blur(10px);
      background: var(--color-fill-default);
      color: #000;
      color: initial;
      gap: 20px;
      text-decoration: none;
      transition: all 300ms ease-out;

      @media (max-width: 896px) {
        flex-direction: column;
        gap: 10px;
      }
    }

    >.card>.image {
      overflow: hidden;
      width: min(140px, 11.57025vw);
      flex: 1 0 auto;
      border-radius: 3px;
      margin: 0;

      @media (max-width: 896px) {
        width: 100%;
        border-radius: 2px;
      }
    }

    >.card>.image>img {
      display: block;
      width: 100%;
      height: auto;
    }

    >.card>.text {
      width: 100%;
      font-size: 1rem;

      @media (max-width: 896px) {
        font-size: 0.875rem;
      }
    }

    >.card:hover {
      @media (min-width: 897px) {
        background-color: var(--color-fill-brand);
        color: var(--color-text-light);
      }
    }
  }

  /* ---------------------------------------------
  .solution-list-monitoring
------------------------------------------------ */
  .solution-list-monitoring {
    display: grid;
    gap: 40px;
    grid-template-columns: repeat(2, 1fr);

    @media (max-width: 896px) {
      gap: 38px;
      grid-template-columns: repeat(1, 1fr);
    }

    >.card {
      display: flex;
      align-items: flex-start;
      gap: 20px;
      text-decoration: none;
      transition: all 300ms ease-out;

      @media (max-width: 896px) {
        flex-direction: column;
      }
    }

    >.card>.image {
      overflow: hidden;
      width: min(230px, 19.00826vw);
      height: 161px;
      flex: 1 0 auto;
      border-radius: 5px;

      @media (max-width: 896px) {
        width: 100%;
        height: auto;
      }
    }

    >.card>.image>img {
      display: block;
      width: 100%;
      height: auto;
      transition: all 300ms ease-out;

      @media (min-width: 897px) {
        height: 100%;
        -o-object-fit: cover;
        object-fit: cover;
      }
    }

    >.card>.content>.heading {
      margin-bottom: 10px;
      font-size: 1.5rem;
      font-weight: 500;
    }

    >.card>.content>.text {
      width: 100%;
      color: var(--color-gray-40);
      font-size: 1rem;
      line-height: 1.75;
    }

    >.card>.content>.link {
      margin-top: 7px;
      text-decoration: none;
    }

    >.card>.content>.link>span {
      position: relative;
      display: inline-block;
      padding: 0 13px 2px 0;
      background-image: linear-gradient(90deg, var(--color-fill-brand), var(--color-fill-brand));
      background-position: 100% 100%;
      background-repeat: no-repeat;
      background-size: 0 1px;
      color: var(--color-text-brand);
      cursor: pointer;
      font-size: 0.875rem;
      text-align: center;
      transition: background-size cubic-bezier(0.215, 0.61, 0.355, 1) 0.3s;
    }

    >.card>.content>.link>span::after {
      position: absolute;
      top: 50%;
      right: 0;
      display: block;
      width: 0;
      height: 0;
      border-width: 4.5px 0 4.5px 7px;
      border-style: solid;
      border-color: transparent transparent transparent var(--color-fill-brand);
      content: "";
      transform: translateY(-50%) rotate(0);
    }

    >.card:is(a):hover>.content>.link>span {
      @media (min-width: 897px) {
        background-position: 0 100%;
        background-size: 100% 1px;
      }
    }

    >.card:is(a):hover>.image>img {
      @media (min-width: 897px) {
        transform: scale(1.1);
      }
    }
  }

  /* ---------------------------------------------
  .solution-container-products
------------------------------------------------ */
  .solution-container-products {
    .heading-02 {
      --mb-sp: 50px;
    }

    .heading-03 {
      --mb-sp: 40px;
    }
  }

  /* ---------------------------------------------
  .solution-card-product
------------------------------------------------ */
  .solution-card-product {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 10px;

    >.image {
      padding: 19px;
      border: 1px solid var(--color-stroke-default);
      border-radius: 5px;
      background-color: var(--color-fill-default);
    }

    >.image>figure {
      display: flex;
      overflow: hidden;
      align-items: center;
      justify-content: center;
      border-radius: 5px;
      background-color: var(--color-fill-default);
    }

    >.image>figure>img {
      width: auto;
      max-width: 100%;
      height: auto;
      max-height: 100%;
      -o-object-fit: contain;
      object-fit: contain;
      transition: all 300ms ease-out;
    }

    @media (hover: hover) {
      &:has(button:hover)>.image>figure>img {
        transform: scale(1.1);
      }
    }

    >.box {
      display: flex;
      flex-direction: column;
      padding: 10px 20px 10px 0;
      gap: 10px;

      @media (max-width: 896px) {
        padding: 10px 0;
      }
    }

    >.box>.heading {
      .subject {
        margin-bottom: 5px;
        color: var(--color-text-subtle);
        font-size: 0.875rem;
        font-weight: 700;
      }
    }

    >.box .model {
      display: block;
      margin-top: 0;
      font-size: 1.25rem;
      font-weight: 500;
      line-height: 1.3;

      >.line {
        display: block;
      }

      .note {
        font-size: 0.875rem;
      }
    }

    >.box .type {
      font-size: 0.875rem;
    }

    >.box .detail {
      .text {
        color: var(--color-text-subtle);
        font-size: 0.8125rem;
        line-height: 1.5;
      }
    }

    >.box>.button {
      z-index: 2;
      margin-top: auto;
    }

    >.box>.detail {
      margin-top: 0;
    }
  }

  /* ---------------------------------------------
  .solution-product-feature-box
------------------------------------------------ */
  .solution-product-feature-box {
    padding: 20px;
    border-radius: 5px;
    margin-top: 10px;
    background-color: var(--color-fill-subtle);

    >.heading {
      margin-bottom: 8px;
      font-size: 0.875rem;
      font-weight: 700;
      line-height: 1;
    }

    >ul {
      display: flex;
      flex-direction: column;
      padding-left: 0;
      margin: 0;
      gap: 4px;
      list-style: none;
    }

    >ul>li {
      position: relative;
      padding-left: 18px;
      color: var(--color-text-default);
      font-size: 0.8125rem;
      line-height: 1.38462;
    }

    >ul>li::before {
      position: absolute;
      top: 9px;
      left: 6px;
      width: 4px;
      height: 4px;
      border-radius: 50%;
      background-color: var(--color-text-default);
      content: "";
      transform: translateY(-50%);
    }
  }

  /* ---------------------------------------------
  .solution-product-button
------------------------------------------------ */
  .solution-product-button {
    display: inline-flex;
    align-items: center;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--color-text-brand);
    cursor: pointer;
    font-size: 0.875rem;
    line-height: 1.42857;
    text-align: left;

    >span {
      position: relative;
      z-index: 2;
      padding-right: 14px;
    }

    >span::after {
      position: absolute;
      top: 50%;
      right: 0;
      display: block;
      width: 0;
      height: 0;
      border-width: 4px 0 4px 7px;
      border-style: solid;
      border-color: transparent transparent transparent var(--color-text-brand);
      content: "";
      transform: translateY(-50%);
    }

    &::before {
      position: absolute;
      content: "";
      inset: 0;
    }

    &:hover>span {
      @media (min-width: 897px) {
        text-decoration: underline;
      }
    }
  }

  /* ---------------------------------------------
  .solution-modal-product
------------------------------------------------ */
  .solution-modal-product {
    position: fixed;
    z-index: 100;
    top: 0;
    left: 0;
    display: none;
    width: 100vw;
    height: 100dvh;
    align-items: center;
    justify-content: center;
    background-color: var(--color-black-90);
    container-type: inline-size;
    padding-inline: 20px;

    >.inner {
      position: relative;
      display: flex;
      width: min(80vw, 1152px);
      height: auto;
      max-height: calc(100dvh - 117px);
      flex-direction: column;
      padding: 70px 132px 70px 150px;
      border-radius: 5px;
      background-color: var(--color-fill-default);
      container-type: inline-size;

      @media (max-width: 896px) {
        width: calc(100vw - 40px);
        max-height: calc(100dvh - 54px);
        padding: 23px 20px 50px;
      }
    }

    >.inner>.close {
      position: absolute;
      top: -16px;
      right: -16px;
      cursor: pointer;
      transition: all 300ms ease-out;

      @media (max-width: 896px) {
        top: -15px;
        right: -15px;
      }
    }

    >.inner>.close:hover {
      @media (min-width: 897px) {
        opacity: 0.7;
      }
    }

    >.inner>.box {
      min-height: 0;
      flex: 1 1 auto;
      margin-right: -10px;
      overflow-y: auto;
      padding-inline: 0 10px;

      @media (max-width: 896px) {
        padding-bottom: 10px;
      }
    }

    >.inner>.button {
      margin-top: 50px;
      text-align: center;

      @media (max-width: 896px) {
        margin-top: 16px;
      }
    }

    >.inner>.box>.panel {
      display: flex;
      flex-direction: column;
      gap: 50px;

      @media (max-width: 896px) {
        gap: 16px;
      }
    }

    .main {
      --solution-product-modal-side-width: min(44%, 370px);

      display: flow-root;

      @media (max-width: 896px) {
        display: flex;
        flex-direction: column;
        gap: 16px;
      }
    }

    .copy {
      display: flex;
      width: calc(100% - var(--solution-product-modal-side-width) - 30px);
      flex-direction: column;
      gap: 25px;

      @media (max-width: 896px) {
        width: 100%;
        gap: 16px;
      }
    }

    .head {
      display: flex;
      flex-direction: column;
      gap: 5px;

      >.badge {
        display: inline-flex;
        width: -moz-fit-content;
        width: fit-content;
        align-items: center;
        justify-content: center;
        padding: 5px 20px;
        border-radius: 5px;
        margin-bottom: 5px;
        background-color: var(--color-fill-brand);
        color: var(--color-text-light);
        font-size: 0.75rem;
        font-weight: 500;
        line-height: 2;
      }

      >.subject {
        color: var(--color-text-subtle);
        font-size: 1.125rem;
        font-weight: 700;
        line-height: 1.44444;

        @media (max-width: 896px) {
          font-size: 0.875rem;
        }
      }

      >.model {
        margin: 0;
        color: var(--color-text-default);
        font-size: 1.5rem;
        font-weight: 500;
        line-height: 1.41667;

        >.line {
          display: block;
        }

        .note {
          font-size: 1.125rem;
        }

        @media (max-width: 896px) {
          padding-bottom: 15px;
          border-bottom: 1px solid var(--color-stroke-default);
          font-size: 1.25rem;
          line-height: 1.3;

          .note {
            font-size: 1rem;
          }
        }
      }

      >.sub-text {
        padding-top: 25px;
        border-top: 1px solid var(--color-stroke-default);
        margin-top: 25px;
        color: var(--color-text-default);
        font-size: 1rem;
        line-height: 1.625;

        @media (max-width: 896px) {
          padding-top: 25px;
          border-top: none;
          margin-top: 0;
          font-size: 0.875rem;
          line-height: 1.57143;
        }
      }
    }

    .table {
      width: calc(100% - var(--solution-product-modal-side-width) - 30px);
      margin-top: 25px;
      border-collapse: collapse;
      table-layout: fixed;

      >tbody>tr {
        @media (max-width: 896px) {
          min-height: 50px;
        }
      }

      >tbody>tr>th,
      >tbody>tr>td {
        padding: 15px 10px;
        border: 1px solid var(--color-stroke-default);
        color: var(--color-text-default);
        font-size: 0.8125rem;
        line-height: 1.53846;
        text-align: left;
        vertical-align: top;

        @media (max-width: 896px) {
          font-size: 0.75rem;
        }
      }

      >tbody>tr>th {
        width: 130px;
        background-color: var(--color-fill-subtle);
        font-weight: 400;
        white-space: nowrap;
      }

      >tbody>tr>td {
        >span {
          display: inline;
        }
      }

      @media (max-width: 896px) {
        width: 100%;
        margin-top: 0;
      }
    }

    .visual {
      width: var(--solution-product-modal-side-width);
      max-width: 370px;
      margin-left: 30px;
      float: right;

      >figure {
        display: flex;
        overflow: hidden;
        align-items: center;
        justify-content: center;
        padding: 19px;
        border: 1px solid var(--color-stroke-default);
        border-radius: 5px;
        margin: 0;
        background-color: var(--color-fill-default);
      }

      >figure>img {
        width: auto;
        max-width: 100%;
        height: auto;
        max-height: 100%;
        -o-object-fit: contain;
        object-fit: contain;
      }

      @media (max-width: 896px) {
        width: 100%;
        max-width: none;
        margin-left: 0;
        float: none;
      }
    }

    .description {
      width: var(--solution-product-modal-side-width);
      max-width: 370px;
      margin-top: 20px;
      clear: right;
      color: var(--color-text-default);
      float: right;
      font-size: 0.875rem;
      line-height: 1.85714;

      @media (max-width: 896px) {
        width: 100%;
        max-width: none;
        margin-top: 0;
        float: none;
        font-size: 0.75rem;
        line-height: 1.75;
      }
    }

    @container (max-width: 896px) {
      >.inner {
        padding: 23px 20px 50px;
      }
    }

    @container (max-width: 730px) {
      .main {
        display: flex;
        flex-direction: column;
        gap: 16px;
      }

      .copy {
        width: 100%;
        gap: 16px;
      }

      .table {
        width: 100%;
        margin-top: 0;
      }

      .visual {
        width: 100%;
        max-width: none;
        margin-left: 0;
        float: none;
      }

      .description {
        width: 100%;
        max-width: none;
        margin-top: 0;
        clear: none;
        float: none;
      }
    }
  }

  /* ---------------------------------------------
  .solution-security-section
------------------------------------------------ */
  .solution-security-section {
    margin-top: 60px;
  }

  /* ---------------------------------------------
  .solution-list-purpose
------------------------------------------------ */
  .solution-list-purpose {
    display: flex;
    overflow: hidden;
    border-radius: 5px;
    gap: 1px;
    margin-block-start: 50px;

    @media (max-width: 896px) {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
    }

    &:first-child {
      margin-block-start: 0;
    }

    >.solution-item-purpose {
      position: relative;
      display: block;
      overflow: hidden;
      width: 25%;

      @media (max-width: 896px) {
        width: 100%;
      }

      &::after {
        position: absolute;
        right: 0;
        bottom: 0;
        width: 30px;
        height: 30px;
        background: url("/assets/images/solution/icon-media-01.svg") center center no-repeat;
        content: "";

        @media (max-width: 896px) {
          display: none;
        }
      }

      @media (hover: hover) and (pointer: fine) {
        &:hover>.image>figure>img {
          transform: scale(1.1);
        }
      }
    }

    >.solution-item-purpose>.image {
      display: block;
      overflow: hidden;
      width: 100%;
      height: auto;
    }

    >.solution-item-purpose>.image>figure>img {
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
      object-fit: cover;
      transition: transform 300ms ease-out;

      @media (max-width: 896px) {
        aspect-ratio: 167 / 150;
      }
    }

    >.solution-item-purpose>.content {
      position: absolute;
      bottom: 15px;
      left: 20px;
      width: calc(100% - 20px);

      @media (max-width: 896px) {
        bottom: 10px;
        left: 10px;
        width: calc(100% - 10px);
      }
    }

    >.solution-item-purpose>.content>.title {
      color: var(--color-text-light);
      font-size: 1.1875rem;
      font-weight: 700;
      line-height: 1.36842;

      @media (max-width: 896px) {
        font-size: 0.875rem;
        line-height: 1.28571;
      }
    }
  }

  /* ---------------------------------------------
  .solution-list-product
------------------------------------------------ */
  .solution-list-product {
    display: grid;
    overflow: hidden;
    border-radius: 5px;
    background-color: var(--color-fill-subtle);
    grid-template-areas: "content image";
    grid-template-columns: repeat(2, 1fr);
    margin-block-start: 80px;

    @media (max-width: 896px) {
      grid-template-areas:
        "image"
        "content";
      grid-template-columns: repeat(1, 1fr);
      margin-block-start: 50px;
    }

    >.content {
      display: flex;
      flex-direction: column;
      justify-content: center;
      padding: 50px 70px;
      gap: 30px;
      grid-area: content;

      @media (max-width: 896px) {
        padding: 20px;
      }
    }

    >.content>.context {
      display: flex;
      flex-direction: column;
      gap: 10px;
    }

    >.content>.context>.title {
      color: var(--color-text-default);
      font-size: 1.875rem;
      font-weight: 700;

      @media (max-width: 896px) {
        font-size: 1.5rem;
      }
    }

    >.content>.context>.text {
      color: var(--color-text-default);
      font-size: 1rem;
      line-height: 2;
    }

    >.content>.button {
      display: flex;

      @media (max-width: 896px) {
        justify-content: center;
      }
    }

    >.image {
      width: 100%;
      grid-area: image;
    }

    >.image>figure {
      height: 100%;
    }

    >.image>figure>img {
      width: 100%;
      height: 100%;
      aspect-ratio: 585 / 308;
      -o-object-fit: cover;
      object-fit: cover;

      @media (max-width: 896px) {
        aspect-ratio: 335 / 176;
      }
    }
  }

  /* ---------------------------------------------
  .solution-box-key-strengths
------------------------------------------------ */
  .solution-box-key-strengths {
    display: grid;
    gap: 3px;
    grid-template-columns: repeat(2, 1fr);

    @media (max-width: 896px) {
      grid-template-columns: 1fr;
    }

    &:not(:first-child) {
      margin-top: 60px;
    }
  }

  /* ---------------------------------------------
  .solution-business-partner
------------------------------------------------ */
  .solution-business-partner {
    margin-top: 30px;

    >.image {
      width: 100%;
    }

    >.image>img {
      display: block;
      width: 100%;
      height: auto;
    }
  }
}

@layer pages {

  /* ---------------------------------------------
  .top-hero
------------------------------------------------ */
  .top-hero {
    position: relative;
    z-index: 10;
    overflow: hidden;
    padding-inline: min(1.25vw, 20px);

    @media (max-width: 896px) {
      margin-top: -60px;
      padding-inline: 0;
    }

    .image {
      overflow: hidden;
      border-radius: 5px;

      @media (max-width: 896px) {
        border-radius: 0;
      }
    }

    .image>picture>img {
      width: 100%;
      height: calc(100dvh - 110px);
      -o-object-fit: cover;
      object-fit: cover;
      -o-object-position: top center;
      object-position: top center;
      transform: scale(1);
      transition: transform 5s ease-out;

      @media (max-width: 896px) {
        height: 100dvh;
      }
    }

    .image>picture>img.is-zoom {
      transform: scale(1.08);
    }

    .caption {
      position: absolute;
      z-index: 10;
      bottom: 60px;
      left: 0;
      width: 100%;
      pointer-events: none;
      transition: transform 0s linear;
      will-change: transform;

      @media (max-width: 896px) {
        top: 75%;
        bottom: unset;
      }
    }

    .caption>.inner {
      width: 100%;
      max-width: 1384px;
      padding: 0 min(1.25vw, 20px);
      margin: 0 auto;

      @media (max-width: 896px) {
        padding: 0 20px;
      }
    }

    .caption>.inner>picture>img {
      width: 776px;
      height: 193px;

      @media (max-width: 896px) {
        width: 311px;
        height: 80px;
      }
    }

    .slide {
      overflow: hidden;
      border-radius: 5px;
      background: var(--global-color-black);
      transition: none;
      will-change: transform;

      @media (max-width: 896px) {
        border-radius: 0;
      }
    }
  }

  /* ---------------------------------------------
  .top-about
------------------------------------------------ */
  .top-about {
    position: relative;
    background: url("/assets/images/top/bg-about.svg") no-repeat calc(50% + 485px) top;

    @media (width <=1384px) {
      background-position: 697px top;
    }

    @media (max-width: 896px) {
      background-position: 100px -58px;
      background-size: 456px auto;
    }

    >.inner {
      position: relative;
      z-index: 2;
      width: 100%;
      max-width: 1384px;
      padding: 140px min(1.25vw, 20px) 240px;
      margin: 0 auto;

      @media (max-width: 896px) {
        padding: 82px 20px 80px;
      }
    }

    >.inner>.title {
      position: fixed;
      bottom: 80px;
      width: 776px;

      @media (max-width: 896px) {
        top: 75%;
        bottom: unset;
        width: 311px;
      }

      &.is-static {
        position: absolute;
        top: 140px;
        bottom: auto;

        @media (max-width: 896px) {
          top: 82px;
        }
      }
    }

    >.inner>.title>picture>img {
      width: 100%;
      height: auto;
    }

    >.inner>.text {
      z-index: -1;
      padding-top: 242px;
      font-size: 1.125rem;
      line-height: 1.83;

      @media (max-width: 896px) {
        padding-top: 115px;
        font-size: 1rem;
        font-weight: bold;
        line-height: 1.88;
      }
    }

    >.inner>.button {
      margin-top: 50px;

      @media (max-width: 896px) {
        margin-top: 29px;
      }
    }
  }

  /* ---------------------------------------------
  .top-heading
------------------------------------------------ */
  .top-heading {
    >h2 {
      display: flex;
      flex-direction: column;
      margin-bottom: 8px;
    }

    >h2>.sub {
      color: var(--color-text-light);
      font-size: 1.25rem;
      font-weight: 700;

      @media (max-width: 896px) {
        font-size: 1rem;
      }
    }

    >h2>.title {
      color: var(--color-text-light);
      font-family: var(--second-family);
      font-size: 5.5rem;
      font-weight: 600;
      line-height: 1.3;

      @media (max-width: 896px) {
        font-size: 3.75rem;
      }
    }

    >.text {
      color: var(--color-text-light);
      font-size: 1rem;
      font-weight: 500;
      line-height: 2;

      @media (max-width: 896px) {
        line-height: 1.75;
      }
    }

    &[data-color-variant="red"] {

      >h2>.sub,
      >h2>.title {
        color: var(--color-primary-30);
      }
    }
  }

  /* ---------------------------------------------
  .top-solutions
------------------------------------------------ */
  .top-solutions {
    position: relative;
    overflow: hidden;
    border-radius: 5px 5px 0 0;
    background-color: var(--color-fill-subtle);
    margin-inline: min(1.25vw, 20px);

    @media (max-width: 896px) {
      border-radius: 0;
      margin-inline: 0;
    }

    &::after {
      position: absolute;
      top: 0;
      left: 0;
      display: block;
      width: 100%;
      height: 797px;
      background: url("/assets/images/top/bg-solution-pc.jpg") no-repeat center top;
      background-size: cover;
      content: "";

      @media (max-width: 896px) {
        height: 343px;
        background-image: url("/assets/images/top/bg-solution-sp.jpg");
      }
    }

    >.inner {
      position: relative;
      z-index: 2;
      width: 100%;
      max-width: 1380px;
      padding: 277px min(1.25vw, 20px) 102px;
      margin: 0 auto;

      @media (max-width: 896px) {
        max-width: 100%;
        padding: 50px 20px 64px;
      }
    }
  }

  .top-solution-find {
    position: relative;
    overflow: hidden;
    padding: 85px 85px 0;
    margin-top: 40px;
    background-color: var(--color-fill-subtle);
    border-top-left-radius: 5px;
    border-top-right-radius: 5px;

    @media (max-width: 896px) {
      width: calc(100% + 40px);
      padding: 38px 20px 0;
      margin-left: -20px;
    }

    &::before {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 8px;
      background: var(--color-fill-brand);
      content: "";

      @media (max-width: 896px) {
        height: 4px;
      }
    }

    .solution-list-product {
      background: var(--color-fill-default);
    }
  }

  /* ---------------------------------------------
  .top-recruit
------------------------------------------------ */
  .top-recruit {
    margin: 20px 20px 0;

    @media (max-width: 896px) {
      margin: 0;
    }

    >.box-info {
      position: relative;
      display: flex;
      overflow: hidden;
      border-radius: 5px;
      background-color: var(--color-fill-brand);

      @media (min-width: 897px) {
        height: 776px;
      }

      @media (max-width: 896px) {
        flex-direction: column;
        border-radius: 0;
      }
    }

    >.box-info>.text-tagline {
      position: absolute;
      right: 0;
      bottom: 0;
      left: 0;
      width: min(90.4375vw, 1447px);
      margin: 0 auto;

      @media (max-width: 896px) {
        display: none;
      }
    }

    >.box-info>.text-tagline>img {
      display: block;
      width: 100%;
      height: auto;
    }

    >.box-info>.image {
      @media (min-width: 897px) {
        width: 50%;
        background: url("/assets/images/top/pict-recruit-01-pc.jpg") no-repeat center top;
        background-size: auto 100%;
      }

      @media (max-width: 896px) {
        width: 100%;
      }
    }

    >.box-info>.image>img {
      @media (min-width: 897px) {
        display: none;
      }

      @media (max-width: 896px) {
        width: 100%;
        height: auto;
        -o-object-fit: cover;
        object-fit: cover;
        -o-object-position: center center;
        object-position: center center;
      }
    }

    >.box-info>.box {
      @media (min-width: 897px) {
        width: 50%;
        max-width: none;
        padding: min(8.625vw, 138px) 40px min(12.5vw, 200px);
      }

      @media (max-width: 896px) {
        width: 100%;
        max-width: 100%;
        padding: 50px 20px;
      }
    }

    >.box-info>.box>.inner {
      max-width: 400px;
      margin: 0 auto;

      @media (max-width: 896px) {
        max-width: 100%;
      }
    }

    >.box-info>.box>.inner>.button {
      margin-top: 50px;

      @media (max-width: 896px) {
        margin-top: 41px;
      }
    }
  }

  .top-recruit-slide {
    margin-top: 20px;

    @media (max-width: 896px) {
      margin: 10px 0 0 10px;
    }
  }

  .top-recruit-list {
    >.item {
      width: calc(25% - 15px);

      @media (max-width: 896px) {
        width: 53.33333vw;
      }
    }

    >.item>.image {
      overflow: hidden;
      border-radius: 5px;
    }

    >.item>.image>img {
      width: 100%;
      height: auto;
    }
  }

  /* ---------------------------------------------
  .top-diary
------------------------------------------------ */
  .top-diary {
    position: relative;
    margin: 20px 20px 0;

    @media (max-width: 896px) {
      margin: 0;
    }

    >.inner {
      position: relative;
      z-index: 2;
      width: 100%;
      max-width: 1170px;
      padding: 150px 0 153px;
      margin: 0 auto;

      @media (max-width: 896px) {
        max-width: 100%;
        padding: 70px 20px 56px;
      }

      &::after {
        @media (min-width: 897px) {
          position: absolute;
          z-index: -1;
          top: 0;
          left: calc(100% - 285px);
          display: block;
          width: 50vw;
          height: 100%;
          border-radius: 5px;
          background-color: var(--color-fill-subtle);
          content: "";
        }
      }
    }

    >.inner>.heading {
      display: flex;
      align-items: center;
      margin-bottom: 95px;
      gap: min(4.13223vw, 50px);

      @media (max-width: 896px) {
        max-width: 100%;
        flex-direction: column;
        margin-bottom: 50px;
        gap: 22px;
      }
    }

    >.inner>.heading>h2 {
      width: min(47.10744vw, 570px);
      flex: 1 0 auto;

      @media (max-width: 896px) {
        width: 100%;
      }
    }

    >.inner>.heading>h2>img {
      width: 100%;
      height: auto;
    }

    >.inner>.heading>.text {
      width: 100%;
      line-height: 2;

      @media (max-width: 896px) {
        line-height: 1.8;
      }
    }

    >.inner>.button {
      display: flex;
      justify-content: center;
      margin-top: 95px;

      @media (max-width: 896px) {
        margin-top: 50px;
      }
    }
  }

  .top-diary-slide {
    padding-bottom: 70px;

    @media (max-width: 896px) {
      padding-bottom: 90px;
    }

    .splide__arrow {
      top: inherit;
      right: 61px;
      bottom: 0;
      left: inherit;
      width: 60px;
      height: 60px;
      border-radius: 5px 0 0 5px;
      background-color: var(--color-fill-default);
      opacity: 1;
      transform: none;

      @media (max-width: 896px) {
        right: inherit;
        left: 0;
        border: 1px solid var(--color-stroke-dark);
        border-radius: 5px;
        background-color: var(--color-fill-default);
      }

      @media (hover: hover) {
        transition: all 300ms ease-out;

        &:hover {
          background-color: var(--color-neutral-90);
        }
      }
    }

    .splide__arrow::after {
      position: absolute;
      top: 50%;
      left: 50%;
      display: block;
      width: 0;
      height: 0;
      border-width: 4.5px 8px 4.5px 0;
      border-style: solid;
      border-color: transparent var(--color-fill-brand) transparent transparent;
      content: "";
      transform: rotate(0deg) translate(-50%, -50%);

      @media (max-width: 896px) {
        border-color: transparent var(--color-gray-5) transparent transparent;
      }
    }

    .splide__arrow>svg {
      display: none;
    }

    .splide__arrow--next {
      right: 0;
      left: inherit;
      border-radius: 0 5px 5px 0;

      @media (max-width: 896px) {
        border-radius: 5px;
      }
    }

    .splide__arrow--next::after {
      border-width: 4.5px 0 4.5px 8px;
      border-color: transparent transparent transparent var(--color-fill-brand);

      @media (max-width: 896px) {
        border-color: transparent transparent transparent var(--color-gray-5);
      }
    }

    .splide__pagination {
      bottom: 24px;
      justify-content: flex-start;
      padding: 0;
      margin-left: calc(min(calc(570 / 1210 * 100vw), 570px) + 30px);
      gap: 5px;

      @media (max-width: 896px) {
        bottom: 25px;
        justify-content: center;
        margin-left: 0;
        padding-inline: 70px;
      }
    }

    .splide__pagination__page {
      width: 40px;
      height: 2px;
      border-radius: 0;
      margin: 0;
      background-color: var(--color-neutral-70);
      opacity: 1;
      transform: none;
      transition-property: all;

      @media (max-width: 896px) {
        width: 25px;
      }

      @media (hover: hover) {
        transition: all 300ms ease-out;

        &:hover {
          background-color: var(--color-neutral-80);
        }
      }
    }

    .splide__pagination__page.is-active {
      background-color: var(--color-text-brand);
    }
  }

  /* ---------------------------------------------
  .top-introduction
------------------------------------------------ */
  .top-introduction {
    margin: 20px 20px 0;

    @media (max-width: 896px) {
      margin: 0;
    }

    >.box-info {
      position: relative;
      display: flex;
      overflow: hidden;
      justify-content: flex-end;
      border-radius: 5px;
      background-color: var(--color-fill-dark);

      @media (min-width: 897px) {
        height: 658px;
      }

      @media (max-width: 896px) {
        flex-direction: column;
        border-radius: 0;
      }
    }

    >.box-info>.image {
      @media (min-width: 897px) {
        width: 50%;
        background: url("/assets/images/top/pict-introduction-01-pc.jpg") no-repeat center top;
        background-size: auto 100%;
      }

      @media (max-width: 896px) {
        width: 100%;
      }
    }

    >.box-info>.image>picture>img {
      @media (min-width: 897px) {
        display: none;
      }

      @media (max-width: 896px) {
        width: 100%;
        height: 100%;
        -o-object-fit: cover;
        object-fit: cover;
      }
    }

    >.box-info>.box {
      @media (min-width: 897px) {
        width: 50%;
        max-width: none;
        padding: min(9.375vw, 150px) 40px;
      }

      @media (max-width: 896px) {
        width: 100%;
        max-width: 100%;
        padding: 50px 20px 55px;
      }
    }

    >.box-info>.box>.inner {
      max-width: 347px;
      margin: 0 auto;

      @media (max-width: 896px) {
        max-width: 100%;
      }
    }

    >.box-info>.box>.inner>.button {
      margin-top: 50px;

      @media (max-width: 896px) {
        margin-top: 30px;
      }
    }
  }

  /* ---------------------------------------------
  .top-news
------------------------------------------------ */
  .top-news {
    display: flex;
    gap: 40px;
    padding-block: 30px 156px;

    @media (max-width: 896px) {
      flex-direction: column;
      margin-top: -10px;
      gap: 21px;
      padding-block: 0 53px;
    }

    >.heading {
      width: min(29.75207vw, 360px);
      flex: 1 0 auto;

      @media (max-width: 896px) {
        width: 100%;
      }
    }

    >.heading>.button {
      margin-top: 26px;
    }

    >.box {
      width: 100%;
    }

    >.button {
      margin-top: 50px;

      @media (max-width: 896px) {
        margin-top: 30px;
      }
    }
  }
}