/* お客様の声: セクション上余白 */
.front-testimonials {
  padding-top: 80px;
  background-color: var(--brand-white);
  background-image: url("../../../../assets/orisen.webp");
  background-repeat: repeat-y;
  background-position: center top;
  background-size: 115vw auto;
}

/* お客様の声: 3列カードグリッド */
.front-testimonials .testimonial-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(257px, 257px));
  justify-content: center;
  justify-items: center;
  gap: 24px;
  margin-bottom: 36px;
}

.front-testimonials .testimonial-carousel-button {
  display: none;
}

/* ペーパーカード: 角折れ風の枠 */
.front-testimonials .paper-card {
  --paper-fold-size: 40px;
  width: 257px;
  height: 401px;
  background-color: var(--brand-white);
  background-image:
    linear-gradient(var(--color-border), var(--color-border)),
    linear-gradient(var(--color-border), var(--color-border)),
    linear-gradient(var(--color-border), var(--color-border)),
    linear-gradient(var(--color-border), var(--color-border));
  background-repeat: no-repeat;
  background-size:
    calc(100% - var(--paper-fold-size)) 1px,
    1px calc(100% - var(--paper-fold-size)),
    1px 100%,
    100% 1px;
  background-position:
    right top,
    left bottom,
    right top,
    left bottom;
  padding: 17px 22px 22px;
  position: relative;
}

/* ペーパーカード: 角折れの装飾 */
.front-testimonials .paper-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: var(--paper-fold-size);
  height: var(--paper-fold-size);
  background: linear-gradient(
    135deg,
    var(--brand-white) calc(50% - 0.5px),
    var(--color-ink) calc(50% - 0.5px),
    var(--color-ink) calc(50% + 0.5px),
    transparent calc(50% + 0.5px)
  );
  border-right: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}

/* カードラベル: 種別やカテゴリ */
.front-testimonials .card-label {
  font-size: 16px;
  font-weight: var(--weight-gothic-medium);
  margin: 0 0 28px;
  text-align: center;
  position: relative;
}

/* カードラベル: 下線アクセント */
.front-testimonials .card-label::after {
  content: "";
  display: block;
  width: 117px;
  height: 2px;
  background: var(--brand-orange);
  margin: 2px auto 0;
}

/* アバター: 丸いプレースホルダー */
.front-testimonials .avatar {
  width: 122px;
  height: 122px;
  border-radius: 50%;
  border: 1px solid var(--color-border);
  display: grid;
  place-items: center;
  margin: 0 auto 28px;
  color: var(--color-muted);
  overflow: hidden;
}

.front-testimonials .avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* お客様の声: コメント本文 */
.front-testimonials .paper-card p {
  font-size: 15px;
  font-weight: var(--weight-gothic-regular);
  color: var(--color-muted);
}

/* お客様の声: セクション下の導線 */
.front-testimonials .section-actions {
  text-align: center;
}

/* お客様の声: CTAボタン群 */
.front-testimonials .testimonials-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
}

/* お客様の声: もっと見るボタンはfeatures準拠のアウトライン版 */
.front-testimonials .testimonials-more-btn {
  width: 229px;
  box-sizing: border-box;
  justify-content: center;
  gap: 15px;
  padding: 10px 0;
  background: var(--brand-white);
  color: var(--color-text);
  border: 1px solid var(--color-border);
}

/* お客様の声: もっと見る文言の改行制御 */
.front-testimonials .testimonials-more-text {
  display: block;
  padding-left: 22px;
  text-align: center;
  line-height: 1.4;
}

@media (max-width: 768px) {
  /* モバイル: 1枚表示カルーセル */
  .front-testimonials .testimonial-carousel {
    --testimonial-button-offset: 14px;
    --testimonial-button-width: 28px;
    --testimonial-slide-gap: 16px;
    --testimonial-side-space: calc(var(--testimonial-button-offset) + var(--testimonial-button-width) + 10px);
    --testimonial-slide-width: min(257px, calc(100vw - (var(--testimonial-side-space) * 2) - var(--testimonial-slide-gap)));
    position: relative;
    margin-inline: calc(50% - 50vw);
    padding-inline: var(--testimonial-side-space);
    margin-bottom: 36px;
  }

  .front-testimonials .testimonial-carousel-viewport {
    width: calc(var(--testimonial-slide-width) + (var(--testimonial-slide-gap) / 2));
    margin: 0 auto;
    overflow: hidden;
  }

  .front-testimonials .testimonial-grid {
    display: flex;
    justify-content: flex-start;
    gap: var(--testimonial-slide-gap);
    margin-bottom: 0;
    transition: transform 0.36s ease;
    will-change: transform;
  }

  .front-testimonials .testimonial-slide {
    flex: 0 0 var(--testimonial-slide-width);
  }

  .front-testimonials .paper-card {
    width: 100%;
    height: auto;
    min-height: 401px;
  }

  .front-testimonials .testimonial-carousel-button {
    display: block;
    width: 28px;
    height: 44px;
    border: none;
    padding: 0;
    background: transparent;
    position: absolute;
    top: 50%;
    cursor: pointer;
    transform: translateY(-50%);
    z-index: 1;
  }

  .front-testimonials .testimonial-carousel-button::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 18px;
    height: 18px;
    border-top: 2px solid var(--color-text);
    border-right: 2px solid var(--color-text);
  }

  .front-testimonials .testimonial-carousel-button--prev::before {
    transform: translate(-40%, -50%) rotate(-135deg);
  }

  .front-testimonials .testimonial-carousel-button--prev {
    left: var(--testimonial-button-offset);
  }

  .front-testimonials .testimonial-carousel-button--next::before {
    transform: translate(-60%, -50%) rotate(45deg);
  }

  .front-testimonials .testimonial-carousel-button--next {
    right: var(--testimonial-button-offset);
  }
}

@media (min-width: 768px) {
  /* PC: 半分見切れから始まる横並びパターン */
  .front-testimonials {
    padding-top: 100px;
    padding-bottom: 150px;
    background-repeat: repeat;
    background-position: calc(-100vw / 6) top;
    background-size: calc(100vw / 3) auto;
  }

  .front-testimonials .section-center {
    margin-bottom: 30px;
  }

  .front-testimonials .testimonial-carousel + .section-center {
    margin-top: 100px;
  }
}
