.img-category {
	text-align: center;
    border: 1px solid #dcebdd;
    /* background: linear-gradient(180deg, #f4fbf5 0%, #edf7ef 100%); */
	color: #0b0b0b;
    border-radius: 14px;
    overflow: hidden;
    padding-bottom: 10px;
    padding-top: 10px;
	transition: all 0.3s ease;
	/* or for specific properties: */
	/* transition: border 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease; */
    box-shadow: none;
}

.img-category:hover {
	border: 1px solid var(--accent-color);
    transform: translateY(-5px);
    box-shadow: 0 8px 18px rgba(20, 78, 38, 0.12);
}


.img-category:hover .img-sec, .img-category.hover-effect .img-sec {
	border: 0px solid var(--accent-color);
	-webkit-transition: all 0.3s ease-in-out;
	transition: all 0.3s ease-in-out;
}

.service-w-bg.tools-service {
    padding: 28px 0 8px;
   
}

.service-w-bg.tools-service-sober {
    padding: 36px 0 26px;
   
}

.tools-service-sober-row {
    row-gap: 28px;
}

.tools-service-sober-item {
    text-align: center;
}

.tools-service-sober-icon {
    width: 54px;
    height: 54px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(42, 128, 67, 0.12) 0%, rgba(42, 128, 67, 0.05) 100%);
    border: 1px solid #cfe1cf;
    margin-bottom: 20px;
}

.tools-service-sober-icon img {
    width: 68%;
    height: 68%;
    object-fit: contain;
    display: block;
    filter: brightness(0) saturate(100%) invert(32%) sepia(18%) saturate(1185%) hue-rotate(110deg) brightness(92%) contrast(91%);
}

.tools-service-sober-icon svg {
    width: 68%;
    height: 68%;
    display: block;
    color: #2a8043;
}

.tools-service-sober-icon svg path,
.tools-service-sober-icon svg ellipse,
.tools-service-sober-icon svg line,
.tools-service-sober-icon svg polyline {
    stroke: currentColor;
    fill: none;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.tools-service-sober-item h3 {
    margin: 0 0 12px;
    font-size: clamp(18px, 2.1vw, 26px);
    line-height: 1.15;
    color: #0e4a56;
    font-weight: 500;
}

.tools-service-sober-item p {
    margin: 0 auto;
    max-width: 280px;
    font-size: clamp(14px, 1.05vw, 20px);
    line-height: 1.45;
    color: #59625f;
}

.tools-service .service-grid-row {
    row-gap: 20px;
}

.tools-service .service-block {
    margin-bottom: 8px;
}

.tools-service .service-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    border: 1px solid #dce6dc;
    background: linear-gradient(180deg, #f8faf8 0%, #f2f5f2 100%);
    border-radius: 18px;
    padding: 22px 18px 18px;
    min-height: 220px;
    transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
}

.tools-service .service-card:hover {
    transform: translateY(-5px);
    border-color: #b9ceb9;
    box-shadow: 0 10px 24px rgba(33, 70, 40, 0.1);
}

.tools-service .service-icon-wrap {
    width: 64px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 16px;
    background: #ffffff;
    border: 1px solid #dce8dc;
    box-shadow: 0 4px 12px rgba(24, 49, 28, 0.08);
    margin-bottom: 14px;
}

.tools-service .service-icon-wrap img {
    width: 66%;
    height: 66%;
    object-fit: contain;
    display: block;
    filter: brightness(0) saturate(100%) invert(32%) sepia(18%) saturate(1185%) hue-rotate(110deg) brightness(92%) contrast(91%);
}

.tools-service .service-card .media-body {
    text-align: center;
}

.tools-service .service-card h4 {
    margin: 0;
    font-size: 20px;
    font-size: clamp(24px, 2.2vw, 34px);
    line-height: 1.15;
    letter-spacing: 0.2px;
    color: #0d4f4e;
    font-weight: 500;
    margin-bottom: 10px;
}

.tools-service .service-card p {
    margin: 0;
    font-size: 20px;
    font-size: clamp(16px, 1.15vw, 22px);
    line-height: 1.45;
    color: #54605a;
    font-weight: 400;
}

/* .img-category:hover {
	border-bottom: 3px solid #3594bf;
} */

.img-category .img-sec {
    border-radius: 0;
    margin: 0;
    width: 100%;
    height: 150px;
	padding: 12px 12px 6px;
    background: linear-gradient(180deg, rgba(42, 128, 67, 0.13) 0%, rgba(42, 128, 67, 0.04) 100%);
	border: 0px solid var(--theme-color);
	-webkit-transition: all 0.3s ease-in-out;
	transition: all 0.3s ease-in-out;
    border-top-left-radius: 14px;
    border-top-right-radius: 14px;
    overflow: hidden;
}

.img-category .img-sec img {
    width: 100%;
    height: calc(100% - 6px);
    padding-top: 6px;
    object-fit: contain;
    object-position: center top;
    display: block;
    box-sizing: border-box;
    filter: drop-shadow(0 8px 10px rgba(0, 0, 0, 0.08));
}

.img-category h4 {
    text-transform: capitalize;
    margin-top: 10px;
    padding: 0 12px;
    color: #000;
    font-weight: 500;
    line-height: 1.3;
    display: inline-block;
    position: relative;
    z-index: 1;
    font-size: 12px;
}

.title2 .title-inner2:after {
    position: absolute;
    height: 2px;
    width: 100%;
    background-color: var(--theme-color);
    opacity: 0.4;
    content: "";
    left: 0;
    right: 0;
    margin: 0 auto;
    bottom: -15px;
    z-index: -1;
}

.title2 .title-inner2 {
    margin-bottom: 50px;
    position: relative;
    display: inline-block;
    padding: 0 25px;
    margin-top: 30px;
    text-transform: capitalize;
    font-size: 24px;
    font-weight: 600;
    color: var(--accent-color);
}

.slick-prev {
    right: 5%;
    top: -12%;
    left: unset;
}

.slick-next {
    right: 0;
    top: -12%;
}

.slick-prev,
.slick-next {
    background: #3594bf;
    border-radius: 100%;
    padding: 5px !important;
    width: 40px !important;
    height: 40px !important;
    z-index: 9999;
}

/* Reusable card surface rules for any Farm-Fresh/related slider section */
.best-product-slider-section .tallbros-grid-v2-card {
    background: #ffffff !important;
    border: 1px solid color-mix(in srgb, var(--theme-color) 10%, #ffffff);
    box-shadow: 0 10px 24px -18px rgba(0, 0, 0, 0.35);
}

.best-product-slider-section .tallbros-grid-v2-card .product-title,
.best-product-slider-section .tallbros-grid-v2-card .tallbros-grid-v2-meta {
    background: #ffffff;
}

.best-product-slider-section .tallbros-grid-v2-card .tallbros-grid-v2-price {
    color: var(--accent-color) !important;
}

.slick-prev:hover,
.slick-prev:focus,
.slick-next:hover,
.slick-next:focus {
    outline: none;
    background: #3594bf;
    color: transparent;
}

/* ---------- Shared Tallbros grid_v2 card styles (home/product/collection) ---------- */
.material-symbols-outlined {
    font-variation-settings: 'FILL' 0, 'wght' 300, 'GRAD' 0, 'opsz' 24;
}

.tallbros-grid-v2-card {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    height: 100%;
    background: #ffffff;
    border: 1px solid color-mix(in srgb, var(--theme-color) 10%, #ffffff);
    border-radius: 12px;
    box-shadow: 0 10px 24px -18px rgba(0, 0, 0, 0.35);
    overflow: visible;
}

.tallbros-grid-v2-card > .aspect-square {
    margin: 12px 12px 10px;
    border-radius: 10px;
    overflow: hidden;
    background: color-mix(in srgb, var(--theme-color) 6%, #f7f7f7);
}

.tallbros-grid-v2-card .wishlist-icon {
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 3;
    background: rgba(255, 255, 255, 0.88);
    padding: 7px;
    border-radius: 999px;
    color: color-mix(in srgb, var(--theme-color) 75%, #1f1f1f) !important;
    text-decoration: none;
    border: 1px solid color-mix(in srgb, var(--theme-color) 14%, #ffffff);
    transition: color 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.tallbros-grid-v2-card .wishlist-icon:hover,
.tallbros-grid-v2-card .wishlist-icon:focus {
    color: var(--accent-color) !important;
    border-color: color-mix(in srgb, var(--accent-color) 45%, #ffffff);
    background: #ffffff;
}

.tallbros-grid-v2-card .wishlist-icon.active,
.tallbros-grid-v2-card .wishlist-icon.active i {
    color: var(--accent-color) !important;
}

.tallbros-grid-v2-card .product-title,
.tallbros-grid-v2-card .tallbros-grid-v2-meta {
    padding-left: 12px;
    padding-right: 12px;
}

.tallbros-grid-v2-card .product-title h3 {
    margin-bottom: 8px;
    color: var(--theme-color);
    font-size: 1rem;
    line-height: 1.28;
}

.tallbros-grid-v2-card .tallbros-grid-v2-meta {
    margin-top: auto;
    padding-bottom: 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.tallbros-grid-v2-card .tallbros-grid-v2-price {
    color: var(--accent-color) !important;
    font-weight: 700;
    font-size: 1.3rem;
    line-height: 1.2;
}

.tallbros-grid-v2-card .tallbros-grid-v2-price .line-through {
    text-decoration: line-through;
        font-size: 1rem;
    font-weight: 500;

}

.tallbros-grid-v2-card .tallbros-grid-v2-add-btn {
    width: 40px;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    border-radius: 999px;
    background-color: var(--accent-color) !important;
    color: #ffffff !important;
    border: 1px solid color-mix(in srgb, var(--accent-color) 82%, #ffffff);
    position: relative;
    z-index: 2;
}

.tallbros-grid-v2-card .tallbros-grid-v2-add-btn:hover {
    background-color: var(--accent-color) !important;
    border-color: var(--accent-color);
}

/* Prevent tooltip clipping inside collection/listing grids */
.product-wrapper-grid,
.product-wrapper-grid .row,
.product-wrapper-grid .col-grid-box {
    overflow: visible;
}

/* Collection mobile filter drawer should sit above sticky header */
@media (max-width: 991.98px) {
    .collection-filter {
        z-index: 3100 !important;
    }

    .collection-mobile-back {
        justify-content: flex-end;
        min-height: 52px;
    }

    .collection-mobile-back .filter-back {
        display: none !important;
    }

    .collection-mobile-back i {
        font-size: 22px;
        line-height: 1;
    }

    /* Collection listing cards: make image panel shorter on mobile */
    .product-wrapper-grid .tallbros-grid-v2-card > .aspect-square {
        aspect-ratio: 6 / 5;
        margin: 10px 10px 8px;
    }
}

/* Keep header above all card overlays */
#main-header,
.sticky-header {
    position: relative;
    z-index: 2000;
}

/* Keep cart drawer above sticky header */
.offcanvas-backdrop.show {
    z-index: 2090;
}

#cartOffcanvas.offcanvas {
    z-index: 2100;
}

/* Collection listing - Load More button */
.product-pagination #load-more-btn,
.collection-load-more-btn {
    background: var(--accent-color) !important;
    border: 1px solid color-mix(in srgb, var(--accent-color) 82%, #ffffff) !important;
    color: #ffffff !important;
    border-radius: 999px;
    min-height: 44px;
    padding: 10px 24px;
    font-weight: 600;
    letter-spacing: 0.01em;
    box-shadow: 0 8px 18px -12px color-mix(in srgb, var(--accent-color) 65%, #000000);
}

.product-pagination #load-more-btn:hover,
.product-pagination #load-more-btn:focus,
.collection-load-more-btn:hover,
.collection-load-more-btn:focus {
    background: var(--theme-color) !important;
    border-color: var(--theme-color) !important;
    color: #ffffff !important;
}

.product-pagination #load-more-btn .ring-animation,
.collection-load-more-btn .ring-animation {
    display: inline-flex;
    align-items: center;
}

@media (max-width: 575.98px) {
    .product-pagination #load-more-btn,
    .collection-load-more-btn {
        width: 100%;
        border-radius: 12px;
        justify-content: center;
    }
}



/* Extra small devices (phones, 600px and down) */
@media only screen and (max-width: 600px) {

    .service-w-bg.tools-service-sober {
        padding: 24px 0 14px;
    }

    .tools-service-sober-row {
        display: flex;
        flex-wrap: nowrap;
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        gap: 12px;
        padding: 0 6px 8px;
        margin: 0;
        scroll-snap-type: x proximity;
    }

    .tools-service-sober-row::-webkit-scrollbar {
        height: 5px;
    }

    .tools-service-sober-row::-webkit-scrollbar-thumb {
        background: rgba(42, 128, 67, 0.28);
        border-radius: 10px;
    }

    .tools-service-sober-item {
        flex: 0 0 calc((100% - 12px) / 2);
        max-width: calc((100% - 12px) / 2);
        scroll-snap-align: start;
    }

    .tools-service-sober-icon {
        width: 54px;
        height: 54px;
        border-radius: 14px;
        margin-bottom: 12px;
    }

    .tools-service-sober-icon img {
        width: 66%;
        height: 66%;
    }

    .tools-service-sober-icon svg {
        width: 66%;
        height: 66%;
    }

    .tools-service-sober-item h3 {
        margin-bottom: 8px;
    }

    .tools-service-sober-item p {
        max-width: 220px;
        line-height: 1.35;
    }

    .service-w-bg.tools-service {
        padding: 20px 0 2px;
    }

    .tools-service .service-grid-row {
        row-gap: 14px;
    }

    .tools-service .service-card {
        min-height: 180px;
        padding: 16px 12px 14px;
        border-radius: 14px;
    }

    .tools-service .service-icon-wrap {
        width: 52px;
        height: 52px;
        border-radius: 13px;
        margin-bottom: 10px;
    }

    .tools-service .service-icon-wrap img {
        width: 64%;
        height: 64%;
    }

    .tools-service .service-card h4 {
        margin-bottom: 8px;
    }

    .tools-service .service-card p {
        line-height: 1.35;
    }


    .title2 .title-inner2 {
        margin-bottom: 45px;
        font-size: 18px;
    }

    .img-category .img-sec {
        height: 124px;
        padding: 10px 10px 4px;
    }

    .img-category h4 {
        text-transform: capitalize;
        margin-top: 12px;
        color: #000;
        font-weight: 300;
        line-height: 1.3;
        display: inline-block;
        position: relative;
        z-index: 1;
        font-size: 12px;
    }

    
.tallbros-grid-v2-card .tallbros-grid-v2-price .line-through {
    font-size: .7rem;

}
.tallbros-grid-v2-card .tallbros-grid-v2-price {
    font-size: 1rem;
}

.tallbros-grid-v2-card .tallbros-grid-v2-add-btn {
    width: 25px;
    height: 25px;
}


}