/* ── TESTIMONIALS ── */
.testimonials {
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, #fff8f3 0%, var(--cream-soft) 48%, #f5ebe2 100%);
  border-top: 1px solid var(--cream-mid);
  border-bottom: 1px solid var(--cream-mid);
}
.testimonials::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    radial-gradient(circle at 12% 22%, rgba(116, 134, 47, 0.12) 0 140px, transparent 140px),
    radial-gradient(circle at 88% 68%, rgba(69, 48, 29, 0.07) 0 180px, transparent 180px);
  opacity: 0.85;
}
.testimonials__inner { position: relative; z-index: 1; }
.testimonials__hint {
  margin: 10px 0 36px;
  font-family: var(--ff-airy);
  font-size: 0.82rem;
  font-weight: 400;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brown-light);
}
.testimonials__carousel {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 14px;
  margin-bottom: 28px;
}
.testimonials__stack {
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(720px, calc(100% - 48px));
  height: calc(100% - 8px);
  transform: translate(-50%, -50%);
  pointer-events: none;
  z-index: 0;
}
.testimonials__stack-layer {
  position: absolute;
  inset: 10px 14px;
  border-radius: var(--radius);
  border: 1px solid rgba(116, 134, 47, 0.14);
  background: rgba(255, 252, 248, 0.55);
  box-shadow: 0 10px 28px rgba(40, 28, 18, 0.08);
}
.testimonials__stack-layer:nth-child(1) { transform: translateY(10px) scale(0.985); opacity: 0.55; }
.testimonials__stack-layer:nth-child(2) { transform: translateY(20px) scale(0.97); opacity: 0.32; }
.testimonials__viewport {
  position: relative;
  z-index: 1;
  min-width: 0;
  overflow: hidden;
  touch-action: pan-y pinch-zoom;
  cursor: grab;
}
.testimonials__viewport.is-dragging { cursor: grabbing; }
.testimonials__track { position: relative; min-height: 280px; }
.testimonial-card {
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: translateX(28px) scale(0.985);
  filter: blur(3px);
  pointer-events: none;
  transition:
    opacity 0.52s cubic-bezier(0.2, 0.7, 0.25, 1),
    transform 0.52s cubic-bezier(0.2, 0.7, 0.25, 1),
    filter 0.52s cubic-bezier(0.2, 0.7, 0.25, 1);
  will-change: opacity, transform, filter;
}
.testimonial-card--active {
  position: relative;
  opacity: 1;
  transform: translateX(0) scale(1);
  filter: blur(0);
  pointer-events: auto;
}
.testimonial-card.is-leaving-left { opacity: 0; transform: translateX(-36px) scale(0.98); filter: blur(2px); }
.testimonial-card.is-leaving-right { opacity: 0; transform: translateX(36px) scale(0.98); filter: blur(2px); }
.testimonial-card.is-entering-left { opacity: 0; transform: translateX(-36px) scale(0.985); filter: blur(3px); }
.testimonial-card.is-entering-right { opacity: 0; transform: translateX(36px) scale(0.985); filter: blur(3px); }
.testimonial-card__inner {
  position: relative;
  padding: 34px 34px 30px;
  border-radius: var(--radius);
  background: rgba(255, 252, 248, 0.88);
  backdrop-filter: blur(18px) saturate(1.12);
  -webkit-backdrop-filter: blur(18px) saturate(1.12);
  border: 1px solid rgba(255, 255, 255, 0.62);
  box-shadow: 0 22px 56px rgba(40, 28, 18, 0.14), 0 0 0 1px rgba(116, 134, 47, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.72);
}
.testimonial-card__inner::before {
  content: "«";
  position: absolute;
  top: 8px;
  right: 22px;
  font-family: var(--ff-airy);
  font-size: 4.2rem;
  font-weight: 200;
  line-height: 1;
  color: rgba(116, 134, 47, 0.14);
  pointer-events: none;
  user-select: none;
}
.testimonial-card__text {
  margin: 0 0 26px;
  font-size: clamp(0.94rem, 2.1vw, 1.02rem);
  line-height: 1.72;
  color: rgba(69, 48, 29, 0.9);
  font-style: italic;
}
.testimonial-card__author { display: flex; align-items: center; gap: 14px; }
.testimonial-card__avatar {
  flex-shrink: 0;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-family: var(--ff-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--white);
  background: linear-gradient(145deg, var(--olive) 0%, var(--olive-dim) 100%);
  box-shadow: 0 6px 16px rgba(94, 108, 35, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.22);
}
.testimonial-card__meta { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.testimonial-card__name {
  font-family: var(--ff-airy);
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--brown-dark);
}
.testimonial-card__role { font-size: 0.82rem; color: var(--brown-light); letter-spacing: 0.03em; }
.testimonials__nav {
  position: relative;
  z-index: 2;
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1.5px solid rgba(116, 134, 47, 0.28);
  background: rgba(255, 252, 248, 0.92);
  color: var(--olive-dim);
  display: grid;
  place-items: center;
  box-shadow: 0 6px 18px rgba(40, 28, 18, 0.1);
  transition: background 0.22s ease, border-color 0.22s ease, color 0.22s ease, transform 0.22s ease, box-shadow 0.22s ease;
}
.testimonials__nav:hover {
  background: var(--white);
  border-color: var(--olive);
  color: var(--olive);
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(40, 28, 18, 0.14);
}
.testimonials__nav:active { transform: translateY(0); }
.testimonials__swipe-hint {
  display: none;
  position: absolute;
  left: 50%;
  bottom: -6px;
  transform: translateX(-50%);
  align-items: center;
  gap: 6px;
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--brown-light);
  animation: testimonialsSwipePulse 2.8s ease-in-out infinite;
}
@keyframes testimonialsSwipePulse {
  0%, 100% { opacity: 0.45; transform: translateX(-50%) translateY(0); }
  50% { opacity: 0.9; transform: translateX(-50%) translateY(-3px); }
}
.testimonials__footer {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  gap: 14px 20px;
  align-items: center;
  max-width: 520px;
  margin: 0 auto;
}
.testimonials__progress {
  grid-column: 1 / -1;
  height: 3px;
  border-radius: 999px;
  background: rgba(69, 48, 29, 0.1);
  overflow: hidden;
}
.testimonials__progress-fill {
  display: block;
  height: 100%;
  width: 10%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--olive-dim), var(--olive));
  transform-origin: left center;
  transition: width 0.52s cubic-bezier(0.2, 0.7, 0.25, 1);
}
.testimonials__dots { display: flex; flex-wrap: wrap; gap: 7px; justify-content: flex-start; }
.testimonials__dot {
  width: 7px;
  height: 7px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: rgba(69, 48, 29, 0.18);
  cursor: pointer;
  transition: background 0.3s ease, transform 0.3s cubic-bezier(0.2, 0.7, 0.25, 1), width 0.3s ease;
}
.testimonials__dot--active { background: var(--olive); transform: scale(1.2); width: 18px; border-radius: 999px; }
.testimonials__counter {
  font-family: var(--ff-airy);
  font-size: 0.82rem;
  font-weight: 400;
  letter-spacing: 0.12em;
  color: var(--brown-mid);
  white-space: nowrap;
}
.testimonials__counter-sep { margin: 0 0.15em; opacity: 0.5; }

@media (max-width: 700px) {
  .testimonials__carousel { grid-template-columns: 1fr; gap: 0; padding-bottom: 22px; }
  .testimonials__nav { display: none; }
  .testimonials__viewport { margin: 0 -4px; }
  .testimonial-card__inner { padding: 26px 22px 24px; }
  .testimonials__swipe-hint { display: flex; }
  .testimonials__footer { max-width: none; grid-template-columns: 1fr; text-align: center; }
  .testimonials__dots { justify-content: center; }
  .testimonials__counter { justify-self: center; }
}
@media (prefers-reduced-motion: reduce) {
  .testimonial-card { transition: opacity 0.2s ease; transform: none; filter: none; }
  .testimonial-card.is-leaving-left,
  .testimonial-card.is-leaving-right,
  .testimonial-card.is-entering-left,
  .testimonial-card.is-entering-right { transform: none; filter: none; }
  .testimonials__swipe-hint { animation: none; opacity: 0.7; }
  .testimonials__progress-fill { transition: width 0.2s ease; }
}
