/* ============================================================
   SwiftSlide Frontend CSS  v1.3.0
   ============================================================ */

/* ── Outer wrapper ──────────────────────────────────────────── */
.ss-outer {
    width: 100%;
    box-sizing: border-box;
}

/* ── Slider shell ───────────────────────────────────────────── */
.ss-slider {
    position: relative;
    width: 100%;
    overflow: hidden;            /* clip slides */
    background: transparent;
}

/* ── Track ──────────────────────────────────────────────────── */
.ss-track {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    height: 100%;
    will-change: transform;
    /* transition applied by JS */
}

/* ── Individual Slide ───────────────────────────────────────── */
.ss-slide {
    flex-shrink: 0;
    position: relative;
    overflow: hidden;
    /* background-image, size, position set inline per slide */
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
    /* height set by scoped <style> per slider */
}

/* ══════════════════════════════════════════════════════════════
   SIDE-BY-SIDE MODE  (spv ≥ 2)
   Like FMarket: slider overflow:hidden, each slide is a clean
   card with its own rounded corners and gap between them.
══════════════════════════════════════════════════════════════ */
.ss-slider.ss-spv-multi {
    overflow: hidden;  /* clip at slider boundary — no overflow:visible needed */
}
/* The outer wrapper does NOT need overflow:hidden for multi —
   the slider itself clips. Reset any previous override: */
.ss-outer {
    overflow: visible;
}
/* Each slide in multi-view gets card styling */
.ss-slider.ss-spv-multi .ss-slide {
    border-radius: 12px;
    overflow: hidden;
}

/* ── FADE MODE ──────────────────────────────────────────────── */
.ss-slider.ss-fade { overflow: hidden; }
.ss-slider.ss-fade .ss-track {
    display: block;
    position: relative;
    height: 100%;
}
.ss-slider.ss-fade .ss-slide {
    position: absolute !important;
    inset: 0;
    width: 100% !important;
    flex: none !important;
    opacity: 0;
    z-index: 1;
    transition: opacity var(--ss-tspeed, 600ms) ease;
}
.ss-slider.ss-fade .ss-slide.ss-active {
    opacity: 1 !important;
    z-index: 2;
    position: relative !important;
}

/* ── Overlay ────────────────────────────────────────────────── */
.ss-overlay {
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
}

/* ── Whole-slide link ───────────────────────────────────────── */
.ss-slide-link {
    position: absolute;
    inset: 0;
    z-index: 5;
    display: block;
}

/* ── Content block ──────────────────────────────────────────── */
.ss-content {
    position: absolute;
    z-index: 15;          /* above overlay (2) and slide-link (5) */
    display: flex;
    flex-direction: column;
    gap: 12px;
    max-width: 65%;
    pointer-events: none;
}
/* Make interactive children clickable */
.ss-content .ss-btn,
.ss-content a {
    pointer-events: auto;
}

/* Horizontal alignment */
.ss-h-left   { left: 0;   right: auto; text-align: left;   align-items: flex-start; }
.ss-h-center { left: 50%; right: auto; transform: translateX(-50%); text-align: center; align-items: center; }
.ss-h-right  { right: 0;  left: auto;  text-align: right;  align-items: flex-end; }

/* Vertical alignment */
.ss-v-top    { top: 0;    bottom: auto; padding-top: 20px; }
.ss-v-middle { top: 50%;  transform: translateY(-50%); }
.ss-v-bottom { bottom: 0; top: auto;   padding-bottom: 20px; }

/* Combined center + middle */
.ss-h-center.ss-v-middle {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

/* ── Text elements ──────────────────────────────────────────── */
.ss-heading {
    margin: 0;
    line-height: 1.2;
    text-shadow: 0 2px 10px rgba(0,0,0,0.35);
}
.ss-subheading {
    margin: 0;
    line-height: 1.5;
    text-shadow: 0 1px 6px rgba(0,0,0,0.25);
}

/* ── Button ─────────────────────────────────────────────────── */
.ss-btn {
    display: inline-block !important;
    padding: 12px 28px;
    text-decoration: none !important;
    cursor: pointer;
    line-height: 1.2;
    white-space: nowrap;
    transition: filter 0.2s, transform 0.15s, box-shadow 0.2s;
    position: relative;
    z-index: 20;
    pointer-events: auto !important;
    opacity: 1 !important;  /* override any animation hiding */
}
.ss-btn:hover {
    filter: brightness(1.12);
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0,0,0,0.22);
    text-decoration: none !important;
    color: inherit;
}

/* ── Navigation arrows ──────────────────────────────────────── */
.ss-nav {
    position: absolute;
    top: var(--ss-nav-pos-v, 50%);
    transform: translateY(-50%);
    z-index: 40;
    background: var(--ss-nav-bg, rgba(255,255,255,0.92));
    color:      var(--ss-nav-color, #333333);
    border: none !important;
    width:  var(--ss-nav-size, 46px);
    height: var(--ss-nav-size, 46px);
    border-radius: var(--ss-nav-radius, 50%);
    cursor: pointer;
    font-size: 18px;
    box-shadow: 0 2px 14px rgba(0,0,0,0.15);
    transition: background 0.2s, color 0.2s, transform 0.2s, box-shadow 0.2s;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    outline: none !important;
    outline-offset: 0 !important;
    -webkit-tap-highlight-color: rgba(0,0,0,0) !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    flex-shrink: 0;
    user-select: none;
    -webkit-user-select: none;
    text-decoration: none;
    -webkit-focus-ring-color: transparent !important;
}
/* Nuclear option: kill focus ring from every angle */
.ss-nav:link,
.ss-nav:visited,
.ss-nav:hover,
.ss-nav:active,
.ss-nav:focus,
.ss-nav:focus-visible,
.ss-nav:focus-within,
button.ss-nav,
button.ss-nav:focus,
button.ss-nav:focus-visible,
button.ss-nav:active,
.ss-slider .ss-prev:focus,
.ss-slider .ss-next:focus,
.ss-outer button.ss-nav:focus,
.ss-outer button.ss-nav:focus-visible,
.ss-outer button.ss-nav:active {
    outline: none !important;
    outline-width: 0 !important;
    outline-color: transparent !important;
    outline-style: none !important;
    box-shadow: 0 2px 14px rgba(0,0,0,0.15) !important;
    border: none !important;
    -webkit-tap-highlight-color: rgba(0,0,0,0) !important;
}
.ss-nav:hover,
button.ss-nav:hover {
    background:   var(--ss-nav-bg-hover,    #ffffff) !important;
    color:        var(--ss-nav-color-hover,  #333333) !important;
    box-shadow:   0 4px 22px rgba(0,0,0,0.22) !important;
    transform:    translateY(-50%) scale(1.1) !important;
    outline: none !important;
}
.ss-prev { left:  var(--ss-nav-pos-h, 16px); }
.ss-next { right: var(--ss-nav-pos-h, 16px); }

/* Nav shapes */
.ss-nav-square  { border-radius: 4px !important; }
.ss-nav-rounded { border-radius: 12px !important; }
.ss-nav-circle  { border-radius: 50% !important; }

/* ── Dots (support CSS variable colors for customization) ────── */
.ss-dots {
    position: absolute;
    bottom: 16px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 40;
    display: flex;
    gap: 8px;
    align-items: center;
}
.ss-dot {
    width: 10px;
    height: 10px;
    border-radius: 5px;
    /* CSS vars allow per-slider color override via scoped <style> */
    background:   var(--ss-dot-bg,     rgba(255,255,255,0.45));
    border: 2px solid var(--ss-dot-border, rgba(255,255,255,0.65));
    cursor: pointer;
    padding: 0;
    transition: background 0.25s, border-color 0.25s, width 0.3s, transform 0.25s;
    outline: none !important;
    -webkit-tap-highlight-color: rgba(0,0,0,0);
    appearance: none;
    -webkit-appearance: none;
}
.ss-dot:focus,
.ss-dot:focus-visible {
    outline: none !important;
}
.ss-dot:hover {
    background:   var(--ss-dot-bg-hover,   rgba(255,255,255,0.72));
    border-color: var(--ss-dot-border,     rgba(255,255,255,0.65));
}
.ss-dot.ss-dot-active {
    background:   var(--ss-dot-active-bg,    #ffffff);
    border-color: var(--ss-dot-active-bg,    #ffffff);
    width: 24px;
    border-radius: 5px;
}
}
@keyframes ss-dot-pop {
    0%   { transform: scale(1); }
    40%  { transform: scale(1.5); }
    100% { transform: scale(1); }
}
.ss-dot.ss-dot-anim { animation: ss-dot-pop 0.35s ease forwards; }

/* ── Content enter animations ───────────────────────────────── */
/* Base: hidden */
.ss-heading, .ss-subheading { opacity: 0; }
/* btn is ALWAYS shown — never hidden by default */
.ss-btn { opacity: 1; }

/* When slide is active, show content */
.ss-slide.ss-active .ss-heading,
.ss-slide.ss-active .ss-subheading { opacity: 1; }

/* Animation triggers on active slide */
.ss-slide.ss-active .ss-heading    { animation-delay: 0.05s; }
.ss-slide.ss-active .ss-subheading { animation-delay: 0.18s; }
.ss-slide.ss-active .ss-btn        { animation-delay: 0.30s; }

.ss-slide.ss-active .ss-anim-fadeIn    { animation: ss-fadeIn   0.70s ease          both; }
.ss-slide.ss-active .ss-anim-slideUp   { animation: ss-slideUp  0.65s cubic-bezier(.22,1,.36,1) both; }
.ss-slide.ss-active .ss-anim-slideDown { animation: ss-slideDown 0.65s cubic-bezier(.22,1,.36,1) both; }
.ss-slide.ss-active .ss-anim-zoomIn    { animation: ss-zoomIn   0.55s cubic-bezier(.22,1,.36,1) both; }
.ss-slide.ss-active .ss-anim-bounceIn  { animation: ss-bounceIn 0.70s              both; }
/* none = instant show, no hide */
.ss-anim-none { animation: none !important; opacity: 1 !important; }

@keyframes ss-fadeIn    { from{opacity:0}                            to{opacity:1} }
@keyframes ss-slideUp   { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
@keyframes ss-slideDown { from{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)} }
@keyframes ss-zoomIn    { from{opacity:0;transform:scale(.80)}       to{opacity:1;transform:scale(1)} }
@keyframes ss-bounceIn  {
    0%  {opacity:0;transform:scale(.75)}
    55% {opacity:1;transform:scale(1.06)}
    75% {transform:scale(.96)}
    100%{opacity:1;transform:scale(1)}
}

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 1024px) {
    .ss-content { max-width: 78%; }
}
@media (max-width: 600px) {
    .ss-content { max-width: 92%; }
    .ss-nav     { width: 36px !important; height: 36px !important; font-size: 14px; }
    .ss-heading    { font-size: clamp(16px,5vw,28px) !important; }
    .ss-subheading { font-size: clamp(12px,3.5vw,16px) !important; }
    .ss-btn        { padding: 9px 18px !important; font-size: 13px !important; }
    /* Force single column on mobile */
    .ss-slider[data-spv="2"] .ss-slide,
    .ss-slider[data-spv="3"] .ss-slide,
    .ss-slider[data-spv="4"] .ss-slide {
        border-radius: 8px;
    }
}
