/* =========================================================
   SmartShop Pro v2.1 — ssp-style.css
   ========================================================= */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
    --ssp-primary:#6C3CE1;
    --ssp-secondary:#3B82F6;
    --ssp-accent:#F59E0B;
    --ssp-danger:#EF4444;
    --ssp-success:#10B981;
    --ssp-text:#111111;
    --ssp-bg:#FFFFFF;
    --ssp-card-bg:#FAFAFA;
    --ssp-footer-bg:#1E1B4B;
    --ssp-primary-light:rgba(108,60,225,.1);
    --ssp-shadow-sm:0 2px 8px rgba(0,0,0,.08);
    --ssp-shadow-md:0 6px 24px rgba(0,0,0,.12);
    --ssp-shadow-lg:0 16px 48px rgba(0,0,0,.18);
    --ssp-radius:14px;
    --ssp-radius-sm:8px;
    --ssp-radius-pill:50px;
    --ssp-transition:.22s cubic-bezier(.4,0,.2,1);
    --ssp-font:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}

@keyframes sspFadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes sspSlideUp{from{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
@keyframes sspPulse{0%,100%{opacity:1}50%{opacity:.45}}
@keyframes sspBounce{0%,100%{transform:scale(1)}50%{transform:scale(1.3)}}
@keyframes sspSpin{to{transform:rotate(360deg)}}

.ssp-loading-spinner{
    width:36px;height:36px;
    border:3px solid #eee;border-top-color:var(--ssp-primary);
    border-radius:50%;animation:sspSpin .7s linear infinite;
    margin:40px auto;
}

/* ── SKELETON ────────────────────────────────────────────── */
.ssp-skeleton{
    background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8 50%,#f0f0f0 75%);
    background-size:200% 100%;
    animation:sspPulse 1.4s ease-in-out infinite;
    border-radius:var(--ssp-radius-sm);
}
.ssp-skeleton-img{width:100%;height:200px}
.ssp-skeleton-line{height:12px;margin:6px 0;border-radius:4px}
.ssp-skeleton-line.short{width:55%}
.ssp-skeleton-card{pointer-events:none}

/* ── GRID WRAPPER ────────────────────────────────────────── */
.ssp-grid-wrapper{
    font-family:var(--ssp-font);
    color:var(--ssp-text);
    width:100%;
}

.ssp-grid-container{
    display:grid;
    grid-template-columns:repeat(var(--ssp-cols,4),1fr);
    gap:20px;
}

/* ── PRODUCT CARD ────────────────────────────────────────── */
.ssp-product-card{
    background:var(--ssp-card-bg);
    border-radius:var(--ssp-radius);
    box-shadow:var(--ssp-shadow-sm);
    border:1px solid rgba(0,0,0,.06);
    display:flex;flex-direction:column;
    overflow:hidden;
    transition:transform var(--ssp-transition),box-shadow var(--ssp-transition);
    cursor:pointer;
}
.ssp-product-card:hover{transform:translateY(-4px);box-shadow:var(--ssp-shadow-md)}

.ssp-card-image-wrap{
    position:relative;overflow:hidden;background:#f5f5f5;
    /* height controlled by inline CSS var set by JS */
    height:var(--ssp-img-h,200px);
    flex-shrink:0;
}
.ssp-card-image-wrap img{
    width:100%;height:100%;object-fit:cover;display:block;
    transition:transform .4s ease;
}
.ssp-product-card:hover .ssp-card-image-wrap img{transform:scale(1.05)}

.ssp-quick-view-overlay{
    position:absolute;inset:0;
    background:rgba(0,0,0,.38);
    display:flex;align-items:center;justify-content:center;
    opacity:0;transition:opacity var(--ssp-transition);
}
.ssp-product-card:hover .ssp-quick-view-overlay{opacity:1}
.ssp-quick-view-btn{
    background:#fff;color:var(--ssp-primary);
    border:none;border-radius:var(--ssp-radius-pill);
    padding:9px 20px;font-size:13px;font-weight:700;cursor:pointer;
    box-shadow:var(--ssp-shadow-md);
    transition:background var(--ssp-transition),transform var(--ssp-transition);
}
.ssp-quick-view-btn:hover{background:var(--ssp-primary);color:#fff;transform:scale(1.05)}

.ssp-discount-badge{
    position:absolute;top:10px;left:10px;z-index:2;
    background:linear-gradient(135deg,var(--ssp-danger),#ff6b6b);
    color:#fff;font-size:11px;font-weight:800;
    padding:3px 10px;border-radius:var(--ssp-radius-pill);
    box-shadow:0 2px 8px rgba(239,68,68,.4);letter-spacing:.5px;
}

.ssp-wish-btn{
    position:absolute;top:10px;right:10px;z-index:2;
    background:#fff;border:none;border-radius:50%;
    width:32px;height:32px;font-size:16px;
    cursor:pointer;color:#aaa;
    box-shadow:var(--ssp-shadow-sm);
    transition:transform var(--ssp-transition),color var(--ssp-transition);
    display:flex;align-items:center;justify-content:center;
}
.ssp-wish-btn:hover{transform:scale(1.2)}
.ssp-wish-btn.active{color:var(--ssp-danger);animation:sspBounce .3s ease}

.ssp-card-body{
    padding:12px 14px 8px;flex:1;
    display:flex;flex-direction:column;gap:4px;
}
.ssp-card-vendor{
    font-size:11px;font-weight:600;color:var(--ssp-secondary);
    text-transform:uppercase;letter-spacing:.6px;
}
.ssp-card-title{
    font-size:var(--ssp-title-fs,14px);
    font-weight:600;color:var(--ssp-text);line-height:1.4;
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.ssp-card-title:hover{color:var(--ssp-primary)}
.ssp-card-price{font-size:var(--ssp-price-fs,15px);font-weight:700;color:var(--ssp-text)}
.ssp-card-price del{color:#aaa;font-weight:400;margin-right:4px}
.ssp-card-price ins{text-decoration:none;color:var(--ssp-danger)}
.ssp-card-rating{display:flex;align-items:center;gap:4px;font-size:12px;color:#777}
.ssp-stars{color:var(--ssp-accent);letter-spacing:1px}
.ssp-rating-count{color:#999}

.ssp-card-footer{padding:8px 12px 12px;display:flex;flex-direction:column;gap:6px}

.ssp-qty-wrap{
    display:flex;align-items:center;
    border:1.5px solid #e0e0e0;border-radius:var(--ssp-radius-pill);
    overflow:hidden;background:#fff;
}
.ssp-qty-btn{
    background:none;border:none;
    width:34px;height:34px;font-size:18px;font-weight:700;
    cursor:pointer;color:var(--ssp-primary);
    transition:background var(--ssp-transition);flex-shrink:0;
}
.ssp-qty-btn:hover{background:var(--ssp-primary-light)}
.ssp-qty-input{
    flex:1;text-align:center;border:none;outline:none;
    font-size:14px;font-weight:700;color:var(--ssp-text);
    width:40px;background:transparent;
}
.ssp-qty-input::-webkit-outer-spin-button,
.ssp-qty-input::-webkit-inner-spin-button{-webkit-appearance:none}

.ssp-add-to-cart-btn{
    width:100%;
    background:linear-gradient(135deg,var(--ssp-primary),var(--ssp-secondary));
    color:#fff;border:none;border-radius:var(--ssp-radius-pill);
    padding:10px 16px;font-size:13px;font-weight:700;
    cursor:pointer;
    transition:opacity var(--ssp-transition),transform var(--ssp-transition);
    box-shadow:0 3px 12px rgba(108,60,225,.3);letter-spacing:.3px;
}
.ssp-add-to-cart-btn:hover{opacity:.88;transform:translateY(-1px)}
.ssp-add-to-cart-btn.added{
    background:linear-gradient(135deg,var(--ssp-success),#06d6a0);
    box-shadow:0 3px 12px rgba(16,185,129,.3);
}
.ssp-add-to-cart-btn:disabled{opacity:.55;cursor:not-allowed}

/* ── LOAD MORE ───────────────────────────────────────────── */
.ssp-load-more-wrap{text-align:center;margin-top:28px}
.ssp-load-more-btn{
    background:#fff;color:var(--ssp-primary);
    border:2px solid var(--ssp-primary);
    border-radius:var(--ssp-radius-pill);
    padding:12px 36px;
    font-size:var(--ssp-more-fs,15px);
    font-weight:700;cursor:pointer;
    transition:all var(--ssp-transition);
    box-shadow:var(--ssp-shadow-sm);letter-spacing:.3px;
}
.ssp-load-more-btn:hover{
    background:var(--ssp-primary);color:#fff;
    box-shadow:0 4px 18px rgba(108,60,225,.35);
    transform:translateY(-2px);
}

/* ── FILTER ──────────────────────────────────────────────── */
.ssp-filter-wrapper{
    display:flex;flex-wrap:wrap;gap:10px;align-items:center;
    justify-content:center;
    padding:14px 18px;
    background:#fff;
    border-radius:var(--ssp-radius);
    box-shadow:var(--ssp-shadow-sm);
    border:1px solid rgba(0,0,0,.06);
    margin-bottom:22px;
    font-family:var(--ssp-font);
    width:100%;
}
.ssp-filter-search{
    display:flex;align-items:center;gap:8px;
    background:#f5f5f5;border-radius:var(--ssp-radius-pill);
    padding:0 14px;border:1.5px solid transparent;
    transition:border-color var(--ssp-transition);
    min-width:160px;flex:1 1 160px;
}
.ssp-filter-search:focus-within{border-color:var(--ssp-primary);background:#fff}
.ssp-filter-search input{
    border:none;outline:none;background:transparent;
    font-size:13px;color:var(--ssp-text);width:100%;padding:9px 0;
}
.ssp-filter-search svg{flex-shrink:0;opacity:.5}

.ssp-filter-select,.ssp-filter-cat,.ssp-rating-select{
    padding:9px 32px 9px 12px;
    border:1.5px solid #e0e0e0;border-radius:var(--ssp-radius-pill);
    font-size:13px;font-weight:600;color:var(--ssp-text);
    background:#fff;cursor:pointer;outline:none;
    appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M0 0l6 8 6-8' fill='none' stroke='%23666' stroke-width='2'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 12px center;
    transition:border-color var(--ssp-transition);
    white-space:nowrap;flex-shrink:0;
}
.ssp-filter-select:focus,.ssp-filter-cat:focus,.ssp-rating-select:focus{border-color:var(--ssp-primary)}

.ssp-price-range-wrap{
    display:flex;align-items:center;gap:6px;font-size:13px;
    flex-shrink:0;
}
.ssp-price-range-wrap input[type=number]{
    width:72px;padding:9px 10px;
    border:1.5px solid #e0e0e0;border-radius:var(--ssp-radius-pill);
    font-size:13px;color:var(--ssp-text);outline:none;
    transition:border-color var(--ssp-transition);
}
.ssp-price-range-wrap input:focus{border-color:var(--ssp-primary)}
.ssp-price-range-wrap span{color:#999}

.ssp-filter-apply-btn{
    background:linear-gradient(135deg,var(--ssp-primary),var(--ssp-secondary));
    color:#fff;border:none;border-radius:var(--ssp-radius-pill);
    padding:10px 22px;font-size:13px;font-weight:700;
    cursor:pointer;transition:opacity var(--ssp-transition),transform var(--ssp-transition);
    box-shadow:0 3px 12px rgba(108,60,225,.25);flex-shrink:0;
}
.ssp-filter-apply-btn:hover{opacity:.88;transform:translateY(-1px)}

/* ── FOOTER BAR ──────────────────────────────────────────── */
.ssp-footer-bar{
    position:fixed;bottom:0;left:0;right:0;z-index:99990;
    background:var(--ssp-footer-bg);
    box-shadow:0 -4px 24px rgba(0,0,0,.22);
    height:62px;
}
body{padding-bottom:62px}

.ssp-bar-inner{
    /* FIX: use full width, evenly distribute buttons */
    width:100%;max-width:100%;
    height:100%;padding:0 8px;
    display:flex;align-items:center;justify-content:space-around;
}
.ssp-bar-btn{
    background:none;border:none;
    color:rgba(255,255,255,.72);
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:2px;padding:4px 0;
    border-radius:var(--ssp-radius-sm);cursor:pointer;
    transition:color var(--ssp-transition),background var(--ssp-transition);
    position:relative;
    flex:1;max-width:160px;
}
.ssp-bar-btn:hover,.ssp-bar-btn.active{color:#fff;background:rgba(255,255,255,.1)}
.ssp-bar-btn.active .ssp-bar-icon{color:var(--ssp-accent)}
.ssp-bar-icon{font-size:22px;line-height:1}
.ssp-bar-label{font-size:10px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;white-space:nowrap}
.ssp-badge{
    position:absolute;top:3px;right:calc(50% - 20px);
    background:var(--ssp-danger);color:#fff;
    font-size:10px;font-weight:800;
    min-width:18px;height:18px;border-radius:9px;
    display:flex;align-items:center;justify-content:center;
    padding:0 4px;border:2px solid var(--ssp-footer-bg);
    box-shadow:0 1px 4px rgba(0,0,0,.3);
}
.ssp-badge.bump{animation:sspBounce .3s ease}

/* ── OVERLAY ─────────────────────────────────────────────── */
.ssp-overlay{
    position:fixed;inset:0;
    background:rgba(0,0,0,.5);backdrop-filter:blur(2px);
    z-index:99991;opacity:0;pointer-events:none;
    transition:opacity var(--ssp-transition);
}
.ssp-overlay.visible{opacity:1;pointer-events:all}

/* ── PANELS ──────────────────────────────────────────────── */
.ssp-panel{
    position:fixed;top:0;right:0;
    width:min(420px,100vw);
    height:calc(100vh - 62px);
    background:var(--ssp-bg);z-index:99992;
    display:flex;flex-direction:column;
    box-shadow:-8px 0 40px rgba(0,0,0,.18);
    border-radius:var(--ssp-radius) 0 0 var(--ssp-radius);
    transform:translateX(100%);
    transition:transform .32s cubic-bezier(.4,0,.2,1);
    overflow:hidden;
}
.ssp-panel.open{transform:translateX(0)}

.ssp-panel-header{
    display:flex;align-items:center;justify-content:space-between;
    padding:18px 20px 16px;border-bottom:1px solid #f0f0f0;
    background:linear-gradient(135deg,var(--ssp-primary),var(--ssp-secondary));
    flex-shrink:0;
}
.ssp-panel-title{font-size:17px;font-weight:800;color:#fff;display:flex;align-items:center;gap:8px}
.ssp-panel-close{
    background:rgba(255,255,255,.2);border:none;border-radius:50%;
    width:32px;height:32px;font-size:16px;font-weight:700;
    color:#fff;cursor:pointer;transition:background var(--ssp-transition);
    display:flex;align-items:center;justify-content:center;
}
.ssp-panel-close:hover{background:rgba(255,255,255,.35)}

.ssp-panel-body{
    flex:1;overflow-y:auto;padding:14px;scroll-behavior:smooth;
}
.ssp-panel-body::-webkit-scrollbar{width:4px}
.ssp-panel-body::-webkit-scrollbar-thumb{background:#ddd;border-radius:2px}

.ssp-panel-footer{
    padding:12px 14px;border-top:1px solid #f0f0f0;background:#fff;
    display:flex;flex-direction:column;gap:8px;flex-shrink:0;
}
.ssp-cart-total-row{
    display:flex;justify-content:space-between;align-items:center;
    font-size:16px;font-weight:800;color:var(--ssp-text);
    padding:4px 0 8px;border-bottom:1px solid #f0f0f0;
}

/* Cart items */
.ssp-cart-item{
    display:flex;align-items:center;gap:12px;
    padding:12px 0;border-bottom:1px solid #f5f5f5;
    animation:sspFadeIn .25s ease;
}
.ssp-cart-item-img{
    width:60px;height:60px;object-fit:cover;
    border-radius:var(--ssp-radius-sm);flex-shrink:0;background:#f5f5f5;
}
.ssp-cart-item-info{flex:1;min-width:0}
.ssp-cart-item-name{font-size:13px;font-weight:600;color:var(--ssp-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ssp-cart-item-price{font-size:13px;color:var(--ssp-primary);font-weight:700;margin-top:3px}
.ssp-cart-item-qty{display:flex;align-items:center;gap:6px;margin-top:6px}
.ssp-cart-item-qty input{
    width:44px;text-align:center;
    border:1px solid #e0e0e0;border-radius:var(--ssp-radius-sm);
    padding:4px;font-size:13px;font-weight:700;outline:none;
}
.ssp-cart-item-qty button{
    background:var(--ssp-primary-light);border:none;border-radius:50%;
    width:24px;height:24px;font-size:14px;font-weight:800;
    cursor:pointer;color:var(--ssp-primary);
    display:flex;align-items:center;justify-content:center;
    transition:background var(--ssp-transition);
}
.ssp-cart-item-qty button:hover{background:var(--ssp-primary);color:#fff}
.ssp-cart-remove{
    background:none;border:none;color:#ccc;cursor:pointer;
    font-size:16px;padding:4px;
    transition:color var(--ssp-transition);flex-shrink:0;
}
.ssp-cart-remove:hover{color:var(--ssp-danger)}

/* Wishlist items */
.ssp-wish-item{
    display:flex;align-items:center;gap:12px;
    padding:12px 0;border-bottom:1px solid #f5f5f5;
    animation:sspFadeIn .25s ease;
}
.ssp-wish-item-img{
    width:60px;height:60px;object-fit:cover;
    border-radius:var(--ssp-radius-sm);flex-shrink:0;background:#f5f5f5;
}
.ssp-wish-item-info{flex:1;min-width:0}
.ssp-wish-item-name{font-size:13px;font-weight:600;color:var(--ssp-text)}
.ssp-wish-item-price{font-size:13px;color:var(--ssp-primary);font-weight:700;margin-top:3px}
.ssp-wish-item-actions{display:flex;gap:6px;margin-top:6px}
.ssp-wish-add-cart{
    background:linear-gradient(135deg,var(--ssp-primary),var(--ssp-secondary));
    color:#fff;border:none;border-radius:var(--ssp-radius-pill);
    padding:6px 14px;font-size:12px;font-weight:700;cursor:pointer;
    transition:opacity var(--ssp-transition);
}
.ssp-wish-add-cart:hover{opacity:.85}
.ssp-wish-remove{
    background:none;border:1.5px solid #e0e0e0;border-radius:var(--ssp-radius-pill);
    padding:6px 10px;font-size:12px;font-weight:600;cursor:pointer;color:#888;
    transition:all var(--ssp-transition);
}
.ssp-wish-remove:hover{border-color:var(--ssp-danger);color:var(--ssp-danger)}

/* Orders */
.ssp-orders-tabs{
    display:flex;gap:4px;padding:10px 12px;
    background:#fafafa;border-bottom:1px solid #f0f0f0;
    overflow-x:auto;flex-shrink:0;
}
.ssp-orders-tabs::-webkit-scrollbar{display:none}
.ssp-tab{
    background:none;border:1.5px solid transparent;
    border-radius:var(--ssp-radius-pill);
    padding:6px 12px;font-size:12px;font-weight:700;
    cursor:pointer;white-space:nowrap;color:#888;
    transition:all var(--ssp-transition);
}
.ssp-tab.active,.ssp-tab:hover{background:var(--ssp-primary);color:#fff;border-color:var(--ssp-primary)}
.ssp-order-card{
    background:#fff;border:1.5px solid #f0f0f0;border-radius:var(--ssp-radius);
    padding:14px;margin-bottom:10px;cursor:pointer;
    transition:all var(--ssp-transition);box-shadow:var(--ssp-shadow-sm);
    animation:sspFadeIn .25s ease;
}
.ssp-order-card:hover{border-color:var(--ssp-primary);transform:translateY(-2px);box-shadow:var(--ssp-shadow-md)}
.ssp-order-header{display:flex;justify-content:space-between;align-items:flex-start}
.ssp-order-number{font-size:15px;font-weight:800;color:var(--ssp-text)}
.ssp-order-date{font-size:12px;color:#aaa;margin-top:2px}
.ssp-order-total{font-size:14px;font-weight:700;color:var(--ssp-primary);margin-top:6px}
.ssp-order-items-preview{font-size:12px;color:#999;margin-top:4px}
.ssp-order-status{
    font-size:11px;font-weight:800;
    padding:4px 10px;border-radius:var(--ssp-radius-pill);
    text-transform:uppercase;letter-spacing:.5px;
}
.ssp-status-completed{background:#d1fae5;color:#065f46}
.ssp-status-pending{background:#fef3c7;color:#92400e}
.ssp-status-processing{background:#dbeafe;color:#1e40af}
.ssp-status-cancelled{background:#fee2e2;color:#991b1b}
.ssp-status-on-hold{background:#f3e8ff;color:#6b21a8}
.ssp-status-refunded{background:#e0f2fe;color:#075985}

/* ── MODALS ──────────────────────────────────────────────── */
.ssp-modal{
    position:fixed;inset:0;z-index:99995;
    background:rgba(0,0,0,.6);backdrop-filter:blur(4px);
    display:flex;align-items:center;justify-content:center;
    padding:16px;
    opacity:0;pointer-events:none;
    transition:opacity var(--ssp-transition);
}
.ssp-modal.open{opacity:1;pointer-events:all}

.ssp-modal-inner{
    background:var(--ssp-bg);border-radius:var(--ssp-radius);
    /* FIX: full available width in desktop with proper max */
    width:100%;max-width:960px;
    max-height:92vh;overflow-y:auto;position:relative;
    box-shadow:var(--ssp-shadow-lg);animation:sspFadeIn .28s ease;
}
.ssp-modal-inner::-webkit-scrollbar{width:4px}
.ssp-modal-inner::-webkit-scrollbar-thumb{background:#ddd;border-radius:2px}

.ssp-modal-close{
    position:absolute;top:14px;right:14px;z-index:2;
    background:rgba(0,0,0,.08);border:none;border-radius:50%;
    width:36px;height:36px;font-size:17px;font-weight:700;
    cursor:pointer;color:var(--ssp-text);
    display:flex;align-items:center;justify-content:center;
    transition:background var(--ssp-transition);
}
.ssp-modal-close:hover{background:rgba(0,0,0,.15)}

/* Quick View — FIX: no outer margin/padding eating space; inner padding only */
.ssp-qv-content{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:0;
    /* no padding here — handled per-column */
}
.ssp-qv-gallery{
    padding:28px 20px 28px 28px;
    display:flex;flex-direction:column;gap:12px;
    border-right:1px solid #f0f0f0;
}
.ssp-qv-main-img{
    width:100%;aspect-ratio:1/1;object-fit:cover;
    border-radius:var(--ssp-radius);box-shadow:var(--ssp-shadow-sm);
    transition:transform .4s ease;
    display:block;
}
.ssp-qv-thumbs{display:flex;gap:8px;flex-wrap:wrap}
.ssp-qv-thumb{
    width:64px;height:64px;object-fit:cover;
    border-radius:var(--ssp-radius-sm);cursor:pointer;
    border:2px solid transparent;opacity:.72;
    transition:border-color var(--ssp-transition),opacity var(--ssp-transition),transform var(--ssp-transition);
}
.ssp-qv-thumb:hover,.ssp-qv-thumb.active{border-color:var(--ssp-primary);opacity:1;transform:scale(1.06)}

.ssp-qv-info{
    padding:28px 28px 28px 20px;
    display:flex;flex-direction:column;gap:14px;
    overflow-y:auto;
}
.ssp-qv-vendor{font-size:12px;font-weight:700;color:var(--ssp-secondary);text-transform:uppercase;letter-spacing:.6px}
.ssp-qv-title{font-size:20px;font-weight:800;color:var(--ssp-text);line-height:1.3}
.ssp-qv-rating{display:flex;align-items:center;gap:6px;font-size:13px;color:#777}
.ssp-qv-price{font-size:22px;font-weight:800;color:var(--ssp-text)}
.ssp-qv-price del{font-size:16px;color:#aaa;font-weight:400;margin-right:6px}
.ssp-qv-price ins{text-decoration:none;color:var(--ssp-danger)}
.ssp-qv-description{font-size:14px;color:#555;line-height:1.6}

.ssp-qv-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.ssp-qv-qty-wrap{
    display:flex;align-items:center;
    border:1.5px solid #e0e0e0;border-radius:var(--ssp-radius-pill);overflow:hidden;
}
.ssp-qv-qty-btn{
    background:none;border:none;width:36px;height:40px;
    font-size:18px;font-weight:800;cursor:pointer;color:var(--ssp-primary);
    transition:background var(--ssp-transition);
}
.ssp-qv-qty-btn:hover{background:var(--ssp-primary-light)}
.ssp-qv-qty-input{
    width:46px;text-align:center;border:none;outline:none;
    font-size:15px;font-weight:700;color:var(--ssp-text);
}
.ssp-qv-add-cart{
    flex:1;
    background:linear-gradient(135deg,var(--ssp-primary),var(--ssp-secondary));
    color:#fff;border:none;border-radius:var(--ssp-radius-pill);
    padding:12px 18px;font-size:14px;font-weight:700;cursor:pointer;
    box-shadow:0 4px 14px rgba(108,60,225,.3);
    transition:opacity var(--ssp-transition),transform var(--ssp-transition);
    white-space:nowrap;
}
.ssp-qv-add-cart:hover{opacity:.88;transform:translateY(-1px)}
.ssp-qv-buy-now{
    flex:1;
    background:linear-gradient(135deg,var(--ssp-accent),#f97316);
    color:#fff;border:none;border-radius:var(--ssp-radius-pill);
    padding:12px 18px;font-size:14px;font-weight:700;cursor:pointer;
    box-shadow:0 4px 14px rgba(245,158,11,.3);
    transition:opacity var(--ssp-transition),transform var(--ssp-transition);
    white-space:nowrap;
}
.ssp-qv-buy-now:hover{opacity:.88;transform:translateY(-1px)}
.ssp-qv-buy-now:disabled{opacity:.6;cursor:not-allowed}
.ssp-qv-wish-btn{
    background:#fff;border:1.5px solid #e0e0e0;border-radius:var(--ssp-radius-pill);
    padding:12px 16px;font-size:16px;cursor:pointer;color:#aaa;
    transition:all var(--ssp-transition);
}
.ssp-qv-wish-btn:hover,.ssp-qv-wish-btn.active{border-color:var(--ssp-danger);color:var(--ssp-danger);background:#fff0f0}

/* QV Reviews row — spans both columns */
.ssp-qv-reviews-row{
    grid-column:1/-1;
    padding:20px 28px 28px;
    border-top:1px solid #f0f0f0;
}
.ssp-qv-reviews-row h3{font-size:16px;font-weight:800;margin-bottom:14px}
.ssp-review-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid #f5f5f5}
.ssp-review-avatar{width:40px;height:40px;border-radius:50%;flex-shrink:0;background:#eee;object-fit:cover}
.ssp-review-body{flex:1}
.ssp-review-header{display:flex;align-items:center;gap:8px;margin-bottom:4px;flex-wrap:wrap}
.ssp-review-author{font-size:13px;font-weight:700;color:var(--ssp-text)}
.ssp-review-date{font-size:11px;color:#aaa}
.ssp-review-text{font-size:13px;color:#555;line-height:1.5}

/* Order Detail Modal */
.ssp-order-modal-inner{max-width:560px;padding:28px}
.ssp-order-detail h3{font-size:20px;font-weight:800;margin-bottom:18px}
.ssp-order-detail-row{
    display:flex;justify-content:space-between;align-items:center;
    padding:8px 0;border-bottom:1px solid #f5f5f5;font-size:14px;
}
.ssp-order-detail-label{color:#888;font-weight:600}
.ssp-order-detail-value{font-weight:700;color:var(--ssp-text);text-align:right}
.ssp-order-items-list{margin-top:14px}
.ssp-order-item-row{
    display:flex;align-items:center;gap:10px;
    padding:8px 0;border-bottom:1px solid #f5f5f5;font-size:13px;
}
.ssp-order-item-img{width:44px;height:44px;border-radius:6px;object-fit:cover;background:#f5f5f5;flex-shrink:0}
.ssp-order-item-name{flex:1;font-weight:600}
.ssp-order-item-qty{color:#888}
.ssp-order-item-price{font-weight:700;color:var(--ssp-primary)}
.ssp-tracking-info{
    margin-top:14px;padding:12px;background:#f0f9ff;
    border-radius:var(--ssp-radius-sm);font-size:13px;color:#0369a1;
    border:1px solid #bae6fd;
}

/* ── BUTTONS ─────────────────────────────────────────────── */
.ssp-btn{
    display:inline-flex;align-items:center;justify-content:center;gap:6px;
    padding:11px 20px;border-radius:var(--ssp-radius-pill);
    font-size:14px;font-weight:700;cursor:pointer;border:none;
    transition:all var(--ssp-transition);text-decoration:none;letter-spacing:.3px;
}
.ssp-btn-full{width:100%}
.ssp-btn-primary{
    background:linear-gradient(135deg,var(--ssp-primary),var(--ssp-secondary));
    color:#fff;box-shadow:0 3px 12px rgba(108,60,225,.3);
}
.ssp-btn-primary:hover{opacity:.88;transform:translateY(-1px);color:#fff}
.ssp-btn-ghost{background:#fff;color:#888;border:1.5px solid #e0e0e0}
.ssp-btn-ghost:hover{border-color:#bbb;color:var(--ssp-text)}

/* ── EMPTY STATE ─────────────────────────────────────────── */
.ssp-empty-state{text-align:center;padding:48px 20px;color:#bbb}
.ssp-empty-icon{font-size:52px;display:block;margin-bottom:12px}
.ssp-empty-state p{font-size:15px;font-weight:600;color:#aaa}

/* ── TOAST ───────────────────────────────────────────────── */
.ssp-toast{
    position:fixed;bottom:80px;left:50%;transform:translateX(-50%);
    background:var(--ssp-success);color:#fff;
    padding:10px 24px;border-radius:var(--ssp-radius-pill);
    font-size:14px;font-weight:700;z-index:999999;
    box-shadow:var(--ssp-shadow-md);white-space:nowrap;
    animation:sspSlideUp .3s ease;pointer-events:none;
}
.ssp-toast.error{background:var(--ssp-danger)}

/* ── ELEMENTOR EDITOR LIVE PREVIEW ──────────────────────── */
/* Show a placeholder grid inside Elementor when no products yet loaded */
.elementor-editor-active .ssp-grid-wrapper:empty::after,
.elementor-editor-active .ssp-grid-container:empty::after{
    content:'SmartShop Grid will render here';
    display:block;padding:24px;text-align:center;
    color:#999;font-size:14px;border:2px dashed #ddd;
    border-radius:var(--ssp-radius);
}

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media (max-width:768px){
    .ssp-grid-container{
        grid-template-columns:repeat(var(--ssp-cols-mobile,2),1fr);
        gap:12px;
    }
    .ssp-card-image-wrap{height:var(--ssp-img-h-mobile,160px) !important}
    .ssp-card-title{font-size:var(--ssp-title-fs-mobile,12px)}
    .ssp-card-price{font-size:var(--ssp-price-fs-mobile,13px)}
    .ssp-load-more-btn{font-size:var(--ssp-more-fs-mobile,13px)}

    /* Filter: keep horizontal, centred, wrap neatly */
    .ssp-filter-wrapper{
        flex-direction:row;
        flex-wrap:wrap;
        justify-content:center;
        gap:8px;
        padding:12px 12px;
    }
    .ssp-filter-search{min-width:100%;flex:1 1 100%}
    .ssp-filter-select,.ssp-filter-cat,.ssp-rating-select{font-size:12px;padding:8px 28px 8px 10px}
    .ssp-price-range-wrap input[type=number]{width:60px}
    .ssp-filter-apply-btn{padding:9px 18px;font-size:12px}

    /* Quick View — single column on mobile */
    .ssp-qv-content{grid-template-columns:1fr}
    .ssp-qv-gallery{border-right:none;border-bottom:1px solid #f0f0f0;padding:16px 16px 14px}
    .ssp-qv-info{padding:14px 16px 16px}
    .ssp-qv-reviews-row{padding:14px 16px 20px}
    .ssp-modal-inner{border-radius:var(--ssp-radius) var(--ssp-radius) 0 0}
    .ssp-modal{align-items:flex-end;padding:0}

    /* Footer bar — ensure text fits */
    .ssp-bar-label{font-size:9px}
    .ssp-bar-icon{font-size:20px}
}

@media (min-width:769px){
    /* Desktop QV — ensure full width usage */
    .ssp-modal{padding:20px}
    .ssp-modal-inner{width:min(960px,96vw)}
    .ssp-qv-content{min-height:480px}
    .ssp-qv-gallery,.ssp-qv-info{min-height:480px}
}