/* renuity-before-after.css */
/* Before/After Carousel Styles — loaded by [before_after_carousel] shortcode */

/* Hide default Slick arrow text */
.before-after-carousel .slick-prev:before,
.before-after-carousel .slick-next:before {
    display: none;
}

.before-after-carousel {
    position: relative;
    padding-bottom: 3em;
}

/* Arrow buttons */
.before-after-carousel .slick-prev,
.before-after-carousel .slick-next {
    padding: 1.2em;
    background: var(--e-global-color-accent);
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1;
    position: absolute;
    top: calc(100% - 2em);
    cursor: pointer;
    transition: background 0.3s ease;
}

.before-after-carousel .slick-prev {
    left: 50%;
    transform: translate(-150%, 6px);
}

.before-after-carousel .slick-next {
    position: absolute;
    left: 50%;
    transform: translate(50%, 6px);
    margin-left: 0px;
    right: 10px;
}

/* Hover */
.before-after-carousel .slick-prev:hover,
.before-after-carousel .slick-next:hover {
    background: var(--e-global-color-secondary);
}

/* Arrow icons */
.before-after-carousel .slick-prev i,
.before-after-carousel .slick-next i {
    font-size: 1em;
    color: white;
}

/* Dots */
.before-after-carousel .slick-dots {
    bottom: 0;
    position: relative;
    order: -1;
}

.before-after-carousel .slick-dots li button:before {
    color: var(--e-global-color-primary);
    opacity: 0.5;
    font-size: 12px;
}

.before-after-carousel .slick-dots li.slick-active button:before {
    color: var(--e-global-color-primary) !important;
    opacity: 1;
}

/* ── Before/After Container ────────────────────────── */

.ba-carousel {
  position: relative;
  width: 100%;
}

.ba-carousel .slick-list,
.ba-carousel .slick-track {
  height: 100%;
}

.ba-container {
  position: relative;
  aspect-ratio: 3/2;
  background-size: cover;
  background-position: center;
}

/* After Image Overlay */
.after-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  clip-path: inset(0 50% 0 0);
  transition: clip-path 0.1s linear;
}

/* Divider Handle */
.divider-handle {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 4px;
  background-color: var(--e-global-color-92a9a76);
  cursor: ew-resize;
  transform: translateX(-50%);
  z-index: 2;
  transition: left 0.1s linear;
  box-shadow: 0 0 15px rgba(0,0,0,0.3);
  will-change: left;
}

.divider-handle::after {
    content: '\e0a6';
    position: absolute;
    font-family: 'Font Awesome 6 Pro';
    top: 50%;
    left: 50%;
    width: 40px;
    height: 40px;
    aspect-ratio: 1;
    display: flex;
    background: var(--e-global-color-92a9a76);
    border-radius: 50%;
    transform: translate(-50%, -50%) rotate(90deg);
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.2);
    justify-content: center;
    align-items: center;
    color: white;
}

/* Slick Slide Aspect Ratio */
.ba-carousel .slick-slide > div {
  height: 100%;
}

/* Ensure active slide visibility */
.before-after-carousel .slick-slide {
  opacity: 0;
  transition: opacity 0.3s;
}

.before-after-carousel .slick-slide.slick-active {
  opacity: 1;
}

/* Handle z-index */
.before-after-carousel .ba-container {
  position: relative;
  z-index: 1;
}

.slick-active .ba-container {
  z-index: 2;
}

/* Active Slide Styling */
.slick-slide.slick-active .ba-container {
  z-index: 1;
  border-radius: 12px;
  overflow: hidden;
  width: 100%;
}

.ba-container .image-label {
    position: absolute;
    bottom: 1em;
    left: 50%;
    transform: translateX(-50%);
    color: #fff;
    border-radius: 6px;
    font-size: 0.9em;
    font-weight: 600;
    z-index: 4;
    pointer-events: none;
    display: flex;
    width: 100%;
    justify-content: space-around;
}

.ba-container .image-label .before-label,
.ba-container .image-label .after-label {
    padding: 8px 14px;
    border-radius: 6px;
    background-color: var(--e-global-color-92a9a76);
}

/* ── Pre-Init Hiding (CLS Prevention) ──────────────── */

/* Hide before/after carousel before Slick initializes */
.ba-carousel:not(.slick-initialized) {
    overflow: hidden;
    height: 0;
    visibility: hidden;
}

.ba-carousel.slick-initialized {
    animation: baFadeIn 0.3s ease forwards;
}

@keyframes baFadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}
