/* ==========================================================
   ホームページ制作 (/digital/homepage-production/)
   ========================================================== */

.page-homepage-production {
  background-color: #fff;
}

.p-hp-production {
  padding-block: clamp(40px, 5vw, 64px) clamp(48px, 6vw, 80px);
}

.p-hp-production__inner {
  padding: 100px 40px;
}

.p-hp-section {
  margin-bottom: clamp(42px, 6vw, 76px);
  max-width: 1080px;
  margin-inline: auto;
}

.p-hp-section__label {
  margin: 0 0 10px;
  font-family: var(--font-fv-display);
  font-size: var(--fs-cta-label);
  font-weight: 400;
  line-height: 1;
  color: var(--color-top-green-main);
}

.p-hp-section__title {
  margin: 0;
  font-size: var(--fs-fluid-20);
  font-weight: 400;
  letter-spacing: 0.06em;
  color: #5b7a62;
}

.p-hp-service__body {
  margin-top: 28px;
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  gap: clamp(20px, 4vw, 48px);
  align-items: center;
}

.p-hp-service__lead {
  margin: 0 0 40px;
  font-size: var(--fs-promo-times-title);
  font-weight: 700;
  line-height: 1.5;
  color: #1f4027;
}

.p-hp-service__text {
  margin: 0 0 20px;
  font-size: var(--fs-fluid-16);
  line-height: 1.9;
  color: var(--color-text);
}

.p-hp-service__note {
  padding: 14px 22px;
  max-width: 520px;
  background: #E5F0E7;
}

.p-hp-service__note p {
  margin: 0;
  font-size: var(--fs-fluid-16);
  line-height: 1.75;
  font-weight: 500;
  color: #2a3730;
}

.p-hp-service__visual {
  position: relative;
  margin: 0;
  isolation: isolate;
}

.p-hp-service__visual-photo {
  width: 100%;
  overflow: hidden;
}

.p-hp-service__visual-photo img {
  display: block;
  width: 100%;
  height: auto;
}

.p-hp-service__bottom-text {
  margin: 34px 0 0;
  font-size: var(--fs-fluid-16);
  line-height: 2;
  color: #2a2f2c;
}

.p-hp-cases {
  background-color: #205836;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  max-width: none;
  padding-block: 80px;
  padding-inline: 40px;
}

.p-hp-cases .p-hp-section__label,
.p-hp-cases .p-hp-section__title {
  color: #ffffff;
}

.p-hp-cases .p-hp-section__label,
.p-hp-cases .p-hp-section__title,
.p-hp-cases .p-hp-cases__grid {
  max-width: 1080px;
  margin-inline: auto;
}

.p-hp-cases__grid {
  margin-top: 40px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 40px;
}

.p-hp-cases__item {
  display: block;
  aspect-ratio: 4 / 3;
  background: #d9d9d9;
  text-decoration: none;
  transform: translate3d(0, 0, 0);
  box-shadow: 0 0 0 rgba(0, 0, 0, 0);
}

@media (hover: hover) {
  .p-hp-cases__item {
    transition:
      transform var(--transition),
      box-shadow var(--transition);
  }

  .p-hp-cases__item:hover {
    transform: translate3d(0, var(--card-link-hover-lift), 0);
    box-shadow: var(--card-link-hover-shadow);
  }
}

.p-hp-flow__visual {
  margin: 80px 0 0;
}

.p-hp-flow__visual-image {
  display: block;
  width: 100%;
  height: auto;
}

.p-hp-flow__carousel {
  display: none;
}

@media (max-width: 1023px) {
  .p-hp-service__visual {
    max-width: min(360px, 82%);
    margin-inline: auto;
  }

  .p-hp-flow__visual {
    margin-top: 56px;
  }
}

@media (max-width: 767px) {
  .p-hp-production__inner {
    padding-inline: 20px;
  }

  .p-hp-cases {
    padding-inline: 20px;
  }

  .p-hp-service__body {
    grid-template-columns: 1fr;
  }

  .p-hp-cases__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .p-hp-flow__visual {
    display: none;
  }

  .p-hp-flow__carousel {
    margin: 40px 0 0;
    padding: 0;
    list-style: none;
    display: flex;
    gap: 12px;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }

  .p-hp-flow__carousel-item {
    flex: 0 0 calc((100% - 12px) / 2);
    height: 260px;
    display: flex;
    align-items: center;
    justify-content: center;
    scroll-snap-align: start;
  }

  .p-hp-flow__carousel-image {
    display: block;
    width: auto;
    max-width: 100%;
    height: 100%;
    object-fit: contain;
  }
}
