/**
 * Shared frontend styles for the Project Review Slider block and shortcode.
 *
 * Shortcode pages enqueue this same handle so the slider has one visual source
 * instead of duplicated rules in public.css.
 */
.rapm-project-review-slider,
.ra-project-reviews-slider,
.ra-reviews-slider {
  --ra-rs-bg: transparent;
  --ra-rs-text: inherit;
  padding: var(--space-10, 5rem) 0;
  color: var(--ra-rs-text);
  background: var(--ra-rs-bg);
}

.rapm-related-city-reviews .rapm-project-review-slider {
  padding: 0;
}

.ra-rs-header {
  margin: 0 0 var(--space-3, 1.5rem);
  text-align: center;
}

.ra-rs-title {
  margin: 0 0 var(--space-1-5, .75rem);
  line-height: 1.15;
}

.ra-rs-intro {
  margin: 0;
  opacity: .9;
}

.ra-rs-stage {
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--space-2, 1rem);
  align-items: center;
}

.ra-rs-stage--no-arrows {
  grid-template-columns: 1fr;
}

.ra-rs-viewport {
  overflow: hidden;
  border-radius: var(--radius-sm, 4px);
  touch-action: pan-y;
}

.ra-rs-track {
  display: flex;
  margin: 0;
  padding: 0;
  list-style: none;
  will-change: transform;
  transition: transform 380ms ease;
}

.ra-rs-track.is-no-anim {
  transition: none !important;
}

.ra-rs-slide {
  flex: 0 0 100%;
}

.ra-rs-card {
  display: grid;
  align-content: center;
  gap: var(--space-2, 1rem);
  min-height: 240px;
  margin: 0;
  padding: var(--space-3, 1.5rem);
  text-align: center;
  background: var(--bg-gray-light, #f5f5f5);
  border-radius: var(--radius-sm, 4px);
}

.ra-rs-quote {
  margin: 0;
  line-height: 1.6;
}

.ra-rs-rating {
  display: inline-flex;
  gap: var(--space-1, .5rem);
  align-items: center;
  justify-content: center;
  font-size: var(--space-2, 1rem);
}

.ra-rs-rating svg {
  width: var(--space-2, 1rem);
  fill: #ffac33;
}

.ra-rs-attrib {
  font-weight: 600;
  opacity: .9;
}

.ra-rs-attrib a {
  color: inherit;
  text-decoration: none;
}

.ra-rs-attrib a:hover {
  text-decoration: underline;
  text-underline-offset: 4px;
}

.ra-rs-arrow {
  display: grid;
  place-items: center;
  width: var(--space-5, 2.5rem);
  height: var(--space-5, 2.5rem);
  color: inherit;
  cursor: pointer;
  background: var(--bg-orange, #ef9f27);
  border: 1px solid var(--bg-orange, #ef9f27);
  border-radius: var(--radius-circle, 999px);
}

.ra-rs-arrow:hover {
  background: rgb(63 72 83 / 28%);
}

.ra-rs-arrow:focus {
  outline: none;
}

.ra-rs-arrow svg {
  width: 1.1rem;
  height: 1.1rem;
  fill: currentColor;
}

.ra-rs-stage > p {
  display: contents;
  margin: 0;
}

.ra-rs-dots {
  display: flex;
  justify-content: center;
  gap: var(--space-3, 1.5rem);
  margin: var(--space-2, 1rem) auto 0;
}

.ra-rs-dot {
  width: var(--space-1-5, .75rem);
  height: var(--space-1-5, .75rem);
  padding: 0;
  cursor: pointer;
  background: transparent;
  border: 1px solid rgb(63 72 83);
  border-radius: var(--radius-circle, 999px);
}

.ra-rs-dot.is-active,
.ra-rs-dot[aria-current="true"] {
  background: rgb(63 72 83);
}

.ra-rs-cta {
  margin-top: var(--space-3, 1.5rem);
  text-align: center;
}

.ra-rs-cta .btn {
  display: inline-block;
}

@media (max-width: 700px) {
  .ra-rs-stage {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .ra-rs-arrow {
    position: absolute;
    top: 50%;
    z-index: 2;
    width: var(--space-4, 2rem);
    height: var(--space-4, 2rem);
    transform: translateY(-50%);
  }

  .ra-rs-arrow--prev {
    left: calc(var(--space-1-5, .75rem) * -2);
  }

  .ra-rs-arrow--next {
    right: calc(var(--space-1-5, .75rem) * -2);
  }
}
