/**
 * =========================================================
 * JoomFlix – VM Slider Pro
 * ---------------------------------------------------------
 * @package     JoomFlix VM Slider Pro
 * @component   VirtueMart Product Slider
 * @version     1.1.0
 *
 * @author      JoomFlix
 * @copyright   © 2025 JoomFlix
 * @license     GNU General Public License v3 or later
 *
 * @link        https://www.joomflix.com
 * @support     https://www.joomflix.com/support
 *
 * @description
 * Performance-optimized styles for the VM Slider Pro module.
 * Designed with mobile-first principles, accessibility,
 * and Google PageSpeed Insights best practices in mind.
 * =========================================================
 */

.jf-vm-slider{--jf-bg:#fff;--jf-text:#333;--jf-radius:1rem;max-width:100%;margin:0 auto;padding:1rem 10px;overflow:hidden;box-sizing:border-box}.jf-vm-slider .swiper-wrapper{padding:0 10px;box-sizing:border-box}.jf-vm-slider .swiper-slide{transition:transform .4s ease;transform:scale(.96)}.jf-vm-slider .swiper-slide-active{transform:scale(1)}@media (max-width:992px){.jf-vm-slider{padding:1rem 15px}}@media (max-width:768px){.jf-vm-slider{padding:1rem 10px}}.jf-vm-slider form.product .quantity-input,.jf-vm-slider form.product .quantity-box,.jf-vm-slider form.product .quantity-controls,.jf-vm-slider form.product label.quantity_box,.jf-vm-slider form.product br{display:none!important}.jf-vm-slider form.product input.addtocart-button{display:inline-block!important;width:auto!important;min-width:150px;text-align:center;font-weight:600;background:var(--bs-primary,var(--primary-color,#1d6db3));color:#fff;border:none;border-radius:1rem;padding:8px 20px;cursor:pointer}.jf-slider-empty{text-align:center;padding:1rem;font-style:italic;color:#666}.jf-item.jf-layout-1{background:var(--jf-bg);color:var(--jf-text);box-shadow:0 4px 12px rgba(0,0,0,.15);overflow:hidden;border-radius:var(--jf-radius);transition:all .3s ease}.jf-item.jf-layout-1:hover{transform:scale(1.03)}.jf-item.jf-layout-1 .jf-image img{width:100%;height:auto;display:block;border-radius:inherit}.jf-item.jf-layout-1 .jf-content{padding:1rem;text-align:center;font-size:.95rem}.jf-item.jf-layout-1 .jf-title a{color:var(--bs-primary,var(--primary-color,#1d6db3));text-decoration:none;font-family:Raleway,sans-serif;font-weight:600;font-size:1.1rem;transition:color .3s ease}.jf-item.jf-layout-1 .jf-title a:hover{color:color-mix(in srgb,var(--bs-primary,var(--primary-color,#1d6db3)) 80%,#000 20%)}.jf-item.jf-layout-1 .jf-desc{color:#333;font-size:.95rem;margin-bottom:.6rem;line-height:1.35;max-height:60px;overflow:hidden;}.jf-item.jf-layout-1 .jf-rating{height:14px;width:70px;background:url('modules/mod_joomflix_vm_slider_pro/assets/img/stars-empty.svg') repeat-x;position:relative;margin:.5rem auto}.jf-item.jf-layout-1 .jf-rating span{height:14px;background:url('modules/mod_joomflix_vm_slider_pro/assets/img/stars-filled.svg') repeat-x;position:absolute;top:0;left:0}.jf-item.jf-layout-1 .jf-prices{margin-top:.6rem}.jf-item.jf-layout-1 .jf-price-row{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;padding:.25rem 0;border-bottom:1px solid #e5e5e5}.jf-item.jf-layout-1 .jf-price-value{font-weight:600;color:var(--bs-primary)}.jf-item.jf-layout-1 .jf-price-bold{font-weight:600;font-size:.95rem;color:var(--bs-primary);transition:color .25s ease}.jf-item.jf-layout-1:hover .jf-price-value,.jf-item.jf-layout-1:hover .jf-price-bold{filter:brightness(.85)}.jf-item.jf-layout-1 .jf-discount-badge{display:inline-flex;align-items:baseline;justify-content:flex-end;background:#ef4444;color:#fff;font-size:.85rem;font-weight:600;border-radius:.4rem;padding:.15rem .25rem;margin-top:.4rem;float:right;width:auto;max-width:fit-content;box-shadow:0 2px 6px rgba(0,0,0,.15);line-height:1.2;white-space:nowrap}.jf-item.jf-layout-1 .jf-discount-badge span[class*="Price"]{font-size:.95rem!important;font-weight:500!important;color:#fff!important;text-decoration:line-through!important;margin-left:-3px!important}.jf-item.jf-layout-1 .jf-buttons{display:flex;flex-direction:column;align-items:center;gap:.3rem;margin-top:.8rem;clear:both}.jf-item.jf-layout-1 .jf-view{background:transparent;border:2px solid var(--bs-primary);color:var(--bs-primary);padding:.35rem .7rem;border-radius:.5rem;font-size:.9rem;font-weight:600;text-decoration:none;min-width:140px;display:inline-block;transition:all .25s ease-in-out}.jf-item.jf-layout-1 .jf-view:hover{background:var(--bs-primary);color:#fff;transform:translateY(-2px)}@media (max-width:768px){.jf-item.jf-layout-1 .jf-content{padding:.8rem}.jf-item.jf-layout-1 .jf-title a{font-size:1rem}.jf-item.jf-layout-1 .jf-buttons{gap:.4rem}}
.jf-item.jf-layout-2{position:relative;overflow:visible!important;border-radius:var(--jf-radius);background:#000;height:100%;display:flex;flex-direction:column}.jf-item.jf-layout-2 .jf-image{width:100%;height:260px;overflow:hidden}.jf-item.jf-layout-2 .jf-image img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease,opacity .4s ease}.jf-item.jf-layout-2:hover .jf-image img{transform:scale(1.08);opacity:.45}.jf-item.jf-layout-2 .jf-content{position:absolute;bottom:auto;left:0;width:100%;padding:1.2rem;color:#fff;opacity:0;transform:translateY(35px);z-index:10;transition:all .35s ease;pointer-events:none;background:linear-gradient(to top,rgba(0,0,0,.82),rgba(0,0,0,.55),rgba(0,0,0,.25),rgba(0,0,0,25))}.jf-item.jf-layout-2:hover .jf-content{opacity:1;transform:translateY(0);pointer-events:auto}.jf-item.jf-layout-2 .jf-title a{color:#fff!important;text-shadow:0 0 8px rgba(0,0,0,.35);font-size:1.2rem;font-weight:700;text-decoration:none;display:block;margin-bottom:.5rem;line-height:1.25;word-wrap:break-word;white-space:normal}.jf-item.jf-layout-2:has(.jf-discount-badge) .jf-title a{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.jf-item.jf-layout-2 .jf-desc{color:rgba(255,255,255,.9);font-size:.85rem;margin-bottom:.6rem;line-height:1.35;max-height:60px;overflow:hidden}.jf-item.jf-layout-2 .jf-content hr.jf-sep:nth-of-type(1),.jf-item.jf-layout-2 .jf-content hr.jf-sep:nth-of-type(2){display:none!important}.jf-item.jf-layout-2 .jf-prices{margin-bottom:.6rem}.jf-item.jf-layout-2 .jf-price-row{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;padding:.15rem 0;border-bottom:1px solid rgba(255,255,255,.15)}.jf-item.jf-layout-2 .jf-price-label{color:rgba(255,255,255,.8)}.jf-item.jf-layout-2 .jf-price-value,.jf-item.jf-layout-2 .jf-price-bold{color:#fff!important;font-weight:600}.jf-item.jf-layout-2 .jf-discount-badge{background:#ff3b30;color:#fff;padding:.15rem .2rem;border-radius:4px;font-size:.8rem;display:inline-flex;align-items:center;gap:.25rem;margin-top:.4rem;width:auto;max-width:fit-content}.jf-item.jf-layout-2 .jf-discount-badge span[class*="Price"]{font-size:.9rem!important;font-weight:500!important;text-decoration:line-through!important;margin-left:2px!important}.jf-item.jf-layout-2 .jf-rating{filter:brightness(1.2);margin-bottom:.5rem;display:none!important}.jf-item.jf-layout-2 .jf-buttons .jf-view{background:transparent!important;border:2px solid var(--bs-primary)!important;color:#fff;padding:.35rem .7rem;border-radius:.5rem;font-size:.9rem;font-weight:600;text-decoration:none;min-width:140px;display:inline-block;transition:all .25s ease-in-out;opacity:1!important}.jf-item.jf-layout-2 .jf-buttons .jf-view:hover{background:var(--bs-primary)!important;color:#fff!important;transform:translateY(-2px);opacity:1!important}.jf-item.jf-layout-2 form.product input.addtocart-button{background:var(--bs-primary)!important;border:2px solid var(--bs-primary)!important;color:#fff!important;border-radius:.5rem!important;padding:.35rem .7rem!important;font-size:.9rem!important;font-weight:600!important;min-width:140px!important;opacity:1!important;transition:all .25s ease-in-out}.jf-item.jf-layout-2 form.product input.addtocart-button:hover{background:var(--bs-primary-dark,var(--bs-primary))!important;border-color:var(--bs-primary-dark,var(--bs-primary))!important;transform:translateY(-2px);opacity:1!important}.jf-item.jf-layout-2::after{content:"";position:absolute;bottom:0;left:0;width:100%;height:60%;background:linear-gradient(to top,rgba(0,0,0,.88),rgba(0,0,0,.55),rgba(0,0,0,.15),rgba(0,0,0,0));opacity:1;transition:opacity .35s ease}.jf-item.jf-layout-2 .jf-buttons{display:flex;justify-content:center;align-items:center;gap:7px;margin-top:.7rem;flex-wrap:wrap}.jf-item.jf-layout-2 .jf-buttons .jf-view,.jf-item.jf-layout-2 form.product input.addtocart-button{display:inline-flex!important;align-items:center!important;justify-content:center!important;height:38px!important;padding:.4rem .75rem!important;line-height:1!important;box-sizing:border-box!important}
.jf-item.jf-layout-3{position:relative;border-radius:var(--jf-radius);overflow:visible!important}.jf-item.jf-layout-3 .jf-compact-image{width:100%;border-radius:inherit}.jf-item.jf-layout-3 .jf-compact-image img{width:100%;height:auto;object-fit:cover;transition:transform .35s ease}.jf-item.jf-layout-3:hover .jf-compact-image img{opacity:.45}.jf-item.jf-layout-3 .jf-compact-panel{position:absolute;bottom:0;left:0;width:100%;height:99%!important;padding-bottom:2.4rem;background:linear-gradient(to top,rgba(255,255,255,.96),rgba(255,255,255,.85),rgba(255,255,255,.4),rgba(255,255,255,0));display:block!important;opacity:0;transform:translateY(20px);transition:all .35s ease;pointer-events:none;z-index:10}.jf-item.jf-layout-3:hover .jf-compact-panel,.jf-item.jf-layout-3.jf-expanded .jf-compact-panel{padding:5px 15px;opacity:1;transform:translateY(0);pointer-events:auto}.jf-item.jf-layout-3 .jf-title a{color:var(--bs-primary);font-size:1.1rem;font-weight:600;text-decoration:none;white-space:nowrap;overflow:visible;text-overflow:ellipsis;margin-bottom:.45rem}.jf-item.jf-layout-3 .jf-desc{font-size:.92rem;font-weight:500;color:#333;max-height:58px;overflow:hidden;line-height:1.32;margin-bottom:.7rem}.jf-item.jf-layout-3 .jf-discount-badge{background:#ef4444;color:#fff;padding:.15rem .2rem;border-radius:.4rem;font-size:.8rem;display:inline-flex;align-items:center;gap:.25rem;margin-bottom:.25rem}.jf-item.jf-layout-3 .jf-discount-badge span[class*="Price"]{text-decoration:line-through!important;font-size:.9rem!important}.jf-item.jf-layout-3 .jf-prices{margin-bottom:.6rem}.jf-item.jf-layout-3 .jf-price-row{display:flex;justify-content:space-between;align-items:center;padding:.15rem 0;border-bottom:1px solid rgba(0,0,0,.15);margin-bottom:.2rem}.jf-item.jf-layout-3 .jf-price-row:last-of-type{border-bottom:none!important;margin-bottom:0!important;padding-bottom:0!important}.jf-item.jf-layout-3 .jf-price-label{font-size:.9rem;font-weight:500;color:#333}.jf-item.jf-layout-3 .jf-price-value,.jf-item.jf-layout-3 .jf-price-bold{font-size:.9rem;color:#000!important;font-weight:600}.jf-item.jf-layout-3 .jf-title+hr,.jf-item.jf-layout-3 .jf-desc+hr{display:none!important}.jf-item.jf-layout-3 .jf-buttons{margin-top:.3rem!important;display:flex;justify-content:center;align-items:center;gap:7px;flex-wrap:wrap}.jf-item.jf-layout-3 .jf-buttons .jf-view{background:transparent!important;border:2px solid var(--bs-primary)!important;color:var(--bs-primary)!important;padding:.32rem .65rem;border-radius:.45rem;font-size:.85rem;font-weight:600;min-width:120px;display:inline-flex;justify-content:center;align-items:center;transition:all .25s ease-in-out}.jf-item.jf-layout-3 .jf-buttons .jf-view:hover{background:var(--bs-primary)!important;color:#fff!important;transform:translateY(-2px)}@media(max-width:768px){.jf-item.jf-layout-3:hover .jf-compact-panel{opacity:0!important}.jf-item.jf-layout-3.jf-expanded .jf-compact-panel{opacity:1!important;transform:scale(1)}}
@media(max-width:768px){.jf-item.jf-layout-3:hover .jf-compact-panel{opacity:0!important}.jf-item.jf-layout-3.jf-expanded .jf-compact-panel{opacity:1!important;transform:scale(1)}}
.jf-slider-title{font-family:Raleway,sans-serif;font-size:1.5rem;font-weight:500;color:#444;margin:45px 0 18px;position:relative;display:inline-block;padding-bottom:12px}
.jf-slider-title:after{content:"";position:absolute;left:3px;bottom:0;width:100%;height:1px;background:#e5e5e5}
.jf-slider-title:before{content:"";position:absolute;left:3px;bottom:0;width:60%;height:2px;background:var(--bs-primary,var(--primary-color,#1d6db3));z-index:2}
