/* Marucha Clean - before / after slider styles
   All rules scoped under .before-after-slider- prefix. */

.before-after-slider-root {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: 2px;
  overflow: hidden;
  background: #EDE9E1;
  border: 1px solid #DDD9D1;
  cursor: ew-resize;
  outline: none;
  user-select: none;
  -webkit-user-select: none;
}

.before-after-slider-root:focus-visible {
  outline: 3px solid #C9A84C;
  outline-offset: 2px;
}

.before-after-slider-frame {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.before-after-slider-before,
.before-after-slider-after {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.before-after-slider-before img,
.before-after-slider-after img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  user-select: none;
  -webkit-user-drag: none;
  pointer-events: none;
}

.before-after-slider-after {
  clip-path: inset(0 0 0 50%);
  -webkit-clip-path: inset(0 0 0 50%);
}

.before-after-slider-divider {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 2px;
  margin-left: -1px;
  background: #C9A84C;
  pointer-events: none;
  box-shadow: 0 0 12px rgba(28, 28, 26, .25);
}

.before-after-slider-handle {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 44px;
  height: 44px;
  margin-left: -22px;
  margin-top: -22px;
  border-radius: 999px;
  background: #2D6A4F;
  color: #F7F4EF;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(28, 28, 26, .25);
  border: 2px solid #F7F4EF;
  pointer-events: none;
}

.before-after-slider-tag {
  position: absolute;
  top: 14px;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 4px 9px;
  border-radius: 2px;
  background: rgba(13, 43, 31, .72);
  color: #F7F4EF;
  pointer-events: none;
  z-index: 2;
}

.before-after-slider-tag-left { left: 14px; }
.before-after-slider-tag-right { right: 14px; }

.before-after-slider-dragging .before-after-slider-handle {
  background: #1B4332;
}

/* Placeholder shown when images are missing or failed to load. */
.before-after-slider-placeholder {
  position: absolute;
  inset: 0;
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  background: linear-gradient(135deg, #2D6A4F 0%, #1B4332 100%);
  color: #F7F4EF;
  text-align: center;
  padding: 1rem;
  pointer-events: none;
  z-index: 3;
}

.before-after-slider-placeholder-active .before-after-slider-placeholder {
  display: flex;
}

.before-after-slider-placeholder-text {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 1.5rem;
  font-weight: 600;
  letter-spacing: -.01em;
}

.before-after-slider-placeholder-todo {
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(201, 168, 76, .85);
}

@media (prefers-reduced-motion: reduce) {
  .before-after-slider-root,
  .before-after-slider-after,
  .before-after-slider-divider {
    transition: none !important;
  }
}
