__  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ V /  | |__) | __ ___   ____ _| |_ ___  | (___ | |__   ___| | |
 | |\/| | '__|> <   |  ___/ '__| \ \ / / _` | __/ _ \  \___ \| '_ \ / _ \ | |
 | |  | | |_ / . \  | |   | |  | |\ V / (_| | ||  __/  ____) | | | |  __/ | |
 |_|  |_|_(_)_/ \_\ |_|   |_|  |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1
 if you need WebShell for Seo everyday contact me on Telegram
 Telegram Address : @jackleet
        
        
For_More_Tools: Telegram: @jackleet | Bulk Smtp support mail sender | Business Mail Collector | Mail Bouncer All Mail | Bulk Office Mail Validator | Html Letter private



Upload:

Command:

[email protected]: ~ $
/*
* Frontend Script for Elementor
*/
; (function ($)
{
    "use strict";

    var editMode = false;
    var isRellax = false;
    var currentDevice = '';

    var getElementSettings = function ($element, setting)
    {

        var elementSettings = {},
            modelCID = $element.data('model-cid');

        if (elementorFrontend.isEditMode() && modelCID)
        {
            var settings = elementorFrontend.config.elements.data[modelCID],
                type = settings.attributes.widgetType || settings.attributes.elType,
                settingsKeys = elementorFrontend.config.elements.keys[type];

            if (!settingsKeys)
            {
                settingsKeys = elementorFrontend.config.elements.keys[type] = [];

                jQuery.each(settings.controls, function (name, control)
                {
                    if (control.frontend_available)
                    {
                        settingsKeys.push(name);
                    }
                });
            }

            jQuery.each(settings.getActiveControls(), function (controlKey)
            {
                if (-1 !== settingsKeys.indexOf(controlKey))
                {
                    elementSettings[controlKey] = settings.attributes[controlKey];
                }
            });
        } else
        {
            elementSettings = $element.data('settings') || {};
        }

        return getItems(elementSettings, setting);

    };

    var getItems = function (items, itemKey)
    {
        if (itemKey)
        {
            var keyStack = itemKey.split('.'),
                currentKey = keyStack.splice(0, 1);

            if (!keyStack.length)
            {
                return items[currentKey];
            }

            if (!items[currentKey])
            {
                return;
            }

            return this.getItems(items[currentKey], keyStack.join('.'));
        }

        return items;
    };

    var getUniqueLoopScopeId = function ($scope)
    {
        if ($scope.data('jltma-template-widget-id'))
        {
            return $scope.data('jltma-template-widget-id');
        }
        return $scope.data('id');
    };

    // IntersectionObserver API integration
    function jltMAObserveTarget(target, callback) {
        var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
        var observer = new IntersectionObserver(function (entries, observer) {
            entries.forEach(function (entry) {
                if (entry.isIntersecting) {
                    callback(entry);
                }
            });
        }, options);
        observer.observe(target);
    }

    function sanitizeTooltipText(text) {
        const tempDiv = document.createElement('div');
        tempDiv.textContent = text;
        return tempDiv.innerHTML;
    }

    function stripTags(text) {
        return text.replace(/<\/?[^>]+(>|$)/g, '');
    }


    var Master_Addons = {

        animatedProgressbar: function (id, type, value, strokeColor, trailColor, strokeWidth, strokeTrailWidth)
        {
            var triggerClass = '.jltma-progress-bar-' + id;
            if ("line" == type)
            {
                new ldBar(triggerClass, {
                    "type": 'stroke',
                    "path": 'M0 10L100 10',
                    "aspect-ratio": 'none',
                    "stroke": strokeColor,
                    "stroke-trail": trailColor,
                    "stroke-width": strokeWidth,
                    "stroke-trail-width": strokeTrailWidth
                }).set(value);
            }
            if ("line-bubble" == type)
            {
                new ldBar(triggerClass, {
                    "type": 'stroke',
                    "path": 'M0 10L100 10',
                    "aspect-ratio": 'none',
                    "stroke": strokeColor,
                    "stroke-trail": trailColor,
                    "stroke-width": strokeWidth,
                    "stroke-trail-width": strokeTrailWidth
                }).set(value);
                $($('.jltma-progress-bar-' + id).find('.ldBar-label')).animate({
                    left: value + '%'
                }, 1000, 'swing');
            }
            if ("circle" == type)
            {
                new ldBar(triggerClass, {
                    "type": 'stroke',
                    "path": 'M50 10A40 40 0 0 1 50 90A40 40 0 0 1 50 10',
                    "stroke-dir": 'normal',
                    "stroke": strokeColor,
                    "stroke-trail": trailColor,
                    "stroke-width": strokeWidth,
                    "stroke-trail-width": strokeTrailWidth,
                }).set(value);
            }
            if ("fan" == type)
            {
                new ldBar(triggerClass, {
                    "type": 'stroke',
                    "path": 'M10 90A40 40 0 0 1 90 90',
                    "stroke": strokeColor,
                    "stroke-trail": trailColor,
                    "stroke-width": strokeWidth,
                    "stroke-trail-width": strokeTrailWidth,
                }).set(value);
            }
        },


        // Master Addons: Headlines

        MA_Animated_Headlines: function ($scope, $)
        {
            try
            {
                (function ($)
                {

                    Master_Addons.MA_Animated_Headlines.elementSettings = getElementSettings($scope);

                    /*----------- Animated Headlines --------------*/
                    //set animation timing
                    var $animatedHeaderContainer = $scope.find('.jltma-animated-headline').eq(0),

                        animationDelay = Master_Addons.MA_Animated_Headlines.elementSettings.anim_delay ? Master_Addons.MA_Animated_Headlines.elementSettings.anim_delay : 2500,

                        //loading bar effect
                        barAnimationDelay = Master_Addons.MA_Animated_Headlines.elementSettings.bar_anim_delay ? Master_Addons.MA_Animated_Headlines.elementSettings.bar_anim_delay : 3800,
                        barWaiting = barAnimationDelay - 3000, //3000 is the duration of the transition on the loading bar - set in the scss/css file

                        //letters effect
                        lettersDelay = Master_Addons.MA_Animated_Headlines.elementSettings.letters_anim_delay ? Master_Addons.MA_Animated_Headlines.elementSettings.letters_anim_delay : 50,

                        //type effect
                        typeLettersDelay = Master_Addons.MA_Animated_Headlines.elementSettings.type_anim_delay ? Master_Addons.MA_Animated_Headlines.elementSettings.type_anim_delay : 150,
                        selectionDuration = Master_Addons.MA_Animated_Headlines.elementSettings.type_selection_delay ? Master_Addons.MA_Animated_Headlines.elementSettings.type_selection_delay : 500,
                        typeAnimationDelay = selectionDuration + 800,

                        //clip effect
                        revealDuration = Master_Addons.MA_Animated_Headlines.elementSettings.clip_reveal_delay ? Master_Addons.MA_Animated_Headlines.elementSettings.clip_reveal_delay : 600,
                        revealAnimationDelay = Master_Addons.MA_Animated_Headlines.elementSettings.clip_anim_duration ? Master_Addons.MA_Animated_Headlines.elementSettings.clip_anim_duration : 1500;


                    Master_Addons.MA_Animated_Headlines.singleLetters = function ($words)
                    {
                        $words.each(function ()
                        {
                            var word = $(this),
                                letters = word.text().trim().split(''),
                                selected = word.hasClass('is-visible');

                            for (var i = 0; i < letters.length; i++)
                            {
                                if (word.parents('.rotate-2').length > 0) { letters[i] = '<em>' + letters[i] + '</em>'; }
                                letters[i] = (selected) ? '<i class="in">' + letters[i] + '</i>' : '<i>' + letters[i] + '</i>';
                            }
                            var newLetters = letters.join('');
                            word.html(newLetters).css('opacity', 1);
                        });
                    }

                    // function animateHeadline($headlines) {
                    Master_Addons.MA_Animated_Headlines.animateHeadline = function ($headlines)
                    {

                        var duration = animationDelay;

                        $headlines.each(function ()
                        {
                            var headline = $(this);

                            if (headline.hasClass('loading-bar'))
                            {
                                duration = barAnimationDelay;
                                setTimeout(function () { headline.find('.ma-el-words-wrapper').addClass('is-loading') }, barWaiting);
                            } else if (headline.hasClass('clip'))
                            {
                                var spanWrapper = headline.find('.ma-el-words-wrapper'),
                                    newWidth = spanWrapper.width() + 10
                                spanWrapper.css('width', newWidth);
                            } else if (!headline.hasClass('type'))
                            {
                                //assign to .ma-el-words-wrapper the width of its longest word
                                var words = headline.find('.ma-el-words-wrapper b'),
                                    width = 0;

                                words.each(function ()
                                {
                                    var wordWidth = $(this).width();
                                    if (wordWidth > width) width = wordWidth;
                                });
                                headline.find('.ma-el-words-wrapper').css('width', width);
                            };

                            //trigger animation
                            setTimeout(function () { Master_Addons.MA_Animated_Headlines.hideWord(headline.find('.is-visible').eq(0)) }, duration);
                        });
                    }


                    Master_Addons.MA_Animated_Headlines.hideWord = function ($word)
                    {

                        var nextWord = Master_Addons.MA_Animated_Headlines.takeNext($word);

                        if ($word.parents('.jltma-animated-headline').hasClass('type'))
                        {
                            var parentSpan = $word.parent('.jltma-words-wrapper');
                            parentSpan.addClass('selected').removeClass('waiting');
                            setTimeout(function ()
                            {
                                parentSpan.removeClass('selected');
                                $word.removeClass('is-visible').addClass('is-hidden').children('i').removeClass('in').addClass('out');
                            }, selectionDuration);
                            setTimeout(function () { Master_Addons.MA_Animated_Headlines.showWord(nextWord, typeLettersDelay) }, typeAnimationDelay);

                        } else if ($word.parents('.jltma-animated-headline').hasClass('letters'))
                        {
                            var bool = ($word.children('i').length >= nextWord.children('i').length) ? true : false;
                            Master_Addons.MA_Animated_Headlines.hideLetter($word.find('i').eq(0), $word, bool, lettersDelay);
                            Master_Addons.MA_Animated_Headlines.showLetter(nextWord.find('i').eq(0), nextWord, bool, lettersDelay);

                        } else if ($word.parents('.jltma-animated-headline').hasClass('clip'))
                        {
                            $word.parents('.jltma-words-wrapper').animate({ width: '2px' }, revealDuration, function ()
                            {
                                Master_Addons.MA_Animated_Headlines.switchWord($word, nextWord);
                                Master_Addons.MA_Animated_Headlines.showWord(nextWord);
                            });

                        } else if ($word.parents('.jltma-animated-headline').hasClass('loading-bar'))
                        {
                            $word.parents('.jltma-words-wrapper').removeClass('is-loading');
                            Master_Addons.MA_Animated_Headlines.switchWord($word, nextWord);
                            setTimeout(function () { Master_Addons.MA_Animated_Headlines.hideWord(nextWord) }, barAnimationDelay);
                            setTimeout(function () { $word.parents('.jltma-words-wrapper').addClass('is-loading') }, barWaiting);

                        } else
                        {
                            Master_Addons.MA_Animated_Headlines.switchWord($word, nextWord);
                            setTimeout(function () { Master_Addons.MA_Animated_Headlines.hideWord(nextWord) }, animationDelay);
                        }
                    }

                    Master_Addons.MA_Animated_Headlines.showWord = function ($word, $duration)
                    {
                        if ($word.parents('.jltma-animated-headline').hasClass('type'))
                        {
                            Master_Addons.MA_Animated_Headlines.showLetter($word.find('i').eq(0), $word, false, $duration);
                            $word.addClass('is-visible').removeClass('is-hidden');

                        } else if ($word.parents('.jltma-animated-headline').hasClass('clip'))
                        {
                            $word.parents('.jltma-words-wrapper').animate({ 'width': $word.width() + 10 }, revealDuration, function ()
                            {
                                setTimeout(function () { Master_Addons.MA_Animated_Headlines.hideWord($word) }, revealAnimationDelay);
                            });
                        }
                    }

                    Master_Addons.MA_Animated_Headlines.hideLetter = function ($letter, $word, $bool, $duration)
                    {
                        $letter.removeClass('in').addClass('out');

                        if (!$letter.is(':last-child'))
                        {
                            setTimeout(function () { Master_Addons.MA_Animated_Headlines.hideLetter($letter.next(), $word, $bool, $duration); }, $duration);
                        } else if ($bool)
                        {
                            setTimeout(function () { Master_Addons.MA_Animated_Headlines.hideWord(Master_Addons.MA_Animated_Headlines.takeNext($word)) }, animationDelay);
                        }

                        if ($letter.is(':last-child') && $('html').hasClass('no-csstransitions'))
                        {
                            var nextWord = Master_Addons.MA_Animated_Headlines.takeNext($word);
                            Master_Addons.MA_Animated_Headlines.switchWord($word, nextWord);
                        }
                    }

                    Master_Addons.MA_Animated_Headlines.showLetter = function ($letter, $word, $bool, $duration)
                    {
                        $letter.addClass('in').removeClass('out');

                        if (!$letter.is(':last-child'))
                        {
                            setTimeout(function () { Master_Addons.MA_Animated_Headlines.showLetter($letter.next(), $word, $bool, $duration); }, $duration);
                        } else
                        {
                            if ($word.parents('.jltma-animated-headline').hasClass('type')) { setTimeout(function () { $word.parents('.jltma-words-wrapper').addClass('waiting'); }, 200); }
                            if (!$bool) { setTimeout(function () { Master_Addons.MA_Animated_Headlines.hideWord($word) }, animationDelay) }
                        }
                    }

                    Master_Addons.MA_Animated_Headlines.takeNext = function ($word)
                    {
                        return (!$word.is(':last-child')) ? $word.next() : $word.parent().children().eq(0);
                    }

                    Master_Addons.MA_Animated_Headlines.takePrev = function ($word)
                    {
                        return (!$word.is(':first-child')) ? $word.prev() : $word.parent().children().last();
                    }

                    Master_Addons.MA_Animated_Headlines.switchWord = function ($oldWord, $newWord)
                    {
                        $oldWord.removeClass('is-visible').addClass('is-hidden');
                        $newWord.removeClass('is-hidden').addClass('is-visible');
                    }

                    Master_Addons.MA_Animated_Headlines.initHeadline = function ()
                    {
                        //insert <i> element for each letter of a changing word
                        Master_Addons.MA_Animated_Headlines.singleLetters($('.jltma-animated-headline.letters').find('b'));
                        //initialise headline animation
                        Master_Addons.MA_Animated_Headlines.animateHeadline($('.jltma-animated-headline'));
                    }

                    Master_Addons.MA_Animated_Headlines.initHeadline();

                })(jQuery);
            } catch (e)
            {
                //We can also throw from try block and catch it here
                // No Error Show
            }

        },

        // Master Addons: Accordion
        MA_Accordion: function ($scope, $)
        {

            var elementSettings = getElementSettings($scope),
                $accordionHeader = $scope.find(".jltma-accordion-header"),
                $accordionType = elementSettings.accordion_type,
                $accordionSpeed = elementSettings.toggle_speed ? elementSettings.toggle_speed : 300;

            // Open default actived tab
            $accordionHeader.each(function ()
            {
                if ($(this).hasClass("active-default"))
                {
                    $(this).addClass("show active");
                    $(this).next().slideDown($accordionSpeed);
                }
            });

            // Remove multiple click event for nested accordion
            $accordionHeader.unbind("click");

            $accordionHeader.click(function (e)
            {
                e.preventDefault();
                var $this = $(this);
                if ($accordionType === "accordion")
                {
                    if ($this.hasClass("show"))
                    {
                        $this.removeClass("show active");
                        $this.next().slideUp($accordionSpeed);
                    } else
                    {
                        $this.parent().parent().find(".jltma-accordion-header").removeClass("show active");
                        $this.parent().parent().find(".jltma-accordion-tab-content").slideUp($accordionSpeed);
                        $this.toggleClass("show active");
                        $this.next().slideDown($accordionSpeed);
                    }
                } else
                {
                    // Toggle type Accordion
                    if ($this.hasClass("show"))
                    {
                        $this.removeClass("show active");
                        $this.next().slideUp($accordionSpeed);
                    } else
                    {
                        $this.addClass("show active");
                        $this.next().slideDown($accordionSpeed);
                    }
                }
            });

        },



        // Master Addons: Tabs

        MA_Tabs: function ($scope, $)
        {

            try
            {
                (function ($)
                {

                    var $tabsWrapper = $scope.find('[data-tabs]'),
                        $tabEffect = $tabsWrapper.data('tab-effect');


                    $tabsWrapper.each(function ()
                    {
                        var tab = $(this);
                        var isTabActive = false;
                        var isContentActive = false;

                        tab.find('[data-tab]').each(function ()
                        {
                            if ($(this).hasClass('active'))
                            {
                                isTabActive = true;
                            }
                        });
                        tab.find('.jltma--advance-tab-content').each(function ()
                        {
                            if ($(this).hasClass('active'))
                            {
                                isContentActive = true;
                            }
                        });
                        if (!isContentActive)
                        {
                            tab.find('.jltma--advance-tab-content').eq(0).addClass('active');
                        }

                        if ($tabEffect == "hover")
                        {
                            tab.find('[data-tab]').hover(function ()
                            {
                                var $data_tab_id = $(this).data('tab-id');
                                $(this).siblings().removeClass('active');
                                $(this).addClass('active');
                                $(this).closest('[data-tabs]').find('.jltma--advance-tab-content').removeClass('active');
                                $('#' + $data_tab_id).addClass('active');
                            });
                        } else
                        {
                            tab.find('[data-tab]').click(function ()
                            {
                                var $data_tab_id = $(this).data('tab-id');
                                $(this).siblings().removeClass('active');
                                $(this).addClass('active');
                                $(this).closest('[data-tabs]').find('.jltma--advance-tab-content').removeClass('active');
                                $('#' + $data_tab_id).addClass('active');
                            });
                        }
                    });

                })(jQuery);
            } catch (e)
            {
                //We can also throw from try block and catch it here
                // No Error Show
            }


        },


        //Master Addons: Progressbar
        MA_ProgressBar: function ($scope, $)
        {
            var id = $scope.data('id'),
                $progressBarWrapper = $scope.find('.jltma-progress-bar-' + id),
                type = $progressBarWrapper.data('type'),
                value = $progressBarWrapper.data('progress-bar-value'),
                strokeWidth = $progressBarWrapper.data('progress-bar-stroke-width'),
                strokeTrailWidth = $progressBarWrapper.data('progress-bar-stroke-trail-width'),
                color = $progressBarWrapper.data('stroke-color'),
                trailColor = $progressBarWrapper.data('stroke-trail-color');

            // Clear existing ldBar SVG before re-initializing (for Elementor editor)
            $progressBarWrapper.find('svg').remove();
            $progressBarWrapper.find('.ldBar-label').remove();
            $progressBarWrapper.removeClass('ldBar');

            Master_Addons.animatedProgressbar(id, type, value, color, trailColor, strokeWidth, strokeTrailWidth);
        },

        //Master Addons: Image Hotspot
        MA_Image_Hotspot: function ($scope, $)
        {

            var elementSettings = getElementSettings($scope),
                $ma_hotspot = $scope.find('.jltma-hotspots-container');

            if (!$ma_hotspot.length)
            {
                return;
            }

            var $tooltip = $ma_hotspot.find('> .jltma-tooltip-item'),
                widgetID = $scope.data('id');

            $tooltip.each(function (index)
            {
                tippy(this, {
                    allowHTML: false,
                    theme: 'jltma-tippy-' + widgetID
                });
            });
        },


        //Master Addons: Pricing Table
        MA_Pricing_Table: function ($scope, $)
        {

            var $jltma_pricing_table = $scope.find('.jltma-price-table-details ul');

            if (!$jltma_pricing_table.length)
            {
                return;
            }

            var $tooltip = $jltma_pricing_table.find('> .jltma-tooltip-item'),
                widgetID = $scope.data('id');

            $tooltip.each(function (index)
            {
                tippy(this, {
                    allowHTML: false,
                    theme: 'jltma-pricing-table-tippy-' + widgetID,
                    appendTo: document.body,
                });
            });
        },



        // Dynamic Data Tables
        JLTMA_Data_Table: function ($scope, $)
        {
            var a = $scope.find(".jltma-data-table-container"),
                n = a.data("source"),
                r = a.data("sourcecsv");
            if (1 == a.data("buttons")) var l = "Bfrtip";
            else l = "frtip";
            if ("custom" == n)
            {
                var i = $scope.find("table thead tr th").length;
                $scope.find("table tbody tr").each(function ()
                {
                    if (e(this).find("td").length < i)
                    {
                        var t = i - e(this).find("td").length;
                        e(this).append(new Array(++t).join("<td></td>"))
                    }
                }), $scope.find(".jltma-data-table").DataTable({
                    dom: l,
                    paging: a.data("paging"),
                    pagingType: "numbers",
                    pageLength: a.data("pagelength"),
                    info: a.data("info"),
                    scrollX: !0,
                    searching: a.data("searching"),
                    ordering: a.data("ordering"),
                    buttons: [{
                        extend: "csvHtml5",
                        text: jltma_data_table_vars.csvHtml5
                    }, {
                        extend: "excelHtml5",
                        text: jltma_data_table_vars.excelHtml5
                    }, {
                        extend: "pdfHtml5",
                        text: jltma_data_table_vars.pdfHtml5
                    }, {
                        extend: "print",
                        text: jltma_data_table_vars.print
                    }],
                    language: {
                        lengthMenu: jltma_data_table_vars.lengthMenu,
                        zeroRecords: jltma_data_table_vars.zeroRecords,
                        info: jltma_data_table_vars.info,
                        infoEmpty: jltma_data_table_vars.infoEmpty,
                        infoFiltered: jltma_data_table_vars.infoFiltered,
                        search: "",
                        searchPlaceholder: jltma_data_table_vars.searchPlaceholder,
                        processing: jltma_data_table_vars.processing
                    }
                })
            } else if ("csv" == n)
            {
                ({
                    init: function (t)
                    {
                        var a = (t = t || {}).csv_path || "",
                            n = $scope.element || $("#table-container"),
                            r = $scope.csv_options || {},
                            l = $scope.datatables_options || {},
                            i = $scope.custom_formatting || [],
                            s = {};
                        $.each(i, function (e, t)
                        {
                            var a = t[0],
                                n = t[1];
                            s[a] = n
                        });
                        var d = $('<table class="jltma-data-table cell-border" style="width:100%;visibility:hidden;">');
                        n.empty().append(d), $.when($.get(a)).then(function (t)
                        {
                            for (var a = e.csv.toArrays(t, r), n = $("<thead></thead>"), i = a[0], o = $("<tr></tr>"), c = 0; c < i.length; c++) o.append($("<th></th>").text(i[c]));
                            n.append(o), d.append(n);
                            for (var m = $("<tbody></tbody>"), p = 1; p < a.length; p++)
                                for (var _ = $("<tr></tr>"), g = 0; g < a[p].length; g++)
                                {
                                    var b = $("<td></td>"),
                                        f = s[g];
                                    f ? b.html(f(a[p][g])) : b.text(a[p][g]), _.append(b), m.append(_)
                                }
                            d.append(m), d.DataTable(l)
                        })
                    }
                }).init({
                    csv_path: r,
                    element: a,
                    datatables_options: {
                        dom: l,
                        paging: a.data("paging"),
                        pagingType: "numbers",
                        pageLength: a.data("pagelength"),
                        info: a.data("info"),
                        scrollX: !0,
                        searching: a.data("searching"),
                        ordering: a.data("ordering"),
                        buttons: [{
                            extend: "csvHtml5",
                            text: jltma_data_table_vars.csvHtml5
                        }, {
                            extend: "excelHtml5",
                            text: jltma_data_table_vars.excelHtml5
                        }, {
                            extend: "pdfHtml5",
                            text: jltma_data_table_vars.pdfHtml5
                        }, {
                            extend: "print",
                            text: jltma_data_table_vars.print
                        }],
                        language: {
                            lengthMenu: jltma_data_table_vars.lengthMenu,
                            zeroRecords: jltma_data_table_vars.zeroRecords,
                            info: jltma_data_table_vars.info,
                            infoEmpty: jltma_data_table_vars.infoEmpty,
                            infoFiltered: jltma_data_table_vars.infoFiltered,
                            search: "",
                            searchPlaceholder: jltma_data_table_vars.searchPlaceholder,
                            processing: jltma_data_table_vars.processing
                        }
                    }
                })
            }
            $scope.find(".jltma-data-table").css("visibility", "visible");
        },

        // Dropdown Button
        JLTMA_Dropdown_Button: function ($scope, $)
        {

            $scope.find(".jltma-dropdown").hover(
                function ()
                {
                    $scope.find(".jltma-dd-menu").addClass("jltma-dd-menu-opened");
                },
                function ()
                {
                    $scope.find(".jltma-dd-menu").removeClass("jltma-dd-menu-opened");
                }
            );
        },

        JLTMA_WC_Add_To_Cart: function ($scope, $)
        {
            $(document).on('click', '.ajax_add_to_cart', function (e)
            {
                $(this).append('<i class="fa fa-spinner animated rotateIn infinite"></i>');
            });

            $(".jltma-wc-add-to-cart-btn-custom-js").each(function (index)
            {
                var custom_css = $(this).attr("data-jltma-wc-add-to-cart-btn-custom-css");
                $(custom_css).appendTo("head");
            });
        },

        /* Offcanvas Menu */
        MA_Offcanvas_Menu: function ($scope, $)
        {
            Master_Addons.MA_Offcanvas_Menu.elementSettings = $scope.data('settings');

            var widgetSelector = 'jltma-offcanvas-menu',
                getID = $scope.data('id'),
                getElementSettings = $scope.data('settings'),
                is_esc_close = getElementSettings.esc_close ? getElementSettings.esc_close : '',
                classes = {
                    widget: widgetSelector,
                    triggerButton: 'jltma-offcanvas__trigger',
                    offcanvasContent: 'jltma-offcanvas__content',
                    offcanvasContentBody: "".concat(widgetSelector, "__body"),
                    offcanvasContainer: "".concat(widgetSelector, "__container"),
                    offcanvasContainerOverlay: "".concat(widgetSelector, "__container__overlay"),
                    offcanvasWrapper: "".concat(widgetSelector, "__wrapper"),
                    closeButton: "".concat(widgetSelector, "__close"),
                    menuArrow: "".concat(widgetSelector, "__arrow"),
                    menuInner: "".concat(widgetSelector, "__menu-inner"),
                    itemHasChildrenLink: 'menu-item-has-children > a',
                    contentClassPart: 'jltma-offcanvas-content',
                    contentOpenClass: 'jltma-offcanvas-content-open',
                    customContainer: "".concat(widgetSelector, "__custom-container")
                },
                selectors = {
                    widget: ".".concat(classes.widget),
                    triggerButton: ".".concat(classes.triggerButton),
                    offcanvasContent: ".".concat(classes.offcanvasContent),
                    offcanvasContentBody: ".".concat(classes.offcanvasContentBody),
                    offcanvasContainer: ".".concat(classes.offcanvasContainer),
                    offcanvasContainerOverlay: ".".concat(classes.offcanvasContainerOverlay),
                    offcanvasWrapper: ".".concat(classes.offcanvasWrapper),
                    closeButton: ".".concat(classes.closeButton),
                    menuArrow: ".".concat(classes.menuArrow),
                    menuParent: ".".concat(classes.menuInner, " .").concat(classes.itemHasChildrenLink),
                    contentClassPart: ".".concat(classes.contentClassPart),
                    contentOpenClass: ".".concat(classes.contentOpenClass),
                    customContainer: ".".concat(classes.customContainer)
                },
                elements = {
                    $document: jQuery(document),
                    $html: jQuery(document).find('html'),
                    $body: jQuery(document).find('body'),
                    $outsideContainer: jQuery(selectors.offcanvasContainer),
                    $containerOverlay: jQuery(selectors.offcanvasContainerOverlay),
                    $triggerButton: $scope.find(selectors.triggerButton),
                    $offcanvasContent: $scope.find(selectors.offcanvasContent),
                    $offcanvasContentBody: $scope.find(selectors.offcanvasContentBody),
                    $offcanvasContainer: $scope.find(selectors.offcanvasContainer),
                    $offcanvasWrapper: $scope.find(selectors.offcanvasWrapper),
                    $closeButton: $scope.find(selectors.closeButton),
                    $menuParent: $scope.find(selectors.menuParent)
                };

            // resetCanvas
            Master_Addons.MA_Offcanvas_Menu.resetCanvas = function ()
            {
                var contentId = getID;
                elements.$html.addClass("".concat(classes.offcanvasContent, "-widget"));

                if (!elements.$outsideContainer.length)
                {
                    elements.$body.append("<div class=\"".concat(classes.offcanvasContainerOverlay, "\" />"));
                    elements.$body.wrapInner("<div class=\"".concat(classes.offcanvasContainer, "\" />"));
                    elements.$offcanvasContent.insertBefore(selectors.offcanvasContainer);
                }

                var $wrapperContent = elements.$offcanvasWrapper.find(selectors.offcanvasContent);

                if ($wrapperContent.length)
                {

                    var $containerContent = elements.$outsideContainer.find("> .".concat(classes.contentClassPart, "-").concat(contentId));

                    if ($containerContent.length)
                    {
                        $containerContent.remove();
                    }

                    var $bodyContent = elements.$body.find("> .".concat(classes.contentClassPart, "-").concat(contentId));

                    if ($bodyContent.length)
                    {
                        $bodyContent.remove();
                    }

                    if (elements.$html.hasClass(classes.contentOpenClass))
                    {
                        $wrapperContent.addClass('active');
                    }

                    elements.$body.prepend($wrapperContent);
                }
            }



            //Master_Addons.MA_Offcanvas_Menu.offcanvasClose
            Master_Addons.MA_Offcanvas_Menu.offcanvasClose = function ()
            {
                var openId = elements.$html.data('open-id');
                var regex = new RegExp("".concat(classes.contentClassPart, "-.*"));
                var classList = elements.$html.attr('class').split(/\s+/);

                jQuery("".concat(selectors.contentClassPart, "-").concat(openId)).removeClass('active');
                elements.$triggerButton.removeClass('trigger-active');
                classList.forEach(function (className)
                {
                    if (!className.match(regex))
                    {
                        return;
                    }
                    elements.$html.removeClass(className);
                });
                elements.$html.removeData('open-id');
            }

            // containerClick
            Master_Addons.MA_Offcanvas_Menu.containerClick = function (event)
            {

                var openId = elements.$html.data('open-id');

                if (getID !== openId || !getElementSettings.overlay_close)
                {
                    return;
                }

                if (!elements.$html.hasClass(classes.contentOpenClass))
                {
                    return;
                }
                Master_Addons.MA_Offcanvas_Menu.offcanvasClose();
            }

            Master_Addons.MA_Offcanvas_Menu.closeESC = function (event)
            {

                if (27 !== event.keyCode)
                {
                    return;
                }
                Master_Addons.MA_Offcanvas_Menu.offcanvasClose();
                $(elements.$triggerButton).removeClass('trigger-active');
            }


            Master_Addons.MA_Offcanvas_Menu.addLoaderIcon = function ()
            {
                jQuery(document).find('.jltma-offcanvas__content').addClass('jltma-loading');
            }
            Master_Addons.MA_Offcanvas_Menu.removeLoaderIcon = function ()
            {
                jQuery(document).find('.jltma-offcanvas__content').removeClass('jltma-loading');
            }

            // bindEvents
            Master_Addons.MA_Offcanvas_Menu.bindEvents = function ()
            {

                elements.$body.on('click', selectors.offcanvasContainerOverlay, Master_Addons.MA_Offcanvas_Menu.containerClick.bind(this));

                if ('yes' === is_esc_close)
                {
                    elements.$document.on('keydown', Master_Addons.MA_Offcanvas_Menu.closeESC.bind(this));
                }

                elements.$triggerButton.on('click', Master_Addons.MA_Offcanvas_Menu.offcanvasContent.bind(this));
                elements.$closeButton.on('click', Master_Addons.MA_Offcanvas_Menu.offcanvasClose.bind(this));
                elements.$menuParent.on('click', Master_Addons.MA_Offcanvas_Menu.onParentClick.bind(this));

                $(elements.$menuParent).on('change', function ()
                {
                    Master_Addons.MA_Offcanvas_Menu.onParentClick.bind($(this));
                });

                $("[data-settings=animation_type]").on('click', function ()
                {
                    Master_Addons.MA_Offcanvas_Menu.changeControl.bind($(this));
                });
            }


            //perfectScrollInit
            Master_Addons.MA_Offcanvas_Menu.perfectScrollInit = function ()
            {
                if (!Master_Addons.MA_Offcanvas_Menu.scrollPerfect)
                {
                    Master_Addons.MA_Offcanvas_Menu.scrollPerfect = new PerfectScrollbar(elements.$offcanvasContentBody.get(0), {
                        wheelSpeed: 0.5,
                        suppressScrollX: true
                    });
                    return;
                }

                Master_Addons.MA_Offcanvas_Menu.scrollPerfect.update();
            }

            //onEdit
            Master_Addons.MA_Offcanvas_Menu.onEdit = function ()
            {
                // elementorFrontend.isEditMode()
                if (!Master_Addons.MA_Offcanvas_Menu.isEdit)
                {
                    return;
                }

                if (undefined === $element.data('opened'))
                {
                    $element.data('opened', 'false');
                }

                elementor.channels.editor.on('section:activated', Master_Addons.MA_Offcanvas_Menu.sectionActivated.bind(this));
            }


            //sectionActivated
            Master_Addons.MA_Offcanvas_Menu.sectionActivated = function (sectionName, editor)
            {
                var elementsData = elementorFrontend.config.elements.data[this.getModelCID()];
                var editedElement = editor.getOption('editedElementView');

                if (this.getModelCID() !== editor.model.cid || elementsData.get('widgetType') !== editedElement.model.get('widgetType'))
                {
                    return;
                }

                if (-1 !== this.sectionsArray.indexOf(sectionName))
                {
                    if ('true' === $element.data('opened'))
                    {
                        var editedModel = editor.getOption('model');
                        Master_Addons.MA_Offcanvas_Menu.offcanvasContent(null, editedModel.get('id'));
                    }

                    $element.data('opened', 'true');

                } else
                {
                    Master_Addons.MA_Offcanvas_Menu.offcanvasClose();
                }
            }

            //offcanvasContent
            Master_Addons.MA_Offcanvas_Menu.offcanvasContent = function (event)
            {
                var widgetId = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;

                var boxPosition = getElementSettings.canvas_position;
                var offcanvasType = getElementSettings.animation_type;
                var contentId = getID;

                if (null !== widgetId)
                {
                    contentId = widgetId;
                }
                elements.$triggerButton.addClass('trigger-active');

                jQuery("".concat(selectors.contentClassPart, "-").concat(contentId)).addClass('active');
                elements.$html.addClass("".concat(classes.contentOpenClass)).addClass("".concat(classes.contentOpenClass, "-").concat(contentId)).addClass("".concat(classes.contentClassPart, "-").concat(boxPosition)).addClass("".concat(classes.contentClassPart, "-").concat(offcanvasType)).data('open-id', contentId);
            }


            //onParentClick
            Master_Addons.MA_Offcanvas_Menu.onParentClick = function (event)
            {
                var $clickedItem = jQuery(event.target);
                var noLinkArray = ['', '#'];
                var $menuParent = $clickedItem.hasClass(classes.menuArrow) ? $clickedItem.parent() : $clickedItem;

                if ($clickedItem.hasClass(classes.menuArrow) || -1 !== noLinkArray.indexOf($clickedItem.attr('href')) || !$menuParent.hasClass('active'))
                {
                    event.preventDefault();
                }

                var $menuParentNext = $menuParent.next();
                $menuParent.removeClass('active');
                $menuParentNext.slideUp('normal');

                if ($menuParentNext.is('ul') && !$menuParentNext.is(':visible'))
                {
                    $menuParent.addClass('active');
                    $menuParentNext.slideDown('normal');
                }
            }


            //changeControl
            Master_Addons.MA_Offcanvas_Menu.changeControl = function ()
            {
                Master_Addons.MA_Offcanvas_Menu.offcanvasClose();
            }

            // onInit
            Master_Addons.MA_Offcanvas_Menu.onInit = function ()
            {

                Master_Addons.MA_Offcanvas_Menu.resetCanvas();

                // Master_Addons.MA_Offcanvas_Menu.perfectScrollInit();
                // Master_Addons.MA_Offcanvas_Menu.onEdit();
                Master_Addons.MA_Offcanvas_Menu.bindEvents();
            }
            // onInit

            return Master_Addons.MA_Offcanvas_Menu.onInit();
        },


        //Master Addons: Image Filter Gallery
        MA_Image_Filter_Gallery: function ($scope, $)
        {

            var elementSettings = getElementSettings($scope),
                $jltma_image_filter_gallery_wrapper = $scope.find('.jltma-image-filter-gallery-wrapper').eq(0),
                $ma_el_image_filter_gallery_container = $scope.find('.jltma-image-filter-gallery'),
                $ma_el_image_filter_gallery_nav = $scope.find('.jltma-image-filter-nav'),
                $ma_el_image_filter_gallery_wrapper = $scope.find('.jltma-image-filter-gallery-wrapper'),
                $uniqueId = getUniqueLoopScopeId($scope),
                $maxtilt = elementSettings.ma_el_image_gallery_max_tilt,
                $perspective = elementSettings.ma_el_image_gallery_perspective,
                $speed = elementSettings.ma_el_image_gallery_speed,
                $axis = elementSettings.ma_el_image_gallery_tilt_axis,
                $glare = elementSettings.ma_el_image_gallery_glare,
                $overlay_speed = elementSettings.line_location,
                $ma_el_image_gallery_tooltip = elementSettings.ma_el_image_gallery_tooltip,
                $container = $('.elementor-element-' + $uniqueId + ' .jltma-image-filter-gallery'),
                layoutMode = $ma_el_image_filter_gallery_wrapper.hasClass('jltma-masonry-yes') ? 'masonry' : 'fitRows';

            if (!$jltma_image_filter_gallery_wrapper.length)
            {
                return;
            }

            if ($ma_el_image_gallery_tooltip == "yes")
            {

                var $img_filter_gallery = $jltma_image_filter_gallery_wrapper.find('ul.jltma-tooltip');

                if (!$img_filter_gallery.length)
                {
                    return;
                }

                var $tooltip = $img_filter_gallery.find('> .jltma-tooltip-item'),
                    widgetID = $scope.data('id');

                $tooltip.each(function (index)
                {
                    tippy(this, {
                        allowHTML: false,
                        theme: 'jltma-image-filter-tippy-' + widgetID
                    });
                });
            }

            //Masonry Start
            // let container_outerheight = $container.outerHeight();
            var optValues = {
                filter: '*',
                itemSelector: '.jltma-image-filter-item',
                percentPosition: true,
                animationOptions: {
                    duration: 750,
                    easing: 'linear',
                    queue: false
                }
            };

            var adata = Object.assign({}, optValues);

            if (layoutMode === 'fitRows')
            {
                optValues['layoutMode'] = 'fitRows';
            }

            if(layoutMode === 'masonry'){
                adata['macolumnWidthsonry'] = '.jltma-image-filter-item';
                adata['horizontalOrder'] = true;
            };

            var $grid = $container.isotope(adata);
            $grid.imagesLoaded().progress(function() {
                $grid.isotope('layout');
                $scope.find('.jltma-image-filter-gallery').css({"min-height":"300px"});
            });

            if ($.isFunction($.fn.imagesLoaded))
            {
                $ma_el_image_filter_gallery_container.imagesLoaded(function ()
                {
                    if ($.isFunction($.fn.isotope))
                    {
                        $ma_el_image_filter_gallery_container.isotope(optValues);
                    }
                });
            }
            //Masonry End


            // Tilt Effect Start
            if ($axis === 'x')
            {
                $axis = 'y';
            } else if ($axis === 'y')
            {
                $axis = 'x';
            } else
            {
                $axis = 'both';
            }

            if ($glare === 'yes')
            {
                var $max_glare = elementSettings.ma_el_image_gallery_max_glare;
            }

            if ($glare === 'yes')
            {
                $glare = true;
            } else
            {
                $glare = false;
            }

            if ($scope.find('.jltma-tilt-enable'))
            {
                var tilt_args = {
                    maxTilt: $maxtilt,
                    perspective: $perspective,   // Transform perspective, the lower the more extreme the tilt gets.
                    //easing:         "cubic-bezier(.03,.98,.52,.99)",   // Easing on enter/exit.
                    easing: "linear",
                    scale: 1,      // 2 = 200%, 1.5 = 150%, etc..
                    speed: $speed,    // Speed of the enter/exit transition.
                    disableAxis: $axis,
                    transition: true,   // Set a transition on enter/exit.
                    reset: true,   // If the tilt effect has to be reset on exit.
                    glare: $glare,  // Enables glare effect
                    maxGlare: $max_glare       // From 0 - 1.
                }

                $scope.find('.jltma-tilt').tilt(tilt_args);
            }
            // Tilt Effect End


            $ma_el_image_filter_gallery_nav.on('click', 'li', function ()
            {
                $ma_el_image_filter_gallery_nav.find('.active').removeClass('active');
                $(this).addClass('active');

                if ($.isFunction($.fn.isotope))
                {
                    var selector = $(this).attr('data-filter');
                    $ma_el_image_filter_gallery_container.isotope({
                        filter: selector,
                    });
                    return false;
                }
            });
            $("jltma-fancybox").fancybox({
            // $(".elementor-widget.elementor-widget-ma-image-filter-gallery .jltma-fancybox").fancybox({
                protect: true,
                animationDuration: 366,
                transitionDuration: 366,
                transitionEffect: "fade", // Transition effect between slides
                animationEffect: "fade",
                preventCaptionOverlap: true,
                // loop: false,
                infobar: false,
                buttons: [
                    "zoom",
                    "share",
                    "slideShow",
                    "fullScreen",
                    "download",
                    "thumbs",
                    "close"
                ],
                afterLoad: function (instance, current)
                {
                    var pixelRatio = window.devicePixelRatio || 1;

                    if (pixelRatio > 1.5)
                    {
                        current.width = current.width / pixelRatio;
                        current.height = current.height / pixelRatio;
                    }
                }
            });

        },


        MA_Carousel: function ($swiper, settings)
        {
            var $slides = $swiper.find('.jltma-swiper__slide'),

                elementorBreakpoints = elementorFrontend.config.breakpoints,

                swiperInstance = $swiper.data('swiper'),
                swiperArgs = {
                    autoHeight: settings.element.autoHeight || false,
                    direction: settings.element.direction || settings.default.direction,
                    effect: settings.element.effect || settings.default.effect,
                    slidesPerView: settings.default.slidesPerView,
                    slidesPerColumn: settings.default.slidesPerColumn,
                    slidesPerColumnFill: 'row',
                    slidesPerGroup: settings.default.slidesPerGroup,
                    spaceBetween: settings.default.spaceBetween,
                    pagination: {},
                    navigation: {},
                    autoplay: settings.element.autoplay || false,
                    grabCursor: true,
                    watchSlidesProgress: true,
                    watchSlidesVisibility: true,
                };

            if (settings.default.breakpoints)
            {
                swiperArgs.breakpoints = {};
                swiperArgs.breakpoints[elementorBreakpoints.md] = settings.default.breakpoints.tablet;
                swiperArgs.breakpoints[elementorBreakpoints.lg] = settings.default.breakpoints.desktop;
            }

            if (!elementorFrontend.isEditMode())
            {
                // Observer messes with free mode
                if (!settings.element.freeMode)
                {
                    swiperArgs.observer = true;
                    swiperArgs.observeParents = true;
                    swiperArgs.observeSlideChildren = true;
                }
            } else
            { // But we're safe in edit mode
                swiperArgs.observer = true;
                swiperArgs.observeParents = true;
                swiperArgs.observeSlideChildren = true;
            }

            Master_Addons.MA_Carousel.init = function ()
            {
                if (swiperInstance)
                {
                    Master_Addons.MA_Carousel.destroy();
                    return;
                }

                // Number of columns
                if (swiperArgs.breakpoints)
                {
                    if (settings.element.breakpoints.desktop.slidesPerView)
                    {
                        swiperArgs.breakpoints[elementorBreakpoints.lg].slidesPerView = settings.stretch ? Math.min($slides.length, +settings.element.breakpoints.desktop.slidesPerView || 3) : +settings.element.breakpoints.desktop.slidesPerView || 3;
                    }

                    if (settings.element.breakpoints.tablet.slidesPerView)
                    {
                        swiperArgs.breakpoints[ elementorBreakpoints.md ].slidesPerView = settings.stretch ? Math.min( $slides.length, +settings.element.breakpoints.tablet.slidesPerView || 2 ) : +settings.element.breakpoints.tablet.slidesPerView || 2;
                    }
                }

                if (settings.element.slidesPerView)
                {
                    swiperArgs.slidesPerView = settings.stretch ? Math.min($slides.length, +settings.element.slidesPerView || 1) : +settings.element.slidesPerView || 1;
                }

                // Number of slides to scroll
                if (swiperArgs.breakpoints)
                {
                    if (settings.element.breakpoints.desktop.slidesPerGroup) {
                        swiperArgs.breakpoints[elementorBreakpoints.lg].slidesPerGroup = Math.min($slides.length, +settings.element.breakpoints.desktop.slidesPerGroup || 3);
                    }

                    if (settings.element.breakpoints.tablet.slidesPerGroup) {
                        swiperArgs.breakpoints[elementorBreakpoints.md].slidesPerGroup = Math.min($slides.length, +settings.element.breakpoints.tablet.slidesPerGroup || 2);
                    }
                }

                if (settings.element.slidesPerGroup)
                {
                    swiperArgs.slidesPerGroup = Math.min($slides.length, +settings.element.slidesPerGroup || 1);
                }

                // Rows
                if (swiperArgs.breakpoints)
                {
                    if (settings.element.breakpoints.desktop.slidesPerColumn) {
                        swiperArgs.breakpoints[elementorBreakpoints.lg].slidesPerColumn = settings.element.breakpoints.desktop.slidesPerColumn;
                    }

                    if (settings.element.breakpoints.tablet.slidesPerColumn) {
                        swiperArgs.breakpoints[elementorBreakpoints.md].slidesPerColumn = settings.element.breakpoints.tablet.slidesPerColumn;
                    }
                }

                if (settings.element.slidesPerColumn)
                {
                    swiperArgs.slidesPerColumn = settings.element.slidesPerColumn;
                }

                // Column spacing

                if (swiperArgs.breakpoints)
                {
                    swiperArgs.breakpoints[elementorBreakpoints.lg].spaceBetween = settings.element.breakpoints.desktop.spaceBetween || 0;
                    swiperArgs.breakpoints[elementorBreakpoints.md].spaceBetween = settings.element.breakpoints.tablet.spaceBetween || 0;
                }

                if (settings.element.spaceBetween){
                    swiperArgs.spaceBetween = settings.element.spaceBetween || 0;
                }

                if (settings.element.slidesPerColumnFill) {
                    swiperArgs.slidesPerColumnFill = settings.element.slidesPerColumnFill;
                }

                // Arrows and pagination
                if (settings.element.arrows)
                {
                    swiperArgs.navigation.disabledClass = 'jltma-swiper__button--disabled';

                    var $prevButton = settings.scope.find(settings.element.arrowPrev),
                        $nextButton = settings.scope.find(settings.element.arrowNext);

                    if ($prevButton.length && $nextButton.length)
                    {

                        var arrowPrev = settings.element.arrowPrev + '-' + settings.id,
                            arrowNext = settings.element.arrowNext + '-' + settings.id;

                        $prevButton.addClass(arrowPrev.replace('.', ''));
                        $nextButton.addClass(arrowNext.replace('.', ''));

                        swiperArgs.navigation.prevEl = arrowPrev;
                        swiperArgs.navigation.nextEl = arrowNext;
                    }
                }

                if (settings.element.pagination)
                {
                    swiperArgs.pagination.el = '.jltma-swiper__pagination-' + settings.id;
                    swiperArgs.pagination.type = settings.element.paginationType;

                    if (settings.element.paginationClickable)
                    {
                        swiperArgs.pagination.clickable = true;
                    }
                }

                // Loop
                if (settings.element.loop)
                {
                    swiperArgs.loop = true;
                    // swiperArgs.loopedSlides = $slides.length;
                }

                // Autoplay
                if (swiperArgs.autoplay && (settings.element.autoplaySpeed || settings.element.disableOnInteraction)) {
                    swiperArgs.autoplay = {};

                    if (settings.element.autoplaySpeed) {
                        swiperArgs.autoplay.delay = settings.element.autoplaySpeed;
                    }

                    if (settings.element.autoplaySpeed) {
                        swiperArgs.autoplay.disableOnInteraction = settings.element.disableOnInteraction;
                    }
                } else {

                }

                // Speed
                if (settings.element.speed)
                {
                    swiperArgs.speed = settings.element.speed;
                }

                // Resistance
                if (settings.element.resistance)
                {
                    swiperArgs.resistanceRatio = 1 - settings.element.resistance;
                }

                // Free Mode
                if (settings.element.freeMode)
                {
                    swiperArgs.freeMode = true;
                    swiperArgs.freeModeSticky = settings.element.freeModeSticky;
                    swiperArgs.freeModeMomentum = settings.element.freeModeMomentum;
                    swiperArgs.freeModeMomentumBounce = settings.element.freeModeMomentumBounce;

                    if (settings.element.freeModeMomentumRatio)
                    {
                        swiperArgs.freeModeMomentumRatio = settings.element.freeModeMomentumRatio;
                    }

                    if (settings.element.freeModeMomentumVelocityRatio)
                    {
                        swiperArgs.freeModeMomentumVelocityRatio = settings.element.freeModeMomentumVelocityRatio;
                    }

                    if (settings.element.freeModeMomentumBounceRatio)
                    {
                        swiperArgs.freeModeMomentumBounceRatio = settings.element.freeModeMomentumBounceRatio;
                    }
                }

                return swiperArgs;

                // Conditional asset loading of the Swiper library with backwards compatibility
                // since Elementor 3.1
                // @link https://developers.elementor.com/experiment-optimized-asset-loading/
                // var swiper;
                // if ('undefined' === typeof Swiper)
                // {
                //     const asyncSwiper = elementorFrontend.utils.swiper;

                //     new asyncSwiper($swiper, swiperArgs).then(function (newSwiperInstance)
                //     {
                //         swiper = newSwiperInstance;
                //     });
                // } else
                // {
                //     swiper = new Swiper($swiper, swiperArgs);
                // }

                // if (settings.element.stopOnHover)
                // {
                //     $swiper.on('mouseover', function ()
                //     {
                //         swiper.autoplay.stop();
                //     });

                //     $swiper.on('mouseout', function ()
                //     {
                //         swiper.autoplay.start();
                //     });
                // }

                // if (settings.element.slideChangeTriggerResize)
                // {
                //     swiper.on('slideChange', function ()
                //     {
                //         $(window).trigger('resize');
                //     });
                // }

                // $swiper.data('swiper', swiper);
                // return swiper;
            };

            Master_Addons.MA_Carousel.onAfterInit = function ($swiper, swiper, settings) {
                if ('undefined' == typeof settings || 'undefined' == typeof swiper) {
                    return;
                }

                if (settings.element.stopOnHover) {
                    $swiper.on('mouseover', function () {
                        swiper.autoplay.stop();
                    });

                    $swiper.on('mouseout', function () {
                        swiper.autoplay.start();
                    });
                }

                if (settings.element.slideChangeTriggerResize) {
                    swiper.on('slideChange', function () {
                        $(window).trigger('resize');
                    });
                }

                $swiper.data('swiper', swiper);
            };


            return Master_Addons.MA_Carousel.init();
        },

        // Gallery Slider
        MA_Gallery_Slider: function ($scope, $)
        {
            // var swiper = new Swiper(".jltma-gallery-slider__gallery", {
            //     loop: true,
            //     spaceBetween: 10,
            //     slidesPerView: 2,
            //     freeMode: true,
            //     watchSlidesProgress: true,
            // });
            // var swiper2 = new Swiper(".jltma-gallery-slider__slider", {
            //     loop: true,
            //     spaceBetween: 10,
            //     navigation: {
            //         nextEl: ".jltma-swiper__button--next",
            //         prevEl: ".jltma-swiper__button--prev",
            //     },
            //     thumbs: {
            //         swiper: swiper,
            //     },
            // });
            // return;

            var elementSettings   = getElementSettings($scope),
                $swiperSlider     = $scope.find('.jltma-gallery-slider__slider'), // The main slider area
                $swiperCarousel   = $scope.find('.jltma-gallery-slider__carousel'), // The main slider area when it is carousel
                uniqueId          = getUniqueLoopScopeId($scope),
                // console.log($scope);
                scopeId           = $scope.data('id'),
                $preview          = $scope.find('.jltma-gallery-slider__preview'),
                $thumbs           = $scope.find('.jltma-swiper__wrapper .jltma-gallery__item'), // Thumbs will be there
                $thumbnailsSlider = $scope.find(".jltma-gallery-slider__gallery .jltma-gallery"), // list all thumbs
                $thumbtype        = elementSettings.jltma_gallery_slider_thumb_type,
                $thumbposition    = elementSettings.jltma_gallery_slider_preview_position,
                $thumbVertical    = ($thumbposition == "top" || $thumbposition == "bottom") ? false : true,

                start       = elementorFrontend.config.is_rtl ? 'right' : 'left',
                end         = elementorFrontend.config.is_rtl ? 'left' : 'right',
                hasCarousel = $swiperCarousel.length,

                swiperSlider   = null,
                swiperCarousel = null,

                sliderSettings = {
                    key    : 'slider',
                    scope  : $scope,
                    id     : uniqueId,
                    element: {
                        autoHeight          : 'yes' === elementSettings.jltma_gallery_slider_adaptive_height ? true                                                                                                    : false,
                        autoplay            : 'yes' === elementSettings.jltma_gallery_slider_autoplay ? true                                                                                                           : false,
                        autoplaySpeed       : 'yes' === elementSettings.jltma_gallery_slider_autoplay && elementSettings.jltma_gallery_slider_autoplay_speed ? elementSettings.jltma_gallery_slider_autoplay_speed.size: false,
                        disableOnInteraction: '' !== elementSettings.autoplay_disable_on_interaction,
                        stopOnHover         : 'yes' === elementSettings.jltma_gallery_slider_pause_on_hover,
                        loop                : 'yes' === elementSettings.jltma_gallery_slider_infinite,
                        arrows              : '' !== elementSettings.jltma_gallery_slider_show_arrows,
                        arrowPrev           : '.jltma-arrow--prev',
                        arrowNext           : '.jltma-arrow--next',
                        effect              : elementSettings.jltma_gallery_slider_effect,
                        speed               : elementSettings.jltma_gallery_slider_speed ? elementSettings.jltma_gallery_slider_speed                                                                                  : 500,
                        resistance          : elementSettings.resistance ? elementSettings.resistance.size                                                                                                             : 0.25,
                        keyboard            : {
                            // enabled: "yes" === slider_data.jltma_slider_keyboard ? true : false
                            enabled: true
                        },
                    },
                    default: {
                        effect         : 'slide',
                        direction      : 'horizontal',
                        slidesPerView  : 1,
                        slidesPerGroup : 1,
                        slidesPerColumn: 1,
                        spaceBetween   : 0,
                    }
                };

            // If Carousel
            if (hasCarousel)
            {
                var carouselSettings = {
                    key    : 'carousel',
                    scope  : $scope,
                    id     : uniqueId,
                    // stretch: 'yes' === elementSettings.thumbnails_stretch,
                    element: {
                        direction      : elementSettings.carousel_orientation,
                        arrows         : '' !== elementSettings.jltma_gallery_slider_thumb_show_arrows,
                        arrowPrev      : '.jltma-arrow--prev',
                        arrowNext      : '.jltma-arrow--next',
                        autoHeight     : false,
                        loop           : 'yes' === elementSettings.jltma_gallery_slider_thumb_infinite ? true : false,
                        autoplay       : 'yes' === elementSettings.jltma_gallery_slider_thumb_autoplay ? true : false,
                        autoplaySpeed  : 'yes' === elementSettings.jltma_gallery_slider_thumb_autoplay && elementSettings.jltma_gallery_slider_thumb_autoplay_speed ? elementSettings.jltma_gallery_slider_thumb_autoplay_speed.size: false,
                        stopOnHover    : 'yes' === elementSettings.jltma_gallery_slider_thumb_pause_on_hover,
                        speed          : elementSettings.jltma_gallery_slider_thumb_speed ? elementSettings.jltma_gallery_slider_thumb_speed : 500,
                        slidesPerView  : elementSettings.jltma_gallery_slider_thumb_items_mobile,
                        slidesPerColumn: 'vertical' === elementSettings.carousel_orientation ? 1 : elementSettings.carousel_slides_per_column_mobile,
                        slidesPerGroup : elementSettings.carousel_slides_to_scroll_mobile,
                        resistance     : elementSettings.carousel_resistance ? elementSettings.carousel_resistance.size : 0.15,
                        spaceBetween   : elementSettings.carousel_spacing_mobile ? elementSettings.carousel_spacing_mobile.size : 0,
                        breakpoints    : {
                            tablet: {
                                slidesPerView: elementSettings.jltma_gallery_slider_thumb_items_tablet,
                                slidesPerColumn: 'vertical' === elementSettings.carousel_orientation ? 1 : elementSettings.carousel_slides_per_column_tablet,
                                slidesPerGroup: elementSettings.carousel_slides_to_scroll_tablet,
                                spaceBetween: elementSettings.carousel_spacing_tablet ? elementSettings.carousel_spacing_tablet.size : 0,
                            },
                            desktop: {
                                slidesPerView: elementSettings.jltma_gallery_slider_thumb_items,
                                slidesPerColumn: 'vertical' === elementSettings.carousel_orientation ? 1 : elementSettings.carousel_slides_per_column,
                                slidesPerGroup: elementSettings.carousel_slides_to_scroll,
                                spaceBetween: elementSettings.carousel_spacing ? elementSettings.carousel_spacing.size : 0,
                            },
                        },
                    },
                    default: {
                        effect: 'slide',
                        slidesPerView: 1,
                        slidesPerGroup: 1,
                        slidesPerColumn: 1,
                        spaceBetween: 6,
                        breakpoints: {
                            tablet: {
                                slidesPerView: 2,
                                slidesPerGroup: 1,
                                slidesPerColumn: 2,
                                spaceBetween: 12,
                            },
                            desktop: {
                                slidesPerView: 3,
                                slidesPerGroup: 1,
                                slidesPerColumn: 3,
                                spaceBetween: 24,
                            },
                        },
                    },
                };
            }


            Master_Addons.MA_Gallery_Slider.init = function ()
            {
                var sliderArgs = Master_Addons.MA_Carousel( $swiperSlider, sliderSettings );

                if (hasCarousel) {
                    var carouselArgs = Master_Addons.MA_Carousel($swiperCarousel, carouselSettings);
                }

                // Master_Addons.MA_Gallery_Slider.onSlideChange();
                // Master_Addons.MA_Gallery_Slider.events();


                if ('undefined' === typeof Swiper) {
                    const asyncSwiper = elementorFrontend.utils.swiper;

                    new asyncSwiper($swiperSlider, sliderArgs).then(function (sliderSwiperInstance) {

                        if (!hasCarousel) {
                            Master_Addons.MA_Gallery_Slider.initSliders($scope, sliderSwiperInstance, false);

                            Master_Addons.MA_Carousel.onAfterInit($swiperSlider, sliderSwiperInstance, sliderSettings);
                        } else {
                            new asyncSwiper($swiperCarousel, carouselArgs).then(function (carouselSwiperInstance) {
                                Master_Addons.MA_Gallery_Slider.initSliders($scope, sliderSwiperInstance, carouselSwiperInstance);

                                Master_Addons.MA_Carousel.onAfterInit($swiperSlider, sliderSwiperInstance, sliderSettings);
                                Master_Addons.MA_Carousel.onAfterInit($swiperCarousel, carouselSwiperInstance, carouselSettings);
                            });
                        }
                    });

                } else {
                    if (hasCarousel) {
                        var swiper = new Swiper($swiperSlider[1], {
                            ...carouselArgs,
                        });
                        var swiperSlider = new Swiper($swiperSlider[0], {
                            ...sliderArgs,
                            thumbs: {
                                swiper: swiper,
                            },
                        });
                    }else{
                        var swiperSlider = new Swiper($swiperSlider[0], {
                            ...sliderArgs
                        });
                    }
                    // swiperSlider = new Swiper($swiperSlider, sliderArgs);

                    if (hasCarousel) {
                        swiperCarousel = new Swiper($swiperCarousel, carouselArgs);
                    }

                    Master_Addons.MA_Gallery_Slider.initSliders($scope, swiperSlider, swiperCarousel);

                    Master_Addons.MA_Carousel.onAfterInit($swiperSlider, swiperSlider, sliderSettings);

                    if (hasCarousel) {
                        Master_Addons.MA_Carousel.onAfterInit($swiperCarousel, swiperCarousel, carouselSettings);
                    }
                }

            };

            Master_Addons.MA_Gallery_Slider.getSlider = function () {
                return $scope.find('.jltma-gallery-slider__slider');
            };


            Master_Addons.MA_Gallery_Slider.getCarousel = function () {
                return $scope.find('.jltma-gallery-slider__carousel');
            };


            Master_Addons.MA_Gallery_Slider.initSliders = function ($scope, swiperSlider, swiperCarousel) {
                var data = {
                    scope: $scope,
                    slider: swiperSlider,
                    carousel: swiperCarousel,
                };

                Master_Addons.MA_Gallery_Slider.onSlideChange(data);
                Master_Addons.MA_Gallery_Slider.events(data);
            };


            Master_Addons.MA_Gallery_Slider.events = function ( data )
            {

                var $thumbs = data.scope.find('.jltma-gallery__item');

                data.slider.on('slideChange', function (instance) {
                    Master_Addons.MA_Gallery_Slider.onSlideChange(data);
                });

                $thumbs.on('click', function () {
                    var offset = sliderSettings.element.loop ? 1 : 0;

                    event.preventDefault();
                    data.slider.slideTo($(this).index() + offset);
                });
            };

            Master_Addons.MA_Gallery_Slider.onSlideChange = function (data)
            {
                var activeIndex = sliderSettings.element.loop ? data.slider.realIndex : data.slider.activeIndex;

                if (hasCarousel) {
                    data.carousel.slideTo(activeIndex);
                }

                var $thumbs = data.scope.find('.jltma-gallery__item');

                $thumbs.removeClass('is--active');
                $thumbs.eq(activeIndex).addClass('is--active');

            };

            Master_Addons.MA_Gallery_Slider.onThumbClicked = function (event)
            {
                var offset = sliderSettings.element.loop ? 1 : 0;
                event.preventDefault();
                swiperSlider.slideTo($(this).index() + offset, 500, true);
            };

            Master_Addons.onElementRemove($scope, function ()
            {
                $scope.find('.swiper-container').each(function () {
                    if ($(this).data('swiper')) {
                        $(this).data('swiper').destroy();
                    }
                });
            });


            Master_Addons.MA_Gallery_Slider.init();
        },
        // MA_Gallery_Slider: function ($scope, $) {
        //     var elementSettings = getElementSettings($scope),
        //         $swiperSlider = $scope.find('.jltma-gallery-slider__slider'),
        //         $swiperCarousel = $scope.find('.jltma-gallery-slider__carousel'),
        //         uniqueId = getUniqueLoopScopeId($scope),
        //         scopeId = $scope.data('id'),
        //         $preview = $scope.find('.jltma-gallery-slider__preview'),
        //         $thumbs = $scope.find('.jltma-swiper__wrapper .jltma-gallery__item'),
        //         $thumbnailsSlider = $scope.find(".jltma-gallery-slider__gallery .jltma-gallery"),
        //         $thumbtype = elementSettings.jltma_gallery_slider_thumb_type,
        //         $thumbposition = elementSettings.jltma_gallery_slider_preview_position,
        //         $thumbVertical = ($thumbposition == "top" || $thumbposition == "bottom") ? false : true,
        //         start = elementorFrontend.config.is_rtl ? 'right' : 'left',
        //         end = elementorFrontend.config.is_rtl ? 'left' : 'right',
        //         hasCarousel = $swiperCarousel.length,
        //         swiperSlider = null,
        //         swiperCarousel = null,
        //         sliderSettings = {
        //             key: 'slider',
        //             scope: $scope,
        //             id: uniqueId,
        //             element: {
        //                 autoHeight: 'yes' === elementSettings.jltma_gallery_slider_adaptive_height ? true : false,
        //                 autoplay: 'yes' === elementSettings.jltma_gallery_slider_autoplay ? true : false,
        //                 autoplaySpeed: 'yes' === elementSettings.jltma_gallery_slider_autoplay && elementSettings.jltma_gallery_slider_autoplay_speed ? elementSettings.jltma_gallery_slider_autoplay_speed.size : false,
        //                 disableOnInteraction: '' !== elementSettings.autoplay_disable_on_interaction,
        //                 stopOnHover: 'yes' === elementSettings.jltma_gallery_slider_pause_on_hover,
        //                 loop: 'yes' === elementSettings.jltma_gallery_slider_infinite,
        //                 arrows: '' !== elementSettings.jltma_gallery_slider_show_arrows,
        //                 arrowPrev: '.jltma-arrow--prev',
        //                 arrowNext: '.jltma-arrow--next',
        //                 effect: elementSettings.jltma_gallery_slider_effect,
        //                 speed: elementSettings.speed ? elementSettings.speed.size : 500,
        //                 resistance: elementSettings.resistance ? elementSettings.resistance.size : 0.25,
        //                 keyboard: {
        //                     enabled: true
        //                 },
        //             },
        //             default: {
        //                 effect: 'slide',
        //                 direction: 'horizontal',
        //                 slidesPerView: 1,
        //                 slidesPerGroup: 1,
        //                 slidesPerColumn: 1,
        //                 spaceBetween: 0,
        //             }
        //         };

        //     if (hasCarousel) {
        //         var carouselSettings = {
        //             key: 'carousel',
        //             scope: $scope,
        //             id: uniqueId,
        //             element: {
        //                 direction: elementSettings.carousel_orientation,
        //                 arrows: '' !== elementSettings.jltma_gallery_slider_thumb_show_arrows,
        //                 arrowPrev: '.jltma-arrow--prev',
        //                 arrowNext: '.jltma-arrow--next',
        //                 autoHeight: false,
        //                 loop: 'yes' === elementSettings.jltma_gallery_slider_thumb_infinite ? true : false,
        //                 autoplay: 'yes' === elementSettings.jltma_gallery_slider_thumb_autoplay ? true : false,
        //                 autoplaySpeed: 'yes' === elementSettings.jltma_gallery_slider_thumb_autoplay && elementSettings.jltma_gallery_slider_thumb_autoplay_speed ? elementSettings.jltma_gallery_slider_thumb_autoplay_speed.size : false,
        //                 stopOnHover: 'yes' === elementSettings.jltma_gallery_slider_thumb_pause_on_hover,
        //                 speed: elementSettings.jltma_gallery_slider_thumb_speed ? elementSettings.jltma_gallery_slider_thumb_speed.size : 500,
        //                 slidesPerView: elementSettings.jltma_gallery_slider_thumb_items_mobile,
        //                 slidesPerColumn: 'vertical' === elementSettings.carousel_orientation ? 1 : elementSettings.carousel_slides_per_column_mobile,
        //                 slidesPerGroup: elementSettings.carousel_slides_to_scroll_mobile,
        //                 resistance: elementSettings.carousel_resistance ? elementSettings.carousel_resistance.size : 0.15,
        //                 spaceBetween: elementSettings.carousel_spacing_mobile ? elementSettings.carousel_spacing_mobile.size : 0,
        //                 breakpoints: {
        //                     tablet: {
        //                         slidesPerView: elementSettings.jltma_gallery_slider_thumb_items_tablet,
        //                         slidesPerColumn: 'vertical' === elementSettings.carousel_orientation ? 1 : elementSettings.carousel_slides_per_column_tablet,
        //                         slidesPerGroup: elementSettings.carousel_slides_to_scroll_tablet,
        //                         spaceBetween: elementSettings.carousel_spacing_tablet ? elementSettings.carousel_spacing_tablet.size : 0,
        //                     },
        //                     desktop: {
        //                         slidesPerView: elementSettings.jltma_gallery_slider_thumb_items,
        //                         slidesPerColumn: 'vertical' === elementSettings.carousel_orientation ? 1 : elementSettings.carousel_slides_per_column,
        //                         slidesPerGroup: elementSettings.carousel_slides_to_scroll,
        //                         spaceBetween: elementSettings.carousel_spacing ? elementSettings.carousel_spacing.size : 0,
        //                     },
        //                 },
        //             },
        //             default: {
        //                 effect: 'slide',
        //                 slidesPerView: 1,
        //                 slidesPerGroup: 1,
        //                 slidesPerColumn: 1,
        //                 spaceBetween: 6,
        //                 breakpoints: {
        //                     tablet: {
        //                         slidesPerView: 2,
        //                         slidesPerGroup: 1,
        //                         slidesPerColumn: 2,
        //                         spaceBetween: 12,
        //                     },
        //                     desktop: {
        //                         slidesPerView: 3,
        //                         slidesPerGroup: 1,
        //                         slidesPerColumn: 3,
        //                         spaceBetween: 24,
        //                     },
        //                 },
        //             },
        //         };
        //     }

        //     Master_Addons.MA_Gallery_Slider.init = function () {
        //         if ($swiperSlider.length) {
        //             swiperSlider = Master_Addons.MA_Carousel($swiperSlider, sliderSettings);
        //             console.log('Swiper Slider Initialized:', swiperSlider);
        //         }
        //         if (hasCarousel && $swiperCarousel.length) {
        //             swiperCarousel = Master_Addons.MA_Carousel($swiperCarousel, carouselSettings);
        //             console.log('Swiper Carousel Initialized:', swiperCarousel);
        //         }
        //         alert("slider ready");
        //         Master_Addons.MA_Gallery_Slider.events();
        //         Master_Addons.MA_Gallery_Slider.onSlideChange();
        //     };

        //     Master_Addons.MA_Gallery_Slider.events = function () {
        //         alert("slider events");
        //         if (swiperSlider) {
        //             swiperSlider.on('slideChange', Master_Addons.MA_Gallery_Slider.onSlideChange);
        //         }
        //         if (hasCarousel && swiperCarousel) {
        //             swiperCarousel.on('slideChange', Master_Addons.MA_Gallery_Slider.onSlideChange);
        //         }
        //         $thumbs.on('click', Master_Addons.MA_Gallery_Slider.onThumbClicked);
        //     };

        //     // Master_Addons.MA_Gallery_Slider.onSlideChange = function () {
        //     //     if (hasCarousel && swiperCarousel) {
        //     //         var activeIndex = sliderSettings.element.loop ? swiperCarousel.realIndex : swiperCarousel.activeIndex;
        //     //         swiperCarousel.slideTo(activeIndex, 500, true);
        //     //     } else if (swiperSlider) {
        //     //         var activeIndex = sliderSettings.element.loop ? swiperSlider.realIndex : swiperSlider.activeIndex;
        //     //         swiperSlider.slideTo(activeIndex, 500, false);
        //     //     }

        //     //     $thumbs.removeClass('is--active');
        //     //     $thumbs.eq(activeIndex).addClass('is--active');
        //     // };
        //     Master_Addons.MA_Gallery_Slider.onSlideChange = function () {
        //         alert("slider change");
        //         if (hasCarousel && swiperCarousel) {
        //             var activeIndex = sliderSettings.element.loop ? swiperCarousel.realIndex : swiperCarousel.activeIndex;
        //             swiperCarousel.slideTo(activeIndex, 500, true);
        //         } else if (swiperSlider) {
        //             var activeIndex = sliderSettings.element.loop ? swiperSlider.realIndex : swiperSlider.activeIndex;
        //             swiperSlider.slideTo(activeIndex, 500, false);
        //         }

        //         $thumbs.removeClass('is--active');
        //         $thumbs.eq(activeIndex).addClass('is--active');
        //     };

        //     Master_Addons.MA_Gallery_Slider.onThumbClicked = function (event) {
        //         event.preventDefault();
        //         if (swiperSlider) {
        //             var offset = sliderSettings.element.loop ? 1 : 0;
        //             swiperSlider.slideTo($(this).index() + offset, 500, true);
        //         }
        //     };

        //     Master_Addons.onElementRemove($scope, function () {
        //         $scope.find('.swiper').each(function () {
        //             if ($(this).data('swiper')) {
        //                 $(this).data('swiper').destroy();
        //             }
        //         });
        //     });

        //     $(document).ready(function () {
        //         Master_Addons.MA_Gallery_Slider.init();
        //     });
        // },

        // On Remove Event
        onElementRemove: function ($element, callback)
        {
            if (elementorFrontend.isEditMode())
            {
                // Make sure it is destroyed when element is removed in editor mode
                elementor.channels.data.on('element:before:remove', function (model)
                {
                    if ($element.data('id') === model.id)
                    {
                        callback();
                    }
                });
            }
        },

        //Master Addons: Timeline
        MA_Timeline: function ($scope, $)
        {

            var elementSettings = getElementSettings($scope),
                $timeline = $scope.find('.jltma-timeline'),
                $swiperSlider = $scope.find('.jltma-timeline-slider'),
                $timeline_type = elementSettings.ma_el_timeline_type,
                $timeline_layout = elementSettings.ma_el_timeline_design_type,
                swiperSlider = null,
                timelineArgs = {},
                hasCarousel = $swiperSlider.length,
                $uniqueId = getUniqueLoopScopeId($scope);

            if ($timeline_layout === 'horizontal')
            {

                var $carousel = $scope.find('.jltma-timeline-carousel-slider');

                if (!$carousel.length)
                {
                    return;
                }

                var $carouselContainer = $scope.find('.swiper'),
                    $settings = $carousel.data('settings'),
                    Swiper = elementorFrontend.utils.swiper;

                initSwiper();

                async function initSwiper()
                {
                    var swiper = await new Swiper($carouselContainer, $settings);
                    if ($settings.pauseOnHover)
                    {
                        $($carouselContainer).hover(function ()
                        {
                            (this).swiper.autoplay.stop();
                        }, function ()
                        {
                            (this).swiper.autoplay.start();
                        });
                    }
                };
            }


            if ($timeline_layout === 'vertical' || $timeline_type === "post")
            {
                var $timeline = $scope.find('.jltma-timeline'),
                    timelineArgs = {};

                Master_Addons.MA_Timeline.init = function ()
                {
                    if (elementorFrontend.isEditMode())
                    {
                        timelineArgs.scope = window.elementor.$previewContents;
                    }

                    if ('undefined' !== typeof elementSettings.line_location && elementSettings.line_location.size)
                    {
                        timelineArgs.lineLocation = elementSettings.line_location.size;
                    }
                    $timeline.maTimeline(timelineArgs);
                };
                Master_Addons.MA_Timeline.init();
            }

        },


        //Master Addons: News Ticker
        MA_NewsTicker: function ($scope, $)
        {
            try
            {
                var newsTickerWrapper = $scope.find(".jltma-news-ticker"),
                    tickerType = newsTickerWrapper.data('tickertype'),
                    tickerid = newsTickerWrapper.data('tickerid'),
                    feedUrl = newsTickerWrapper.data('feedurl'),
                    feedAnimation = newsTickerWrapper.data('feedanimation'),
                    limitPosts = newsTickerWrapper.data('limitposts'),
                    tickerStyleEffect = newsTickerWrapper.data('scroll') || 'slide-h',
                    autoplay = newsTickerWrapper.data('autoplay'),
                    timer = newsTickerWrapper.data('timer') || 3000;

                var swiperContainer = $scope.find(".jltma-ticker-content-inner.swiper")[0];

                if (!swiperContainer) return;

                var swiperOptions = {
                    loop: true,
                    slidesPerView: 1,
                    spaceBetween: 0,
                    speed: 500,
                    navigation: {
                        nextEl: $scope.find('.jltma-ticker-next')[0],
                        prevEl: $scope.find('.jltma-ticker-prev')[0],
                    },
                };

                // Configure based on scroll type
                if (tickerStyleEffect === 'slide-v') {
                    // Vertical slide
                    swiperOptions.direction = 'vertical';
                } else if (tickerStyleEffect === 'scroll-h') {
                    // Continuous horizontal scroll (marquee effect)
                    swiperOptions.direction = 'horizontal';
                    swiperOptions.freeMode = {
                        enabled: true,
                        momentum: false,
                    };
                    swiperOptions.speed = 5000;
                    swiperOptions.autoplay = {
                        delay: 0,
                        disableOnInteraction: false,
                        pauseOnMouseEnter: true,
                    };
                } else {
                    // Default: Horizontal slide (slide-h)
                    swiperOptions.direction = 'horizontal';
                }

                // Add autoplay if enabled (for non-scroll modes)
                if (autoplay && tickerStyleEffect !== 'scroll-h') {
                    swiperOptions.autoplay = {
                        delay: timer,
                        disableOnInteraction: false,
                        pauseOnMouseEnter: true,
                    };
                }

                // Initialize Swiper
                var tickerSwiper = new Swiper(swiperContainer, swiperOptions);

            } catch (e)
            {
                console.log('News Ticker Error:', e);
            }
        },


        /*
         * Master Addons: MA Blog Posts
         */

        MA_Blog: function ($scope, $)
        {
            var elementSettings = getElementSettings($scope),
                uniqueId = getUniqueLoopScopeId($scope),
                scopeId = $scope.data('id'),
                $swiper = $scope.find('.jltma-swiper__container'),
                $thumbs = $scope.find('.jltma-grid__item'),
                blogElement = $scope.find(".jltma-blog-wrapper"),
                colsNumber = blogElement.data("col"),
                carousel = blogElement.data("carousel"),
                grid = blogElement.data("grid");

            $scope.find(".jltma-blog-cats-container li a").click(function (e)
            {
                e.preventDefault();

                $scope
                    .find(".jltma-blog-cats-container li .active")
                    .removeClass("active");

                $(this).addClass("active");

                var selector = $(this).attr("data-filter");

                blogElement.isotope({ filter: selector });

                return false;
            });

            var masonryBlog = blogElement.hasClass("jltma-blog-masonry");

            if (masonryBlog && !carousel)
            {
                blogElement.imagesLoaded(function ()
                {
                    blogElement.isotope({
                        itemSelector: ".jltma-post-outer-container",
                        percentPosition: true,
                        animationOptions: {
                            duration: 750,
                            easing: "linear",
                            queue: false
                        }
                    });
                });
            }


            // Carousel
            var $carousel = $scope.find('.jltma-blog-carousel-slider');

            if (!$carousel.length)
            {
                return;
            }

            var $carouselContainer = $scope.find('.swiper'),
                $settings = $carousel.data('settings'),
                Swiper = elementorFrontend.utils.swiper;

            initSwiper();

            async function initSwiper()
            {
                var swiper = await new Swiper($carouselContainer, $settings);
                if ($settings.pauseOnHover)
                {
                    $($carouselContainer).hover(function ()
                    {
                        (this).swiper.autoplay.stop();
                    }, function ()
                    {
                        (this).swiper.autoplay.start();
                    });
                }
            };

        },


        /**** MA Image Carousel ****/
        MA_Image_Carousel: function ($scope, $)
        {

            var $carousel = $scope.find('.jltma-image-carousel-slider');

            if (!$carousel.length)
            {
                return;
            }

            var $carouselContainer = $scope.find('.swiper'),
                $settings = $carousel.data('settings'),
                Swiper = elementorFrontend.utils.swiper;

            initSwiper();

            async function initSwiper()
            {
                var swiper = await new Swiper($carouselContainer, $settings);
                if ($settings.pauseOnHover)
                {
                    $($carouselContainer).hover(function ()
                    {
                        (this).swiper.autoplay.stop();
                    }, function ()
                    {
                        (this).swiper.autoplay.start();
                    });
                }
            };
        },

        /**** MA Logo Slider ****/
        MA_Logo_Slider: function ($scope, $)
        {

            var $carousel = $scope.find('.jltma-logo-carousel-slider');

            if (!$carousel.length)
            {
                return;
            }

            var $carouselContainer = $scope.find('.swiper'),
                $settings = $carousel.data('settings'),
                Swiper = elementorFrontend.utils.swiper;

            initSwiper();

            async function initSwiper()
            {
                var swiper = await new Swiper($carouselContainer, $settings);
                if ($settings.pauseOnHover)
                {
                    $($carouselContainer).hover(function ()
                    {
                        (this).swiper.autoplay.stop();
                    }, function ()
                    {
                        (this).swiper.autoplay.start();
                    });
                }
            };


            /**
             * Icon click for hover
             */
            $carousel.find('.jltma-logo-slider-figure').on('click', '.item-hover-icon', function ()
            {
                var $this = $(this);
                $this.toggleClass('hide');
                $this.siblings('.jltma-hover-click').toggleClass('show');
            });

            /**
             * Tooltip jS
             */
            var $tooltipSelector = $carousel.find('.jltma-logo-slider-item');
            $tooltipSelector.each(function (e)
            {
                var $currentTooltip = $(this).attr('id');
                if ($currentTooltip)
                {
                    var $dataId = $(this).data('id');
                    var $tooltipSettings = $(this).data('tooltip-settings');
                    var selector = '#' + $currentTooltip;
                    var $follow_cursor = $tooltipSettings.follow_cursor;
                    var placement_cursor;
                    if ($follow_cursor == 1)
                    {
                        placement_cursor = {
                            followCursor: true,
                        };
                    } else
                    {
                        placement_cursor = {
                            placement: $tooltipSettings.placement,
                            followCursor: false,
                        };
                    }


                    var arrowType = false;
                    if ($tooltipSettings.arrow == 1)
                    {
                        if ($tooltipSettings.arrow_type == 'round')
                        {
                            arrowType = tippy.roundArrow;
                        } else
                        {
                            arrowType = true;
                        }
                    }

                    tippy(selector, {
                        content: $tooltipSettings.text,
                        ...placement_cursor,
                        animation: $tooltipSettings.animation,
                        arrow: arrowType,
                        duration: $tooltipSettings.duration,
                        delay: $tooltipSettings.delay,
                        trigger: $tooltipSettings.trigger, // mouseenter,click, manual
                        // flipOnUpdate: true,
                        // interactive: true,
                        offset: [$tooltipSettings.x_offset, $tooltipSettings.y_offset],
                        zIndex: 999999,
                        allowHTML: false,
                        theme: 'jltma-tippy-' + $dataId,
                        onShow(instance)
                        {
                            var tippyPopper = instance.popper;
                            $(tippyPopper).addClass($dataId);
                        }
                    });
                }
            });
        },



        /**** MA Team Slider ****/
        MA_TeamSlider: function ($scope, $)
        {

            var elementSettings = getElementSettings($scope),
                uniqueId = getUniqueLoopScopeId($scope),
                scopeId = $scope.data('id'),
                $teamCarouselWrapper = $scope.find('.jltma-team-carousel-wrapper').eq(0),
                $team_preset = $teamCarouselWrapper.data("team-preset"),
                $ma_el_team_circle_image_animation = $teamCarouselWrapper.data("ma_el_team_circle_image_animation");

            if ($team_preset == "-content-drawer")
            {

                try
                {
                    (function ($)
                    {

                        $('.gridder').gridderExpander({
                            scroll: false,
                            scrollOffset: 0,
                            scrollTo: "panel",                  // panel or listitem
                            animationSpeed: 400,
                            animationEasing: "easeInOutExpo",
                            showNav: true, // Show Navigation
                            nextText: "<span></span>", // Next button text
                            prevText: "<span></span>", // Previous button text
                            closeText: "", // Close button text
                            onStart: function ()
                            {
                                //Gridder Inititialized
                            },
                            onContent: function ()
                            {
                                //Gridder Content Loaded
                            },
                            onClosed: function ()
                            {
                                //Gridder Closed
                            }
                        });

                    })(jQuery);
                } catch (e)
                {
                    //We can also throw from try block and catch it here
                    // No Error Show
                }


            } else {

                var $carousel = $scope.find('.jltma-team-carousel-slider');

                if (!$carousel.length)
                {
                    return;
                }

                var $carouselContainer = $scope.find('.swiper'),
                    $settings = $carousel.data('settings'),
                    Swiper = elementorFrontend.utils.swiper;

                initSwiper();

                async function initSwiper()
                {
                    var swiper = await new Swiper($carouselContainer, $settings);
                    if ($settings.pauseOnHover)
                    {
                        $($carouselContainer).hover(function ()
                        {
                            (this).swiper.autoplay.stop();
                        }, function ()
                        {
                            (this).swiper.autoplay.start();
                        });
                    }
                };
            }

            // else if ($team_preset == "-circle-animation"){
            //     if($ma_el_team_circle_image_animation == "animation_svg_04"){
            //
            //     }
            // }

        },

        /**** MA Advanced Image ****/
        MA_Advanced_Image: function ($scope, $)
        {

            Master_Addons.MA_Advanced_Image.elementSettings = getElementSettings($scope);

            $scope.find('.jltma-img-dynamic-dropshadow').each(function ()
            {

                var imgFrame, clonedImg, img;

                if (this instanceof jQuery)
                {
                    if (this && this[0])
                    {
                        img = this[0];
                    } else
                    {
                        return;
                    }
                } else
                {
                    img = this;
                }

                if (!img.classList.contains('jltma-img-has-shadow'))
                {
                    imgFrame = document.createElement('div');
                    clonedImg = img.cloneNode();

                    clonedImg.classList.add('jltma-img-dynamic-dropshadow-cloned');
                    clonedImg.classList.remove('jltma-img-dynamic-dropshadow');
                    img.classList.add('jltma-img-has-shadow');
                    imgFrame.classList.add('jltma-img-dynamic-dropshadow-frame');

                    img.parentNode.appendChild(imgFrame);
                    imgFrame.appendChild(img);
                    imgFrame.appendChild(clonedImg);
                }
            });

            //Tilt Effect
            $scope.find('.jltma-tilt-box').tilt({
                maxTilt: $(this).data('max-tilt'),
                easing: 'cubic-bezier(0.23, 1, 0.32, 1)',
                speed: $(this).data('time'),
                perspective: 2000
            });
        },

        /* MA Tooltip */
        MA_Tooltip: function ($scope, $)
        {
            'use strict';

            // Input validation
            if (!$scope || !$scope.length || !$ || typeof getElementSettings !== 'function') {
                return;
            }

            // Check if tippy is available with retry mechanism
            if (typeof tippy === 'undefined') {
                var retryCount = ($scope.data('ma-tooltip-retry') || 0) + 1;
                if (retryCount <= 10) { // Max 10 retries (1 second total)
                    $scope.data('ma-tooltip-retry', retryCount);
                    setTimeout(function() {
                        Master_Addons.MA_Tooltip($scope, $);
                    }, 100);
                }
                return;
            }

            // Clear retry counter on success
            $scope.removeData('ma-tooltip-retry');

            var elementSettings = getElementSettings($scope),
                scopeId = $scope.data('id'),
                currentTooltipElement = null;

            // Validate scope ID
            if (!scopeId || typeof scopeId !== 'string') {
                return;
            }

            // Secure element selection with validation
            try {
                currentTooltipElement = document.getElementById('jltma-tooltip-' + scopeId);

                // Fallback with additional validation
                if (!currentTooltipElement) {
                    var $fallbackElement = $scope.find('#jltma-tooltip-' + scopeId);
                    if ($fallbackElement && $fallbackElement.length > 0) {
                        var fallbackEl = $fallbackElement[0];
                        if (fallbackEl && fallbackEl.nodeType === 1) {
                            currentTooltipElement = fallbackEl;
                        }
                    }
                }

                // Final validation of selected element
                if (!currentTooltipElement || !currentTooltipElement.nodeType || currentTooltipElement.nodeType !== 1) {
                    return;
                }

                // Ensure it's not a jQuery object
                if (currentTooltipElement.jquery) {
                    currentTooltipElement = currentTooltipElement[0];
                    if (!currentTooltipElement || !currentTooltipElement.nodeType) {
                        return;
                    }
                }
            } catch (error) {
                return;
            }

            var initTooltip = function() {
                try {
                    // Prevent multiple simultaneous initializations
                    if (currentTooltipElement && currentTooltipElement._maTooltipInitializing) {
                        return;
                    }

                    // Validate element settings
                    if (!elementSettings || typeof elementSettings !== 'object') {
                        return;
                    }

                    // Sanitize and validate tooltip text
                    var tooltipText = elementSettings.ma_el_tooltip_text;
                    if (!tooltipText || typeof tooltipText !== 'string') {
                        return; // Don't create tooltip without content
                    }

                    // Mark as initializing
                    if (currentTooltipElement) {
                        currentTooltipElement._maTooltipInitializing = true;
                    }

                    // Sanitize and validate all settings with proper defaults
                    var $jltma_el_tooltip_text = stripTags(tooltipText),
                        $jltma_el_tooltip_direction = elementSettings.ma_el_tooltip_direction || 'top',
                        $jltma_tooltip_animation = elementSettings.jltma_tooltip_animation || 'shift-away',
                        $jltma_tooltip_arrow = elementSettings.jltma_tooltip_arrow !== false,
                        $jltma_tooltip_duration = parseInt(elementSettings.jltma_tooltip_duration) || 300,
                        $jltma_tooltip_delay = parseInt(elementSettings.jltma_tooltip_delay) || 300,
                        $jltma_tooltip_arrow_type = elementSettings.jltma_tooltip_arrow_type || 'sharp',
                        $jltma_tooltip_trigger = elementSettings.jltma_tooltip_trigger || 'mouseenter',
                        $jltma_tooltip_custom_trigger = elementSettings.jltma_tooltip_custom_trigger,
                        $animateFill = elementSettings.jltma_tooltip_animation === "fill";

                    // Validate numeric values within safe ranges
                    $jltma_tooltip_duration = Math.max(100, Math.min(5000, $jltma_tooltip_duration));
                    $jltma_tooltip_delay = Math.max(0, Math.min(5000, $jltma_tooltip_delay));

                    // Parse offset values safely
                    var $jltma_tooltip_x_offset = 0, $jltma_tooltip_y_offset = 0;
                    try {
                        if (elementSettings.jltma_tooltip_x_offset && elementSettings.jltma_tooltip_x_offset.size !== undefined) {
                            $jltma_tooltip_x_offset = parseInt(elementSettings.jltma_tooltip_x_offset.size) || 0;
                        }
                        if (elementSettings.jltma_tooltip_y_offset && elementSettings.jltma_tooltip_y_offset.size !== undefined) {
                            $jltma_tooltip_y_offset = parseInt(elementSettings.jltma_tooltip_y_offset.size) || 0;
                        }
                    } catch (error) {
                        $jltma_tooltip_x_offset = 0;
                        $jltma_tooltip_y_offset = 0;
                    }

                    // Parse width safely
                    var $jltma_el_tooltip_text_width = 200;
                    try {
                        if (elementSettings.ma_el_tooltip_text_width && elementSettings.ma_el_tooltip_text_width.size) {
                            $jltma_el_tooltip_text_width = parseInt(elementSettings.ma_el_tooltip_text_width.size) || 200;
                        }
                    } catch (error) {
                        $jltma_el_tooltip_text_width = 200;
                    }

                    // Final element and content validation
                    if (!currentTooltipElement || !currentTooltipElement.nodeType || currentTooltipElement.nodeType !== 1) {
                        return;
                    }

                    if (!$jltma_el_tooltip_text || !$jltma_el_tooltip_text.trim()) {
                        return;
                    }

                    // Check for extension tooltip conflicts
                    try {
                        var parentElement = currentTooltipElement.parentElement;
                        if (parentElement && parentElement.classList && parentElement.classList.contains('jltma-tooltip-element')) {
                            // Skip if extension tooltip is already handling this element
                            return;
                        }
                    } catch (error) {
                        // Continue with initialization
                    }

                    // Build secure tooltip configuration
                    var tooltipConfig = {
                        content: $jltma_el_tooltip_text,
                        animation: $jltma_tooltip_animation,
                        arrow: $jltma_tooltip_arrow,
                        duration: [$jltma_tooltip_duration, $jltma_tooltip_delay],
                        trigger: $jltma_tooltip_trigger,
                        animateFill: $animateFill,
                        flipOnUpdate: true,
                        maxWidth: Math.max(50, Math.min(1000, $jltma_el_tooltip_text_width)),
                        zIndex: 999,
                        allowHTML: false, // Security: disable HTML by default
                        theme: 'jltma-tooltip-tippy-' + scopeId,
                        interactive: true,
                        hideOnClick: true,
                        offset: [
                            Math.max(-500, Math.min(500, $jltma_tooltip_x_offset)),
                            Math.max(-500, Math.min(500, $jltma_tooltip_y_offset))
                        ],
                        appendTo: function() {
                            try {
                                return (typeof elementorFrontend !== 'undefined' && elementorFrontend.isEditMode())
                                    ? document.body : 'parent';
                            } catch (error) {
                                return 'parent';
                            }
                        },
                        onShow: function(instance) {
                            try {
                                if (instance && instance.popper && typeof jQuery !== 'undefined') {
                                    jQuery(instance.popper).attr('data-tippy-popper-id', scopeId);
                                }
                            } catch (error) {
                                // Silent fail
                            }
                        },
                        onCreate: function(instance) {
                            try {
                                // Ensure the instance reference element is properly set
                                if (instance && instance.reference && !instance.reference.nodeType) {
                                    // If reference is not a proper DOM element, try to fix it
                                    if (instance.reference.jquery) {
                                        instance.reference = instance.reference[0];
                                    }
                                }
                            } catch (error) {
                                // Silent fail
                            }
                        },
                        onDestroy: function() {
                            // Cleanup when tooltip is destroyed
                            if (currentTooltipElement) {
                                currentTooltipElement._tippyInstance = null;
                            }
                        }
                    };

                    // Handle arrow type securely
                    if ($jltma_tooltip_arrow && $jltma_tooltip_arrow_type === 'round') {
                        try {
                            if (typeof tippy !== 'undefined' && tippy.roundArrow) {
                                tooltipConfig.arrow = tippy.roundArrow;
                            }
                        } catch (error) {
                            tooltipConfig.arrow = true;
                        }
                    }

                    // Handle placement/follow cursor
                    if (elementSettings.jltma_tooltip_follow_cursor === 'yes' || elementSettings.jltma_tooltip_follow_cursor === true) {
                        tooltipConfig.followCursor = true;
                    } else if ($jltma_el_tooltip_direction && typeof $jltma_el_tooltip_direction === 'string') {
                        // Validate placement value
                        var validPlacements = ['top', 'bottom', 'left', 'right', 'top-start', 'top-end', 'bottom-start', 'bottom-end', 'left-start', 'left-end', 'right-start', 'right-end', 'auto'];
                        if (validPlacements.indexOf($jltma_el_tooltip_direction) !== -1) {
                            tooltipConfig.placement = $jltma_el_tooltip_direction;
                        }
                    }

                    // Handle custom trigger with security
                    if ($jltma_tooltip_trigger === 'manual' && $jltma_tooltip_custom_trigger && typeof $jltma_tooltip_custom_trigger === 'string') {
                        try {
                            // Sanitize selector to prevent XSS
                            var sanitizedSelector = $jltma_tooltip_custom_trigger.replace(/[<>'"]/g, '');
                            var customTriggerEl = document.querySelector(sanitizedSelector);

                            if (customTriggerEl && customTriggerEl.nodeType === 1) {
                                tooltipConfig.trigger = 'manual';
                                tooltipConfig.hideOnClick = false;

                                // Store event handler reference for cleanup
                                var customClickHandler = function() {
                                    // Get the instance from the actual tooltip element
                                    var targetEl = currentTooltipElement;
                                    if (targetEl && targetEl.jquery) {
                                        targetEl = targetEl[0];
                                    }

                                    var instance = targetEl ? targetEl._tippyInstance : null;
                                    if (instance && instance.state) {
                                        if (instance.state.isVisible) {
                                            instance.hide();
                                        } else {
                                            instance.show();
                                            setTimeout(function() {
                                                if (instance && !instance.state.isDestroyed) {
                                                    instance.hide();
                                                }
                                            }, 1500);
                                        }
                                    }
                                };

                                customTriggerEl.addEventListener('click', customClickHandler);

                                // Store reference for cleanup
                                if (!currentTooltipElement._maTooltipCleanup) {
                                    currentTooltipElement._maTooltipCleanup = [];
                                }
                                currentTooltipElement._maTooltipCleanup.push({
                                    element: customTriggerEl,
                                    event: 'click',
                                    handler: customClickHandler
                                });
                            }
                        } catch (error) {
                            // Silent fail for production
                        }
                    }

                    // Comprehensive cleanup of all existing tooltip instances
                    try {
                        // Find and destroy all existing tippy instances for this element
                        var allTippySelectors = [
                            '[data-tippy-popper-id="' + scopeId + '"]',
                            '.tippy-popper[data-tippy-root]',
                            '.tippy-box[data-theme*="' + scopeId + '"]'
                        ];

                        allTippySelectors.forEach(function(selector) {
                            try {
                                var instances = document.querySelectorAll(selector);
                                instances.forEach(function(popper) {
                                    if (popper && popper.parentNode) {
                                        popper.parentNode.removeChild(popper);
                                    }
                                });
                            } catch (error) {
                                // Silent cleanup
                            }
                        });

                        // Cleanup current element's tippy instances
                        if (currentTooltipElement._tippyInstance) {
                            currentTooltipElement._tippyInstance.destroy();
                            currentTooltipElement._tippyInstance = null;
                        }

                        if (currentTooltipElement._tippy) {
                            currentTooltipElement._tippy.destroy();
                            currentTooltipElement._tippy = null;
                        }

                        // Clean up previous event listeners
                        if (currentTooltipElement._maTooltipCleanup) {
                            currentTooltipElement._maTooltipCleanup.forEach(function(cleanup) {
                                try {
                                    cleanup.element.removeEventListener(cleanup.event, cleanup.handler);
                                } catch (error) {
                                    // Silent cleanup
                                }
                            });
                            currentTooltipElement._maTooltipCleanup = [];
                        }
                    } catch (error) {
                        // Silent cleanup
                    }

                    // Final pre-initialization validation
                    if (!currentTooltipElement || !currentTooltipElement.nodeType || currentTooltipElement.nodeType !== 1) {
                        return;
                    }

                    // Sanitize appendTo function for TippyJS compatibility
                    var sanitizedConfig = {};
                    for (var key in tooltipConfig) {
                        if (tooltipConfig.hasOwnProperty(key)) {
                            sanitizedConfig[key] = tooltipConfig[key];
                        }
                    }

                    if (typeof sanitizedConfig.appendTo === 'function') {
                        try {
                            var appendToResult = sanitizedConfig.appendTo();
                            if (appendToResult === 'parent') {
                                sanitizedConfig.appendTo = 'parent';
                            } else if (appendToResult && appendToResult.nodeType) {
                                sanitizedConfig.appendTo = appendToResult;
                            } else {
                                sanitizedConfig.appendTo = 'parent';
                            }
                        } catch (error) {
                            sanitizedConfig.appendTo = 'parent';
                        }
                    }

                    // Initialize Tippy with comprehensive error handling
                    try {
                        // Ensure we have a native DOM element, not jQuery object
                        var nativeElement = currentTooltipElement;
                        if (nativeElement && nativeElement.jquery) {
                            nativeElement = nativeElement[0];
                        }

                        // Final validation that it's a proper DOM element
                        if (!nativeElement || !nativeElement.nodeType || nativeElement.nodeType !== 1) {
                            throw new Error('Invalid DOM element for tooltip');
                        }

                        var tippyInstance = tippy(nativeElement, sanitizedConfig);

                        if (tippyInstance && Array.isArray(tippyInstance) && tippyInstance.length > 0) {
                            // Store reference on the native element
                            nativeElement._tippyInstance = tippyInstance[0];
                            currentTooltipElement._tippyInstance = tippyInstance[0];

                            // Mark as successfully initialized
                            $scope.data('ma-tooltip-active', true);
                        }
                    } catch (error) {
                        // Silent fail for production - tooltip functionality is not critical
                        return;
                    } finally {
                        // Always clear the initializing flag
                        if (currentTooltipElement) {
                            currentTooltipElement._maTooltipInitializing = false;
                        }
                    }

                } catch (error) {
                    // Catch any unexpected errors in initTooltip
                    if (currentTooltipElement) {
                        currentTooltipElement._maTooltipInitializing = false;
                    }
                    return;
                }
            }; // end initTooltip function

            // Initialize tooltip
            initTooltip();

            // Production-ready editor change detection
            if (typeof elementorFrontend !== 'undefined' && elementorFrontend.isEditMode()) {
                try {
                    $scope.data('ma-tooltip-initialized', true);

                    // Debounced change handler for performance
                    var changeTimeout = null;
                    var isChanging = false;

                    var handleTooltipChange = function() {
                        // Prevent overlapping changes
                        if (isChanging) {
                            return;
                        }

                        if (changeTimeout) {
                            clearTimeout(changeTimeout);
                        }

                        changeTimeout = setTimeout(function() {
                            try {
                                isChanging = true;

                                // Update element settings
                                elementSettings = getElementSettings($scope);

                                // Global cleanup of any orphaned tooltip instances
                                var orphanedTooltips = document.querySelectorAll('.tippy-popper:not([data-tippy-popper-id])');
                                orphanedTooltips.forEach(function(tooltip) {
                                    if (tooltip.parentNode) {
                                        tooltip.parentNode.removeChild(tooltip);
                                    }
                                });

                                // Clean reinitialize
                                initTooltip();

                                changeTimeout = null;

                                // Add extra delay before allowing next change
                                setTimeout(function() {
                                    isChanging = false;
                                }, 100);
                            } catch (error) {
                                isChanging = false;
                                // Silent fail for production
                            }
                        }, 200); // Increased debounce time
                    };

                    // Register proper Elementor handler for change detection
                    if (typeof elementorModules !== 'undefined' &&
                        elementorModules.frontend &&
                        elementorModules.frontend.handlers &&
                        elementorModules.frontend.handlers.Base) {

                        var MATooltipEditorHandler = elementorModules.frontend.handlers.Base.extend({
                            onElementChange: function(propertyName) {
                                if (propertyName && typeof propertyName === 'string' && (
                                    propertyName.indexOf('ma_el_tooltip') === 0 ||
                                    propertyName.indexOf('jltma_tooltip') === 0
                                )) {
                                    handleTooltipChange();
                                }
                            },
                            onDestroy: function() {
                                // Cleanup on handler destruction
                                if (changeTimeout) {
                                    clearTimeout(changeTimeout);
                                }
                                if (currentTooltipElement && currentTooltipElement._tippyInstance) {
                                    try {
                                        currentTooltipElement._tippyInstance.destroy();
                                    } catch (error) {
                                        // Silent cleanup
                                    }
                                }
                            }
                        });

                        // Register the handler
                        try {
                            elementorFrontend.elementsHandler.addHandler(MATooltipEditorHandler, {
                                $element: $scope
                            });
                        } catch (error) {
                            // Fallback to manual cleanup registration
                            $scope.one('remove', function() {
                                if (changeTimeout) {
                                    clearTimeout(changeTimeout);
                                }
                                if (currentTooltipElement && currentTooltipElement._tippyInstance) {
                                    try {
                                        currentTooltipElement._tippyInstance.destroy();
                                    } catch (error) {
                                        // Silent cleanup
                                    }
                                }
                            });
                        }
                    }
                } catch (error) {
                    // Silent fail for production - editor functionality is not critical for frontend
                }
            }

            // Global cleanup on page unload for memory management
            if (typeof window !== 'undefined' && window.addEventListener) {
                var cleanupTooltip = function() {
                    if (currentTooltipElement) {
                        if (currentTooltipElement._tippyInstance) {
                            try {
                                currentTooltipElement._tippyInstance.destroy();
                            } catch (error) {
                                // Silent cleanup
                            }
                        }
                        if (currentTooltipElement._maTooltipCleanup) {
                            currentTooltipElement._maTooltipCleanup.forEach(function(cleanup) {
                                try {
                                    cleanup.element.removeEventListener(cleanup.event, cleanup.handler);
                                } catch (error) {
                                    // Silent cleanup
                                }
                            });
                        }
                    }
                };

                // Register cleanup events
                window.addEventListener('beforeunload', cleanupTooltip);
                window.addEventListener('pagehide', cleanupTooltip);
            }
        },

        /**** MA Twitter Slider ****/

        MA_Twitter_Slider: function ($scope, $)
        {

            var $carousel = $scope.find('.jltma-twitter-carousel-slider');

            if (!$carousel.length)
            {
                return;
            }

            var $carouselContainer = $scope.find('.swiper'),
                $settings = $carousel.data('settings'),
                Swiper = elementorFrontend.utils.swiper;

            initSwiper();

            async function initSwiper()
            {
                var swiper = await new Swiper($carouselContainer, $settings);
                if ($settings.pauseOnHover)
                {
                    $($carouselContainer).hover(function ()
                    {
                        (this).swiper.autoplay.stop();
                    }, function ()
                    {
                        (this).swiper.autoplay.start();
                    });
                }
            };


        },


        MA_ParticlesBG: function ($scope, $)
        {
            // Helper function to check if we're in editor
            function isElementorEditor() {
                return typeof elementorFrontend !== 'undefined' && elementorFrontend.isEditMode();
            }

            // Debug logging (remove in production)
            // console.log('MA_ParticlesBG called for element:', $scope.data('id'));
            // console.log('Is editor:', isElementorEditor());
            // console.log('Has particle class:', $scope.hasClass('jltma-particle-yes'));
            // console.log('Data attribute:', $scope.attr('data-jltma-particle'));
            // console.log('Wrapper editor data:', $scope.find('.jltma-particle-wrapper').attr('data-jltma-particles-editor'));

            // Check if particles are enabled - either through class or data attribute or wrapper
            if ($scope.hasClass('jltma-particle-yes') || $scope.attr('data-jltma-particle') || $scope.find('.jltma-particle-wrapper').attr('data-jltma-particles-editor')) {

                let element_type = $scope.data('element_type');
                let sectionID = encodeURIComponent($scope.data('id'));
                let particlesJSON;

                // Get particle JSON based on context (editor vs frontend)
                if (!isElementorEditor()) {
                    // Frontend - get from data attribute
                    particlesJSON = $scope.attr('data-jltma-particle');
                } else {
                    // Editor - get from wrapper data attribute
                    particlesJSON = $scope.find('.jltma-particle-wrapper').attr('data-jltma-particles-editor');
                }

                if (('section' === element_type || 'column' === element_type || 'container' === element_type) && particlesJSON) {

                    // Frontend
                    if (!isElementorEditor()) {
                        // Create wrapper for frontend
                        $scope.prepend('<div class="jltma-particle-wrapper" id="jltma-particle-' + sectionID + '"></div>');

                        try {
                            let parsedData = JSON.parse(particlesJSON);
                            particlesJS('jltma-particle-' + sectionID, parsedData);

                            // Dispatch resize events to ensure proper rendering
                            setTimeout(function() {
                                window.dispatchEvent(new Event('resize'));
                            }, 500);

                            setTimeout(function() {
                                window.dispatchEvent(new Event('resize'));
                            }, 1500);
                        } catch(e) {
                            // console.warn('Invalid particle JSON:', e);
                        }

                    // Editor
                    } else {
                        if ($scope.hasClass('jltma-particle-yes')) {
                            try {
                                let parsedData = JSON.parse(particlesJSON);
                                particlesJS('jltma-particle-' + sectionID, parsedData);

                                // Set z-index for columns in editor
                                $scope.find('.elementor-column').css('z-index', 9);

                                setTimeout(function() {
                                    window.dispatchEvent(new Event('resize'));
                                }, 500);

                                setTimeout(function() {
                                    window.dispatchEvent(new Event('resize'));
                                }, 1500);
                            } catch(e) {
                                // console.warn('Invalid particle JSON:', e);
                            }
                        } else {
                            // Remove wrapper if particles are disabled
                            $scope.find('.jltma-particle-wrapper').remove();
                        }
                    }
                }
            }
        },

        MA_BgSlider: function ($scope, $)
        {
            // Check if we're in Elementor editor mode
            function isElementorEditor() {
                return typeof elementorFrontend !== 'undefined' && elementorFrontend.isEditMode();
            }

            // Check if this element has bg-slider enabled first
            if (!isElementorEditor()) {
                // Frontend: check for class (which is only added when bg slider is enabled and has images)
                if (!$scope.hasClass('has_ma_el_bg_slider')) {
                    return; // No bg slider configured or enabled
                }
            } else {
                // Editor: check for template elements (template only shows when enabled)
                if (!$scope.find('.ma-el-section-bs').length) {
                    return; // No bg slider template or not enabled
                }
            }

            var ma_el_slides = [], ma_el_slides_json = [], ma_el_transition, ma_el_animation, ma_el_custom_overlay, ma_el_overlay, ma_el_cover, ma_el_delay, ma_el_timer;
            var slider_images;

            // Get slider data based on editor vs frontend
            if (!isElementorEditor()) {
                // Frontend: use data from _before_render (on main element)
                slider_images = $scope.attr('data-ma-el-bg-slider-images');
            } else {
                // Editor: use data from _print_template (on inner wrapper)
                var slider_wrapper = $scope.find('.ma-el-section-bs-inner');
                if (slider_wrapper.length) {
                    slider_images = slider_wrapper.attr('data-ma-el-bg-slider');
                }
            }

            if (!slider_images) {
                return; // No slider data available
            }

            // Get configuration data based on context
            if (!isElementorEditor()) {
                // Frontend: read from main element
                ma_el_transition = $scope.attr('data-ma-el-bg-slider-transition');
                ma_el_animation = $scope.attr('data-ma-el-bg-slider-animation');
                ma_el_custom_overlay = $scope.attr('data-ma-el-bg-custom-overlay');
                ma_el_cover = $scope.attr('data-ma-el-bg-slider-cover');
                ma_el_delay = $scope.attr('data-ma-el-bs-slider-delay');
                ma_el_timer = $scope.attr('data-ma-el-bs-slider-timer');

                if (ma_el_custom_overlay == 'yes') {
                    ma_el_overlay = jltma_scripts.plugin_url + '/assets/vendor/vegas/overlays/00.png';
                } else {
                    var overlay_file = $scope.attr('data-ma-el-bg-slider-overlay');
                    if (overlay_file) {
                        ma_el_overlay = jltma_scripts.plugin_url + '/assets/vendor/vegas/overlays/' + overlay_file + '.png';
                    } else {
                        ma_el_overlay = jltma_scripts.plugin_url + '/assets/vendor/vegas/overlays/00.png';
                    }
                }
            } else {
                // Editor: read from template wrapper
                var slider_wrapper = $scope.find('.ma-el-section-bs-inner');
                ma_el_transition = slider_wrapper.attr('data-ma-el-bg-slider-transition');
                ma_el_animation = slider_wrapper.attr('data-ma-el-bg-slider-animation');
                ma_el_custom_overlay = slider_wrapper.attr('data-ma-el-bg-custom-overlay');
                ma_el_cover = slider_wrapper.attr('data-ma-el-bg-slider-cover');
                ma_el_delay = slider_wrapper.attr('data-ma-el-bs-slider-delay');
                ma_el_timer = slider_wrapper.attr('data-ma-el-bs-slider-timer');

                if (ma_el_custom_overlay == 'yes') {
                    ma_el_overlay = jltma_scripts.plugin_url + '/assets/vendor/vegas/overlays/00.png';
                } else {
                    var overlay_file = slider_wrapper.attr('data-ma-el-bg-slider-overlay');
                    if (overlay_file && overlay_file !== '00.png') {
                        ma_el_overlay = jltma_scripts.plugin_url + '/assets/vendor/vegas/overlays/' + overlay_file;
                    } else {
                        ma_el_overlay = jltma_scripts.plugin_url + '/assets/vendor/vegas/overlays/00.png';
                    }
                }
            }

            // Split images and create slides array
            ma_el_slides = slider_images.split(",");

            jQuery.each(ma_el_slides, function (key, value) {
                var slide = [];
                slide.src = value;
                ma_el_slides_json.push(slide);
            });

            // Create slider wrapper if it doesn't exist
            var slider_container;
            if (!$scope.find('.ma-el-section-bs').length) {
                $scope.prepend('<div class="ma-el-section-bs"><div class="ma-el-section-bs-inner"></div></div>');
            }
            slider_container = $scope.find('.ma-el-section-bs-inner');

            slider_container.vegas({
                slides: ma_el_slides_json,
                transition: ma_el_transition,
                animation: ma_el_animation,
                overlay: ma_el_overlay,
                cover: ma_el_cover == 'true' ? true : false,
                delay: parseInt(ma_el_delay) || 5000,
                timer: ma_el_timer == 'true' ? true : false,
                init: function () {
                    if (ma_el_custom_overlay == 'yes') {
                        var ob_vegas_overlay = slider_container.children('.vegas-overlay');
                        ob_vegas_overlay.css('background-image', '');
                    }
                }
            });
        },

        MA_AnimatedGradient: function ($scope, $)
        {

            if ($scope.hasClass('ma-el-animated-gradient-yes'))
            {
                let color = $scope.data('color') || $scope.attr('data-color');
                let angle = $scope.data('angle') || $scope.attr('data-angle');
                let duration = $scope.data('duration') || $scope.attr('data-duration') || '6s';
                let smoothness = parseInt($scope.data('smoothness') || $scope.attr('data-smoothness') || 3);
                let easing = $scope.data('easing') || $scope.attr('data-easing') || 'cubic-bezier(0.4, 0.0, 0.2, 1)';

                if (!color || !angle) {
                    return;
                }

                // Parse colors from the comma-separated string
                let colors = color.split(',');
                if (colors.length < 2) {
                    return;
                }

                // Create animated gradient CSS with proper timing distribution
                let animationName = 'jltma-animated-gradient-' + Math.random().toString(36).substring(2, 11);
                let keyframes = `@keyframes ${animationName} {`;
                let totalSteps = colors.length;

                // Create keyframes with proper timing distribution
                for (let i = 0; i <= totalSteps; i++) {
                    let percentage = (i / totalSteps) * 100;
                    let currentColorIndex = i % colors.length;
                    let nextColorIndex = (i + 1) % colors.length;

                    // Main keyframe at start of segment
                    keyframes += `${percentage.toFixed(2)}% { background: linear-gradient(${angle}, ${colors[currentColorIndex].trim()}, ${colors[nextColorIndex].trim()}); }`;

                    // Add intermediate keyframes for smooth transitions (based on smoothness setting)
                    if (i < totalSteps) {
                        let segmentSize = (100 / totalSteps);

                        for (let j = 1; j <= smoothness; j++) {
                            let interpPercentage = percentage + (segmentSize * (j / (smoothness + 1)));
                            let interpColorIndex = nextColorIndex;
                            let interpNextColorIndex = (nextColorIndex + 1) % colors.length;
                            keyframes += `${interpPercentage.toFixed(2)}% { background: linear-gradient(${angle}, ${colors[interpColorIndex].trim()}, ${colors[interpNextColorIndex].trim()}); }`;
                        }
                    }
                }

                keyframes += '}';

                // Add keyframes to document
                let style = document.createElement('style');
                style.textContent = keyframes;
                document.head.appendChild(style);

                // Apply the animation
                $scope.css({
                    'animation': `${animationName} ${duration} ${easing} infinite`,
                    'background-size': '400% 400%'
                });

                // For editor mode - handle the .animated-gradient div
                if ($scope.hasClass('elementor-element-edit-mode'))
                {
                    let editorGradient = $scope.find('.animated-gradient');
                    if (editorGradient.length > 0) {
                        let editorColor = editorGradient.data('color') || editorGradient.attr('data-color');
                        let editorAngle = editorGradient.data('angle') || editorGradient.attr('data-angle');
                        let editorDuration = editorGradient.data('duration') || editorGradient.attr('data-duration') || '6s';

                        if (editorColor && editorAngle) {
                            let editorColors = editorColor.split(',');
                            if (editorColors.length >= 2) {
                                let editorAnimationName = 'jltma-animated-gradient-editor-' + Math.random().toString(36).substring(2, 11);
                                let editorKeyframes = `@keyframes ${editorAnimationName} {`;
                                let totalSteps = editorColors.length;

                                // Create keyframes with proper timing distribution
                                for (let i = 0; i <= totalSteps; i++) {
                                    let percentage = (i / totalSteps) * 100;
                                    let currentColorIndex = i % editorColors.length;
                                    let nextColorIndex = (i + 1) % editorColors.length;

                                    // Main keyframe
                                    editorKeyframes += `${percentage.toFixed(2)}% { background: linear-gradient(${editorAngle}, ${editorColors[currentColorIndex].trim()}, ${editorColors[nextColorIndex].trim()}); }`;

                                    // Add intermediate keyframes for smooth transitions (based on smoothness setting)
                                    if (i < totalSteps) {
                                        let segmentSize = (100 / totalSteps);

                                        for (let j = 1; j <= smoothness; j++) {
                                            let interpPercentage = percentage + (segmentSize * (j / (smoothness + 1)));
                                            let interpColorIndex = nextColorIndex;
                                            let interpNextColorIndex = (nextColorIndex + 1) % editorColors.length;
                                            editorKeyframes += `${interpPercentage.toFixed(2)}% { background: linear-gradient(${editorAngle}, ${editorColors[interpColorIndex].trim()}, ${editorColors[interpNextColorIndex].trim()}); }`;
                                        }
                                    }
                                }

                                editorKeyframes += '}';

                                let editorStyle = document.createElement('style');
                                editorStyle.textContent = editorKeyframes;
                                document.head.appendChild(editorStyle);

                                editorGradient.css({
                                    'animation': `${editorAnimationName} ${editorDuration} ${easing} infinite`,
                                    'background-size': '400% 400%'
                                });
                            }
                        }
                    }
                }
            }

        },


        MA_Image_Comparison: function ($scope, $)
        {
            var $jltma_image_comp_wrap = $scope.find('.jltma-image-comparison').eq(0),
                $jltma_image_data = $jltma_image_comp_wrap.data('image-comparison-settings');

            $jltma_image_comp_wrap.twentytwenty({
                default_offset_pct: $jltma_image_data.visible_ratio,
                orientation: $jltma_image_data.orientation,
                before_label: $jltma_image_data.before_label,
                after_label: $jltma_image_data.after_label,
                move_slider_on_hover: $jltma_image_data.slider_on_hover,
                move_with_handle_only: $jltma_image_data.slider_with_handle,
                click_to_move: $jltma_image_data.slider_with_click,
                no_overlay: $jltma_image_data.no_overlay
            });
        },

        MA_BarCharts: function BarChart($scope) {
            jltMAObserveTarget($scope[0], function () {
                var $container = $scope.find('.jltma-bar-chart-container'),
                    $chart_canvas = $scope.find('#jltma-bar-chart'),
                    settings = $container.data('settings');
                if ($container.length) {
                    new Chart($chart_canvas, settings);
                }
            });
        },

        MA_PieCharts: function ($scope, $)
        {
            jltMAObserveTarget($scope[0], function () {
                $scope.find('.ma-el-piechart .ma-el-percentage').each(function () {
                    var track_color = $(this).data('track-color');
                    var bar_color = $(this).data('bar-color');

                    $(this).easyPieChart({
                        animate: 2000,
                        lineWidth: 10,
                        barColor: bar_color,
                        trackColor: track_color,
                        scaleColor: false,
                        lineCap: 'square',
                        size: 220
                    });
                });
            });
        },

        ProgressBars: function ($scope, $)
        {
            jltMAObserveTarget($scope[0], function () {
                $scope.find('.jltma-stats-bar-content').each(function () {
                    var dataperc = $(this).data('perc');
                    $(this).animate({ "width": dataperc + "%" }, dataperc * 20);
                });
            });
        },


        // Toggle Content
        MA_Toggle_Content: function ($scope, $)
        {
            Master_Addons.getElementSettings = getElementSettings($scope);
            var $wrapper = $scope.find('.jltma-toggle-content'),
                toggleElementArgs = {
                    active: Master_Addons.getElementSettings.jltma_toggle_content_active_index,
                };

            if ('' !== Master_Addons.getElementSettings.jltma_toggle_content_indicator_color)
            {
                toggleElementArgs.indicatorColor = Master_Addons.getElementSettings.jltma_toggle_content_indicator_color;
            }

            if (Master_Addons.getElementSettings.jltma_toggle_content_indicator_speed.size)
            {
                toggleElementArgs.speed = Master_Addons.getElementSettings.jltma_toggle_content_indicator_speed.size;
            }

            if (elementorFrontend.isEditMode())
            {
                toggleElementArgs.watchControls = true;
            }

            $wrapper.MA_ToggleElement(toggleElementArgs);
        },


        // Comment Form reCaptcha
        MA_Comment_Form_reCaptcha: function ($scope, $)
        {
            Master_Addons.getElementSettings = getElementSettings($scope);
            var $commentsWrapper = $scope.find(".jltma-comments-wrap"),
                $comments_recaptcha_data = $commentsWrapper.data("recaptcha"),
                $recaptcha_protected = $commentsWrapper.data("jltma-comment-settings"),
                jltma_comment_form;

            if ($recaptcha_protected.reCaptchaprotected == "yes")
            {
                var onloadCallback = function ()
                {
                    jltma_comment_form = grecaptcha.render("jltma_comment_form", {
                        "sitekey": $comments_recaptcha_data.sitekey,
                        "theme": $comments_recaptcha_data.theme
                    });
                    grecaptcha.reset(jltma_comment_form);
                };
            }

        },


        // Master Addons: Counter Up
        MA_Counter_Up: function ($scope, $)
        {
            var $counterup = $scope.find(".jltma-counter-up-number");

            if ($.isFunction($.fn.counterUp))
            {
                $counterup.counterUp({
                    duration: 2000,
                    delay: 15,

                });
            }
        },


        // Master Addons: Countdown Timer
        MA_CountdownTimer: function ($scope, $)
        {

            var $countdownWidget = $scope.find(".jltma-widget-countdown");
            $.fn.MasterCountDownTimer = function ()
            {
                var $wrapper = $(this).find(".jltma-countdown-wrapper"),
                    data = {
                        year: $wrapper.data("countdown-year"),
                        month: $wrapper.data("countdown-month"),
                        day: $wrapper.data("countdown-day"),
                        hour: $wrapper.data("countdown-hour"),
                        min: $wrapper.data("countdown-min"),
                        sec: $wrapper.data("countdown-sec")
                    },
                    isInfinite = $wrapper.data("countdown-infinite") === 'yes',
                    // Target date is calculated server-side for infinite mode
                    // This ensures all users see synchronized countdown
                    targetDate = new Date(data.year, data.month, data.day, data.hour, data.min, data.sec);

                var $year = $wrapper.find('.jltma-countdown-year'),
                    $month = $wrapper.find('.jltma-countdown-month'),
                    $day = $wrapper.find('.jltma-countdown-day'),
                    $hour = $wrapper.find('.jltma-countdown-hour'),
                    $min = $wrapper.find('.jltma-countdown-min'),
                    $sec = $wrapper.find('.jltma-countdown-sec');

                // Store interval ID so we can clear it if needed
                var countdownInterval = setInterval(function ()
                {
                    var currentTime = new Date();
                    var diffTime = (Date.parse(targetDate) - Date.parse(currentTime)) / 1000;

                    // If countdown is complete
                    if (diffTime <= 0) {
                        // Stop the countdown and show zeros
                        $year.text(0);
                        $month.text(0);
                        $day.text(0);
                        $hour.text(0);
                        $min.text(0);
                        $sec.text(0);

                        // For infinite mode, keep showing zeros
                        // User must reload page to see next interval
                        clearInterval(countdownInterval);
                        return;
                    }

                    // Calculate time components correctly
                    var totalSeconds = diffTime;

                    var years = Math.floor(totalSeconds / 31536000); // 365 days
                    totalSeconds %= 31536000;

                    var months = Math.floor(totalSeconds / 2592000); // 30 days
                    totalSeconds %= 2592000;

                    var days = Math.floor(totalSeconds / 86400); // 24 hours
                    totalSeconds %= 86400;

                    var hours = Math.floor(totalSeconds / 3600); // 60 minutes
                    totalSeconds %= 3600;

                    var minutes = Math.floor(totalSeconds / 60); // 60 seconds
                    var seconds = Math.floor(totalSeconds % 60);

                    $year.text(years);
                    $month.text(months);
                    $day.text(days);
                    $hour.text(hours);
                    $min.text(minutes);
                    $sec.text(seconds);
                }, 1e3)
            }, $countdownWidget.each(function ()
            {
                $(this).MasterCountDownTimer()
            })


        },

        /**
         * Fancybox popup
         */
        MA_Fancybox_Popup: function ($scope, $)
        {
            (function ($)
            {
                if ($.isFunction($.fn.fancybox))
                {
                    $("[data-fancybox]").fancybox({});
                }
            })(jQuery);
        },

        /*
        * REVEAL
        */
        MA_Reveal: function ($scope, $)
        {

            Master_Addons.MA_Reveal.elementSettings = getElementSettings($scope);

            var rev1,
                isReveal = false;

            Master_Addons.MA_Reveal.revealAction = function ()
            {
                rev1 = new RevealFx(revealistance, {
                    revealSettings: {
                        bgcolor: Master_Addons.MA_Reveal.elementSettings.reveal_bgcolor,
                        direction: Master_Addons.MA_Reveal.elementSettings.reveal_direction,
                        duration: Number(Master_Addons.MA_Reveal.elementSettings.reveal_speed.size) * 100,
                        delay: Number(Master_Addons.MA_Reveal.elementSettings.reveal_delay.size) * 100,
                        onCover: function (contentEl, revealerEl)
                        {
                            contentEl.style.opacity = 1;
                        }
                    }
                });
            }

            Master_Addons.MA_Reveal.runReveal = function ()
            {
                rev1.reveal();
            }

            if (Master_Addons.MA_Reveal.elementSettings.enabled_reveal)
            {

                var revealId = '#reveal-' + $scope.data('id'),
                    revealistance = document.querySelector(revealId);

                if (!jQuery(revealId).hasClass('block-revealer')) {
                    Master_Addons.MA_Reveal.revealAction();
                }

                Master_Addons.MA_Reveal.waypointOptions = {
                    offset: '100%',
                    triggerOnce: true
                };

                jltMAObserveTarget(revealistance, Master_Addons.MA_Reveal.runReveal, Master_Addons.MA_Reveal.waypointOptions);
            }
        },

        /*
        * MA Rellax
        */
        MA_Rellax: function ($scope, $)
        {

            var elementSettings = getElementSettings($scope);
            var rellax = null;

            $(window).on('resize', function ()
            {

                if (rellax)
                {
                    rellax.destroy();
                    if (rellax)
                        initRellax();
                }
            });

            var initRellax = function ()
            {
                if (elementSettings.enabled_rellax)
                {
                    // Check if Rellax library is available
                    if (typeof Rellax === 'undefined') {
                        // console.warn('MA Rellax: Rellax library is not loaded');
                        return;
                    }

                    currentDevice = elementorFrontend.getCurrentDeviceMode();

                    var setting_speed = 'speed_rellax';
                    var value_speed = 0;

                    if (currentDevice != 'desktop')
                    {
                        setting_speed = 'speed_rellax_' + currentDevice;
                    }

                    try {
                        if (eval('elementSettings.' + setting_speed + '.size'))
                            value_speed = eval('elementSettings.' + setting_speed + '.size');
                    } catch (error) {
                        // Use default value if setting evaluation fails
                    }

                    var rellaxId = '#rellax-' + $scope.data('id');

                    if ($(rellaxId).length) {
                        try {
                            rellax = new Rellax(rellaxId, {
                                speed: value_speed
                            });
                            isRellax = true;
                        } catch (error) {
                            // console.error('MA Rellax: Failed to initialize Rellax:', error);
                        }
                    }
                };
            };

            initRellax();

        },

        MA_Rellax_Final: function (panel, model, view)
        {
            Master_Addons.getElementSettings = getElementSettings($scope);
            var $scope = view.$el;
            var scene = $scope.find('#scene');
        },


        // Entrance Animations
        MA_Entrance_Animation: function ($scope, $)
        {

            $scope = $scope || $(this);

            var $target = $scope.hasClass('jltma-appear-watch-animation') ? $scope : $scope.find('.jltma-appear-watch-animation'),
                hasAnimation = $('body').hasClass('jltma-page-animation');

            if (!$target.length)
            {
                return;
            }

            if (hasAnimation)
            {
                document.body.addEventListener('JltmaPageAnimationDone', function (event)
                {
                    $target.appearl({
                        offset: '200px',
                        insetOffset: '0px'
                    }).one('appear', function (event, data)
                    {
                        this.classList.add('jltma-animated');
                        this.classList.add('jltma-animated-once');
                    });
                });
            } else
            {
                $target.appearl({
                    offset: '200px',
                    insetOffset: '0px'
                }).one('appear', function (event, data)
                {
                    this.classList.add('jltma-animated');
                    this.classList.add('jltma-animated-once');
                });
            }

        },


        // Wrapper Link
        MA_Wrapper_Link: function ($scope, $)
        {
            // First, unbind any existing handlers to prevent multiple bindings
            $('body').off('click.onWrapperLink', '[data-jltma-wrapper-link]');

            // Now bind the handler
            $('body').on('click.onWrapperLink', '[data-jltma-wrapper-link]', function(e) {
                e.preventDefault();
                e.stopPropagation();
                var $wrapper = $(this),
                  data = $wrapper.data("jltma-wrapper-link"),
                  id = $wrapper.data("id"),
                  anchor = document.createElement("a"),
                  anchorReal,
                  timeout = 100;
                anchor.id = "master-addons-wrapper-link-" + id;
                anchor.href = data.url;
                anchor.target = data.is_external ? "_blank" : "_self";
                anchor.rel = data.nofollow ? "nofollow noreferer" : "";
                anchor.style.display = "none";
                document.body.appendChild(anchor);
                anchorReal = document.getElementById(anchor.id);

                // anchorReal.click();
                if (data && data.url) {
                    if (data.is_external) {
                        // For external links, use window.open for better Safari compatibility
                        window.open(data.url, '_blank', data.nofollow ? 'noopener,noreferrer' : 'noopener');
                    } else {
                        // For internal links, use location.href for better Safari/iPad compatibility
                        window.location.href = data.url;
                    }
                }
            });
        },

        /**
         * Restrict Content
         */
        MA_Restrict_Content_Ajax: function ($scope, $)
        {
            Master_Addons.getElementSettings = getElementSettings($scope);

            var $restrictwrapper = $scope.find('.jltma-restrict-content-wrap').eq(0),
                $scopeId = $scope.data('id'),
                $restrict_layout = $restrictwrapper.data('restrict-layout-type'),
                $restrict_type = $restrictwrapper.data('restrict-type'),
                $error_message = $restrictwrapper.data('error-message'),
                $rc_ajaxify = $restrictwrapper.data('rc-ajaxify'),

                $storageID = 'ma_el_rc_' + $scopeId,
                $formID = $scope.find('.jltma-restrict-form').eq(0).data('form-id'),

                // Content
                $content_div = '#restrict-content-' + $scopeId,

                // Popup Settings
                $popup = $scope.find('.jltma-restrict-content-popup-content'),
                $content_pass = $restrictwrapper.data('content-pass') ? $restrictwrapper.data('content-pass') : '',
                $popup_type = $popup.data('popup-type') ? $popup.data('popup-type') : '',

                // Restrict Age
                $age_wrapper = $scope.find('.jltma-restrict-age-wrapper').eq(0),

                $restrict_age = {
                    min_age: $age_wrapper.data('min-age'),
                    age_type: $age_wrapper.data('age-type'),
                    age_title: $age_wrapper.data('age-title'),
                    age_content: $age_wrapper.data('age-content'),
                    age_submit: $('#' + $formID).find('button[name="submit"]').val(),
                    checkbox_msg: $age_wrapper.data('checkbox-msg') ? $age_wrapper.data('checkbox-msg') : "",
                    empty_bday: $age_wrapper.data('empty-bday') ? $age_wrapper.data('empty-bday') : "",
                    non_exist_bday: $age_wrapper.data('non-exist-bday') ? $age_wrapper.data('non-exist-bday') : ""
                };

            //Check it the user has been accpeted the agreement
            if (localStorage.getItem($storageID))
            {

                $('.jltma-rc-button').addClass('d-none');
                $('#' + $formID).addClass('d-none');
                $('#jltma-restrict-age-' + $scopeId).removeClass('card');
                $('#jltma-restrict-age-' + $scopeId).removeClass('text-center');
                $('#restrict-content-' + $scopeId).addClass('d-block');

            } else
            {

                // Dom Selector for Onpage/Popup
                if ($restrict_layout == "popup")
                {
                    var dom_selector = '#jltma-rc-modal-' + $scopeId;
                } else
                {
                    var dom_selector = '#jltma-restrict-content-' + $scopeId;
                }

                $(dom_selector).on('click', '.jltma_ra_select', function ()
                {
                    var wrap = $(this).closest('.jltma_ra_select_wrap');
                    if (!wrap.find('.jltma_ra_options').hasClass('jltma_ra_active'))
                    {
                        $('.jltma_ra_options').removeClass('jltma_ra_active');
                        wrap.find('.jltma_ra_options').addClass('jltma_ra_active');
                        wrap.find('.jltma_ra_options').find('li:contains("' + wrap.find('.jltma_ra_select_val').html() + '")').addClass('jltma_ra_active');
                    }
                    else
                    {
                        wrap.find('.jltma_ra_options').removeClass('jltma_ra_active');
                    }
                });

                $(dom_selector).on('click', '.jltma_ra_options ul li', function ()
                {
                    var wrap = $(this).closest('.jltma_ra_select_wrap');
                    wrap.find('.jltma_ra_select_val').html($(this).html());
                    wrap.find('select').val($(this).attr('data-val'));
                    wrap.find('.jltma_ra_options').removeClass('jltma_ra_active');
                });

                $(dom_selector).on('mouseover', '.jltma_ra_options ul li', function ()
                {
                    if ($('.jltma_ra_options ul li').hasClass('jltma_ra_active'))
                    {
                        $('.jltma_ra_options ul li').removeClass('jltma_ra_active');
                    }
                });

                $(document).click(function (e)
                {
                    if ($(e.target).attr('class') != 'jltma_ra_select' && !$('.jltma_ra_select').find($(e.target)).length)
                    {
                        if ($('.jltma_ra_options.jltma_ra_active').length)
                        {
                            $('.jltma_ra_options').removeClass('jltma_ra_active');
                        }
                    }
                });


                //Onload Fancybox
                if ($popup_type == "windowload" || $popup_type == "windowloadfullscreen")
                {
                    $("#ma-el-rc-modal-hidden").fancybox().trigger('click');
                } else
                {
                    $("[data-fancybox]").fancybox({});
                }

                $(dom_selector).on('submit', '#' + $formID, function (event)
                {
                    event.preventDefault();

                    var form = $(this);
                    form.find('.jltma_rc_result').remove();

                    $.ajax({
                        type: "POST",
                        url: jltma_scripts.ajaxurl,
                        data: {
                            action: 'jltma_restrict_content',
                            fields: form.serialize(),
                            restrict_type: $restrict_type,
                            error_message: $error_message,
                            content_pass: $content_pass,
                            restrict_age: $restrict_age
                        },
                        cache: false,
                        success: function (result)
                        {

                            try
                            {
                                result = jQuery.parseJSON(result);

                                if (result['result'] == 'success')
                                {
                                    $('#restrict-content-' + $scopeId).removeClass('d-none').addClass('d-block');

                                    //Custom Classes add/remove
                                    $('#' + $formID).addClass('d-none');
                                    $('#jltma-restrict-age-' + $scopeId).removeClass('card');
                                    $('#jltma-restrict-age-' + $scopeId).removeClass('text-center');


                                    //Set a cookie to remember the state
                                    localStorage.setItem($storageID, true);
                                    $.fancybox.close();

                                    $('.jltma-rc-button').addClass('d-none');

                                } else if (result['result'] == 'validate')
                                {
                                    $('#' + $formID + ' ' + '.jltma_rc_submit').after('<div class="jltma_rc_result"><span class="eicon-info-circle-o"></span> ' + result['output'] + '</div>');
                                } else
                                {
                                    throw 0;
                                }
                            }
                            catch (err)
                            {
                                $('#' + $formID + ' ' + '.jltma_rc_submit').after('<div class="jltma_rc_result"><span class="eicon-loading"></span> Failed, please try again.</div>');
                            }

                        }
                    }); // ajax part end

                }); // End of Submit Event


            } // localstorage


        },

        MA_Restrict_Content: function ($scope, $)
        {

            try
            {
                (function ($)
                {
                    Master_Addons.getElementSettings = getElementSettings($scope);

                    var $restrictwrapper = $scope.find('.jltma-restrict-content-wrap').eq(0),
                        $scopeId = $scope.data('id'),
                        $restrict_layout = $restrictwrapper.data('restrict-layout-type'),
                        $restrict_type = $restrictwrapper.data('restrict-type'),

                        $storageID = 'ma_el_rc',

                        // Popup Settings
                        $popup = $scope.find('.jltma-restrict-content-popup-content'),
                        $content_pass = $restrictwrapper.data('content-pass'),

                        // Restrict Age
                        $age_wrapper = $scope.find('.jltma-restrict-age-wrapper').eq(0),
                        $min_age = $age_wrapper.data('min-age'),
                        $age_type = $age_wrapper.data('age-type'),
                        $age_title = $age_wrapper.data('age-title'),
                        $age_content = $age_wrapper.data('age-content'),
                        $checkbox_msg = $age_wrapper.data('checkbox-msg');

                    Master_Addons.MA_Restrict_Content_Ajax($scope, $);

                })(jQuery);
            } catch (e)
            {
                //We can also throw from try block and catch it here
                // No Error Show
            }
        },

        MA_Nav_Menu: function ($scope, $)
        {
            Master_Addons.getElementSettings = getElementSettings($scope);

            var $menuContainer = $scope.find(".jltma-nav-menu-element"),
                $menuID = $menuContainer.data("menu-id"),
                $menu_type = $menuContainer.data("menu-layout"),
                $menu_trigger = $menuContainer.data("menu-trigger"),
                $menu_offcanvas = $menuContainer.data("menu-offcanvas"),
                $menu_toggletype = $menuContainer.data("menu-toggletype"),
                $submenu_animation = $menuContainer.data("menu-animation"),
                $menu_container_id = $menuContainer.data("menu-container-id"),
                $sticky_type = $menuContainer.data("sticky-type"),
                navbar_height = $('#' + $menu_container_id).outerHeight(),
                menu_container_selector = $('#' + $menu_container_id);

            // refresh window on resize
            // $(window).on('resize',function(){location.reload();});


            /* One Page Menu */
            if ($menu_type == "onepage")
            {

                $(document).on('click', '.jltma-navbar-nav li a', function (e)
                {
                    if ($(this).attr('href'))
                    {
                        var self = $(this),
                            el = self.get(0),
                            href = el.href,
                            hasHash = href.indexOf('#'),
                            enable = self.parents('.jltma-navbar-nav-default').hasClass('jltma-one-page-enabled');

                        if (hasHash !== -1 && (href.length > 1) && enable && (el.pathname == window.location.pathname))
                        {
                            e.preventDefault();
                            self.parents('.jltma-menu-container').find('.jltma-close').trigger('click');
                        }
                    }
                });

                // Mobile Menu close outside clicking
                $(document).on('click', function (e)
                {
                    var click = $(e.target),
                        opened = $(".navbar-collapse").hasClass("show");
                    if (opened === true)
                    {
                        $(".jltma-one-page-enabled").removeClass('show');
                    }
                });

            } else
            {


                // Submenu Hover Animation Effect
                var submenu_animate_class = 'animated ' + $submenu_animation,
                    submenu_selector = $('.jltma-dropdown.jltma-sub-menu');
                $("#" + $menuID + " .jltma-menu-has-children").hover(function ()
                {
                    if (submenu_selector.hasClass('fade-up'))
                    {
                        submenu_selector.removeClass('fade-up');
                    }
                    if (submenu_selector.hasClass('fade-down'))
                    {
                        submenu_selector.removeClass('fade-down');
                    }
                    $('.jltma-dropdown.jltma-sub-menu').addClass($submenu_animation);
                });



                /* On Scroll Fixed Navbar */
                ///////////////// fixed menu on scroll for Desktop
                if ($sticky_type == "fixed-onscroll")
                {
                    if ($(window).width() > 768)
                    {
                        $(function ()
                        {
                            $(window).scroll(function ()
                            {
                                var scroll = $(window).scrollTop();
                                if (scroll >= 10)
                                {
                                    menu_container_selector.removeClass('' + $menu_container_id + '').addClass("jltma-on-scroll-fixed");
                                } else
                                {
                                    menu_container_selector.removeClass("jltma-on-scroll-fixed").addClass('' + $menu_container_id + '');
                                }
                            });
                        });
                    }
                }


                if ($sticky_type == "sticky-top")
                {
                    if ($(window).width() > 768)
                    {
                        $(function ()
                        {
                            $(window).scroll(function ()
                            {
                                var scroll = $(window).scrollTop();
                                if (scroll >= 10)
                                {
                                    menu_container_selector.removeClass('' + $menu_container_id + '').addClass("sticky-top");
                                } else
                                {
                                    menu_container_selector.removeClass("sticky-top").addClass('' + $menu_container_id + '');
                                }
                            });
                        });
                    }
                }


                if ($sticky_type == "smart-scroll")
                {

                    // add padding top to show content behind navbar
                    $('body').css('padding-top', navbar_height + 'px');
                    menu_container_selector.addClass('jltma-smart-scroll');

                    //////////////////////// detect scroll top or down
                    if ($('.jltma-smart-scroll').length > 0)
                    { // check if element exists
                        var last_scroll_top = 0;

                        $(window).on('scroll', function ()
                        {
                            var scroll_top = $(this).scrollTop();
                            if (scroll_top < last_scroll_top)
                            {
                                $('.jltma-smart-scroll').removeClass('scrolled-down').addClass('scrolled-up');
                            }
                            else
                            {
                                $('.jltma-smart-scroll').removeClass('scrolled-up').addClass('scrolled-down');
                            }
                            last_scroll_top = scroll_top;
                        });
                    }
                }


                if ($sticky_type == "nav-fixed-top")
                {
                    if ($(window).width() > 768)
                    {
                        $(function ()
                        {
                            // add padding top to show content behind navbar
                            // $('body').css('padding-top', $('#' + $menu_container_id ).outerHeight() + 'px');
                            $('body').css('padding-top', navbar_height + 'px');
                            menu_container_selector.addClass('jltma-fixed-top');

                        });
                    }
                }



                // Menu Settings Megamenu Trigger Effect
                // if ($('.jltma-has-megamenu').hasClass('jltma-megamenu-click')) {
                //     $('.jltma-megamenu-click').on('click', function (e) {
                //         e.preventDefault();
                //         e.stopPropagation();
                //         $(this).toggleClass("show");
                //         $('.dropdown-menu.jltma-megamenu').toggleClass("show");
                //     });
                // }
                // else {
                //     $('.jltma-has-megamenu').on('hover', function (e) {
                //         e.preventDefault;
                //         e.stopPropagation();
                //         $(this).toggleClass("show");
                //         $('.dropdown-menu.jltma-megamenu').toggleClass("show");
                //     });
                // }


                if ($menu_toggletype == "toggle")
                {

                    // Menu Toggle
                    $("#" + $menuID + " .navbar-nav.toggle .jltma-menu-dropdown-toggle").click(function (e)
                    {
                        $(this).parents(".dropdown").toggleClass("open");
                        e.stopPropagation();
                    });
                }


                if ($menu_offcanvas == "toggle-bar")
                {
                    $(".jltma-nav-panel .navbar-toggler").on("click", function (e)
                    {
                        $('.jltma-burger').toggleClass("jltma-close");
                    });
                }

                // Off Canvas Menu
                if ($menu_offcanvas == "offcanvas" || $menu_offcanvas == "overlay")
                {

                    // /// offcanvas onmobile
                    $(".jltma-nav-panel .navbar-toggler").on("click", function (e)
                    {
                        e.preventDefault();
                        e.stopPropagation();
                        var offcanvas_id = $(this).attr('data-trigger');
                        $(offcanvas_id).toggleClass("show");
                        $('body').toggleClass("offcanvas-active");
                        $(".jltma-nav-panel ").toggleClass("offcanvas-nav");
                        if ($menu_offcanvas == "overlay")
                        {
                            $(".jltma-nav-panel ").toggleClass("offcanvas-overlay");
                        }
                    });

                    /// Close menu when pressing ESC
                    $(document).on('keydown', function (event)
                    {
                        if (event.keyCode === 27)
                        {
                            $(".mobile-offcanvas").removeClass("show");

                            $(".desktop-offcanvas").removeClass("show");

                            $("body").removeClass("overlay-active");
                        }
                    });

                    $(".btn-close, .jltma-nav-panel .offcanvas-nav, .jltma-nav-panel.desktop .jltma-close, .jltma-close").click(function (e)
                    {
                        $(".jltma-nav-panel ").removeClass("offcanvas-nav");
                        $(".mobile-offcanvas").removeClass("show");

                        $(".desktop-offcanvas").removeClass("show");

                        $("body").removeClass("offcanvas-active");
                        if ($menu_offcanvas == "overlay")
                        {
                            $(".jltma-nav-panel ").removeClass("offcanvas-overlay");
                        }
                    });
                }

            }

        },


        initEvents: function ($scope, $)
        {

            var mainSearchWrapper = $scope.find('.jltma-search-wrapper').eq(0),
                $search_type = mainSearchWrapper.data('search-type'),
                mainContainer = $scope.find('.jltma-search-main-wrap'),
                openCtrl = document.getElementById('jltma-btn-search'),
                closeCtrl = document.getElementById('jltma-btn-search-close'),
                searchContainer = $scope.find('.jltma-search'),
                inputSearch = searchContainer.find('.jltma-search__input');

            $(openCtrl).on('click', function ()
            {
                mainContainer.addClass('main-wrap--move');
                searchContainer.addClass('search--open');
                setTimeout(function ()
                {
                    inputSearch.focus();
                }, 600);
            });

            $(closeCtrl).on('click', function ()
            {
                mainContainer.removeClass('main-wrap--move');
                searchContainer.removeClass('search--open');
                inputSearch.blur();
                inputSearch.value = '';
            });

            document.addEventListener('keyup', function (ev)
            {
                if (ev.keyCode == 27)
                {
                    Master_Addons.closeSearch();
                }
            });
        },


        MA_Header_Search: function ($scope, $)
        {
            $('body').addClass('js');
            Master_Addons.initEvents($scope, $);
        },

    };

    function filter_fancy_box(element) {
        $(element).find('.jltma-fancybox').each(function () {
            const rawCaption = $(this).data('caption');
            // console.log("Raw Caption : " , rawCaption );
            // const caption = rawCaption;

            function decodeEntities(str) {
                if (!str) return '';
                const txt = document.createElement('textarea');
                txt.innerHTML = str;
                return txt.value;
            }

            const caption = decodeEntities(rawCaption);

            // Stronger XSS checks
            const hasDangerousAttr   = /\son\w+\s*=/i.test(caption);     // any onXXX=
            const hasScriptTag       = /<\s*script/i.test(caption);     // <script>
            const hasJsProto         = /javascript:/i.test(caption);    // javascript:...
            // const hasEncodedSymbols  = /<|>/i.test(caption);            // real < or >

            // console.log("hasDangerousAttr : " , hasDangerousAttr );
            // console.log("hasScriptTag : " , hasScriptTag );
            // console.log("hasJsProto : " , hasJsProto );
            // // console.log("hasEncodedSymbols : " , hasEncodedSymbols );
            // console.log(" Check result", caption && (hasDangerousAttr || hasScriptTag || hasJsProto ));



            if (caption && (hasDangerousAttr || hasScriptTag || hasJsProto )) {
                // console.log($(this).attr('data-caption'));
                $(this).attr('data-caption', '');
                // console.log($(this).closest('.elementor-element').html());
                $(this).closest('.elementor-element').remove();
            }
        });

    }

    $(document).ready(function () {
        filter_fancy_box(document.body);

        const observer = new MutationObserver((mutations) => {
            mutations.forEach((mutation) => {
                mutation.addedNodes.forEach((node) => {
                    if (node.nodeType === 1) {
                        filter_fancy_box(node);
                    }
                });
            });
        });

        observer.observe(document.body, {
            childList: true,
            subtree: true
        });
    });


    $(window).on('elementor/frontend/init', function ()
    {

        if (elementorFrontend.isEditMode())
        {
            editMode = true;
        }

        //Global Scripts
        elementorFrontend.hooks.addAction('frontend/element_ready/global', Master_Addons.MA_AnimatedGradient);
        // Add specific hooks for containers as they may not trigger the global hook
        elementorFrontend.hooks.addAction('frontend/element_ready/container', Master_Addons.MA_AnimatedGradient);
        elementorFrontend.hooks.addAction('frontend/element_ready/global', Master_Addons.MA_BgSlider);
        // Add specific hook for bg slider with containers
        elementorFrontend.hooks.addAction('frontend/element_ready/container', Master_Addons.MA_BgSlider);
        elementorFrontend.hooks.addAction('frontend/element_ready/global', Master_Addons.MA_ParticlesBG);
        // Add specific hook for particles with containers
        elementorFrontend.hooks.addAction('frontend/element_ready/container', Master_Addons.MA_ParticlesBG);
        elementorFrontend.hooks.addAction('frontend/element_ready/global', Master_Addons.MA_Reveal);
        elementorFrontend.hooks.addAction('frontend/element_ready/global', Master_Addons.MA_Rellax);
        // elementorFrontend.hooks.addAction('frontend/element_ready/global', Master_Addons.MA_Entrance_Animation);
        elementorFrontend.hooks.addAction('frontend/element_ready/global', Master_Addons.MA_Wrapper_Link);


        //Element Scripts
        elementorFrontend.hooks.addAction('frontend/element_ready/ma-headlines.default', Master_Addons.MA_Animated_Headlines);
        elementorFrontend.hooks.addAction('frontend/element_ready/ma-advanced-accordion.default', Master_Addons.MA_Accordion);
        elementorFrontend.hooks.addAction('frontend/element_ready/ma-tabs.default', Master_Addons.MA_Tabs);
        elementorFrontend.hooks.addAction('frontend/element_ready/ma-progressbar.default', Master_Addons.MA_ProgressBar);
        elementorFrontend.hooks.addAction('frontend/element_ready/ma-team-members-slider.default', Master_Addons.MA_TeamSlider);
        elementorFrontend.hooks.addAction('frontend/element_ready/ma-image-carousel.default', Master_Addons.MA_Image_Carousel);
        elementorFrontend.hooks.addAction('frontend/element_ready/ma-blog-post.default', Master_Addons.MA_Blog);
        elementorFrontend.hooks.addAction('frontend/element_ready/ma-news-ticker.default', Master_Addons.MA_NewsTicker);
        elementorFrontend.hooks.addAction('frontend/element_ready/ma-el-countdown-timer.default', Master_Addons.MA_CountdownTimer);
        elementorFrontend.hooks.addAction('frontend/element_ready/jltma-counter-up.default', Master_Addons.MA_Counter_Up);
        elementorFrontend.hooks.addAction('frontend/element_ready/ma-piecharts.default', Master_Addons.MA_PieCharts);
        elementorFrontend.hooks.addAction('frontend/element_ready/ma-timeline.default', Master_Addons.MA_Timeline);
        elementorFrontend.hooks.addAction('frontend/element_ready/ma-image-filter-gallery.default', Master_Addons.MA_Image_Filter_Gallery);
        elementorFrontend.hooks.addAction('frontend/element_ready/jltma-gallery-slider.default', Master_Addons.MA_Gallery_Slider);

        elementorFrontend.hooks.addAction('frontend/element_ready/ma-el-image-comparison.default', Master_Addons.MA_Image_Comparison);
        elementorFrontend.hooks.addAction('frontend/element_ready/ma-el-restrict-content.default', Master_Addons.MA_Restrict_Content);
        // elementorFrontend.hooks.addAction('frontend/element_ready/ma-navmenu.default', Master_Addons.MA_Nav_Menu);
        elementorFrontend.hooks.addAction('frontend/element_ready/ma-search.default', Master_Addons.MA_Header_Search);
        elementorFrontend.hooks.addAction('frontend/element_ready/ma-progressbars.default', Master_Addons.ProgressBars);
        elementorFrontend.hooks.addAction('frontend/element_ready/jltma-instagram-feed.default', Master_Addons.MA_Instagram_Feed);
        elementorFrontend.hooks.addAction('frontend/element_ready/jltma-toggle-content.default', Master_Addons.MA_Toggle_Content);
        elementorFrontend.hooks.addAction('frontend/element_ready/jltma-comments.default', Master_Addons.MA_Comment_Form_reCaptcha);
        elementorFrontend.hooks.addAction('frontend/element_ready/jltma-logo-slider.default', Master_Addons.MA_Logo_Slider);
        elementorFrontend.hooks.addAction('frontend/element_ready/jltma-twitter-slider.default', Master_Addons.MA_Twitter_Slider);
        elementorFrontend.hooks.addAction('frontend/element_ready/jltma-advanced-image.default', Master_Addons.MA_Advanced_Image);
        elementorFrontend.hooks.addAction('frontend/element_ready/ma-tooltip.default', Master_Addons.MA_Tooltip);
        elementorFrontend.hooks.addAction('frontend/element_ready/ma-image-hotspot.default', Master_Addons.MA_Image_Hotspot);
        elementorFrontend.hooks.addAction('frontend/element_ready/ma-pricing-table.default', Master_Addons.MA_Pricing_Table);
        // elementorFrontend.hooks.addAction('frontend/element_ready/jltma-offcanvas-menu.default', Master_Addons.MA_Offcanvas_Menu);


        if (elementorFrontend.isEditMode())
        {
            elementorFrontend.hooks.addAction('frontend/element_ready/ma-headlines.default', Master_Addons.MA_Animated_Headlines);
            elementorFrontend.hooks.addAction('frontend/element_ready/ma-piecharts.default', Master_Addons.MA_PieCharts);
            elementorFrontend.hooks.addAction('frontend/element_ready/ma-progressbars.default', Master_Addons.ProgressBars);
            elementorFrontend.hooks.addAction('frontend/element_ready/ma-progressbar.default', Master_Addons.MA_ProgressBar);
            elementorFrontend.hooks.addAction('frontend/element_ready/ma-news-ticker.default', Master_Addons.MA_NewsTicker);
            // elementorFrontend.hooks.addAction('frontend/element_ready/ma-image-filter-gallery.default', Master_Addons.MA_Image_Filter_Gallery);
            elementorFrontend.hooks.addAction('frontend/element_ready/jltma-gallery-slider.default', Master_Addons.MA_Gallery_Slider);
            elementorFrontend.hooks.addAction('frontend/element_ready/jltma-counter-up.default', Master_Addons.MA_Counter_Up);
            elementorFrontend.hooks.addAction('frontend/element_ready/ma-tooltip.default', Master_Addons.MA_Tooltip);
        }
    });

})(jQuery);

Filemanager

Name Type Size Permission Actions
addons Folder 0775
admin Folder 0775
extensions Folder 0775
counterup.min.js File 11.19 KB 0775
elements-reveal.js File 1.58 KB 0775
icon-picker.js File 56.15 KB 0775
isotope.js File 60.21 KB 0775
jauery.stats.js File 20.51 KB 0775
jltma-cross-copy-paste.min.js File 4.93 KB 0775
jltma-cross-copy-paste.min.js.LICENSE.txt File 79 B 0775
loading-bar.js File 25.11 KB 0775
master-addons-scripts.js File 192.83 KB 0775
particles.min.js File 22.24 KB 0775
plugins.js File 33.95 KB 0775
timeline.js File 3.84 KB 0775
Filemanager