@charset "UTF-8";

@layer utility {
  /* =====================
    u-hover
  ===================== */
  .u-hover {
    transition: opacity 250ms ease 0s;
    @media (any-hover: hover) {
      &:hover {
        opacity: 0.7;
      }
    }
  }

  /* =====================
    u-inner
  ===================== */
  .u-inner {
    inline-size: 1160px;
    margin-inline: auto;

    @media (width <= 768px) {
      inline-size: 100%;
      padding-inline: calc((100 / 750) * 40 * 1vw);
    }
  }

  /* =====================
    u-anchor
  ===================== */
  .u-anchor {
    display: block flow;
    inline-size: fit-content;
    background-color: #61d7db;
    transition: all 0.5s ease;
    padding-block: 16px;
    padding-inline: 30px;
    outline: 1px solid #61d7db;
    outline-offset: -1px;

    @media (width <= 768px) {
      padding-block: calc((100 / 750) * 29 * 1vw);
      padding-inline: calc((100 / 750) * 48 * 1vw);
    }
    .btn-txt {
      transition: all 0.5s ease;
      font-weight: 500;
      color: #fff;
      display: block flex;
      gap: 24px;
      align-items: center;

      &::after {
        content: '';
        inline-size: 18px;
        aspect-ratio: 18 / 13;
        mask-repeat: no-repeat;
        mask-size: contain;
        mask-position: center;
        mask-image: var(--icon-arrow);
        background-color: currentColor;
        transition: all 0.5s ease;
      }

      @media (width <= 768px) {
        gap: calc((100 / 750) * 40 * 1vw);
        &::after {
          inline-size: calc((100 / 750) * 26 * 1vw);
        }
      }
    }
    @media (any-hover: hover) {
      &:hover {
        background-color: #fff;

        .btn-txt {
          color: #61d7db;
          &::after {
            background-color: #61d7db;
          }
        }
      }
    }
    &[data-color='white'] {
      background-color: transparent;
      outline: 1px solid #fff;
      outline-offset: -1px;
      .btn-txt {
        color: #fff;
      }
      @media (any-hover: hover) {
        &:hover {
          outline: 1px solid #61d7db;
          .btn-txt {
            color: #61d7db;
            &::after {
              background-color: #61d7db;
            }
          }
        }
      }
    }
  }

  /* =====================
  u-h2-title
  ===================== */
  .u-h2-title {
    display: block grid;
    gap: 7px;
    inline-size: fit-content;

    @media (width <= 768px) {
      gap: calc((100 / 750) * 11 * 1vw);
    }

    & > span[lang='en'] {
      font-family: var(--tajawal);
      font-size: 56px;
      font-weight: 200;
      line-height: 1;
      color: #666;

      @media (width <= 768px) {
        font-size: calc((100 / 750) * 66 * 1vw);
      }
    }
    & > h2.title {
      font-weight: 500;
    }
    /* ==== 白文字 ==== */
    &[data-color='white'] {
      & > span[lang='en'] {
        color: #fff;
      }
      & > h2.title {
        color: #fff;
      }
    }
    &[data-position='center'] {
      margin-inline: auto;
      justify-items: center;
    }
  }

  /* =====================
    u-table
  ===================== */
  .u-table {
    --_border-color: #61d7db;

    display: block grid;
    grid-template-columns: 210px 1fr;
    max-inline-size: 880px;
    margin-inline: auto;

    @media (width <= 768px) {
      grid-template-columns: calc((100 / 750) * 160 * 1vw) 1fr;
    }

    /* ==== tr ==== */
    .tr {
      display: block grid;
      grid-template-columns: subgrid;
      grid-column: 1 / -1;

      & :where(dt, dd) {
        block-size: 100%;
        padding-inline: 40px;
        padding-block: 30px;
        color: #333;

        @media (width <= 768px) {
          padding-block: calc((100 / 750) * 23.4 * 1vw);
          padding-inline: calc((100 / 750) * 20 * 1vw);
        }
      }

      &:last-child {
        & dt {
          border-block-end-color: #61d7db;
        }

        & dd {
          border-block-end-color: var(--_border-color);
        }
      }
      /* ==== dt ==== */
      & dt {
        font-weight: 500;
        place-content: center start;
        border-block-start: 1px solid #61d7db;
        border-block-end: 1px solid transparent;
        word-break: auto-phrase;

        @media (width <= 768px) {
          place-content: start;
          padding-inline: calc((100 / 750) * 20 * 1vw) 0;
          place-content: center;
        }
      }

      /* ==== dd ==== */
      & dd {
        padding-inline: 40px 70px;
        border-block-start: 1px solid #61d7db;
        border-block-end: 1px solid transparent;

        @media (width <= 768px) {
          padding-inline: calc((100 / 750) * 40 * 1vw) 0;
        }
      }
    }
  }
  /* =====================
    箱付き文字
  ===================== */
  .box {
    display: inline-block;
    border: 1px solid currentColor;
    padding-inline: 0.6em;
    padding-block: 0.3em;
    vertical-align: text-bottom;

    @media (width <= 768px) {
      padding-inline: 0.65em;
      padding-block: 0.4em;
      vertical-align: baseline;
    }
  }

  /* =====================
    斜めキャッチ
  ===================== */
  .left-in-catch {
    inline-size: fit-content;
    transform: rotate(-6deg);
    font-family: var(--cedarville);
    font-size: 32px;
    line-height: 1;
    text-align: left;
    color: #61d7db;

    @media (width <= 768px) {
      font-size: calc((100 / 750) * 48 * 1vw);
    }

    &.js-parallax {
      .left-in-txt {
        clip-path: inset(0 100% 0 0);
        transition: all 600ms var(--easeOutExpo) 0s;
      }
    }
    &.js-parallax.on {
      .left-in-txt {
        clip-path: inset(0 0 0 0);
      }
    }
    &[data-color='white'] {
      color: #fff;
    }
  }

  /* =====================
    mv
  ===================== */
  .u-mv {
    position: relative;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    inline-size: 100%;
    block-size: 400px;
    padding-inline: 70px;
    padding-block-start: 115px;

    @media (width <= 768px) {
      block-size: calc((100 / 750) * 500 * 1vw);
      padding-inline: calc((100 / 750) * 40 * 1vw);
      padding-block-start: calc((100 / 750) * 189 * 1vw);
    }

    & > hgroup {
      position: relative;
      z-index: 5;

      & span[lang='en'] {
        font-family: var(--tajawal);
        font-size: 96px;
        font-weight: 200;
        line-height: 1;
        color: #fff;

        @media (width <= 768px) {
          font-size: calc((100 / 750) * 96 * 1vw);
        }
      }
      .title {
        font-size: 20px;
        line-height: 1;
        color: #fff;
        margin-block-start: 9px;

        @media (width <= 768px) {
          font-size: calc((100 / 750) * 28 * 1vw);
          margin-block-start: calc((100 / 750) * 7 * 1vw);
        }
      }
    }
    .breadcrumb {
      display: block flex;
      justify-content: flex-end;
      align-items: center;
      gap: 20px;
      font-size: 15px;
      font-weight: normal;
      line-height: 1;
      margin-block-start: 100px;
      color: #fff;

      @media (width <= 768px) {
        font-size: calc((100 / 750) * 24 * 1vw);
        margin-block-start: calc((100 / 750) * 108 * 1vw);
        gap: calc((100 / 750) * 20 * 1vw);
      }

      & > li {
        display: block flex;
        gap: 21px;

        @media (width <= 768px) {
          gap: calc((100 / 750) * 21 * 1vw);
        }
      }

      & li + li {
        &::before {
          content: '―';
          display: inline-block;
          flex-shrink: 0;
        }
      }
    }
  }
}
