.elementor-widget-container .eael-protected-content-message{font-family:var( --e-global-typography-secondary-font-family ), Sans-serif;font-weight:var( --e-global-typography-secondary-font-weight );}.elementor-widget-container .protected-content-error-msg{font-family:var( --e-global-typography-secondary-font-family ), Sans-serif;font-weight:var( --e-global-typography-secondary-font-weight );}.elementor-846 .elementor-element.elementor-element-5487b79{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}.elementor-846 .elementor-element.elementor-element-9906a28{--display:flex;}.elementor-846 .elementor-element.elementor-element-9906a28.e-con{--flex-grow:0;--flex-shrink:0;}.elementor-widget-shortcode .eael-protected-content-message{font-family:var( --e-global-typography-secondary-font-family ), Sans-serif;font-weight:var( --e-global-typography-secondary-font-weight );}.elementor-widget-shortcode .protected-content-error-msg{font-family:var( --e-global-typography-secondary-font-family ), Sans-serif;font-weight:var( --e-global-typography-secondary-font-weight );}.elementor-846 .elementor-element.elementor-element-f7aa491{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}@media(max-width:767px){.elementor-846 .elementor-element.elementor-element-9906a28{--width:81px;}.elementor-846 .elementor-element.elementor-element-f7aa491{--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}}/* Start custom CSS for shortcode, class: .elementor-element-af977eb *//* =========================
   CATEGORY NAV (WRAPPER)
========================= */

.elementor-846 .elementor-element.elementor-element-af977eb .cat-nav {
    display: flex;
    flex-direction: column;
    gap: 10px;
}


/* =========================
   CATEGORY ITEM (PREMIUM CARD 🔥)
========================= */

.elementor-846 .elementor-element.elementor-element-af977eb .cat-item {
    width: 100%;
    position: relative;

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    padding: 10px 6px;
    border-radius: 16px;

    background: transparent;

    text-decoration: none;
    color: #333;

    transition: all 0.25s ease;

    cursor: pointer;
}


/* =========================
   ICON
========================= */

.elementor-846 .elementor-element.elementor-element-af977eb .cat-item img {
    width: 40px;
    height: 40px;
    border-radius: 12px;

    margin-bottom: 6px;

    object-fit: cover;
}


/* =========================
   TEXT
========================= */

.elementor-846 .elementor-element.elementor-element-af977eb .cat-item span {
    font-size: 11px;
    font-weight: 500;
    text-align: center;
    line-height: 1.2;
}


/* =========================
   HOVER EFFECT 🔥
========================= */

.elementor-846 .elementor-element.elementor-element-af977eb .cat-item:hover {
    background: #fff3e8;
    transform: translateY(-2px);
}


/* =========================
   ACTIVE STATE 🔥
========================= */

.elementor-846 .elementor-element.elementor-element-af977eb .cat-item.active {
    background: #fc8105;
    color: #fff;
}


/* LEFT ORANGE INDICATOR */
.elementor-846 .elementor-element.elementor-element-af977eb .cat-item.active::before {
    content: "";
    position: absolute;
    left: -6px;
    top: 15%;
    height: 70%;
    width: 4px;
    background: #fc8105;
    border-radius: 4px;
}


/* ICON SCALE ON ACTIVE */
.elementor-846 .elementor-element.elementor-element-af977eb .cat-item.active img {
    transform: scale(1.05);
}


/* =========================
   MOBILE OPTIMIZATION 📱
========================= */

@media (max-width: 768px) {

    .elementor-846 .elementor-element.elementor-element-af977eb .cat-nav {
        gap: 8px;
    }

    .elementor-846 .elementor-element.elementor-element-af977eb .cat-item {
        padding: 8px 4px;
        border-radius: 14px;
    }

    .elementor-846 .elementor-element.elementor-element-af977eb .cat-item img {
        width: 34px;
        height: 34px;
        border-radius: 10px;
    }

    .elementor-846 .elementor-element.elementor-element-af977eb .cat-item span {
        font-size: 10px;
    }

}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-9906a28 *//* =========================
   SIDEBAR CONTAINER (FINAL 🔥)
========================= */

.elementor-846 .elementor-element.elementor-element-9906a28 {
    width: 90px;
    min-width: 90px;
    max-width: 90px;
    flex: 0 0 90px;

    background: #f6f6f6;
    padding: 10px 6px;

    /* 🔥 IMPORTANT FIX */
    position: sticky;
    top: 80px; /* header ke niche */

    height: calc(100vh - 130px); 
    /* 80 header + 50 bottom nav approx */

    overflow-y: auto;

    border-right: 1px solid #eee;

    z-index: 20;

    scrollbar-width: none;
}

/* Hide scrollbar */
.elementor-846 .elementor-element.elementor-element-9906a28::-webkit-scrollbar {
    display: none;
}
@media (max-width: 768px) {

    .elementor-846 .elementor-element.elementor-element-9906a28 {
        width: 75px;
        min-width: 75px;
        max-width: 75px;
        flex: 0 0 75px;

        padding: 8px 4px;

        top: 70px;

        height: calc(100vh - 120px); 
        /* mobile header + bottom nav */

    }

}/* End custom CSS */
/* Start custom CSS for shortcode, class: .elementor-element-37e4b2a *//* =========================
   PRODUCT GRID
========================= */

.elementor-846 .elementor-element.elementor-element-37e4b2a .custom-products-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}


/* =========================
   PRODUCT CARD
========================= */

.elementor-846 .elementor-element.elementor-element-37e4b2a .product-card {
    width: 100%;
    background: #fff;
    border-radius: 18px;
    padding: 10px;
    border: 1px solid #f2f2f2;
    box-shadow: 0 3px 10px rgba(0,0,0,0.04);
    transition: all 0.25s ease;
    position: relative;
    overflow: hidden;
}

.elementor-846 .elementor-element.elementor-element-37e4b2a .product-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 18px rgba(0,0,0,0.08);
}


/* =========================
   IMAGE
========================= */

.elementor-846 .elementor-element.elementor-element-37e4b2a .product-card .img {
    border-radius: 12px;
    overflow: hidden;
    background: #fafafa;
}

.elementor-846 .elementor-element.elementor-element-37e4b2a .product-card img {
    width: 100%;
    display: block;
    border-radius: 12px;
    aspect-ratio: 1/1;
    object-fit: contain;
}


/* =========================
   TITLE
========================= */

.elementor-846 .elementor-element.elementor-element-37e4b2a .product-card h3 {
    font-size: 13px;
    margin: 8px 0 4px;
    font-weight: 600;
    color: #1a1a1a;
    line-height: 1.3;

    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}


/* =========================
   PRICE
========================= */

.elementor-846 .elementor-element.elementor-element-37e4b2a .product-card .price {
    color: #fc8105;
    font-weight: 600;
    font-size: 13px;
}

.elementor-846 .elementor-element.elementor-element-37e4b2a .product-card .price del {
    color: #999;
    font-size: 11px;
    margin-left: 4px;
}


/* =========================
   DISCOUNT BADGE
========================= */

.elementor-846 .elementor-element.elementor-element-37e4b2a .discount-badge {
    position: absolute;
    top: 8px;
    left: 8px;

    background: #ff3e3e;
    color: #fff;

    padding: 3px 8px;
    font-size: 9px;

    border-radius: 20px;
    z-index: 2;
}


/* =========================
   QTY WRAPPER
========================= */

.elementor-846 .elementor-element.elementor-element-37e4b2a .qty-wrapper {
    position: absolute;
    top: 8px;
    right: 8px;
    z-index: 3;
}


/* =========================
   + BUTTON
========================= */

.elementor-846 .elementor-element.elementor-element-37e4b2a .qty-add {
    width: 28px;
    height: 28px;

    border-radius: 8px;
    border: 1.5px solid #fc8105;

    background: #fff;
    color: #fc8105;

    font-size: 14px;
    font-weight: 600;

    display: flex;
    align-items: center;
    justify-content: center;

    cursor: pointer;
}


/* =========================
   QTY BOX (PERFECT ALIGN 🔥)
========================= */

.elementor-846 .elementor-element.elementor-element-37e4b2a .qty-box {
    display: none;
}

.elementor-846 .elementor-element.elementor-element-37e4b2a .qty-wrapper.active .qty-add {
    display: none;
}

.elementor-846 .elementor-element.elementor-element-37e4b2a .qty-wrapper.active .qty-box {
    display: flex;
    align-items: center;
    justify-content: center; /* 🔥 center everything */

    width: 72px;
    height: 30px;

    background: #fff;
    border: 1.5px solid #fc8105;
    border-radius: 10px;

    padding: 0 8px; /* 🔥 equal spacing */

    box-shadow: 0 4px 12px rgba(0,0,0,0.10);
}


/* BUTTONS (EQUAL WIDTH) */
.elementor-846 .elementor-element.elementor-element-37e4b2a .qty-box button {
    border: none;
    background: none;
    color: #fc8105;

    font-size: 14px;
    font-weight: 600;

    cursor: pointer;

    width: 18px; /* 🔥 equal spacing fix */
    text-align: center;
}


/* COUNT PERFECT CENTER */
.elementor-846 .elementor-element.elementor-element-37e4b2a .qty-count {
    font-size: 13px;
    font-weight: 600;
    color: #000;

    min-width: 18px;
    text-align: center;
}


/* =========================
   TABLET
========================= */

@media (max-width: 1024px) {

    .elementor-846 .elementor-element.elementor-element-37e4b2a .custom-products-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 12px;
    }

}


/* =========================
   MOBILE 🔥 FINAL POLISH
========================= */

@media (max-width: 768px) {

    .elementor-846 .elementor-element.elementor-element-37e4b2a .custom-products-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .elementor-846 .elementor-element.elementor-element-37e4b2a .product-card {
        padding: 8px;
        border-radius: 14px;
    }

    .elementor-846 .elementor-element.elementor-element-37e4b2a .product-card h3 {
        font-size: 12px;
    }

    .elementor-846 .elementor-element.elementor-element-37e4b2a .product-card .price {
        font-size: 12px;
    }

    .elementor-846 .elementor-element.elementor-element-37e4b2a .qty-wrapper {
        top: 6px;
        right: 6px;
    }

    .elementor-846 .elementor-element.elementor-element-37e4b2a .qty-wrapper.active .qty-box {
        width: 66px;
        height: 28px;
        padding: 0 7px;
    }

    .elementor-846 .elementor-element.elementor-element-37e4b2a .qty-box button {
        width: 16px;
        font-size: 13px;
    }

    .elementor-846 .elementor-element.elementor-element-37e4b2a .qty-count {
        font-size: 12px;
        min-width: 16px;
    }

}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-f7aa491 *//* =========================
   PRODUCTS CONTAINER (FINAL 🔥)
========================= */

.elementor-846 .elementor-element.elementor-element-f7aa491 {
    flex: 1;

    height: calc(100vh - 130px); 
    /* header + filter adjust */

    overflow-y: auto;

    padding: 10px;

    -webkit-overflow-scrolling: touch;
}


/* =========================
   📱 MOBILE FIX (BOTTOM NAV SPACE)
========================= */

@media (max-width: 768px) {

    .elementor-846 .elementor-element.elementor-element-f7aa491 {
        height: calc(100vh - 120px);

        padding: 8px;

        padding-bottom: 100px; 
        /* 🔥 FIX: bottom nav overlap remove */
    }

}


/* =========================
   📱 TABLET (SAFE FIX)
========================= */

@media (max-width: 1024px) {

    .elementor-846 .elementor-element.elementor-element-f7aa491 {
        padding-bottom: 90px;
    }

}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-5487b79 *//* =========================
   🔥 MAIN FLEX APP LAYOUT
========================= */

.elementor-846 .elementor-element.elementor-element-5487b79 {
    display: flex;
    height: calc(100vh - 120px); /* 🔥 header + footer adjust */
    overflow: hidden;
}


/* =========================
   LEFT SIDEBAR (FIXED + SCROLL)
========================= */

.elementor-846 .elementor-element.elementor-element-5487b79 .category-sidebar {
    width: 85px;
    min-width: 85px;
    max-width: 85px;
    flex: 0 0 85px;

    height: 100%;
    overflow-y: auto;

    background: #f8f8f8;
    padding: 10px 5px;

    scrollbar-width: none;
}

.elementor-846 .elementor-element.elementor-element-5487b79 .category-sidebar::-webkit-scrollbar {
    display: none;
}


/* =========================
   CATEGORY NAV
========================= */

.elementor-846 .elementor-element.elementor-element-5487b79 .cat-nav {
    display: flex;
    flex-direction: column;
    gap: 10px;
}


/* CATEGORY ITEM */
.elementor-846 .elementor-element.elementor-element-5487b79 .cat-item {
    width: 100%;

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    padding: 10px 5px;
    border-radius: 12px;
    background: #fff;

    text-decoration: none;
    color: #333;

    transition: all 0.2s ease;
}


/* ICON */
.elementor-846 .elementor-element.elementor-element-5487b79 .cat-item img {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    margin-bottom: 5px;
}


/* TEXT */
.elementor-846 .elementor-element.elementor-element-5487b79 .cat-item span {
    font-size: 10px;
    text-align: center;
    line-height: 1.2;
}


/* HOVER */
.elementor-846 .elementor-element.elementor-element-5487b79 .cat-item:hover {
    background: #fff3e8;
}


/* ACTIVE */
.elementor-846 .elementor-element.elementor-element-5487b79 .cat-item.active {
    background: #fc8105;
    color: #fff;
    position: relative;
}

/* LEFT INDICATOR */
.elementor-846 .elementor-element.elementor-element-5487b79 .cat-item.active::before {
    content: "";
    position: absolute;
    left: -4px;
    top: 15%;
    height: 70%;
    width: 3px;
    background: #fc8105;
    border-radius: 3px;
}


/* =========================
   RIGHT PRODUCTS (ONLY SCROLL 🔥)
========================= */

.elementor-846 .elementor-element.elementor-element-5487b79 .archive-products {
    flex: 1;
    height: 100%;

    overflow-y: auto;
    padding: 10px;

    -webkit-overflow-scrolling: touch;
}


/* PRODUCT GRID */
.elementor-846 .elementor-element.elementor-element-5487b79 .archive-products .woocommerce ul.products {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
    margin: 0;
}


/* =========================
   TABLET
========================= */

@media (max-width: 1024px) {

    .elementor-846 .elementor-element.elementor-element-5487b79 {
        height: calc(100vh - 110px);
    }

    .elementor-846 .elementor-element.elementor-element-5487b79 .archive-products .woocommerce ul.products {
        grid-template-columns: repeat(3, 1fr);
    }
}


/* =========================
   MOBILE (APP STYLE 🔥)
========================= */

@media (max-width: 768px) {

    .elementor-846 .elementor-element.elementor-element-5487b79 {
        flex-direction: row !important;
        height: calc(100vh - 110px); /* 🔥 fix */
    }

    /* SIDEBAR */
    .elementor-846 .elementor-element.elementor-element-5487b79 .category-sidebar {
        width: 75px;
        min-width: 75px;
        max-width: 75px;
        padding: 8px 4px;
    }

    /* PRODUCTS */
    .elementor-846 .elementor-element.elementor-element-5487b79 .archive-products {
        padding: 8px;
    }

    /* GRID */
    .elementor-846 .elementor-element.elementor-element-5487b79 .archive-products .woocommerce ul.products {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
    }

    /* ICON */
    .elementor-846 .elementor-element.elementor-element-5487b79 .cat-item img {
        width: 34px;
        height: 34px;
    }

    /* TEXT */
    .elementor-846 .elementor-element.elementor-element-5487b79 .cat-item span {
        font-size: 9px;
    }
}/* End custom CSS */