/* ========================================
   STUDIO CODE ROOD — Recensies (standalone)
   Wit kaartje, rood quote-badge, italic quote.
   ======================================== */

.scr-recensies {
  /* Brand-kleuren via Elementor globals (met fallback) */
  --rec-red: var(--e-global-color-primary, #ff0028);
  --rec-text: var(--e-global-color-text, #2a221e);

  /* Locale tokens — niet uit Elementor */
  --rec-text-muted: #7a716a;
  --rec-quote-text: #4b5563;
  --rec-border: #e8e2d6;
  --rec-card-bg: #ffffff;
  --rec-fade-from: rgba(255, 255, 255, 0);
  --rec-radius: 24px;
  --rec-pad: clamp(28px, 4vw, 44px);
  --rec-badge: clamp(56px, 6vw, 76px);
  --rec-ease: cubic-bezier(0.25, 1, 0.5, 1);

  position: relative;
  width: 100%;
  max-width: 1280px;
  margin-inline: auto;
  padding-block: 32px;
  box-sizing: border-box;
}

.scr-recensies *,
.scr-recensies *::before,
.scr-recensies *::after {
  box-sizing: border-box;
}

/* ── Track: grid of slider ──────────────────────────── */
.scr-recensies__track {
  display: grid;
  gap: 24px;
}

.scr-recensies--grid .scr-recensies__track {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr));
}

.scr-recensies--slider .scr-recensies__track {
  grid-auto-flow: column;
  grid-auto-columns: 100%;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;
  padding-block: calc(var(--rec-badge) / 2);
  padding-inline: 16px;
}

.scr-recensies--slider .scr-recensies__track::-webkit-scrollbar { display: none; }

.scr-recensies--slider .scr-recensies__item {
  scroll-snap-align: center;
  display: flex;
  justify-content: center;
}

.scr-recensies--slider .scr-recensies__item > .scr-recensie {
  max-width: 720px;
  width: 100%;
}

/* ── Kaart ──────────────────────────────────────────── */
.scr-recensies .scr-recensie {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 24px;
  padding: var(--rec-pad);
  padding-top: calc(var(--rec-pad) + var(--rec-badge) / 2);
  background: var(--rec-card-bg);
  border-radius: var(--rec-radius);
  box-shadow:
    0 1px 2px rgba(30, 22, 18, 0.04),
    0 12px 25px -12px rgba(30, 22, 18, 0.12);
  text-decoration: none;
  color: var(--rec-text);
  transition:
    transform 300ms var(--rec-ease),
    box-shadow 300ms var(--rec-ease);
}


/* ── Quote badge ────────────────────────────────────── */
.scr-recensies .scr-recensie__badge {
  position: absolute;
  top: calc(var(--rec-badge) / -2);
  left: var(--rec-pad);
  width: var(--rec-badge);
  height: var(--rec-badge);
  display: grid;
  place-items: center;
  background: var(--rec-red) !important;
  color: #ffffff;
  border-radius: calc(var(--rec-radius) - 6px);
  box-shadow: 0 8px 20px -6px rgba(255, 0, 40, 0.45);
}

.scr-recensies .scr-recensie__badge svg {
  width: 55%;
  height: 55%;
  display: block;
}

/* ── Quote wrap (quote + expand button) ─────────────── */
.scr-recensies .scr-recensie__quote-wrap {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* ── Quote text ─────────────────────────────────────── */
.scr-recensies .scr-recensie__quote {
  position: relative;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  font-size: clamp(0.95rem, 0.85rem + 0.25vw, 1.05rem);
  font-style: italic;
  font-weight: 400;
  line-height: 1.55;
  color: var(--rec-quote-text) !important;
  quotes: "\201C" "\201D";

  /* Animatable clamp via max-height (default 6 regels via inline --rec-clamp) */
  display: block;
  max-height: calc(var(--rec-clamp, 6) * 1.55em);
  overflow: hidden;
  transition: max-height 650ms cubic-bezier(0.65, 0, 0.35, 1);
  will-change: max-height;
}

/* Gradient fade-out aan de onderkant — hint dat er meer is */
.scr-recensies .scr-recensie__quote::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2.4em;
  background: linear-gradient(to bottom, var(--rec-fade-from), var(--rec-card-bg) 92%);
  pointer-events: none;
  opacity: 0;
  transition: opacity 350ms ease;
}

.scr-recensies .scr-recensie.has-overflow:not(.is-expanded) .scr-recensie__quote::after {
  opacity: 1;
}

.scr-recensies .scr-recensie__quote p {
  margin: 0 0 0.6em;
  color: inherit !important;
  font-style: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
}

.scr-recensies .scr-recensie__quote p:last-child {
  margin-bottom: 0;
}

.scr-recensies .scr-recensie__quote p:first-child::before { content: open-quote; }
.scr-recensies .scr-recensie__quote p:last-child::after  { content: close-quote; }

/* ── Expand button — Elementor button-reset ─────────── */
.scr-recensies .scr-recensie__expand,
button.scr-recensie__expand {
  -webkit-appearance: none !important;
  appearance: none !important;
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  min-width: 0 !important;
  min-height: 0 !important;
  font-family: inherit;
  font-size: 0.875rem;
  font-weight: 600;
  font-style: normal;
  letter-spacing: 0.02em;
  color: var(--rec-red) !important;
  cursor: pointer;
  text-decoration: none;
  text-transform: none;
}

.scr-recensies .scr-recensie__expand[hidden] {
  display: none !important;
}

.scr-recensies .scr-recensie__expand::after {
  content: "→";
  display: inline-block;
  transition: transform 450ms cubic-bezier(0.34, 1.56, 0.64, 1);
}

.scr-recensies .scr-recensie.is-expanded .scr-recensie__expand::after {
  transform: rotate(-90deg);
}

.scr-recensies .scr-recensie__expand:hover,
.scr-recensies .scr-recensie__expand:focus-visible {
  text-decoration: underline;
  text-underline-offset: 3px;
}

.scr-recensies .scr-recensie__expand:focus-visible {
  outline: 2px solid var(--rec-red);
  outline-offset: 4px;
  border-radius: 2px;
}

/* ── Footer: naam + klant + project-link ────────────── */
.scr-recensies .scr-recensie__footer {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin-top: auto;
  flex-wrap: wrap;
}

.scr-recensies .scr-recensie__person {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.scr-recensies .scr-recensie__naam {
  font-size: 1rem;
  font-weight: 700;
  font-style: normal;
  color: var(--rec-text) !important;
  line-height: 1.2;
}

.scr-recensies .scr-recensie__meta {
  font-size: 0.75rem;
  font-weight: 600;
  font-style: normal;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #9ca3af !important;
  line-height: 1.3;
}

.scr-recensies .scr-recensie__project-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: inherit;
  font-size: 0.875rem;
  font-weight: 600;
  font-style: normal;
  text-decoration: none;
  color: var(--rec-red) !important;
  white-space: nowrap;
  transition: gap 200ms var(--rec-ease);
}

.scr-recensies .scr-recensie__project-link:hover,
.scr-recensies .scr-recensie__project-link:focus-visible {
  gap: 10px;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.scr-recensies .scr-recensie__project-link:focus-visible {
  outline: 2px solid var(--rec-red);
  outline-offset: 4px;
  border-radius: 2px;
}

.scr-recensies .scr-recensie__project-link svg {
  transition: transform 200ms var(--rec-ease);
}

.scr-recensies .scr-recensie__project-link:hover svg,
.scr-recensies .scr-recensie__project-link:focus-visible svg {
  transform: translateX(2px);
}

/* ── Nav-row (arrows + dots) ────────────────────────── */
.scr-recensies__nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  margin-top: 24px;
  padding-inline: 16px;
}

/* ── Arrows ─────────────────────────────────────────── */
.scr-recensies__arrows {
  display: flex;
  gap: 8px;
}

.scr-recensies .scr-recensies__arrow,
button.scr-recensies__arrow {
  -webkit-appearance: none !important;
  appearance: none !important;
  display: grid;
  place-items: center;
  width: 40px !important;
  height: 40px !important;
  min-width: 0 !important;
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 1.5px solid var(--rec-red) !important;
  border-radius: 99px !important;
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  color: var(--rec-red) !important;
  cursor: pointer;
  transition:
    background-color 200ms var(--rec-ease),
    color 200ms var(--rec-ease),
    opacity 200ms var(--rec-ease),
    transform 200ms var(--rec-ease);
}

.scr-recensies .scr-recensies__arrow svg {
  width: 18px;
  height: 18px;
  display: block;
}

.scr-recensies .scr-recensies__arrow:hover:not(:disabled),
.scr-recensies .scr-recensies__arrow:focus-visible:not(:disabled) {
  background: var(--rec-red) !important;
  color: #fff !important;
}

.scr-recensies .scr-recensies__arrow:focus-visible {
  outline: 2px solid var(--rec-red);
  outline-offset: 3px;
}

.scr-recensies .scr-recensies__arrow:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

/* ── Dots — stretch pill, Elementor button-reset ────── */
.scr-recensies__dots {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
}

.scr-recensies .scr-recensies__dot,
button.scr-recensies__dot {
  -webkit-appearance: none !important;
  appearance: none !important;
  position: relative;
  display: inline-block;
  width: 10px !important;
  height: 10px !important;
  min-width: 0 !important;
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 1.5px solid var(--rec-red) !important;
  border-radius: 99px !important;
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  font: inherit;
  color: transparent !important;
  cursor: pointer;
  overflow: hidden;
  transition:
    width 450ms var(--rec-ease),
    background-color 250ms var(--rec-ease),
    opacity 200ms var(--rec-ease);
}

/* Onzichtbaar uitgebreid klikgebied (WCAG AA target size) */
.scr-recensies .scr-recensies__dot::after {
  content: "";
  position: absolute;
  inset: -7px;
}

.scr-recensies .scr-recensies__dot:hover {
  background: var(--rec-red) !important;
  opacity: 0.45;
}

.scr-recensies .scr-recensies__dot.is-active {
  width: 32px !important;
  background: var(--rec-red) !important;
  opacity: 1;
}

.scr-recensies .scr-recensies__dot.is-active:hover {
  opacity: 1;
}

.scr-recensies .scr-recensies__dot:focus-visible {
  outline: 2px solid var(--rec-red);
  outline-offset: 4px;
}

/* ── Variant: achtergrond="secondary" ───────────────── */
.scr-recensies--bg-secondary {
  --rec-card-bg: var(--e-global-color-secondary, #FAF8F3);
  --rec-fade-from: transparent;
}

/* ── Variant: achtergrond="lichtrood" ───────────────── */
.scr-recensies--bg-lichtrood {
  --rec-card-bg: var(--e-global-color-bd26511, #ffe5e9);
  --rec-fade-from: transparent;
}

/* ── Empty state ────────────────────────────────────── */
.scr-recensies--empty {
  text-align: center;
  padding: 48px;
  color: var(--rec-text-muted);
  font-style: italic;
}

/* ── Reduced motion ─────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .scr-recensies .scr-recensie,
  .scr-recensies .scr-recensies__dot,
  .scr-recensies--slider .scr-recensies__track {
    transition: none;
    scroll-behavior: auto;
  }
  .scr-recensies .scr-recensie__expand::after,
  .scr-recensies .scr-recensie__project-link svg { transition: none; }
}
