/* ==========================================================================
   Responsive Image Slider v1.2.0 — Front-end Styles
   Fully defensive against theme CSS interference.
   Every rule uses high-specificity selectors and explicit resets.
   ========================================================================== */

/* ── CSS Variables --------------------------------------------------------- */
.ris-slider {
    --ris-arrow-size:     44px;
    --ris-arrow-bg:       rgba(0,0,0,.45);
    --ris-arrow-hover:    rgba(0,0,0,.75);
    --ris-dot-size:       10px;
    --ris-dot-gap:        8px;
    --ris-dot-color:      #bbb;
    --ris-dot-active-bg:  #333;
    --ris-dot-active-w:   28px;
    --ris-caption-bg:     rgba(0,0,0,.52);
    --ris-radius:         8px;
    --ris-transition:     .65s cubic-bezier(.45,0,.15,1);
    --ris-zoom-scale:     1.06;    /* how much the incoming image zooms in */
    --ris-aspect-ratio:   16 / 9;
}

/* ── Outer wrapper --------------------------------------------------------- */
.ris-slider {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow: visible !important;
    border-radius: var(--ris-radius);
    -webkit-user-select: none;
    user-select: none;
    touch-action: pan-y;
    box-sizing: border-box !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ── Track wrapper — padding-top trick for reliable aspect ratio ----------
 *
 *  WHY: aspect-ratio + height:100% breaks when themes override img heights.
 *  The padding-top trick is CSS2, works everywhere, and cannot be broken
 *  by any theme override.
 *
 *  padding-top % is relative to WIDTH, so:
 *    16:9  → 9/16  = 56.25%
 *    4:3   → 3/4   = 75%
 *    1:1   → 1/1   = 100%
 *    3:2   → 2/3   = 66.67%
 *    2:3   → 3/2   = 150%
 *    9:16  → 16/9  = 177.78%
 *    21:9  → 9/21  = 42.86%
 *  The actual padding value is set by PHP as an inline style on the wrapper.
 * ----------------------------------------------------------------------- */
.ris-slider .ris-track-wrapper {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    height: 0 !important;             /* height comes from padding-top only */
    /* padding-top set inline by PHP e.g. style="padding-top:56.25%" */
    overflow: hidden !important;
    border-radius: var(--ris-radius) !important;
    background: #111 !important;
    box-sizing: border-box !important;
    margin: 0 !important;
}

/* ── Track — absolutely fills the padding-top box ------------------------- */
.ris-slider .ris-track {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
    width: 100% !important;
    height: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
    will-change: transform;
    box-sizing: border-box !important;
}
.ris-slider.ris-transition-slide .ris-track {
    /* Smooth deceleration easing — feels like a physical slide */
    transition: transform var(--ris-transition);
}

/* ── Slides ---------------------------------------------------------------- */
.ris-slider .ris-track .ris-slide {
    flex: 0 0 100% !important;
    min-width: 0 !important;
    width: 100% !important;
    height: 100% !important;
    position: relative !important;
    overflow: hidden !important;
    display: block !important;
    box-sizing: border-box !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ── Image wrapper — pure background-image, no <img> tag ------------------
 *
 *  We intentionally do NOT use an <img> element. Every WordPress theme
 *  ships rules like  img { height: auto !important }  that we cannot
 *  reliably override. A <div> with background-image is completely immune:
 *  no theme rule targets div backgrounds, and inline style="background-image:…"
 *  cannot be overridden by any stylesheet.
 *
 *  The div fills the slide (which fills the padding-top aspect-ratio box),
 *  and background-size:cover does the same job as object-fit:cover.
 * ----------------------------------------------------------------------- */
.ris-slider .ris-track .ris-slide .ris-img-wrap {
    display: block !important;
    position: absolute !important;    /* fill the slide box completely */
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
}

/* ── Slide entrance animation — zoom in on the background image ----------
 *
 *  The incoming slide's background starts slightly zoomed out and scales
 *  to normal over the transition duration. Combined with the track slide,
 *  this gives a "Ken Burns lite" feel without any JS.
 * ----------------------------------------------------------------------- */

/* Every slide starts at normal scale */
.ris-slider .ris-track .ris-slide .ris-img-wrap {
    transform: scale(1) !important;
    transition: transform var(--ris-transition) !important;
}

/* The active (visible) slide's image gently zooms in */
.ris-slider .ris-track .ris-slide.ris-slide--active .ris-img-wrap {
    animation: ris-zoom-in var(--ris-transition) ease-out forwards !important;
}

@keyframes ris-zoom-in {
    from { transform: scale(var(--ris-zoom-scale)); }
    to   { transform: scale(1); }
}

/* Link wrapper — also absolutely fills the slide */
.ris-slider .ris-track .ris-slide .ris-slide-link {
    display: block !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    line-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    z-index: 1 !important;
}
.ris-slider .ris-track .ris-slide .ris-slide-link:focus-visible {
    outline: 3px solid #2271b1;
    outline-offset: -3px;
}

/* ── Caption — slides up into view when its slide becomes active ---------- */
.ris-slider .ris-track .ris-slide .ris-caption {
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    padding: 12px 16px !important;
    margin: 0 !important;
    background: var(--ris-caption-bg) !important;
    color: #fff !important;
    font-size: clamp(.8rem, 2.2vw, 1rem) !important;
    line-height: 1.4 !important;
    backdrop-filter: blur(4px);
    box-sizing: border-box !important;
    /* Start hidden — animate in when parent slide is active */
    opacity: 0 !important;
    transform: translateY(12px) !important;
    transition: opacity .35s ease .3s, transform .35s ease .3s !important;
}
/* Caption visible when slide is active */
.ris-slider .ris-track .ris-slide.ris-slide--active .ris-caption {
    opacity: 1 !important;
    transform: translateY(0) !important;
}

/* ── Arrows ---------------------------------------------------------------- */
.ris-slider .ris-track-wrapper .ris-arrow {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    z-index: 10 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: var(--ris-arrow-size) !important;
    height: var(--ris-arrow-size) !important;
    border-radius: 50% !important;
    background: var(--ris-arrow-bg) !important;
    border: none !important;
    cursor: pointer !important;
    padding: 0 !important;
    margin: 0 !important;
    transition: background .25s ease, transform .25s ease !important;
    box-shadow: none !important;
    text-decoration: none !important;
}
.ris-slider .ris-track-wrapper .ris-arrow:hover,
.ris-slider .ris-track-wrapper .ris-arrow:focus-visible {
    background: var(--ris-arrow-hover) !important;
    outline: none !important;
    transform: translateY(-50%) scale(1.1) !important;
}
.ris-slider .ris-track-wrapper .ris-arrow svg {
    display: block !important;
    width: 20px !important;
    height: 20px !important;
    stroke: #fff !important;
    stroke-width: 2.5 !important;
    fill: none !important;
    stroke-linecap: round;
    stroke-linejoin: round;
}
.ris-slider .ris-track-wrapper .ris-prev { left: 12px !important; right: auto !important; }
.ris-slider .ris-track-wrapper .ris-next { right: 12px !important; left: auto !important; }

/* ── Dots ------------------------------------------------------------------ */
.ris-slider .ris-dots {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: var(--ris-dot-gap) !important;
    list-style: none !important;
    padding: 12px 0 4px !important;
    margin: 0 !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

.ris-slider .ris-dots .ris-dot {
    /* Explicit px sizes — not affected by theme font-size or line-height */
    display: inline-block !important;
    width: var(--ris-dot-size) !important;
    height: var(--ris-dot-size) !important;
    min-width: 0 !important;
    min-height: 0 !important;
    border-radius: 999px !important;
    background: var(--ris-dot-color) !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    cursor: pointer !important;
    flex-shrink: 0 !important;
    box-shadow: none !important;
    transition: width var(--ris-transition), background-color .25s;
    vertical-align: middle !important;
    line-height: 1 !important;
    font-size: 0 !important;            /* kill any inherited text rendering */
}
.ris-slider .ris-dots .ris-dot:hover,
.ris-slider .ris-dots .ris-dot:focus-visible {
    background: #888 !important;
    outline: none !important;
}
.ris-slider .ris-dots .ris-dot.ris-dot--active {
    width: var(--ris-dot-active-w) !important;
    background: var(--ris-dot-active-bg) !important;
}

/* ── Fade transition ------------------------------------------------------- */
.ris-slider.ris-transition-fade .ris-track {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: 1fr !important;
}
.ris-slider.ris-transition-fade .ris-track .ris-slide {
    grid-area: 1 / 1 !important;
    opacity: 0 !important;
    transition: opacity var(--ris-transition) !important;
    pointer-events: none !important;
}
.ris-slider.ris-transition-fade .ris-track .ris-slide.ris-slide--active {
    opacity: 1 !important;
    pointer-events: auto !important;
}

/* ── Phone portrait -------------------------------------------------------- */
@media (max-width: 479px) {
    .ris-slider {
        --ris-arrow-size:   36px;
        --ris-dot-size:     8px;
        --ris-dot-active-w: 22px;
    }
    .ris-slider .ris-track-wrapper .ris-arrow svg {
        width: 16px !important;
        height: 16px !important;
    }
    .ris-slider .ris-track-wrapper .ris-prev { left:  6px !important; }
    .ris-slider .ris-track-wrapper .ris-next { right: 6px !important; }
    .ris-slider .ris-track .ris-slide .ris-caption {
        padding: 8px 10px !important;
        font-size: .8rem !important;
    }
}

/* ── Phone landscape ------------------------------------------------------- */
@media (max-height: 500px) and (orientation: landscape) {
    .ris-slider .ris-track-wrapper {
        /* Override padding-top ratio with a fixed height in landscape */
        padding-top: 0 !important;
        height: 70vmin !important;
    }
    .ris-slider { --ris-arrow-size: 34px; }
    .ris-slider .ris-dots { padding: 8px 0 2px !important; }
}

/* ── Hide arrows on touch devices ----------------------------------------- */
@media (hover: none) and (pointer: coarse) {
    .ris-slider .ris-track-wrapper .ris-arrow { display: none !important; }
}

/* ── Reduced motion -------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
    .ris-slider.ris-transition-slide .ris-track,
    .ris-slider.ris-transition-fade .ris-track .ris-slide,
    .ris-slider .ris-dots .ris-dot { transition: none !important; }
}

/* ==========================================================================
   WPBakery Page Builder — compatibility overrides
   WPBakery resets ul/li margins, img heights, and position inside .wpb_wrapper.
   These rules use WPBakery's own wrapper classes to raise specificity.
   ========================================================================== */

/* Wrapper box: WPBakery sometimes sets height:auto on children of .wpb_wrapper */
.wpb_wrapper .ris-slider .ris-track-wrapper,
.vc_column_inner .ris-slider .ris-track-wrapper,
.vc_column .ris-slider .ris-track-wrapper {
    height: 0 !important;
    position: relative !important;
    overflow: hidden !important;
    /* padding-top is set inline by PHP — this just enforces the container shape */
}

/* Track: WPBakery resets position on lists inside columns */
.wpb_wrapper .ris-slider .ris-track,
.vc_column_inner .ris-slider .ris-track,
.vc_column .ris-slider .ris-track {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

/* Slides: WPBakery adds margin-bottom to li elements */
.wpb_wrapper .ris-slider .ris-track .ris-slide,
.vc_column_inner .ris-slider .ris-track .ris-slide,
.vc_column .ris-slider .ris-track .ris-slide {
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    height: 100% !important;
    flex: 0 0 100% !important;
}

/* Image wrapper: WPBakery sets max-width and margin:auto on images */
.wpb_wrapper .ris-slider .ris-img-wrap,
.vc_column_inner .ris-slider .ris-img-wrap,
.vc_column .ris-slider .ris-img-wrap {
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    display: block !important;
}

/* Images: WPBakery's .wpb_wrapper img { height: auto } is the main culprit */
.wpb_wrapper .ris-slider .ris-img-wrap img,
.vc_column_inner .ris-slider .ris-img-wrap img,
.vc_column .ris-slider .ris-img-wrap img,
.wpb_wrapper .ris-slider img.ris-slide-img,
.vc_column_inner .ris-slider img.ris-slide-img,
.vc_column .ris-slider img.ris-slide-img {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    max-height: none !important;
    object-fit: cover !important;
    object-position: center center !important;
    margin: 0 !important;
    padding: 0 !important;
    display: block !important;
}

/* Dots: WPBakery resets button styles and li inside .wpb_wrapper */
.wpb_wrapper .ris-slider .ris-dots,
.vc_column .ris-slider .ris-dots {
    padding: 12px 0 4px !important;
    margin: 0 !important;
    list-style: none !important;
    display: flex !important;
    gap: var(--ris-dot-gap) !important;
}
.wpb_wrapper .ris-slider .ris-dots .ris-dot,
.vc_column .ris-slider .ris-dots .ris-dot {
    width: var(--ris-dot-size) !important;
    height: var(--ris-dot-size) !important;
    border-radius: 999px !important;
    margin: 0 !important;
    padding: 0 !important;
    display: inline-block !important;
    font-size: 0 !important;
    line-height: 1 !important;
}
.wpb_wrapper .ris-slider .ris-dots .ris-dot.ris-dot--active,
.vc_column .ris-slider .ris-dots .ris-dot.ris-dot--active {
    width: var(--ris-dot-active-w) !important;
}

/* ==========================================================================
   Ihsan Theme — compatibility overrides (degromiest.nl)
   The Ihsan theme ships rules like: .inner_content img { height: auto }
   and .dg-article img { max-width:100%; height:auto }
   These target our images directly. We override them here.
   ========================================================================== */

.inner_content .ris-slider .ris-img-wrap,
.dg-article .ris-slider .ris-img-wrap,
.fl-content .ris-slider .ris-img-wrap,
.fl-content-wrapper .ris-slider .ris-img-wrap {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    position: relative !important;
    overflow: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
    background-size: cover !important;
    background-position: center !important;
}

/* Kill height:auto on our images from Ihsan's .inner_content img rule */
.inner_content .ris-slider .ris-img-wrap img.ris-slide-img,
.dg-article .ris-slider .ris-img-wrap img.ris-slide-img,
.fl-content .ris-slider .ris-img-wrap img.ris-slide-img,
.fl-content-wrapper .ris-slider .ris-img-wrap img.ris-slide-img {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    max-height: none !important;
    object-fit: cover !important;
    object-position: center !important;
    margin: 0 !important;
    padding: 0 !important;
    display: block !important;
}

/* Ihsan resets li margin/padding inside .inner_content ul */
.inner_content .ris-slider .ris-track .ris-slide,
.dg-article .ris-slider .ris-track .ris-slide,
.fl-content .ris-slider .ris-track .ris-slide {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
    flex: 0 0 100% !important;
    width: 100% !important;
    height: 100% !important;
}
