/* ============================================================
   TESTIMONIALS.CSS — auto-sliding glass cards, neon borders
   ============================================================ */

.testimonials { max-width: 100%; }
.testimonials .section-head { max-width: var(--max); margin-left: auto; margin-right: auto; padding: 0 clamp(1.25rem, 5vw, 3rem); }

/* Edge-fade viewport */
.testi-viewport {
  overflow: hidden;
  -webkit-mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
  mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
}

.testi-track {
  display: flex;
  gap: 1.4rem;
  width: max-content;
  padding: 0 1rem;
  animation: slideX 36s linear infinite;
}
.testi-track:hover { animation-play-state: paused; }
@keyframes slideX {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); } /* track is duplicated in JS */
}

.testi-card {
  position: relative;
  width: 380px;
  flex: 0 0 auto;
  padding: 1.8rem;
  border-radius: var(--radius);
}
/* Neon gradient border */
.testi-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: var(--radius);
  padding: 1.4px;
  background: var(--grad);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0.4;
}
.testi-card blockquote {
  font-size: 1.08rem;
  line-height: 1.55;
  margin-bottom: 1.4rem;
  color: #e7ecf5;
}
.testi-card figcaption {
  display: flex;
  align-items: center;
  gap: 0.8rem;
}
.t-avatar {
  width: 42px; height: 42px;
  border-radius: 50%;
  display: grid; place-items: center;
  font-family: var(--font-display);
  font-weight: 600;
  background: var(--grad);
  color: #06070f;
}
.testi-card figcaption span:last-child { display: flex; flex-direction: column; }
.testi-card strong { font-size: 0.98rem; }
.testi-card em { font-style: normal; font-size: 0.82rem; color: var(--muted); }
