/* ==========================================
   1. BASE & ANIMATIONS
   ========================================== */
@keyframes saFadeInUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
@keyframes saPulse { 0% { transform: scale(1); } 50% { transform: scale(1.02); } 100% { transform: scale(1); } }
@keyframes sa-spin { to { transform: rotate(360deg); } }

.sa-animate-card { animation: saFadeInUp 0.6s cubic-bezier(0.16, 1, 0.3, 1) forwards; opacity: 0; }
.sa-btn-pulse { animation: saPulse 0.4s ease; }
.sa-loader { display:inline-block; width: 14px; height: 14px; border: 2px solid rgba(255,255,255,0.3); border-radius: 50%; border-top-color: #fff; animation: sa-spin 1s ease-in-out infinite; margin-right:5px; }

/* Added to Cart Color Override */
.sa-wrapper .added-to-cart, .sa-pc-wrapper .added-to-cart, .sa-pc-btn.added-to-cart { background-color: #10b981 !important; color: #fff !important; border-color: #059669 !important; }
.sa-pc-btn.added-to-cart svg { stroke: #fff !important; }

/* ==========================================
   2. LAYOUT WRAPPERS (Bulletproof Structure)
   ========================================== */
.sa-pc-wrapper, .sa-wrapper { font-family: 'Anek Bangla', sans-serif !important; max-width: 100% !important; margin: 0 auto !important; box-sizing: border-box !important; color: #333 !important; }
.sa-wrapper *, .sa-pc-wrapper * { box-sizing: border-box !important; }
.sa-row { display: flex !important; flex-wrap: wrap !important; gap: 20px !important; align-items: flex-start !important; width: 100% !important; margin: 0 !important; padding: 0 !important; }

.sa-col-left { flex: 1.5 !important; min-width: 300px !important; border: 1px solid #eaeaea !important; border-radius: 8px !important; padding: 20px !important; background: #fff !important; box-shadow: 0 4px 15px rgba(0,0,0,0.02) !important; box-sizing: border-box !important; display: block !important; width: auto !important; }
.sa-col-right { flex: 1 !important; min-width: 300px !important; border: 1px solid #eaeaea !important; border-radius: 8px !important; padding: 20px !important; background: #fff !important; position: sticky !important; top: 20px !important; box-shadow: 0 4px 15px rgba(0,0,0,0.02) !important; box-sizing: border-box !important; display: block !important; width: auto !important; }
.sa-heading { font-size: 18px !important; font-weight: 700 !important; margin-bottom: 10px !important; margin-top: 5px !important; color: #222 !important; display: block !important; }

/* ==========================================
   3. CATEGORY GRID & CARDS
   ========================================== */
.sa-pc-grid { display: grid !important; gap: 15px !important; margin-bottom: 30px !important; width: 100% !important; }
.sa-pc-card-hz { background: #fff !important; border: 1px solid #eaeaea !important; border-radius: 10px !important; box-shadow: 0 4px 15px rgba(0,0,0,0.03) !important; margin-bottom: 15px !important; display: flex !important; transition: all 0.3s ease !important; width: 100% !important; box-sizing: border-box !important;}
.sa-pc-card-hz:hover { transform: translateY(-3px) !important; box-shadow: 0 8px 25px rgba(0,0,0,0.06) !important; border-color: #cbd5e1 !important; }

/* FULL BLEED IMAGE STYLE FOR VERTICAL CARD - 1:1 SQUARE ASPECT RATIO */
.sa-card-layout-vertical { flex-direction: column !important; align-items: center !important; text-align: center !important; padding: 0 !important; gap: 0 !important; overflow: hidden !important; }
.sa-card-layout-vertical .sa-pc-card-hz-img-wrap { width: 100% !important; aspect-ratio: 1 / 1 !important; text-align: center !important; overflow: hidden !important; border-radius: 10px 10px 0 0 !important; display: block !important; background: #f8fafc !important; border-bottom: 1px solid #f1f5f9 !important; }
.sa-card-layout-vertical img { width: 100% !important; height: 100% !important; object-fit: cover !important; border-radius: 10px 10px 0 0 !important; transition: transform 0.5s ease !important; display: block !important; margin: 0 !important; }
.sa-pc-card-hz:hover img { transform: scale(1.05) !important; }

/* Add padding to the content area inside vertical layout */
.sa-card-layout-vertical .sa-pc-card-hz-content { padding: 18px 15px 20px 15px !important; width: 100% !important; box-sizing: border-box !important; }

/* Reduced height & width for category buttons */
.sa-card-layout-vertical .sa-pc-btn-wrap { justify-content: center !important; width: 100% !important; margin-top: 15px !important; display: flex !important; }

.sa-card-layout-horizontal { flex-direction: row !important; align-items: center !important; text-align: left !important; padding: 15px !important; gap: 15px !important; }
.sa-card-layout-horizontal .sa-pc-card-hz-img-wrap { width: 80px !important; height: 80px !important; flex-shrink: 0 !important; overflow: hidden !important; border-radius: 6px !important; display: block !important; }
.sa-card-layout-horizontal img { width: 100% !important; height: 100% !important; object-fit: cover !important; border-radius: 6px !important; border: 1px solid #f1f1f1 !important; }
.sa-card-layout-horizontal .sa-pc-card-hz-content { justify-content: center !important; }
.sa-card-layout-horizontal .sa-pc-btn-wrap { margin-left: auto !important; margin-top: 0 !important; display: flex !important; }

.sa-pc-card-hz-content { width: 100% !important; display: flex !important; flex-direction: column !important; }
.sa-pc-card-hz-title { font-size: 16px !important; font-weight: 600 !important; color: #333 !important; margin: 0 0 4px 0 !important; line-height: 1.3 !important; display: -webkit-box !important; -webkit-line-clamp: 2 !important; -webkit-box-orient: vertical !important; overflow: hidden !important; text-overflow: ellipsis !important; }
.sa-pc-card-hz-price { font-size: 18px !important; color: #f97316 !important; margin: 0 !important; font-weight: bold !important; display: flex !important; align-items: center !important; }
.sa-card-layout-vertical .sa-pc-card-hz-price { justify-content: center !important; width: 100% !important; }
.sa-card-layout-horizontal .sa-pc-card-hz-price { justify-content: flex-start !important; }

/* ==========================================
   4. BUTTONS & QUANTITY CONTROLS
   ========================================== */
.sa-pc-btn-wrap { display: flex !important; align-items: center !important; }
.sa-col-left .sa-pc-btn-wrap { margin-left: auto !important; }

.sa-pc-btn { background: #f97316; color: #fff !important; border: none !important; border-radius: 50px !important; padding: 8px 18px !important; font-size: 15px !important; font-weight: 600 !important; cursor: pointer !important; transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1) !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; gap: 5px !important; font-family: inherit !important; position:relative !important; overflow:hidden !important; box-shadow: none !important; white-space: nowrap !important; }
.sa-col-left .sa-pc-btn { border-radius: 50px !important; padding: 8px 18px !important; font-size: 14px !important; }
.sa-pc-btn:not(:disabled):hover { opacity: 0.9 !important; transform: translateY(-2px) !important; box-shadow: 0 4px 12px rgba(249,115,22,0.2) !important; }
.sa-pc-btn:not(:disabled):active { transform: scale(0.92) translateY(0) !important; box-shadow: 0 1px 3px rgba(249,115,22,0.1) !important; }
.sa-pc-btn.hidden { display: none !important; }

.sa-qty-ctrl { display: none !important; align-items: center !important; background: #f8f9fa !important; border: 1px solid #eaeaea !important; border-radius: 50px !important; padding: 4px !important; font-size: 16px !important; font-weight: 600 !important; width: 110px !important; justify-content: space-between !important; transition: all 0.3s ease !important; flex-shrink: 0 !important; }
.sa-col-left .sa-qty-ctrl { padding: 4px !important; font-size: 15px !important; width: 110px !important; border-radius: 50px !important; }
.sa-qty-ctrl.active { display: inline-flex !important; animation: saFadeInUp 0.3s ease forwards !important; }

.sa-qty-btn { background: #f97316; border: none !important; color: #fff !important; width: 28px !important; height: 28px !important; border-radius: 50% !important; display: flex !important; align-items: center !important; justify-content: center !important; cursor: pointer !important; font-size: 20px !important; font-weight: bold !important; line-height: 1 !important; padding: 0 !important; box-shadow: 0 2px 4px rgba(0,0,0,0.1) !important; transition: all 0.25s cubic-bezier(0.25, 0.8, 0.25, 1) !important; flex-shrink: 0 !important; }
.sa-col-left .sa-qty-btn { width: 26px !important; height: 26px !important; font-size: 18px !important; }
.sa-qty-btn:hover { transform: scale(1.1) !important; }
.sa-qty-btn:active { transform: scale(0.85) !important; }
.sa-qty-val { padding: 0 !important; flex: 1 !important; text-align: center !important; color: #333 !important; font-size: 17px !important; display: block !important; }
.sa-col-left .sa-qty-val { font-size: 15px !important; }

.sa-btn { display: block !important; width: 100% !important; padding: 14px !important; background-color: #f97316; color: #fff !important; text-align: center !important; font-size: 18px !important; font-weight: 700 !important; border: none !important; border-radius: 50px !important; cursor: pointer !important; margin-top: 15px !important; font-family: inherit !important; transition:all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1) !important; position: relative !important; overflow: hidden !important; box-shadow: none !important; white-space: nowrap !important; }
.sa-btn:not(:disabled):hover { opacity: 0.9 !important; transform: translateY(-2px) !important; box-shadow: 0 6px 15px rgba(249,115,22,0.3) !important; }
.sa-btn:not(:disabled):active { transform: scale(0.96) translateY(0) !important; box-shadow: 0 2px 5px rgba(249,115,22,0.2) !important; }
.sa-btn:disabled, .sa-mobile-btn:disabled { opacity: 0.5 !important; cursor: not-allowed !important; }

/* ==========================================
   5. HERO PRODUCT & VARIATIONS
   ========================================== */
.sa-pc-single-layout { margin-bottom: 10px !important; display: block !important; width: 100% !important;}

.sa-pc-single-layout .sa-pc-card-hz { 
    padding: 12px !important; 
    gap: 15px !important; 
    border-radius: 8px !important; 
    box-shadow: 0 2px 8px rgba(0,0,0,0.02) !important; 
    flex-wrap: wrap !important; 
    align-items: center !important; 
}
.sa-pc-single-layout .sa-pc-card-hz-img { width: 70px !important; height: 70px !important; flex-shrink: 0 !important; display:flex !important; align-items:center !important; justify-content:center !important; overflow: hidden !important; border-radius: 6px !important;}
.sa-pc-single-layout .sa-pc-card-hz-img img { max-width: 100% !important; max-height: 100% !important; object-fit: contain !important; border-radius: 6px !important; transition: transform 0.4s ease !important;}
.sa-pc-single-layout .sa-pc-card-hz:hover .sa-pc-card-hz-img img { transform: scale(1.08) !important; }

.sa-pc-single-layout .sa-pc-card-hz-content { 
    flex: 1 1 0% !important; 
    width: auto !important; 
    min-width: 0 !important; 
    justify-content: center !important; 
}
.sa-pc-single-layout .sa-pc-btn-wrap { 
    margin-left: auto !important; 
    flex: 0 0 auto !important; 
}

.sa-hero-var-grid { flex: 0 0 100% !important; display: flex !important; flex-wrap: wrap !important; gap: 10px !important; margin: 12px 0 0 0 !important; width: 100% !important; }
.sa-hero-var-box { border: 1px solid #cbd5e1 !important; border-radius: 6px !important; overflow: hidden !important; cursor: pointer !important; transition: all 0.2s ease !important; background: #fff !important; display: flex !important; position: relative !important; align-items: center !important; }
.sa-hero-var-box:hover { border-color: #f97316 !important; transform: translateY(-2px) !important; }
.sa-hero-var-box:active { transform: scale(0.95) !important; }
.sa-hero-var-box.selected { border-color: #f97316 !important; box-shadow: 0 0 0 1px #f97316 !important; background: #fffaf5 !important; }
.sa-hero-var-img img { max-width: 100% !important; max-height: 100% !important; object-fit: contain !important; mix-blend-mode: multiply !important; }
.sa-hero-var-title { font-weight: 600 !important; color: #334155 !important; line-height: 1.2 !important; word-break: break-word !important; font-size: 14px !important; }

.sa-hero-var-grid.layout-vertical .sa-hero-var-box { flex: 1 !important; min-width: 70px !important; max-width: 100px !important; flex-direction: column !important; justify-content: center !important; }
.sa-hero-var-grid.layout-vertical .sa-hero-var-img { width: 100% !important; aspect-ratio: 1/1 !important; display: flex !important; align-items: center !important; justify-content: center !important; background: #f8fafc !important; border-bottom: 1px solid #eaeaea !important; padding: 4px !important; overflow:hidden !important;}
.sa-hero-var-grid.layout-vertical .sa-hero-var-title { font-size: 13px !important; padding: 6px !important; text-align: center !important; width: 100% !important; display: block !important; }
.sa-hero-var-grid.layout-vertical .sa-hero-var-box.no-img .sa-hero-var-title { padding: 12px 8px !important; font-size: 14px !important; }

.sa-hero-var-grid.layout-horizontal { display: grid !important; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)) !important; }
.sa-hero-var-grid.layout-horizontal .sa-hero-var-box { flex-direction: row !important; justify-content: flex-start !important; padding: 6px 10px !important; max-width: 100% !important; width: 100% !important; }
.sa-hero-var-grid.layout-horizontal .sa-hero-var-img { width: 32px !important; height: 32px !important; flex-shrink: 0 !important; margin-right: 10px !important; display: flex !important; align-items: center !important; justify-content: center !important; background: transparent !important; border-bottom: none !important; border-radius: 4px !important; padding: 0 !important; }
.sa-hero-var-grid.layout-horizontal .sa-hero-var-title { font-size: 14px !important; text-align: left !important; padding: 0 !important; display: block !important; }

/* ==========================================
   6. RECOMMENDED PRODUCTS
   ========================================== */
.sa-rec-grid { display: grid !important; grid-template-columns: repeat(6, 1fr) !important; gap: 8px !important; margin-bottom: 10px !important; width: 100% !important; }
@media (min-width: 769px) { .sa-rec-grid-right { grid-template-columns: repeat(3, 1fr) !important; margin-top: 20px !important; } }
.sa-rec-card { border: 1px solid #eaeaea !important; border-radius: 8px !important; padding: 8px 6px !important; text-align: center !important; background: #fff !important; display: flex !important; flex-direction: column !important; justify-content: space-between !important; box-shadow: 0 1px 4px rgba(0,0,0,0.02) !important; transition: all 0.3s ease !important; box-sizing: border-box !important;}
.sa-rec-card:hover { border-color: #cbd5e1 !important; transform: translateY(-3px) !important; box-shadow: 0 6px 15px rgba(0,0,0,0.04) !important; }
.sa-rec-img-wrap { width: 100% !important; aspect-ratio: 1/1 !important; display:flex !important; align-items:center !important; justify-content:center !important; overflow: hidden !important; margin-bottom: 6px !important; background: transparent !important;}
.sa-rec-img { max-width: 100% !important; max-height: 100% !important; object-fit: contain !important; transition: transform 0.4s ease !important; }
.sa-rec-card:hover .sa-rec-img { transform: scale(1.1) !important; }
.sa-rec-title { font-size: 13px !important; font-weight: 600 !important; margin: 0 0 4px !important; color: #333 !important; line-height: 1.3 !important; display: -webkit-box !important; -webkit-line-clamp: 2 !important; -webkit-box-orient: vertical !important; overflow: hidden !important; }
.sa-rec-price { font-size: 14px !important; font-weight: 700 !important; color: #f97316 !important; margin-bottom: 8px !important; display: flex !important; align-items: center !important; justify-content: center !important; text-align: center !important; }

.sa-rec-btn-wrap { display: flex !important; justify-content: center !important; width: 100% !important; height: 30px !important; align-items: center !important; box-sizing: border-box !important; }

.sa-rec-add-btn { padding: 4px 8px !important; font-size: 12px !important; height: 100% !important; width: 100% !important; justify-content: center !important; border-radius: 50px !important; background: rgba(249, 115, 22, 0.1) !important; color: #f97316 !important; border: 1px solid rgba(249, 115, 22, 0.3) !important; box-shadow:none !important; white-space: nowrap !important; overflow: hidden !important; text-overflow: ellipsis !important; box-sizing: border-box !important; margin: 0 !important; }
.sa-rec-add-btn span { white-space: nowrap !important; }
.sa-rec-add-btn svg { stroke: #f97316 !important; width: 10px !important; height: 10px !important; flex-shrink: 0 !important; }
.sa-rec-add-btn:not(.added-to-cart):hover { background: rgba(249, 115, 22, 0.2) !important; transform: translateY(-2px) !important; }
.sa-rec-add-btn:active { transform: scale(0.92) translateY(0) !important; }

.sa-rec-card .sa-qty-ctrl { height: 100% !important; padding: 2px !important; border-radius: 50px !important; width: 100% !important; justify-content: space-between !important; box-sizing: border-box !important; margin: 0 !important; }
.sa-rec-card .sa-qty-btn { width: 24px !important; height: 24px !important; font-size: 15px !important; }
.sa-rec-card .sa-qty-val { font-size: 14px !important; }

/* ==========================================
   7. FORM INPUTS & DELIVERY OPTIONS
   ========================================== */
.sa-input-group { margin-bottom: 8px !important; display: block !important; width: 100% !important; }
.sa-input-group:last-child { margin-bottom: 0 !important; }
.sa-input { width: 100% !important; padding: 12px 15px !important; border: 1px solid #eaeaea !important; border-radius: 8px !important; font-size: 15px !important; background: #fafafa !important; font-family: inherit !important; transition: 0.3s !important; box-sizing: border-box !important; color: #333 !important; }
.sa-input:focus { outline: none !important; border-color: #f97316 !important; background: #fff !important; box-shadow: 0 0 0 3px rgba(249,115,22,0.1) !important; }
textarea.sa-input { resize: none !important; height: 55px !important; min-height: 55px !important; }

.sa-delivery-box { border: 1px solid #ddd !important; padding: 12px 15px !important; border-radius: 8px !important; margin-bottom: 8px !important; cursor: pointer !important; display: flex !important; align-items: center !important; transition: all 0.3s ease !important; background: #fff !important; width: 100% !important; box-sizing: border-box !important; }
.sa-delivery-box:hover { border-color: #cbd5e1 !important; transform: translateY(-1px) !important; }
.sa-delivery-box:active { transform: scale(0.98) !important; }
.sa-delivery-box.active { border-color: #f97316 !important; background: #fffaf5 !important; transform: translateY(-2px) !important; box-shadow: 0 4px 10px rgba(249,115,22,0.1) !important; }
.sa-delivery-icon { width: 32px !important; height: 32px !important; border-radius: 50% !important; background: #f97316 !important; display: flex !important; align-items: center !important; justify-content: center !important; margin-right: 12px !important; transition: all 0.3s ease !important; flex-shrink: 0 !important;}
.sa-delivery-box:not(.active) .sa-delivery-icon { background: #f1f1f1 !important; }
.sa-delivery-box.active .sa-delivery-icon svg { fill: #fff !important; }
.sa-delivery-box:not(.active) .sa-delivery-icon svg { fill: #666 !important; }
.sa-delivery-icon svg { width: 16px !important; display: block !important; }

.sa-delivery-text { flex: 1 !important; display: block !important; text-align: left !important;}
.sa-delivery-text strong { display: block !important; font-size: 15px !important; color: #f97316 !important; font-weight: 600 !important; margin-bottom: 2px !important; }
.sa-delivery-box:not(.active) .sa-delivery-text strong { color: #333 !important; }
.sa-delivery-text span { font-size: 13px !important; color: #666 !important; display: inline-block !important; line-height: 1.4 !important; }
.sa-radio-input { display: none !important; }

/* ==========================================
   8. ORDER SUMMARY TABLE
   ========================================== */
.sa-table { width: 100% !important; border-collapse: collapse !important; border: none !important; margin: 0 !important; background: transparent !important;}
.sa-table tbody, .sa-table thead, .sa-table tfoot, .sa-table tr { border: none !important; background: transparent !important; outline: none !important; box-shadow: none !important; }
.sa-table th, .sa-table td { padding: 10px 0 !important; text-align: left !important; background: transparent !important; border-left: none !important; border-right: none !important;}
.sa-table th { font-weight: 700 !important; font-size: 15px !important; border-bottom: 1px dashed #ddd !important; border-top: none !important; color: #111 !important;}
.sa-table td { font-size: 14px !important; color: #444 !important; border-bottom: 1px dashed #ddd !important; transition: all 0.3s ease !important; border-top: none !important;}
.sa-table td:last-child, .sa-table th:last-child { text-align: right !important; }
.sa-prod-td { display: flex !important; align-items: center !important; gap: 8px !important; animation: saFadeInUp 0.4s ease forwards !important; border-bottom: none !important;}
.sa-remove-item { cursor: pointer !important; color: #bbb !important; font-size: 16px !important; margin-right: 5px !important; font-weight: bold !important; transition:0.3s !important; padding:4px !important; line-height:1 !important;}
.sa-remove-item:hover { color: #ef4444 !important; transform: scale(1.2) !important; }
.sa-prod-td img { width: 35px !important; height: 35px !important; border-radius: 6px !important; object-fit: cover !important; display: block !important; }
.sa-total-row td { border-bottom: none !important; font-size: 18px !important; font-weight: 700 !important; color: #000 !important; padding-top: 15px !important; }
#sa-dynamic-cart-items tr td { padding: 8px 0 !important; }

/* ==========================================
   8.1. ORDER SUMMARY WIDGET (Thank You Page)
   ========================================== */
.elementor-widget-salesassi_order_summary table,
.elementor-widget-salesassi_order_summary tbody,
.elementor-widget-salesassi_order_summary tr,
.elementor-widget-salesassi_order_summary th,
.elementor-widget-salesassi_order_summary td {
    border-left: none !important;
    border-right: none !important;
    border-top: none !important;
    background: transparent !important;
    box-shadow: none !important;
}
.elementor-widget-salesassi_order_summary table {
    border-collapse: collapse !important;
    width: 100% !important;
}

/* ==========================================
   9. MODALS (Variation, Fraud & Gallery)
   ========================================== */
.sa-var-modal { display: none !important; position: fixed !important; top: 0 !important; left: 0 !important; width: 100vw !important; height: 100vh !important; background: rgba(15,23,42,0.6) !important; z-index: 999999 !important; align-items: center !important; justify-content: center !important; backdrop-filter: blur(3px) !important; opacity:0 !important; transition: opacity 0.3s ease !important; margin: 0 !important; padding: 0 !important;}
.sa-var-modal.sa-show { display: flex !important; opacity: 1 !important; }
.sa-var-box { background: #fff !important; width: 420px !important; max-width: 90% !important; border-radius: 12px !important; padding: 20px !important; box-shadow: 0 20px 40px rgba(0,0,0,0.2) !important; transform: scale(0.95) !important; transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275) !important; box-sizing: border-box !important;}
.sa-var-modal.sa-show .sa-var-box { transform: scale(1) !important; }
.sa-var-title { margin:0 0 15px !important; font-size:18px !important; color:#0f172a !important; font-weight:700 !important; border-bottom:1px solid #e2e8f0 !important; padding-bottom:10px !important; display:flex !important; justify-content:space-between !important; align-items:center !important; }
.sa-var-list { display: flex !important; flex-direction: column !important; gap: 8px !important; max-height: 60vh !important; overflow-y: auto !important; padding-right: 5px !important; }
.sa-var-item { display: flex !important; align-items: center !important; justify-content: space-between !important; padding: 8px 12px !important; border: 1px solid #cbd5e1 !important; border-radius: 8px !important; background: #fff !important; width: 100% !important; box-sizing: border-box !important;}
.sa-var-item-left { display: flex !important; align-items: center !important; flex: 1 !important; }
.sa-var-item img { width: 35px !important; height: 35px !important; border-radius: 4px !important; margin-right: 12px !important; object-fit: cover !important; display: block !important;}
.sa-var-item-info { flex: 1 !important; text-align: left !important;}
.sa-var-item-name { font-size: 15px !important; font-weight: 600 !important; color: #334155 !important; margin:0 0 2px !important; line-height: 1.2 !important; display: block !important;}
.sa-var-item-price { font-size: 15px !important; font-weight: 700 !important; color: #f97316 !important; margin:0 !important; display: block !important;}
.sa-var-item-actions { display: flex !important; align-items: center !important; flex-shrink: 0 !important; margin-left: 10px !important; }

/* Image Gallery Trigger */
.sa-gallery-trigger { cursor: zoom-in !important; }

/* Gallery Popup Modal */
.sa-gallery-modal { display: none !important; position: fixed !important; top: 0 !important; left: 0 !important; width: 100vw !important; height: 100vh !important; background: rgba(0,0,0,0.92) !important; z-index: 9999999 !important; align-items: center !important; justify-content: center !important; flex-direction: column !important; opacity: 0 !important; transition: opacity 0.3s ease !important; margin:0 !important; padding:0 !important;}
.sa-gallery-modal.sa-show { display: flex !important; opacity: 1 !important; }
.sa-gallery-close { position: absolute !important; top: 20px !important; right: 25px !important; color: #fff !important; font-size: 40px !important; cursor: pointer !important; z-index: 2 !important; line-height: 1 !important; text-shadow: 0 2px 4px rgba(0,0,0,0.5) !important;}
.sa-gallery-content { position: relative !important; max-width: 90% !important; max-height: 75vh !important; display: flex !important; align-items: center !important; justify-content: center !important; }
.sa-gallery-img { max-width: 100% !important; max-height: 75vh !important; object-fit: contain !important; border-radius: 8px !important; transition: opacity 0.2s ease !important; box-shadow: 0 10px 30px rgba(0,0,0,0.5) !important; }
.sa-gallery-nav { display: flex !important; align-items: center !important; justify-content: center !important; gap: 20px !important; margin-top: 25px !important; }
.sa-gallery-btn { background: rgba(255,255,255,0.15) !important; color: #fff !important; border: 1px solid rgba(255,255,255,0.3) !important; width: 45px !important; height: 45px !important; border-radius: 50% !important; font-size: 20px !important; cursor: pointer !important; display: flex !important; align-items: center !important; justify-content: center !important; transition: 0.3s !important; padding:0 !important;}
.sa-gallery-btn:hover { background: #f97316 !important; border-color: #f97316 !important; }

/* ==========================================
   10. MOBILE SPECIFIC (BULLETPROOF VW)
   ========================================== */
.sa-mobile-sticky { display: none !important; }

@media (max-width: 768px) {
    /* Added 2.5% padding to left and right in mobile view */
    .sa-pc-wrapper, .sa-wrapper { padding: 0 2.5% !important; margin: 0 auto !important; box-sizing: border-box !important; overflow-x: hidden !important; display: block !important;}
    .elementor-widget-salesassi_checkout, .elementor-widget-salesassi_products_display { margin: 0 !important; padding: 0 !important; }

    .sa-row { display: block !important; width: 100% !important; margin: 0 !important; padding: 0 !important; }
    .sa-col-left { padding: 10px 8px 15px 8px !important; display: block !important; width: 100% !important; max-width: 100% !important; border: none !important; border-radius: 0 !important; margin: 0 !important; box-sizing: border-box !important; box-shadow: none !important; }
    .sa-col-right { padding: 15px 8px 20px 8px !important; display: block !important; width: 100% !important; max-width: 100% !important; border-left: none !important; border-right: none !important; border-radius: 0 !important; margin: 0 0 70px 0 !important; box-sizing: border-box !important; box-shadow: none !important; border-top: 8px solid #f1f5f9 !important; background: #fff !important; }
    
    .sa-pc-grid { gap: 10px !important; }
    
    .sa-pc-card-hz { padding: 8px !important; margin-bottom: 8px !important; gap: 8px !important; }
    /* OVERRIDE MOBILE PADDING FOR VERTICAL LAYOUT TO KEEP FULL BLEED */
    .sa-card-layout-vertical.sa-pc-card-hz { padding: 0 !important; gap: 0 !important; }
    .sa-card-layout-vertical .sa-pc-card-hz-content { padding: 12px 10px 15px 10px !important; }
    
    .sa-card-layout-horizontal { padding: 10px !important; gap: 10px !important; }
    .sa-card-layout-horizontal .sa-pc-card-hz-img-wrap { width: 60px !important; height: 60px !important; }

    .sa-pc-single-layout .sa-pc-card-hz { flex-wrap: wrap !important; padding: 10px !important; gap: 10px !important; }
    .sa-pc-card-hz-img { width: 60px !important; height: 60px !important; }
    .sa-pc-card-hz-title { font-size: 15px !important; margin-bottom: 2px !important; }
    .sa-pc-card-hz-price { font-size: 15px !important; }
    .sa-pc-single-layout .sa-pc-btn-wrap { width: auto !important; margin-left: auto !important; flex: 0 0 auto !important; }
    
    /* Mobile Buttons */
    .sa-pc-btn { padding: 6px 12px !important; font-size: 14px !important; border-radius: 50px !important; }
    .sa-card-layout-vertical .sa-pc-btn { width: 85% !important; max-width: 250px !important; margin: 0 auto !important; }
    
    .sa-qty-ctrl { padding: 3px !important; width: 90px !important; border-radius: 50px !important; }
    .sa-card-layout-vertical .sa-qty-ctrl { width: 85% !important; max-width: 250px !important; margin: 0 auto !important; }
    .sa-qty-btn { width: 26px !important; height: 26px !important; font-size: 18px !important; }
    
    .sa-hero-var-grid.layout-vertical { gap: 6px !important; margin-top: 8px !important;}
    .sa-hero-var-grid.layout-vertical .sa-hero-var-box { min-width: 60px !important; max-width: 85px !important; }
    .sa-hero-var-grid.layout-vertical .sa-hero-var-title { font-size: 12px !important; padding: 4px 2px !important; }
    .sa-hero-var-grid.layout-vertical .sa-hero-var-box.no-img .sa-hero-var-title { padding: 8px 4px !important; font-size: 13px !important; }
    
    .sa-hero-var-grid.layout-horizontal { grid-template-columns: repeat(3, 1fr) !important; gap: 4px !important; margin-top: 8px !important;}
    .sa-hero-var-grid.layout-horizontal .sa-hero-var-box { padding: 4px !important; flex-direction: row !important; align-items: center !important; justify-content: flex-start !important; }
    .sa-hero-var-grid.layout-horizontal .sa-hero-var-img { width: 20px !important; height: 20px !important; margin-right: 4px !important; margin-bottom: 0 !important; padding: 0 !important; border:none !important;}
    .sa-hero-var-grid.layout-horizontal .sa-hero-var-title { font-size: 12px !important; padding: 0 !important; text-align: left !important; line-height: 1.1 !important;}

    .sa-rec-grid { grid-template-columns: repeat(3, 1fr) !important; gap: 6px !important; margin-bottom: 10px !important; }
    .sa-rec-card { padding: 6px 4px !important; box-shadow: 0 1px 3px rgba(0,0,0,0.05) !important; margin-bottom: 0 !important;}
    .sa-rec-img-wrap { margin-bottom: 4px !important; }
    .sa-rec-title { font-size: 12px !important; margin-bottom: 3px !important; line-height: 1.1 !important; }
    .sa-rec-price { font-size: 13px !important; margin-bottom: 5px !important; }
    
    .sa-rec-btn-wrap { height: 28px !important; }
    .sa-rec-add-btn { padding: 2px 6px !important; font-size: 12px !important; }
    .sa-rec-card .sa-qty-btn { padding: 2px !important; font-size: 14px !important; width: 20px !important; height: 20px !important; }
    .sa-rec-card .sa-qty-val { padding: 0 2px !important; min-width: 12px !important; font-size: 13px !important; }
    
    .sa-btn-desktop { display: none !important; }
    .sa-mobile-sticky { display: flex !important; position: fixed !important; bottom: 0 !important; left: 0 !important; width: 100vw !important; max-width: 100vw !important; background: #fff !important; box-shadow: 0 -4px 20px rgba(0,0,0,0.08) !important; padding: 8px 12px !important; align-items: center !important; justify-content: space-between !important; z-index: 99999 !important; box-sizing: border-box !important; animation: saFadeInUp 0.5s ease !important; border-top-left-radius: 12px !important; border-top-right-radius: 12px !important;}
    .sa-mobile-price { font-size: 18px !important; font-weight: 700 !important; color: #2ed573 !important; display: flex !important; align-items: center !important; gap: 4px !important; }
    .sa-mobile-price span:first-child { font-size: 13px !important; }
    .sa-mobile-btn { background-color: #f97316 !important; color: #fff !important; padding: 10px 20px !important; border-radius: 50px !important; font-weight: 700 !important; border: none !important; font-size: 16px !important; display: flex !important; align-items: center !important; justify-content: center !important; gap: 4px !important; font-family: inherit !important; transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1) !important; box-shadow: none !important; white-space: nowrap !important; }
    .sa-mobile-btn:active { transform: scale(0.92) !important; box-shadow: 0 2px 5px rgba(249,115,22,0.2) !important; }
}