:root {
    --wa-primary: #2C3E36;
    --wa-secondary: #B5C9BE;
    --wa-bg: #F9F7F5;
    --wa-text: #4A4A4A;
    --wa-whatsapp: #25D366;
    --wa-white: #ffffff;
    --wa-border: #E8E8E8;
    --wa-radius-card: 16px;
    --wa-font: 'Assistant', sans-serif;
    --wa-sale: #E53935;
}

/* ULTIMATE WRAPPER FIX - FORCES ELEMENTOR TO OBEY 100% WIDTH */
.wa-store-wrapper * { box-sizing: border-box !important; max-width: none !important; outline: none !important; }
.wa-store-wrapper { 
    font-family: var(--wa-font) !important; 
    color: var(--wa-text) !important; 
    margin: 0 auto !important; 
    padding: 20px 0 !important;
    direction: rtl !important; 
    width: 100% !important; 
    max-width: 100% !important; 
    display: block !important; 
    clear: both !important;
}

body.wa-modal-open { overflow: hidden !important; touch-action: none !important; }

/* INSTAGRAM HIGHLIGHTS */
.wa-ig-highlights-container { width: 100% !important; max-width: 100% !important; margin: 0 auto 20px auto !important; padding: 5px 0 15px 0 !important; border-bottom: 1px solid rgba(0,0,0,0.05) !important; display: block !important; overflow: hidden !important; }
.wa-ig-highlights { display: flex !important; gap: 15px !important; overflow-x: auto !important; padding: 5px !important; scrollbar-width: none !important; -ms-overflow-style: none !important; width: 100% !important; max-width: 100% !important; justify-content: flex-start !important; }
.wa-ig-highlights::-webkit-scrollbar { display: none !important; }
.wa-ig-item { display: flex !important; flex-direction: column !important; align-items: center !important; gap: 6px !important; cursor: pointer !important; flex-shrink: 0 !important; width: 70px !important; transition: transform 0.2s !important; margin: 0 !important; padding: 0 !important; background: transparent !important; border: none !important; }
.wa-ig-item:active { transform: scale(0.95) !important; }
.wa-ig-img-wrap { width: 65px !important; height: 65px !important; min-width: 65px !important; min-height: 65px !important; max-width: 65px !important; max-height: 65px !important; border-radius: 50% !important; padding: 2px !important; background: #e0e0e0 !important; display: flex !important; align-items: center !important; justify-content: center !important; margin: 0 !important; border: none !important; }
.wa-ig-item.active .wa-ig-img-wrap { background: linear-gradient(45deg, var(--wa-primary), var(--wa-secondary)) !important; }
.wa-ig-img-wrap img { width: 100% !important; height: 100% !important; border-radius: 50% !important; object-fit: cover !important; border: 2px solid white !important; display: block !important; margin: 0 !important; padding: 0 !important; background: #fff !important; }
.wa-ig-name { font-size: 11px !important; font-weight: 400 !important; text-align: center !important; color: var(--wa-text) !important; line-height: 1.2 !important; margin: 0 !important; white-space: nowrap !important; overflow: hidden !important; text-overflow: ellipsis !important; width: 100% !important; }
.wa-ig-item.active .wa-ig-name { font-weight: 700 !important; color: var(--wa-primary) !important; }

/* SEARCH BAR */
.wa-search-container { width: 100% !important; margin: 0 auto 30px auto !important; padding: 0 !important; display: block !important; }
.wa-search-wrapper { position: relative !important; display: flex !important; align-items: center !important; width: 100% !important; max-width: 400px !important; margin: 0 auto !important; }
.wa-search-icon { position: absolute !important; right: 15px !important; color: #a0a0a0 !important; pointer-events: none !important; display: block !important; }
#wa-search-input { width: 100% !important; padding: 12px 15px 12px 45px !important; padding-right: 45px !important; border-radius: 50px !important; border: 1px solid var(--wa-border) !important; background: var(--wa-white) !important; font-family: var(--wa-font) !important; font-size: 15px !important; color: var(--wa-text) !important; outline: none !important; transition: all 0.3s ease !important; box-shadow: 0 4px 15px rgba(0,0,0,0.02) !important; display: block !important; }
#wa-search-input:focus { border-color: var(--wa-secondary) !important; box-shadow: 0 4px 20px rgba(181, 201, 190, 0.2) !important; }
#wa-search-input::placeholder { color: #a0a0a0 !important; font-weight: 400 !important; }
.wa-no-results { width: 100% !important; text-align: center !important; padding: 40px 20px !important; color: #888 !important; font-size: 16px !important; display: none !important; }

/* PRODUCT GRID */
.wa-store-grid { display: grid !important; gap: 20px !important; width: 100% !important; max-width: 100% !important; margin: 0 !important; padding: 0 !important; justify-content: start !important; align-items: stretch !important; }
.wa-product-card { background: var(--wa-white) !important; border-radius: var(--wa-radius-card) !important; overflow: hidden !important; border: 1px solid var(--wa-border) !important; display: flex !important; flex-direction: column !important; justify-content: flex-start !important; margin: 0 !important; padding: 0 !important; width: 100% !important; height: 100% !important; transition: opacity 0.3s ease !important; }
.wa-product-img-container { width: 100% !important; aspect-ratio: 1 / 1 !important; position: relative !important; overflow: hidden !important; background: #f5f5f5 !important; flex-shrink: 0 !important;}
.wa-product-img { width: 100% !important; height: 100% !important; object-fit: cover !important; object-position: center !important; display: block !important; margin: 0 !important; padding: 0 !important; }

@media (min-width: 551px) {
    .wa-store-grid.layout-desktop-auto { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important; }
    .wa-store-grid.layout-desktop-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
    .wa-store-grid.layout-desktop-grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)) !important; }
    .wa-store-grid.layout-desktop-list { grid-template-columns: 1fr !important; }
    .wa-store-grid.layout-desktop-list .wa-product-card { flex-direction: row !important; height: auto !important; align-items: stretch !important; }
    .wa-store-grid.layout-desktop-list .wa-product-img-container { width: 220px !important; min-height: 220px !important; flex-shrink: 0 !important; aspect-ratio: auto !important;}
    .wa-store-grid.layout-desktop-list .wa-product-info { align-items: flex-start !important; justify-content: center !important; text-align: right !important; }
    .wa-store-grid.layout-desktop-list .wa-product-title, .wa-store-grid.layout-desktop-list .wa-product-price, .wa-store-grid.layout-desktop-list .wa-product-short-desc { text-align: right !important; justify-content: flex-start !important; }
    .wa-store-grid.layout-desktop-list .wa-btn-open-modal { margin: 15px 0 0 0 !important; max-width: 250px !important; }
}

@media (max-width: 550px) {
    .wa-store-grid.layout-mobile-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 12px !important; }
    .wa-store-grid.layout-mobile-grid-1 { grid-template-columns: minmax(0, 1fr) !important; gap: 15px !important; }
    .wa-store-grid.layout-mobile-list { grid-template-columns: minmax(0, 1fr) !important; gap: 12px !important; }
    .wa-store-grid.layout-mobile-list .wa-product-card { flex-direction: row !important; height: auto !important; align-items: stretch !important; padding: 0 !important; }
    .wa-store-grid.layout-mobile-list .wa-product-img-container { width: 130px !important; min-height: 130px !important; flex-shrink: 0 !important; aspect-ratio: auto !important; }
    .wa-store-grid.layout-mobile-list .wa-product-info { padding: 12px !important; text-align: right !important; align-items: flex-start !important; justify-content: center !important; }
    .wa-store-grid.layout-mobile-list .wa-product-title { font-size: 15px !important; text-align: right !important; margin-bottom: 2px !important; }
    .wa-store-grid.layout-mobile-list .wa-product-price { font-size: 14px !important; text-align: right !important; justify-content: flex-start !important; margin-bottom: 5px !important;}
    .wa-store-grid.layout-mobile-list .wa-product-short-desc { display: none !important; }
    
    .wa-store-grid.layout-mobile-list .wa-btn-open-modal { 
        margin: auto 0 0 0 !important; 
        width: auto !important; 
        max-width: none !important;
        height: 36px !important;
        min-height: 36px !important;
        max-height: 36px !important;
        padding: 0 15px !important;
        font-size: 13px !important;
    }
}

/* BADGES & INFO */
.wa-out-of-stock-badge { position: absolute !important; top: 10px !important; left: 10px !important; background: rgba(255,255,255,0.95) !important; color: #d32f2f !important; padding: 4px 10px !important; border-radius: 50px !important; font-size: 11px !important; font-weight: bold !important; line-height: 1 !important; z-index: 10 !important; box-shadow: 0 2px 5px rgba(0,0,0,0.1) !important;}
.wa-hot-badge { position: absolute !important; top: 10px !important; right: 10px !important; background: linear-gradient(135deg, #FF416C 0%, #FF4B2B 100%) !important; color: white !important; padding: 4px 10px !important; border-radius: 50px !important; font-size: 11px !important; font-weight: bold !important; line-height: 1 !important; z-index: 10 !important; box-shadow: 0 2px 8px rgba(255, 65, 108, 0.4) !important;}

.wa-product-info { padding: 15px !important; display: flex !important; flex-direction: column !important; flex-grow: 1 !important; background: #fff !important; text-align: center !important; align-items: center !important; justify-content: flex-start !important; }
.wa-product-title { font-family: 'Assistant', sans-serif !important; font-size: 16px !important; color: var(--wa-primary) !important; margin: 0 0 5px 0 !important; font-weight: 700 !important; line-height: 1.2 !important; text-align: center !important; width: 100% !important;}
.wa-product-price { font-size: 15px !important; font-weight: 700 !important; color: var(--wa-primary) !important; margin-bottom: 12px !important; text-align: center !important; width: 100% !important; display: flex !important; justify-content: center !important; align-items: center !important; gap: 8px !important; flex-wrap: wrap !important;}
.wa-product-short-desc { font-size: 12px !important; color: #666 !important; margin-bottom: 15px !important; line-height: 1.4 !important; display: -webkit-box !important; -webkit-line-clamp: 2 !important; -webkit-box-orient: vertical !important; overflow: hidden !important; text-overflow: ellipsis !important; text-align: center !important; font-family: var(--wa-font) !important; width: 100% !important;}

.wa-sale-price { color: var(--wa-sale) !important; font-size: 16px !important; font-weight: 800 !important; }
.wa-regular-price-del { color: #aaa !important; font-size: 13px !important; text-decoration: line-through !important; font-weight: 400 !important; }

/* -------------------------------------------------------------------
   SOLID BUTTON DESIGN - STRICT HEIGHT 
-------------------------------------------------------------------- */
.wa-btn-open-modal { 
    margin: auto auto 0 auto !important; 
    width: 100% !important; 
    max-width: 220px !important; 
    height: 44px !important; 
    min-height: 44px !important;
    max-height: 44px !important;
    flex: 0 0 auto !important; 
    background: var(--wa-primary) !important; 
    color: var(--wa-white) !important; 
    border: none !important; 
    padding: 0 15px !important; 
    border-radius: 8px !important; 
    font-size: 15px !important; 
    font-weight: 700 !important; 
    cursor: pointer !important; 
    display: flex !important; 
    align-items: center !important;
    justify-content: center !important;
    font-family: var(--wa-font) !important; 
    transition: all 0.2s ease !important; 
    box-sizing: border-box !important;
    line-height: 1 !important;
}
.wa-btn-open-modal:hover:not(:disabled) { background: #1a2720 !important; transform: translateY(-2px) !important; }
.wa-btn-open-modal:active:not(:disabled) { transform: translateY(0) scale(0.98) !important; }
.wa-btn-open-modal:disabled { opacity: 0.5 !important; cursor: not-allowed !important; background: #ccc !important; color: #666 !important; }


/* MODAL & MULTI VARIATIONS */
.wa-modal { position: fixed !important; inset: 0 !important; z-index: 999999 !important; display: flex !important; align-items: center !important; justify-content: center !important; opacity: 0; pointer-events: none; transition: opacity 0.3s ease !important; }
.wa-modal.open { opacity: 1 !important; pointer-events: auto !important; }
.wa-modal-overlay { position: absolute !important; inset: 0 !important; background: rgba(0, 0, 0, 0.6) !important; backdrop-filter: blur(2px) !important; cursor: pointer !important;}
.wa-modal-content { background: var(--wa-white) !important; width: 90% !important; max-width: 800px !important; max-height: 85vh !important; border-radius: var(--wa-radius-card) !important; position: relative !important; z-index: 1 !important; overflow-y: auto !important; box-shadow: 0 25px 50px rgba(0,0,0,0.2) !important; transform: translateY(20px) !important; transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important; padding: 0 !important; margin: 0 !important; border: none !important; }
.wa-modal.open .wa-modal-content { transform: translateY(0) !important; }
.wa-modal-close { position: absolute !important; top: 15px !important; right: 15px !important; background: rgba(255,255,255,0.9) !important; border: none !important; width: 35px !important; height: 35px !important; border-radius: 50% !important; cursor: pointer !important; display: flex !important; align-items: center !important; justify-content: center !important; z-index: 20 !important; color: #333 !important; padding: 0 !important; box-shadow: 0 2px 10px rgba(0,0,0,0.1) !important;}
.wa-modal-close svg { width: 18px !important; height: 18px !important; }
.wa-modal-grid { display: grid !important; grid-template-columns: 1fr 1.1fr !important; gap: 0 !important; margin: 0 !important; padding: 0 !important; width: 100% !important; height: 100% !important;}

.wa-modal-image-col { padding: 25px !important; background: #fcfcfc !important; border-left: 1px solid #f0f0f0 !important; display: flex !important; flex-direction: column !important; margin: 0 !important; }
.wa-m-main-img-wrapper { width: 100% !important; aspect-ratio: 1/1 !important; border-radius: 12px !important; overflow: hidden !important; background: #fff !important; display: block !important; margin: 0 !important; padding: 0 !important; box-shadow: 0 2px 8px rgba(0,0,0,0.05) !important;}
.wa-m-main-img-wrapper img { width: 100% !important; height: 100% !important; object-fit: cover !important; transition: opacity 0.2s ease !important; display: block !important; margin: 0 !important; padding: 0 !important; }
.wa-m-gallery { display: flex !important; gap: 10px !important; margin-top: 15px !important; overflow-x: auto !important; padding-bottom: 5px !important; scrollbar-width: none !important; }
.wa-m-gallery::-webkit-scrollbar { display: none !important; }
.wa-m-thumb { width: 60px !important; height: 60px !important; min-width: 60px !important; min-height: 60px !important; border-radius: 8px !important; object-fit: cover !important; cursor: pointer !important; border: 2px solid transparent !important; flex-shrink: 0 !important; margin: 0 !important; padding: 0 !important; display: block !important; opacity: 0.6 !important; }
.wa-m-thumb.active { border-color: var(--wa-primary) !important; opacity: 1 !important; }

.wa-modal-info-col { padding: 30px !important; display: flex !important; flex-direction: column !important; margin: 0 !important; background: #fff !important; text-align: right !important; }
.wa-modal-info-col h2 { font-family: 'Assistant', sans-serif !important; font-size: 24px !important; color: var(--wa-primary) !important; margin: 0 0 5px 0 !important; line-height: 1.2 !important; font-weight: 700 !important; }
.wa-m-price { font-size: 20px !important; font-weight: 700 !important; color: var(--wa-primary) !important; margin-bottom: 15px !important; }
.wa-m-desc { color: #555 !important; font-size: 14px !important; line-height: 1.5 !important; margin-bottom: 25px !important; }
.wa-m-controls-box { background: transparent !important; padding: 0 !important; border-radius: 0 !important; margin-bottom: 25px !important; display: flex !important; flex-direction: column !important; gap: 15px !important; border: none !important; }
.wa-v-group { display: flex !important; align-items: center !important; justify-content: space-between !important; margin: 0 !important; padding: 15px !important; background: #f9f9f9 !important; border-radius: 12px !important; border: 1px solid #eee !important;}
.wa-v-group label { font-size: 13px !important; font-weight: 600 !important; color: var(--wa-text) !important; margin: 0 !important; }

/* MULTI VARIATION LIST */
.wa-v-list-wrapper { display: flex !important; flex-direction: column !important; gap: 8px !important; max-height: 200px !important; overflow-y: auto !important; padding-right: 5px !important; }
.wa-v-list-wrapper::-webkit-scrollbar { width: 4px !important; }
.wa-v-list-wrapper::-webkit-scrollbar-thumb { background: #ddd !important; border-radius: 4px !important; }

.wa-var-list-item { display: flex !important; justify-content: space-between !important; align-items: center !important; background: #f9f9f9 !important; padding: 10px 15px !important; border-radius: 8px !important; border: 1px solid #eee !important; transition: border 0.2s; }
.wa-var-list-item:hover { border-color: #ddd !important; }
.wa-var-list-info { display: flex !important; flex-direction: column !important; text-align: right !important; flex: 1 !important; padding-left: 10px !important;}
.wa-var-list-info strong { font-size: 14px !important; color: var(--wa-primary) !important; line-height: 1.2 !important; margin-bottom: 2px !important; font-weight: 700 !important; }
.wa-var-list-info small { font-size: 13px !important; color: #666 !important; font-weight: 500 !important;}

/* Quantity Buttons */
.wa-qty-selector { display: flex !important; align-items: center !important; background: #fff !important; border: 1px solid #ddd !important; border-radius: 6px !important; overflow: hidden !important; margin: 0 !important; padding: 0 !important; flex-shrink: 0 !important; }
.wa-qty-btn { background: #fafafa !important; border: none !important; width: 34px !important; height: 34px !important; font-size: 18px !important; cursor: pointer !important; color: var(--wa-text) !important; display: flex !important; align-items: center !important; justify-content: center !important; padding: 0 !important; margin: 0 !important; }
.wa-qty-btn:active { background: #eee !important; }
.wa-qty-selector input { width: 40px !important; text-align: center !important; border: none !important; font-size: 14px !important; font-weight: bold !important; outline: none !important; pointer-events: none !important; background: transparent !important; color: #333 !important; padding: 0 !important; margin: 0 !important; border-left: 1px solid #eee !important; border-right: 1px solid #eee !important; }

/* Totals and Order Button */
.wa-m-total-row { display: flex !important; justify-content: space-between !important; align-items: center !important; margin-bottom: 15px !important; padding-top: 15px !important; border-top: 1px solid #eee !important; }
.wa-m-total-row span { color: #666 !important; font-size: 14px !important;}
.wa-m-total-row strong { color: var(--wa-primary) !important; font-size: 22px !important; font-weight: 700 !important; }
.wa-btn-order { background: var(--wa-whatsapp) !important; color: white !important; border: none !important; width: 100% !important; padding: 14px !important; border-radius: 12px !important; font-size: 16px !important; font-weight: 700 !important; cursor: pointer !important; display: flex !important; align-items: center !important; justify-content: center !important; gap: 8px !important; font-family: var(--wa-font) !important; line-height: 1 !important; margin: 0 !important; }
.wa-btn-order svg { width: 20px !important; height: 20px !important; display: block !important; margin: 0 !important; }
.wa-btn-order:active { transform: scale(0.98) !important; background: #20bd5a !important; }

@media (max-width: 768px) {
    .wa-modal { align-items: flex-end !important; }
    .wa-modal-content { width: 100% !important; max-width: 100% !important; height: 90vh !important; max-height: 90vh !important; border-radius: 24px 24px 0 0 !important; transform: translateY(100%) !important; }
    .wa-modal-grid { grid-template-columns: 1fr !important; display: flex !important; flex-direction: column !important; height: 100% !important; overflow-y: auto !important; }
    .wa-modal-image-col { padding: 0 !important; border: none !important; background: transparent !important; flex-shrink: 0 !important;}
    .wa-m-main-img-wrapper { border-radius: 24px 24px 0 0 !important; aspect-ratio: 1/1 !important; max-height: 45vh !important; border-bottom: 1px solid #f0f0f0 !important;}
    .wa-m-gallery { padding: 10px 15px !important; margin: 0 !important; }
    .wa-modal-info-col { padding: 20px !important; flex-grow: 1 !important; padding-bottom: 40px !important;}
    .wa-modal-close { top: 10px !important; right: 10px !important; background: rgba(255,255,255,0.95) !important; backdrop-filter: blur(5px) !important; box-shadow: 0 4px 15px rgba(0,0,0,0.15) !important;}
    .wa-v-group { flex-direction: column !important; align-items: flex-start !important; gap: 10px !important;}
    .wa-v-group .wa-qty-selector { width: 100% !important; justify-content: space-between !important; }
    .wa-v-group .wa-qty-selector input { flex: 1 !important; }
}