/* assets/css/components/front-testimonials.css
 * @layer components — Testimonials Splide slider
 * ════════════════════════════════════════════════════════════════════ */

@layer components {

  /* ── Slider wrapper ── */

  .front-testimonials__slider {
    container-type: inline-size;
    container-name: front-testimonials-slider;
  }

  /* ── Horizontal split card (avatar left, content right) ── */

  .front-testimonials__card {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--space-2xl);
    align-items: center;
    padding: var(--space-xl) var(--space-l);
  }

  .front-testimonials__avatar-col {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }

  img.front-testimonials__avatar {
    display: block;
    inline-size: clamp(7rem, 12vw, 10rem);
    block-size: clamp(7rem, 12vw, 10rem);
    border-radius: var(--radius-full);
    object-fit: cover;
    border: 3px solid var(--border-subtle);
    filter: grayscale(1);
    transition: filter var(--duration-normal) var(--ease-default);
  }

  .splide__slide.is-active img.front-testimonials__avatar {
    filter: grayscale(0);
  }

  /* SVG placeholder avatar */
  .front-testimonials__avatar--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    inline-size: clamp(7rem, 12vw, 10rem);
    block-size: clamp(7rem, 12vw, 10rem);
    border-radius: var(--radius-full);
    background-color: var(--avatar-bg);
    color: var(--avatar-text);
    border: 3px solid var(--border-subtle);
  }

  .front-testimonials__content {
    display: flex;
    flex-direction: column;
    gap: var(--space-m);
  }

  /* Star rating row */
  .front-testimonials__stars {
    display: flex;
    gap: var(--space-3xs);
    color: var(--icon-color);
  }

  .front-testimonials__quote {
    margin: 0;
  }

  .front-testimonials__quote,
  .front-testimonials__quote p {
    margin: 0;
    font-style: normal;
  }

  .front-testimonials__quote p {
    font-size: clamp(var(--text-l), 2vw, var(--heading-xs));
    font-weight: var(--weight-regular);
    line-height: var(--leading-relaxed);
    color: var(--text-body);
  }

  .front-testimonials__meta {
    display: flex;
    flex-direction: column;
    gap: var(--space-3xs);
  }

  .front-testimonials__author-wrap {
    display: flex;
    flex-direction: column;
    gap: var(--space-3xs);
  }

  .front-testimonials__author {
    margin: 0;
    font-size: var(--text-m);
    font-weight: var(--weight-bold);
    color: var(--text-main);
  }

  .front-testimonials__role {
    margin: 0;
    font-size: var(--text-s);
    color: var(--text-muted);
  }

  /* ── Splide fade mode ── */

  .front-testimonials__splide:not(.splide--fade) .splide__slide + .splide__slide {
    display: none;
  }

  .front-testimonials__splide.splide--fade .splide__slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    z-index: 0;
    transition: opacity 1s ease;
  }

  .front-testimonials__splide.splide--fade .splide__slide.is-active {
    opacity: 1;
    z-index: 1;
    position: relative;
  }

  /* ── Splide pagination dots ── */

  .front-testimonials__splide .splide__pagination {
    margin-block-start: var(--space-l);
    display: flex;
    justify-content: center;
    gap: var(--space-xs);
    list-style: none;
    padding: 0;
  }

  .front-testimonials__splide .splide__pagination__page {
    display: block;
    inline-size: 8px;
    block-size: 8px;
    border-radius: var(--radius-full);
    background-color: var(--border-default);
    border: none;
    cursor: pointer;
    padding: 0;
    transition:
      background-color var(--duration-fast) var(--ease-default),
      transform        var(--duration-fast) var(--ease-default);
  }

  .front-testimonials__splide .splide__pagination__page.is-active {
    background-color: var(--surface-primary);
    transform: scale(1.4);
  }

  /* ── Responsive: stack on narrow ── */

  @container front-testimonials-slider (width < 40rem) {
    .front-testimonials__card {
      grid-template-columns: 1fr;
      gap: var(--space-l);
      text-align: center;
      justify-items: center;
    }

    img.front-testimonials__avatar,
    .front-testimonials__avatar--placeholder {
      inline-size: 6rem;
      block-size: 6rem;
    }

    .front-testimonials__meta {
      align-items: center;
    }

    .front-testimonials__author-wrap {
      align-items: center;
    }
  }

}
