/* ═══════════════════════════════════════════════════════════════
   TESTIMONIALS — infinite scrolling row of review cards
═══════════════════════════════════════════════════════════════ */

#testi { background: var(--bg); overflow: hidden; padding: 80px 0; }
.testi-header { padding: 0 48px; margin-bottom: 36px; text-align: center; }

.ttr { overflow: hidden; position: relative; }
.ttr::before, .ttr::after {
  content: ''; position: absolute; top: 0; bottom: 0;
  width: 64px; z-index: 1; pointer-events: none;
}
.ttr::before { left:  0; background: linear-gradient(90deg,  var(--bg), transparent); }
.ttr::after  { right: 0; background: linear-gradient(-90deg, var(--bg), transparent); }

.tsl {
  display: flex; gap: 16px;
  animation: slide 32s linear infinite;
  width: max-content;
  padding: 0 48px;
}
.tsl:hover { animation-play-state: paused; }
@keyframes slide { from { transform: translateX(0); } to { transform: translateX(-50%); } }

.tc {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: var(--rlg);
  padding: 24px; min-width: 320px; max-width: 320px;
  transition: border-color .2s, box-shadow .2s, transform .2s;
}
.tc:hover { border-color: rgba(201,168,76,.3); box-shadow: var(--shadow-md); transform: translateY(-2px); }

.tc-stars { color: var(--gold); font-size: 13px; letter-spacing: 1px; margin-bottom: 10px; }
.tc-text  { font-size: 14px; line-height: 1.65; color: var(--text2); margin-bottom: 16px; }
.tc-auth  { display: flex; align-items: center; gap: 12px; }
.tc-av {
  width: 38px; height: 38px; border-radius: 50%;
  background: linear-gradient(135deg, var(--navy), var(--navy2));
  display: flex; align-items: center; justify-content: center;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 15px; font-weight: 800; color: var(--gold2);
}
.tc-name { font-size: 14px; font-weight: 700; color: var(--navy); }
.tc-role { font-size: 11px; color: var(--muted); margin-top: 2px; }

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 1080px) {
  #testi        { padding: 64px 0; }
  .testi-header { padding: 0 24px; }
  .tsl          { padding: 0 24px; }
}
@media (max-width: 768px) {
  #testi        { padding: 52px 0; }
  .testi-header { padding: 0 20px; }
  .tc           { min-width: 270px; max-width: 270px; padding: 20px; }
}
@media (max-width: 480px) {
  .testi-header { padding: 0 16px; }
  .tc           { min-width: 250px; max-width: 250px; padding: 18px; }
}
