@charset "utf-8";

.p-top-fv {
  margin-top: 97px;
  padding-top: calc(30vw / 13.66);
  width: 100%;
  aspect-ratio: 1366 / calc(768 - 97);
  background: linear-gradient(180deg, #ffffff 0%, #f5f5f5 35%, #d3d7eb 67%, #bdc6d8 100%);
  position: relative;
  overflow: hidden;

  @media (width < 768px) {
    margin-top: 70px;
    padding-top: calc(40vw / 3.75);
    aspect-ratio: 1366 / 1200;
  }
}

.p-top-fv__bg-text1,
.p-top-fv__bg-text2 {
  position: absolute;
  font-family: var(--font-noto-sans);
  font-weight: 400;
  font-size: calc(97vw / 13.66);
  color: transparent;
  -webkit-text-stroke: 0.01em #c4cbde;
  paint-order: stroke;
  z-index: 1;
}

.gjs-dashed *[data-highlightable] .p-top-fv__bg-text1,
.gjs-dashed *[data-highlightable] .p-top-fv__bg-text2 {
  z-index: 4;
  line-height: 1;
}

.p-top-fv__bg-text1 {
  top: 0;
  right: 4%;
}

.p-top-fv__bg-text2 {
  top: 24%;
  left: -15%;
}

.p-top-fv__images {
  display: flex;
  justify-content: center;
  gap: calc(34vw / 13.66);
  position: relative;
  height: 82%;

  @media (width < 768px) {
    height: calc(240vw / 3.75);
  }
}

.p-top-fv__left,
.p-top-fv__right {
  width: 20%;
  position: relative;
  z-index: 3;

  @media (width < 768px) {
    flex-shrink: 0;
    height: 60%;
  }

  img {
    position: absolute;
    border-radius: calc(8vw / 13.66);
    object-fit: cover;
  }
}

.p-top-fv__left {
  img:nth-of-type(1) {
    width: calc(235vw / 13.66);
    aspect-ratio: 235/136;
    top: calc(43vw / 13.66);
    left: calc(-3vw / 13.66);
  }

  img:nth-of-type(2) {
    width: calc(122vw / 13.66);
    aspect-ratio: 122/86;
    top: 46%;
    left: calc(80vw / 13.66);
  }

  img:nth-of-type(3) {
    width: calc(195vw / 13.66);
    aspect-ratio: 195/153;
    bottom: 0;
    left: calc(-53vw / 13.66);
  }
}

.p-top-fv__main {
  width: 54.5%;
  aspect-ratio: 744/415;
  align-self: start;
  position: relative;
  z-index: 1;

  @media (width < 768px) {
    flex-shrink: 0;
    width: 72%;
  }

  img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}

.p-top-fv__right {
  img:nth-of-type(1) {
    width: calc(166vw / 13.66);
    aspect-ratio: 166/123;
    top: calc(56vw / 13.66);
    right: calc(-4vw / 13.66);
  }

  img:nth-of-type(2) {
    width: calc(135vw / 13.66);
    aspect-ratio: 135/95;
    top: 39%;
    left: calc(-12vw / 13.66);
  }

  img:nth-of-type(3) {
    width: calc(101vw / 13.66);
    aspect-ratio: 101/71;
    top: 54%;
    right: calc(-46vw / 13.66);
  }

  img:nth-of-type(4) {
    width: calc(177vw / 13.66);
    aspect-ratio: 177/125;
    bottom: calc(26vw / 13.66);
    right: calc(26vw / 13.66);
  }
}

.p-top-fv__title-inner {
  margin: 0 auto;
  width: fit-content;
  color: var(--color-white);
  position: relative;
  z-index: 3;
  bottom: calc(196vw / 13.66);

  @media (width < 768px) {
    bottom: calc(80vw / 3.75);
  }
}

.p-top-fv__title {
  margin-right: calc(80vw / 13.66);
  font-weight: 400;
  font-family: var(--font-noto-sans);
  font-size: clamp(36px, calc(97vw / 13.66), 200px);
  line-height: 0.85;
  letter-spacing: 0.01em;

  @media (width < 768px) {
    margin-right: 0;
  }

  span {
    font-size: clamp(24px, calc(67vw / 13.66), 200px);
    font-weight: 700;
  }
}

.p-top-fv__sub-title {
  margin-top: calc(20vw / 13.66);
  margin-right: calc(54vw / 13.66);
  font-weight: bold;
  font-size: clamp(16px, calc(32vw / 13.66), 100px);
  line-height: 1.438;
  letter-spacing: 0.05em;
  text-align: center;

  @media (width < 768px) {
    margin-right: 0;
  }
}

.p-about {
  padding: 153px 0 130px;
  background: linear-gradient(180deg, #dee2ed 0%, #fafafa 100%, #ffffff 100%);

  @media (width < 768px) {
    padding: 80px 0;
  }

  .l-inner {
    display: flex;
    justify-content: space-between;
    gap: 20px;

    @media (width < 768px) {
      flex-direction: column;
      gap: 40px;
    }
  }
}

.p-about__left {
  width: fit-content;

  .c-heading__en {
    @media (width < 1120px) {
      font-size: 45px;
    }

    @media (width < 768px) {
      font-size: 53px;
    }
  }

  .c-heading__ja {
    white-space: nowrap;
  }
}

.p-about__head {
  margin-top: 47px;
  font-weight: 600;
  font-size: 30px;
  line-height: 1.667;
  letter-spacing: 0.05em;

  @media (width < 1120px) {
    font-size: 22px;
  }

  @media (width < 768px) {
    margin-top: 30px;
  }
}

.p-about__center {
  width: 39%;
  max-width: 456px;
  align-self: start;
  margin-top: 63px;
  aspect-ratio: 456/530;

  @media (width < 768px) {
    width: 100%;
    margin: 0 auto;
  }
}

.gjs-dashed *[data-highlightable] .p-about__center {
  aspect-ratio: auto;
}

.p-about__right {
  margin-top: 198px;
  width: 26%;
  display: flex;
  flex-direction: column;
  gap: 36px;

  @media (width < 1120px) {
    width: 36%;
    margin-top: 100px;
  }

  @media (width < 768px) {
    margin-top: 0;
    width: 100%;
    gap: 20px;
  }
}

.p-about__text {
  font-weight: 700;
  line-height: 2.714;
}

.p-top-features {
  padding: 142px 0 46px;
  overflow: hidden;

  @media (width < 768px) {
    padding: 80px 0 40px;
  }

  .l-inner {
    max-width: 1256px;
  }
}

.p-top-features__main {
  position: relative;
  width: 100%;
  height: 550px;
}

.p-top-features__head {
  margin: 0 auto;
  padding: 22px 20px 0;
  max-width: 1206px;
  position: relative;
  z-index: 1;
}

.p-top-features__head-text {
  margin-top: 36px;
  max-width: 264px;
  font-weight: 700;
  line-height: 2.714;
}

.p-top-features__main-image {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 0;
  width: 78%;
  height: 100%;
  object-fit: cover;
}

.p-top-features__container {
  margin-top: -130px;
  position: relative;
}

.p-top-features__lists {
  background: var(--color-white);
  width: 82%;
  margin: 0 0 0 auto;
  padding: 120px 40px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;

  @media (width < 1120px) {
    padding: 40px;
  }

  @media (width < 768px) {
    width: 78%;
    padding: 40px 20px;
  }

  img {
    position: absolute;
  }

  img:nth-of-type(1) {
    top: 165px;
    left: -194px;
    width: 190px;
    aspect-ratio: 190/259;
    object-fit: cover;

    @media (width < 768px) {
      left: -160px;
      width: 150px;
    }
  }

  img:nth-of-type(2) {
    bottom: 154px;
    left: -118px;
    width: 151px;
    aspect-ratio: 151/154;
    object-fit: cover;

    @media (width < 768px) {
      left: -95px;
      width: 100px;
      bottom: auto;
      top: 400px;
    }
  }
}

.p-top-features-list {
  max-width: 833px;
  margin: 0 auto;
  border-top: 2px solid #c7c7c7;
  padding: 41px 20px 33px;
  display: flex;
  align-items: center;
  gap: 20px;

  @media (width < 768px) {
    flex-direction: column;
    padding: 20px 0;
  }
}

.p-top-features-list:last-of-type {
  border-bottom: 2px solid #c7c7c7;
}

.p-top-features-list__head {
  width: 78%;
  min-width: 210px;

  @media (width < 768px) {
    width: 100%;
  }
}

.p-top-features-list__number {
  color: var(--color-red);
  font-weight: 700;
  font-size: 13px;
  font-family: var(--font-noto-sans);
  line-height: 1.1;
  letter-spacing: 0.02em;
}

.p-top-features-list__head-text {
  margin-top: 16px;
  color: #5a5a5a;
  font-weight: 600;
  font-size: 20px;
  line-height: 1.75;
  letter-spacing: 0.05em;
}

.p-top-features-list__text {
  margin-top: 1.4em;
}

.p-top-service {
  padding: 140px 0 142px;
  background: transparent linear-gradient(0deg, #dee2ed 0%, #fafafa 100%, #ffffff 100%);

  @media (width < 768px) {
    padding: 80px 0;
  }

  .l-inner {
    display: flex;
    justify-content: space-between;
    gap: 20px;

    @media (width < 768px) {
      flex-direction: column;
      gap: 40px;
    }
  }
}

.p-top-service__left {
  width: 26%;

  @media (width < 768px) {
    width: 100%;
  }

  .c-heading__en {
    @media (width < 1120px) {
      font-size: 45px;
    }

    @media (width < 768px) {
      font-size: 53px;
    }
  }

  .c-heading__ja {
    white-space: nowrap;
  }
}

.p-top-service__head-text {
  margin-top: 36px;
  line-height: 2.714;
  max-width: 264px;

  @media (width < 768px) {
    max-width: none;
  }
}

.p-top-service__center {
  width: 41%;
  max-width: 470px;
  align-self: start;
  margin-top: 74px;
  aspect-ratio: 470/474;

  @media (width < 768px) {
    width: 100%;
    margin: 0 auto;
  }

  .c-link-btn {
    margin: 90px auto 0;
    padding: 11px 9px;
    width: 100%;
    max-width: 400px;
    justify-content: center;
    position: relative;

    @media (width < 768px) {
      margin: 24px auto 0;
    }

    .c-link-btn__arrow {
      position: absolute;
      right: 18px;
    }
  }
}

.gjs-dashed *[data-highlightable] .p-top-service__center {
  aspect-ratio: auto;
}

.p-top-service__right {
  margin-top: 250px;
  width: 26%;
  display: flex;
  flex-direction: column;
  gap: 20px;

  @media (width < 1120px) {
    width: 36%;
    margin-top: 100px;
  }

  @media (width < 768px) {
    margin-top: 80px;
    width: 100%;
    gap: 20px;
  }
}

.p-top-service__text {
  font-weight: 700;
  line-height: 2.714;
}

.p-top-works {
  margin-top: 143px;

  @media (width < 768px) {
    margin-top: 80px;
  }
}

.p-top-works__head {
  display: flex;
  justify-content: space-between;
  align-items: center;

  @media (width < 768px) {
    flex-direction: column;
    align-items: start;
    gap: 20px;
  }

  .c-link-btn {
    width: 220px;

    @media (width < 768px) {
      align-self: flex-end;
    }
  }
}

.p-top-works__lists {
  margin-top: 60px;

  section {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 46px 20px;

    @media (width < 1120px) {
      gap: 40px 20px;
    }

    @media (width < 768px) {
      grid-template-columns: repeat(2, 1fr);
    }
  }
}

.p-company {
  margin-top: 116px;
  scroll-margin-top: 97px;
  margin-bottom: 140px;

  @media (width < 768px) {
    scroll-margin-top: 70px;
    margin-top: 80px;
    margin-bottom: 100px;
  }
}

.p-company__flex {
  margin-top: 40px;
  display: flex;
  gap: 20px;
  justify-content: space-between;
  align-items: start;

  @media (width < 768px) {
    flex-direction: column;
    align-items: center;
    gap: 30px;
  }
}

.p-company__map {
  margin: 24px auto 0;
  width: 50%;
  max-width: 583px;
  aspect-ratio: 583/601;

  @media (width < 768px) {
    margin: 0 auto;
    width: 100%;
  }
}

.p-company__lists {
  width: 44%;

  @media (width < 768px) {
    width: 100%;
  }
}

.p-company-list {
  padding-bottom: 17px;
  border-bottom: 1px solid hsla(0, 0%, 60%, 0.3);
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.p-company-list:not(:first-of-type) {
  padding-top: 16px;
}

.p-company-list__head {
  font-weight: 700;
  color: var(--color-red);
}

.p-company-list__text {
  color: #464646;
  line-height: 2.143;

  a:hover {
    opacity: 0.7;
  }
}
