/* ── Image Slider block ──────────────────────────────────────────────────── */

.nyehs-islider {
    position:         relative;
    overflow:         hidden;
    width:            100%;
    user-select:      none;
    -webkit-user-select: none;
}

/* Edge + bottom fade via composited CSS masks ───────────────────────────────
   Layer 1 (top): horizontal gradient fades left + right edges to transparent.
   Layer 2 (bottom): vertical gradient fades the bottom third to transparent.
   mask-composite: intersect means the final mask is the intersection — both
   gradients must be opaque for a pixel to show. */

.nyehs-islider__inner {
    display:        flex;
    flex-direction: column;
    gap:            var(--nyehs-islider-gap, 12px);

    -webkit-mask-image:
        linear-gradient(to right, transparent 0%, black 11%, black 89%, transparent 100%),
        linear-gradient(to bottom, black 0%, black 55%, transparent 100%);
    mask-image:
        linear-gradient(to right, transparent 0%, black 11%, black 89%, transparent 100%),
        linear-gradient(to bottom, black 0%, black 55%, transparent 100%);
    -webkit-mask-composite: source-in;
    mask-composite:         intersect;

    /* The CSS mask restricts pointer events to non-masked pixels, making items
       under the edge/bottom fades unclickable. Setting none here removes that
       restriction; children opt back in with pointer-events: auto below. */
    pointer-events: none;
}

/* ── Scrolling track ─────────────────────────────────────────────────────── */

.nyehs-islider__track {
    display:    flex;
    flex-wrap:  nowrap;
    gap:        var(--nyehs-islider-gap, 12px);
    width:      max-content;
    /* --nyehs-islider-dur is set per-track by view.js after images load */
    animation:  nyehs-islider-scroll var(--nyehs-islider-dur, 20s) linear infinite;
    will-change: transform;
}

@keyframes nyehs-islider-scroll {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}

.nyehs-islider:hover .nyehs-islider__track {
    animation-play-state: paused;
}

/* ── Image items ─────────────────────────────────────────────────────────── */

.nyehs-islider__item {
    margin:         0;
    padding:        0;
    flex-shrink:    0;
    width:          var(--nyehs-islider-tile-w, 200px);
    height:         var(--nyehs-islider-img-h, 280px);
    border-radius:  10px;
    overflow:       hidden;
    cursor:         pointer;
    pointer-events: auto; /* restore after parent's pointer-events: none */
}

.nyehs-islider__item:focus-visible {
    outline:        2px solid rgba(255, 255, 255, 0.6);
    outline-offset: 3px;
}

.nyehs-islider__item img {
    display:         block;
    width:           100%;
    height:          100%;
    object-fit:      cover;
    object-position: center;
    filter:          grayscale(100%) brightness(0.85);
    transition:      filter 0.4s ease;
}

.nyehs-islider__item:hover img,
.nyehs-islider__item:focus-visible img {
    filter: grayscale(0%) brightness(1);
}

.nyehs-islider__item--clone {
    pointer-events: auto;
}

/* ── Lightbox ────────────────────────────────────────────────────────────── */

.nyehs-islider__lightbox {
    position:        fixed;
    inset:           0;
    z-index:         99999;
    display:         flex;
    align-items:     center;
    justify-content: center;
    opacity:         0;
    pointer-events:  none;
    transition:      opacity 0.25s ease;
}

.nyehs-islider__lightbox.is-open {
    opacity:        1;
    pointer-events: auto;
}

.nyehs-islider__lb-bg {
    position:              absolute;
    inset:                 0;
    background:            rgba(0, 0, 0, 0.88);
    backdrop-filter:       blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

.nyehs-islider__lb-content {
    position:   relative;
    z-index:    1;
    max-width:  90vw;
    max-height: 90vh;
    transform:  scale(0.88);
    transition: transform 0.28s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.nyehs-islider__lightbox.is-open .nyehs-islider__lb-content {
    transform: scale(1);
}

.nyehs-islider__lb-img {
    display:       block;
    max-width:     100%;
    max-height:    90vh;
    border-radius: 14px;
    box-shadow:    0 28px 80px rgba(0, 0, 0, 0.6);
    object-fit:    contain;
}

.nyehs-islider__lb-caption {
    position:   absolute;
    bottom:     18px;
    left:       50%;
    transform:  translateX( -50% );
    max-width:  calc( 100% - 40px );
    padding:    8px 20px;
    background: rgba( 0, 0, 0, 0.42 );
    backdrop-filter:         blur( 14px );
    -webkit-backdrop-filter: blur( 14px );
    border:        1px solid rgba( 255, 255, 255, 0.18 );
    border-radius: 999px;
    color:         rgba( 255, 255, 255, 0.92 );
    font-size:     13px;
    font-weight:   500;
    line-height:   1.4;
    white-space:   nowrap;
    overflow:      hidden;
    text-overflow: ellipsis;
    pointer-events: none;
}

.nyehs-islider__lb-close {
    position:    absolute;
    top:         16px;
    right:       20px;
    z-index:     2;
    font-size:   38px;
    line-height: 1;
    color:       rgba(255, 255, 255, 0.7);
    background:  none;
    border:      none;
    cursor:      pointer;
    padding:     4px 8px;
    transition:  color 0.2s ease, transform 0.2s ease;
}

.nyehs-islider__lb-close:hover {
    color:     #fff;
    transform: scale(1.12);
}

body.nyehs-islider--lb-open {
    overflow: hidden;
}

/* ── Reduced motion ──────────────────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
    .nyehs-islider__track {
        animation-play-state: paused;
    }
}
