/* =====================================================
   LUXE PRODUCT SLIDER v3
   Every rule is prefixed with .lps to prevent bleed.
   Uses CSS resets on every element to defeat themes.
   ===================================================== */

/* ── FULL-WIDTH BREAKOUT ─────────────────────────────
   This makes the slider escape any narrow WP container */
.lps {
    width: 100vw !important;
    position: relative !important;
    left: 50% !important;
    right: 50% !important;
    margin-left: -50vw !important;
    margin-right: -50vw !important;
    box-sizing: border-box !important;

    /* CSS custom props */
    --lps-bg:      #ffffff;
    --lps-card-bg: #ffffff;
    --lps-name:    #111111;
    --lps-price:   #111111;
    --lps-btn-bg:  #111111;
    --lps-btn-clr: #ffffff;
    --lps-accent:  #111111;
    --lps-vis:     4;
    --lps-gap:     16px;
    --lps-radius:  2px;
    --lps-ease:    cubic-bezier(.4,0,.2,1);

    display: block !important;
    background: var(--lps-bg) !important;
    padding: 52px 40px 60px !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif !important;
    -webkit-font-smoothing: antialiased !important;
    overflow: hidden !important;
}

/* ── SECTION HEADER ──────────────────────────────── */
.lps .lps__head {
    text-align: center !important;
    margin: 0 auto 40px !important;
    padding: 0 !important;
    max-width: 600px !important;
}
.lps .lps__title {
    all: unset !important;
    display: block !important;
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif !important;
    font-size: clamp(20px, 2.5vw, 32px) !important;
    font-weight: 300 !important;
    letter-spacing: .22em !important;
    text-transform: uppercase !important;
    color: var(--lps-name) !important;
    line-height: 1.3 !important;
    margin-bottom: 10px !important;
}
.lps .lps__sub {
    all: unset !important;
    display: block !important;
    font-family: inherit !important;
    font-size: 13px !important;
    letter-spacing: .08em !important;
    color: #999 !important;
    margin-top: 8px !important;
}

/* ── STAGE (arrows + viewport) ───────────────────── */
.lps .lps__stage {
    display: flex !important;
    align-items: center !important;
    gap: 0 !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    position: relative !important;
}

/* ── NAV ARROWS ──────────────────────────────────── */
.lps .lps__nav {
    all: unset !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-shrink: 0 !important;
    width: 50px !important;
    height: 50px !important;
    min-width: 50px !important;
    border-radius: 50% !important;
    background: #fff !important;
    border: 1.5px solid #e0e0e0 !important;
    color: #111 !important;
    cursor: pointer !important;
    box-shadow: 0 2px 14px rgba(0,0,0,.09) !important;
    transition: all .25s var(--lps-ease) !important;
    position: relative !important;
    z-index: 5 !important;
}
.lps .lps__nav:hover {
    background: var(--lps-accent) !important;
    border-color: var(--lps-accent) !important;
    color: #fff !important;
    box-shadow: 0 6px 22px rgba(0,0,0,.18) !important;
    transform: scale(1.08) !important;
}
.lps .lps__nav:disabled,
.lps .lps__nav[disabled] {
    opacity: .25 !important;
    cursor: default !important;
    transform: none !important;
    box-shadow: none !important;
}
.lps .lps__nav svg {
    display: block !important;
    width: 20px !important;
    height: 20px !important;
    pointer-events: none !important;
}

/* ── VIEWPORT ────────────────────────────────────── */
.lps .lps__port {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    overflow: hidden !important;
    margin: 0 14px !important;
}

/* ── TRACK ───────────────────────────────────────── */
.lps .lps__track {
    display: flex !important;
    gap: var(--lps-gap) !important;
    transition: transform .5s var(--lps-ease) !important;
    will-change: transform !important;
    padding: 10px 2px 20px !important;
    margin: 0 !important;
    list-style: none !important;
    align-items: stretch !important;
}

/* ── CARD ────────────────────────────────────────── */
.lps .lps__card {
    /* width calculated by JS, but we set a sensible CSS fallback */
    flex: 0 0 auto !important;
    width: calc((100% - (var(--lps-vis) - 1) * var(--lps-gap)) / var(--lps-vis)) !important;
    background: var(--lps-card-bg) !important;
    border-radius: var(--lps-radius) !important;
    overflow: hidden !important;
    box-shadow: 0 2px 16px rgba(0,0,0,.07) !important;
    transition: box-shadow .35s ease, transform .35s ease !important;
    display: flex !important;
    flex-direction: column !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    outline: none !important;
    position: relative !important;
    cursor: default !important;
}
.lps .lps__card:hover {
    box-shadow: 0 16px 48px rgba(0,0,0,.14) !important;
    transform: translateY(-5px) !important;
}

/* ── CARD IMAGE ──────────────────────────────────── */
.lps .lps__img-wrap {
    display: block !important;
    position: relative !important;
    overflow: hidden !important;
    aspect-ratio: 3/4 !important;
    background: #f4f2ef !important;
    text-decoration: none !important;
    flex-shrink: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
}
.lps .lps__img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: top center !important;
    transition: transform .7s var(--lps-ease) !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    max-width: none !important;
    border-radius: 0 !important;
}
.lps .lps__card:hover .lps__img {
    transform: scale(1.08) !important;
}

/* ── HOVER OVERLAY ───────────────────────────────── */
.lps .lps__overlay {
    position: absolute !important;
    inset: 0 !important;
    background: rgba(0,0,0,.3) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    opacity: 0 !important;
    transition: opacity .3s ease !important;
    pointer-events: none !important;
}
.lps .lps__card:hover .lps__overlay {
    opacity: 1 !important;
}
.lps .lps__quick {
    display: inline-block !important;
    background: #fff !important;
    color: #111 !important;
    font-family: inherit !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    letter-spacing: .18em !important;
    text-transform: uppercase !important;
    padding: 10px 22px !important;
    transform: translateY(10px) !important;
    transition: transform .3s ease !important;
    white-space: nowrap !important;
}
.lps .lps__card:hover .lps__quick {
    transform: translateY(0) !important;
}

/* ── SALE BADGE ──────────────────────────────────── */
.lps .lps__badge {
    position: absolute !important;
    top: 12px !important;
    left: 12px !important;
    z-index: 4 !important;
    background: #b91c1c !important;
    color: #fff !important;
    font-family: inherit !important;
    font-size: 9px !important;
    font-weight: 800 !important;
    letter-spacing: .14em !important;
    text-transform: uppercase !important;
    padding: 4px 10px !important;
    border-radius: 0 !important;
    line-height: 1.4 !important;
}

/* ── CARD BODY ───────────────────────────────────── */
.lps .lps__body {
    padding: 16px 16px 18px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    flex: 1 !important;
    background: var(--lps-card-bg) !important;
    border-top: 1px solid #f0eeeb !important;
}

/* ── NAME ────────────────────────────────────────── */
.lps .lps__name {
    all: unset !important;
    display: block !important;
    font-family: inherit !important;
    font-size: 12px !important;
    font-weight: 400 !important;
    letter-spacing: .1em !important;
    text-transform: uppercase !important;
    color: var(--lps-name) !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    line-height: 1.5 !important;
    margin: 0 !important;
    padding: 0 !important;
}
.lps .lps__name a {
    all: unset !important;
    color: inherit !important;
    font: inherit !important;
    letter-spacing: inherit !important;
    text-transform: inherit !important;
    cursor: pointer !important;
    text-decoration: none !important;
}
.lps .lps__name a:hover {
    text-decoration: underline !important;
    text-underline-offset: 3px !important;
}

/* ── PRICE — reset WooCommerce fully ─────────────── */
.lps .lps__price {
    display: block !important;
    line-height: 1.5 !important;
    margin: 0 !important;
    padding: 0 !important;
}
.lps .lps__price,
.lps .lps__price *,
.lps .lps__price .price,
.lps .lps__price .woocommerce-Price-amount,
.lps .lps__price .woocommerce-Price-currencySymbol {
    font-family: inherit !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: var(--lps-price) !important;
    letter-spacing: .04em !important;
    text-decoration: none !important;
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
}
.lps .lps__price del,
.lps .lps__price del * {
    opacity: .4 !important;
    font-size: 11px !important;
    margin-right: 4px !important;
}
.lps .lps__price ins,
.lps .lps__price ins * {
    text-decoration: none !important;
    font-weight: 600 !important;
    color: #b91c1c !important;
}

/* ── BUTTON ──────────────────────────────────────── */
.lps .lps__btn {
    all: unset !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    box-sizing: border-box !important;
    padding: 12px 16px !important;
    font-family: inherit !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    letter-spacing: .2em !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    border-radius: 0 !important;
    transition: background .25s ease, color .25s ease, border-color .25s ease !important;
    text-align: center !important;
    line-height: 1 !important;
    margin-top: auto !important;
    white-space: nowrap !important;
}
.lps .lps__btn--dark {
    background: var(--lps-btn-bg) !important;
    color: var(--lps-btn-clr) !important;
    border: 1.5px solid var(--lps-btn-bg) !important;
}
.lps .lps__btn--dark:hover {
    background: transparent !important;
    color: var(--lps-btn-bg) !important;
    border-color: var(--lps-btn-bg) !important;
}
.lps .lps__btn--ghost {
    background: transparent !important;
    color: var(--lps-btn-bg) !important;
    border: 1.5px solid var(--lps-btn-bg) !important;
    text-decoration: none !important;
}
.lps .lps__btn--ghost:hover {
    background: var(--lps-btn-bg) !important;
    color: var(--lps-btn-clr) !important;
}
.lps .lps__btn.is-adding {
    opacity: .55 !important;
    cursor: wait !important;
    pointer-events: none !important;
}
.lps .lps__btn.is-added {
    background: #16a34a !important;
    border-color: #16a34a !important;
    color: #fff !important;
}

/* ── DOTS ────────────────────────────────────────── */
.lps .lps__dots {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 9px !important;
    margin-top: 30px !important;
    padding: 0 !important;
    list-style: none !important;
}
.lps .lps__dot {
    all: unset !important;
    display: block !important;
    width: 7px !important;
    height: 7px !important;
    border-radius: 50% !important;
    background: #d0d0d0 !important;
    cursor: pointer !important;
    transition: background .3s ease, transform .3s ease !important;
}
.lps .lps__dot.on {
    background: var(--lps-accent) !important;
    transform: scale(1.5) !important;
}

/* ── RESPONSIVE ──────────────────────────────────── */
@media (max-width: 1199px) {
    .lps { padding: 40px 24px 48px !important; }
}
@media (max-width: 991px) {
    .lps { --lps-vis: 3 !important; }
}
@media (max-width: 767px) {
    .lps {
        --lps-vis: 2 !important;
        padding: 32px 12px 40px !important;
    }
    .lps .lps__nav { width: 40px !important; min-width: 40px !important; height: 40px !important; }
    .lps .lps__port { margin: 0 8px !important; }
}
@media (max-width: 479px) {
    .lps { --lps-vis: 1 !important; padding: 28px 8px 36px !important; }
    .lps .lps__nav { width: 34px !important; min-width: 34px !important; height: 34px !important; }
}
