/**
 * Custom CSS for Product Layout and Nutrition Card  
 */


.featured_image_section_product {
    -webkit-mask-image: radial-gradient(85% 200px at 50% 119%, transparent 99%, #000 100%);
}

a.filtered-class-term {
    color: #000 !important;
    font-size: 14px;
    text-align: center;
    margin: auto;
    display: block;
}

.single-product-terms a.filtered-class-term {
    color: #fff !important;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.product-card-image,
#collection-product-grid .elementor-post__thumbnail__link,
#content-attribute-product-grid .elementor-post__thumbnail__link {
    transition: transform 0.3s ease-out !important;

    &:hover {
        transform: scale(1.08) !important;
    }
}

@media (max-width: 767px) {
    .featured_image_section_product {
        -webkit-mask-image: radial-gradient(76% 74px at 50% 100%, transparent 99%, var(--term-color) 100%) !important;
        mask-image: radial-gradient(76% 74px at 50% 100%, transparent 99%, var(--term-color) 100%) !important;
        padding-bottom: 100px !important;
        height: auto !important;
        min-height: unset !important;
    }

    ul.standard-list-container.chapmans-checklist.plain li span {
        font-size: 14px !important;
    }
}

.nutri-table,
.nutri-table th,
.nutri-table td {
    border: none !important;
    border-collapse: collapse;
}

.nutri-table td,
.nutri-table th {
    border-bottom: 1px solid #000 !important;
    /* Adjust color to match image_857840.jpg */
    padding: 6px 0;
}

.calories-row th {
    border-top: 4px solid #000 !important;
    border-bottom: 1px solid #000 !important;
}

.nutri-table tr:last-child td {
    border-bottom: none !important;
}

ul.standard-list-container.chapmans-checklist.plain {
    padding-inline-start: 20px !important;

    li {
        gap: 0px !important;
        padding: 0px !important;
    }
}

ul.standard-list-container.chapmans-checklist.plain li span {
    font-size: inherit;
}

.chapmans-nutrition-box {
    max-width: 350px;
    /* Pink left border from image_85ce97.jpg */
    padding: 20px 15px;
    font-family: Arial, sans-serif;
}

.nutri-header h3 {
    font-weight: normal;
    font-size: 14px;
    margin: 0;
    display: flex;
    justify-content: space-between;
}

.serving-line {
    padding: 10px 0;
}

.nutri-table {
    width: 100%;
    border-collapse: collapse;
}

tr.calories-row .text-right {
    font-size: 14px;
    text-align: right;
}

/* Thick Black Bar for Calories */
.calories-row th {
    border-top: 4px solid #000;
    border-bottom: 1px solid #000;
    padding: 8px 0;
    text-align: left;
    font-size: 18px;
}

.nutri-table td {
    padding: 4px 0;
    border-bottom: 1px solid #000;
    font-size: 13px;
}

/* Bold Main Categories */
.row-main .label {
    font-weight: bold;
}


/* UPDATED: Indentation Logic for Sub-items and Minerals */
/* This handles Saturated, Sugars*/
.row-sub td:first-child {
    padding-left: 15px;
}


tr.row-main.sodium {
    border-bottom: 2px solid;
}

table.nutri-table td,
table.nutri-table tr {
    background-color: transparent !important;
}

tr.row-sub.saturated,
tr.row-sub.saturated td,
tr.row-sub.fibre,
tr.row-sub.fibre td,
tr.row-sub.sugars,
tr.row-sub.sugars td {
    border-color: transparent !important;
    background: transparent !important;
}

tr.row-main.sattrans,
tr.row-main.sugar.alcohols {
    display: none;
}

tr.row-sub.sugars td {
    border-bottom: 1px solid black !important;
}

/* Ensure sub-item labels are not bold to match image_85ce97.jpg */
.row-sub .label {
    font-weight: normal;
}

.text-right {
    text-align: right;
}

.nutri-footer {
    font-size: 11px;
    padding-top: 5px;
}

/** 
 * NEW: Ensure vertical lines from image_857823.jpg are stripped 
 * by forcing horizontal-only borders 
 */
.nutri-table td,
.nutri-table th {
    border-left: 0 !important;
    border-right: 0 !important;
}



@media (min-width: 767px) and (max-width: 1024px) {
    .elementor-post__thumbnail {
        margin: auto !important;
    }

    .featured_image_section_product {
        min-height: 600px !important;
        height: auto !important;
        -webkit-mask-image: radial-gradient(60% 60px at 50% 100%, transparent 99%, var(--term-color) 100%) !important;
        mask-image: radial-gradient(60% 60px at 50% 100%, transparent 99%, var(--term-color) 100%) !important;
    }

    .cm-lang {
        display: none !important;
    }

}



.elementor-posts .elementor-post__card .elementor-post__thumbnail img,
.elementor-post__thumbnail {
    max-width: 353px !important;
    max-height: 353px !important;
}

.elementor-posts .elementor-post__card .elementor-post__title,
.elementor-post__text {
    margin-top: 0px !important;
    margin-bottom: 0px !important;
    padding-top: 0px !important;
}


/* Base tab transition */
.chapmans-product-filter-tabs .e-n-tabs-heading .e-n-tab-title {
    transition:
        background-color 0.3s ease-in-out
}

/* Active tab */
.chapmans-product-filter-tabs .e-n-tabs-heading .e-n-tab-title[aria-selected='true'] {
    background-color: #e31c4b;
    color: #fff;
}

/* Inactive tab */
.chapmans-product-filter-tabs .e-n-tabs-heading .e-n-tab-title[aria-selected='false'] {
    background-color: transparent;
    color: #bcbcbc;
}

.chapmans-product-filter-tabs .e-n-tabs-heading .e-n-tab-title[aria-selected="false"]:hover {
    background: #4F4F54 !important;
}

.reset-form {
    transition:
        background-color 0.3s ease-out,
        color 0.3s ease-out,
        border-color 0.3s ease-out;
}

.chapmans-product-info-accordion .e-n-accordion-item-title,
.chapmans-recipe-info-accordion .e-n-accordion-item-title,
.elementor-widget-n-accordion .e-n-accordion-item-title {
    transition: color 0.3s ease;
    /* The smooth transition instruction */
}

/* 
* Style for grid/list view toggle in mobile 
* Only apply these layout overrides on Mobile 
*/
@media (max-width: 767px) {

    /* DEFAULT STATE: List / Condensed View */
    #product-grid,
    #content-attribute-product-grid {
        .e-loop-container {
            display: flex !important;
            flex-direction: column !important;
            gap: 20px !important;
        }

        .e-loop-item {
            display: flex !important;
            flex-direction: row !important;
            align-items: center;
            text-align: left;
            width: 100% !important;

            .elementor-widget-image {
                width: 140px !important;
                max-width: 40% !important;
                margin-bottom: 0 !important;
            }


        }
        a.filtered-class-term{
            text-align:left!important;
        }
    }

    /* MODIFIER STATE: Grid / Large View */
    #product-grid.list-view-active,
    #content-attribute-product-grid.list-view-active {
        .e-loop-container {
            display: grid !important;
            grid-template-columns: repeat(2, 1fr) !important;
            gap: 20px !important;
            text-align: center !important;
        }

        .e-loop-item {
            flex-direction: column !important;
            align-items: center !important;
            text-align: center !important;

            .e-con,
            .e-con-inner,
            .product-card-details * {
                width: 100% !important;
                align-items: center !important;
                justify-content: center !important;
                margin: auto !important;
                text-align: center !important;
            }

            .elementor-widget-image {
                width: 353px !important;
                max-width: 100% !important;
                margin-right: 0 !important;
                margin: auto !important;
                margin-bottom: 0px !important;
            }

            .elementor-widget-heading,
            .elementor-widget-text-editor {
                width: 100% !important;

                .elementor-widget-container {
                    text-align: center !important;
                }
            }
        }
    }

    .list-icon-trigger,
    .grid-icon-trigger {
        cursor: pointer;

        i,
        svg path {
            stroke: #A0A0A0;
        }

        /* Fixed syntax: removed semicolon before !important */
        &.is-active i,
        &.is-active svg path {
            stroke: var(--e-global-color-primary) !important;
        }
    }
}

/* Optional: Hide the toggle icons on Desktop if they are only for mobile */
@media (min-width: 768px) {

    .grid-icon-trigger,
    .list-icon-trigger {
        display: none !important;
    }
}