@charset "utf-8";

.p-fv {
  padding-top: 105px;
  overflow: hidden;

  @media (width < 1120px) {
    padding-top: 80px;
  }

  .l-inner {
    max-width: 1356px;

    .c-heading {
      margin: 0 auto;
      max-width: 1146px;
      position: relative;
      z-index: 2;

      @media (width < 1120px) {
        margin-left: 0;
      }
    }

    .c-heading__en {
      letter-spacing: 0.01em;
    }
  }
}

.p-fv__breadcrumb {
  display: flex;
  justify-content: end;
  align-items: center;
  gap: 43px;
  position: relative;
  z-index: 2;

  a:hover {
    opacity: 0.7;
  }
}

.p-fv__breadcrumb-text {
  color: #848484;
  font-weight: 400;
  font-size: 13px;
  letter-spacing: 0.06em;
  position: relative;
}

.p-fv__breadcrumb-text:not(:last-of-type)::after {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
  right: -26px;
  width: 7px;
  height: 8px;
  background: #848484;
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
}

.p-fv__bg-text {
  position: absolute;
  top: -0.8em;
  right: 0;
  z-index: -1;
  color: #fff;
  -webkit-text-stroke: 0.01em #addbf8;
  paint-order: stroke;
  font-family: var(--font-noto-sans);
  font-size: 175px;
  font-size: clamp(60px, calc(175vw / 13.66), 175px);
  font-weight: 400;
  letter-spacing: 0.01em;
  line-height: 0.85;
}

.p-fv__img {
  margin-top: 45px;
  width: 100%;
  aspect-ratio: 1316/485;
  position: relative;
  z-index: 0;

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

  img {
    width: 100%;
    height: 100%;
    border-radius: 5px;
    overflow: hidden;
    object-fit: cover;
  }
}

.gjs-dashed *[data-highlightable] .p-fv__img {
  z-index: 3;
}

.p-fv__img::before {
  content: "";
  position: absolute;
  z-index: 1;
  bottom: 0;
  width: 100%;
  height: 100%;
  border-radius: 5px;
  background: transparent linear-gradient(180deg, #ffffff00 0%, #8dbdef00 38%, #438bca89 63%, #0360aa 100%);
}

.gjs-dashed *[data-highlightable] .p-fv__img::before {
  z-index: -1;
}
