%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /var/www/html/shaban/laviva/wp-content/themes/levelup/assets/js/
Upload File :
Create Path :
Current File : /var/www/html/shaban/laviva/wp-content/themes/levelup/assets/js/default.js

var rdyGlobals = {};

rdyGlobals.isMobile	= (/(Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini|windows phone)/.test(navigator.userAgent));
rdyGlobals.isAndroid = (/(Android)/.test(navigator.userAgent));
rdyGlobals.isiOS = (/(iPhone|iPod|iPad)/.test(navigator.userAgent));
rdyGlobals.isiPhone	= (/(iPhone|iPod)/.test(navigator.userAgent));
rdyGlobals.isiPad = (/(iPad)/.test(navigator.userAgent));
rdyGlobals.isBuggy = (navigator.userAgent.match(/AppleWebKit/) && typeof window.ontouchstart === 'undefined' && ! navigator.userAgent.match(/Chrome/));
rdyGlobals.isWindowsPhone = navigator.userAgent.match(/IEMobile/i);

if (rdyGlobals.isMobile) {
    document.documentElement.className += " mobile-true";
} else {
    document.documentElement.className += " mobile-false";
}

rdyGlobals.logoURL = false;
rdyGlobals.logoH = false;
rdyGlobals.logoW = false;
rdyGlobals.isHovering = false;


var $ = jQuery.noConflict();

(function($) {

    function is_touch_device() {
        return ('ontouchstart'in document.documentElement);
    }

    var setSkrollr = function($el, data) {
        for (var i = 0, l = data.length; i < l; i++) {
            var d = data[i],
                px = d[0];
            var css = d[1];
            $el.attr('data-' + px, css);
        }
    };

    $.fn.exists = function() {
        if ($(this).length > 0) {
            return true;
        } else {
            return false;
        }
    };


    $.fn.loaded = function(callback, jointCallback, ensureCallback){
        var len	= this.length;
        if (len > 0) {
            return this.each(function() {
                var	el		= this,
                    $el		= $(el),
                    blank	= "";

                $el.on("load.rdy", function(event) {
                    $(this).off("load.rdy");
                    if (typeof callback === "function") {
                        callback.call(this);
                    }
                    if (--len <= 0 && (typeof jointCallback === "function")){
                        jointCallback.call(this);
                    }
                });

                if (!el.complete || el.complete === undefined) {
                    el.src = el.src;
                } else {
                    $el.trigger("load.rdy");
                }
            });
        } else if (ensureCallback) {
            if (typeof jointCallback === "function") {
                jointCallback.call(this);
            }
            return this;
        }
    };


    window.isDesktop = !0;


    /**
     *  VC vc_rowBehaviour Rewrite
     */

    window.vc_rowBehaviour = function () {
        var $ = window.jQuery;

        function parallaxRow() {
            var parallaxRows = new Array();
            var speedDivider = 0.25;
            var bodyTop = document.documentElement.scrollTop || document.body.scrollTop;
            var wwidth = window.innerWidth || document.documentElement.clientWidth;
            var wheight = window.innerHeight || document.documentElement.clientHeight;

            var skrollrSpeed, skrollrSize, skrollrStart, skrollrEnd, $parallaxElement, parallaxImage, youtubeId;

            $(".vc_parallax-inner").remove();
            $(".vc_parallax[data-vc-parallax]").each(function () {
                if ("on" === $(this).data("vcParallaxOFade")) {
                    $(this).children('.row-container').children('.row-inner').attr("data-5p-top-bottom", "opacity:0;").attr("data-50p-top-bottom", "opacity:1;");
                }

                var $parallaxElement = $("<div/>").addClass("vc_parallax-inner").appendTo($(this));
                parallaxImage = $(this).data("vcParallaxImage");
                youtubeId = vcExtractYoutubeId(parallaxImage);
                if (youtubeId) {
                    insertYoutubeVideoAsBackground($parallaxElement, youtubeId);
                } else if("undefined" !== typeof parallaxImage) {
                    $parallaxElement.css("background-image", "url(" + parallaxImage + ")");
                }

                parallaxRows.push($parallaxElement);
            });

            setParallaxOffset = function(el, valueY) {
                var translate = 'translate3d(0, ' + valueY + 'px' + ', 0)';
                el.css({
                    '-webkit-transform': translate,
                    '-moz-transform': translate,
                    '-ms-transform': translate,
                    '-o-transform': translate,
                    'transform': translate
                });
            };

            parallaxRowCol = function(bodyTop) {
                var offsetValue;
                if (typeof parallaxRows === 'object') {
                    for (var i = 0; i < parallaxRows.length; i++) {
                        var parallaxRow = parallaxRows[i];
                        var holder = parallaxRows[i].parent(),

                            thisHeight = parallaxRow.outerHeight(),
                            sectionHeight = holder.outerHeight(),
                            offSetTop = bodyTop + (holder !== null ? holder.get(0).getBoundingClientRect().top : 0),
                            offSetPosition = wheight + bodyTop - offSetTop;

                        if (offSetPosition > 0 && offSetPosition < (sectionHeight + wheight)) {
                            offsetValue = ((offSetPosition - wheight) * speedDivider);

                            if (Math.abs(offsetValue) < (thisHeight - sectionHeight)) {
                                setParallaxOffset(parallaxRow, offsetValue);
                            } else {
                                setParallaxOffset(parallaxRow, thisHeight - sectionHeight);
                            }
                        }
                    }
                }
            };

            scrollFunction = function() {
                // if (logoel != undefined && logoel.length) shrinkMenu(bodyTop);
                // if (menusticky != undefined && menusticky.length && !isMobile) stickMenu(bodyTop);
                // if (!isMobile) hideMenu(bodyTop);
                // if (header && menusticky != undefined && menusticky.length) switchColorsMenu(bodyTop);
                parallaxRowCol(bodyTop);
                // parallaxHeader(bodyTop);
                // headerOpacity(bodyTop);
            };

            window.addEventListener('scroll', function(e) {
                bodyTop = document.documentElement.scrollTop || document.body.scrollTop;
                // if (wwidth > mediaQuery && !isMobile) {
                scrollFunction();
                // }
                // showHideScrollup(bodyTop);
            }, false);

            parallaxRowCol(bodyTop);

            if (window.skrollr) {
                vcSkrollrOptions = {
                    forceHeight: !1,
                    smoothScrolling: !1,
                    mobileCheck: function () {
                        return false;
                    }
                }
                window.vcParallaxSkroll = skrollr.init(vcSkrollrOptions)
            }

            /*var skrollrSpeed, skrollrSize, skrollrStart, skrollrEnd, $parallaxElement, parallaxImage, youtubeId;

            $(".vc_parallax-inner").remove();
            $(".vc_parallax[data-vc-parallax]").each(function () {
                var $parallaxElement = $("<div style='height: 100%' />").addClass("vc_parallax-inner").appendTo($(this));
                parallaxImage = $(this).data("vcParallaxImage");
                youtubeId = vcExtractYoutubeId(parallaxImage);
                if (youtubeId) {
                    insertYoutubeVideoAsBackground($parallaxElement, youtubeId);
                } else if("undefined" !== typeof parallaxImage) {
                    //$parallaxElement.css("background-image", "url(" + parallaxImage + ")");
                }

                $parallaxElement.parallax({speed: 0.2, imageSrc: parallaxImage});
            });*/




            /*var vcSkrollrOptions, callSkrollInit = !1;
            return window.vcParallaxSkroll && window.vcParallaxSkroll.destroy(),
                $(".vc_parallax-inner").remove(),
                $("[data-5p-top-bottom]").removeAttr("data-5p-top-bottom data-30p-top-bottom"),
                $("[data-vc-parallax]").each(function () {
                    var skrollrSpeed, skrollrSize, skrollrStart, skrollrEnd, $parallaxElement, parallaxImage, youtubeId;
                    callSkrollInit = !0,
                    "on" === $(this).data("vcParallaxOFade") && $(this).children('.row-container').children('.row-inner').attr("data-5p-top-bottom", "opacity:0;").attr("data-30p-top-bottom", "opacity:1;"),
                    skrollrSize = 100 * 1.3;//$(this).data("vcParallax"),
                    $parallaxElement = $("<div />").addClass("vc_parallax-inner").appendTo($(this)),
                    $parallaxElement.height(skrollrSize + "%"),
                    parallaxImage = $(this).data("vcParallaxImage"),
                    youtubeId = vcExtractYoutubeId(parallaxImage),
                    youtubeId ? insertYoutubeVideoAsBackground($parallaxElement, youtubeId) : "undefined" !== typeof parallaxImage && $parallaxElement.css("background-image", "url(" + parallaxImage + ")"),
                    skrollrSpeed = skrollrSize - 100,
                    skrollrStart = -skrollrSpeed,
                    skrollrEnd = 0,
                    $parallaxElement.attr("data-bottom-top", "top: " + skrollrStart + "%;").attr("data-top-bottom", "top: " + skrollrEnd + "%;");
                }),

                //window.skrollr ? skrollr.get().refresh()
                callSkrollInit && window.skrollr ? (vcSkrollrOptions = {
                    forceHeight: !1,
                    smoothScrolling: !1,
                    mobileCheck: function () {
                        return false;
                    }
                },
                window.vcParallaxSkroll = skrollr.init(vcSkrollrOptions), window.vcParallaxSkroll

                ) : !1;
*/

        }

        function fullHeightRow() {
            var $element = $(".vc_row-o-full-height:first");
            if ($element.length) {
                var $window, windowHeight, offsetTop, fullHeight;
                $window = $(window);
                windowHeight = $window.height();
                offsetTop = $element.offset().top;

                if (windowHeight > offsetTop) {
                    fullHeight = 100 - offsetTop / (windowHeight / 100);
                    $element.css("min-height", fullHeight + "vh");
                }
            }
            $(document).trigger("vc-full-height-row", $element);
        }

        // VC-mod
        function rdyFixIeFlexbox() {
            var ua = window.navigator.userAgent, msie = ua.indexOf("MSIE ");
            if (msie > 0 || navigator.userAgent.match(/Trident.*rv\:11\./)) {
                $(".rdy_vc_row-o-full-height").each(function () {
                    $(this).addClass('rdy_vc_ie-flexbox-fixer');
                });
            }

            if (msie > 0 || navigator.userAgent.match(/Trident.*rv\:11\./)) {
                $(".rdy_vc_row-o-equal-height > .row-container > .row-inner").each(function () {
                    if("flex" === $(this).css("display")) {
                        $(this).find('.vc_column-inner > .wpb_wrapper').addClass('rdy_vc_ie-flexbox-fixer-h');
                    }
                });
            }
        }

        $(window).off("resize.vcRowBehaviour"); fullHeightRow(); rdyFixIeFlexbox(); vc_initVideoBackgroundsYV(); parallaxRow();

    };

    /**
     *  END ## VC vc_rowBehaviour Rewrite
     */


    function vcExtractVimeoId(url) {
        if ("undefined" == typeof url)return !1;
        var id = url.match(/(http|https)?:\/\/(www\.)?vimeo.com\/(?:channels\/(?:\w+\/)?|groups\/([^\/]*)\/videos\/|)(\d+)(?:|\/\?)/);
        return null !== id && id[4];
    }

    function vc_initVideoBackgroundsYV() {
        jQuery("[data-vc-video-bg]").each(function () {
            var youtubeUrl,
                youtubeId,
                $element = jQuery(this);

            $element.data("vcVideoBg") ? (
                youtubeUrl = $element.data("vcVideoBg"),
                    youtubeId = vcExtractYoutubeId(youtubeUrl),
                    vimeoId = vcExtractVimeoId(youtubeUrl),
                youtubeId && (
                    $element.find(".vc_video-bg").remove(),
                        insertYoutubeVideoAsBackground($element, youtubeId)
                ),
                vimeoId && (
                    $element.find(".vc_video-bg").remove(),
                        insertVimeoVideoAsBackground($element, vimeoId)
                ),
                jQuery(window).on("grid:items:added", function (event, $grid) {
                    $element.has($grid).length && vcResizeVideoBackground($element);
                })
            ) :
                $element.find(".vc_video-bg").remove();
        });
    }

    function insertVimeoVideoAsBackground($element, vimeoId, counter) {
        var $container = $element.prepend('<div class="vc_video-bg vc_hidden-xs"><div class="inner"><iframe src="https://player.vimeo.com/video/' + vimeoId + '?wmode=opaque&background=1&api=1&autoplay=1&loop=1&player_id=video_' + vimeoId + '&title=0&byline=0&portrait=0&color=" id="video_' + vimeoId + '" width="640" height="320" frameborder="0" webkitAllowFullScreen mozallowfullscreen allowFullScreen></iframe></div></div>').find(".inner");
        $element.data('provider', 'vimeo');

        var player = $f($element.find('iframe')[0]);
        player.addEvent('ready', function() {
            player.api('setVolume', 0);
        });

        vcResizeVideoBackground($element), jQuery(window).bind("resize", function () {
            vcResizeVideoBackground($element);
        });
    }

    jQuery(".wpb_tour_tabs_wrapper").on( "tabsactivate tabsshow", function( event, ui ) {
        var panel = ui.panel || ui.newPanel;
        var $iso = panel.find(".iso-container, .products.products-grid:not(.owl-carousel)");

        $iso.length && $iso.each(function () {
            jQuery(this).isotope("layout");
        });
    } );

    jQuery(".wpb_accordion_wrapper").on( "accordionactivate accordionchange", function( event, ui ) {
        var panel = ui.panel || ui.newPanel;
        panel.find(".iso-container").length && panel.find(".iso-container").each(function () {
            jQuery(this).isotope("layout");
        });
    } );


    function vcResizeVideoBackground($element) {
        var iframeW,
            iframeH,
            marginLeft,
            marginTop,
            containerW = $element.innerWidth(),
            containerH = $element.innerHeight(),
            ratio1 = 16,
            ratio2 = 9,
            a = 5;

        ratio = ratio1 / ratio2;
        controls_remove = 50;

        if(containerW / containerH < ratio1 / ratio2) {
            iframeW = containerH * (ratio1 / ratio2);
            iframeH = containerH;
            // marginLeft = -Math.round((iframeW - containerW) / 2) + "px",
            // marginTop = -Math.round((iframeH - containerH) / 2) + "px",
            // iframeW += "px",
            // iframeH += "px"
        } else {
            iframeW = containerW;
            iframeH = containerW * (ratio2 / ratio1);
        }

        if($element.data('provider') == 'vimeo'){
            iframeH = iframeH + controls_remove * 2;
            iframeW = ratio * iframeH;
        }

        marginTop = -Math.round((iframeH - containerH) / 2) + "px";
        marginLeft = -Math.round((iframeW - containerW) / 2) + "px";
        iframeW += "px";
        iframeH += "px";

        $element.find(".vc_video-bg iframe").css({
            maxWidth: "1000%",
            marginLeft: marginLeft,
            marginTop: marginTop,
            width: iframeW,
            height: iframeH
        });

    }


    $(window).load(function () {

        initNavigationBar();
        rdy.can.init();

        $('.rev_slider_wrapper').each(function(){
            var $this = jQuery(this),
                id_array = $this.attr("id").split("_"),
                id = id_array[2];

            if (id != undefined && id != '') {

                $this.bind("revolution.slide.onloaded", function (e,data) {
                    var style = jQuery(e.currentTarget).find("li").eq(0).attr("data-skin");
                    if (style != undefined) {
                        $('.columns-project').data('slider-nav-color', style);
                        $('.columns-project').removeClass('slider-nav-color-dark').addClass('slider-nav-color-' + style );
                    }
                });
                $this.bind("revolution.slide.onbeforeswap", function (e,data) {
                    var style = data.nextslide.attr("data-skin");
                    if (style != undefined) {
                        $('.columns-project').data('slider-nav-color', style);
                        $('.columns-project').removeClass('slider-nav-color-dark').addClass('slider-nav-color-' + style );
                    }
                });

            }
        });

    });


    jQuery(document).ready(function($) {


        /*function initContent(){
            var scrollbarWidth,
                windowWidth = window.innerWidth || document.documentElement.clientWidth;

            // initContent
            if (!rdyGlobals.isMobile && scrollbarWidth == undefined) {
                // Create the measurement node
                var scrollDiv = document.createElement("div");
                scrollDiv.className = "scrollbar-measure";
                var dombody = document.body;
                if (dombody != null) {
                    dombody.appendChild(scrollDiv);
                    // Get the scrollbar width
                    scrollbarWidth = scrollDiv.offsetWidth - scrollDiv.clientWidth;
                    // Delete the DIV
                    dombody.removeChild(scrollDiv);
                }
            }
            if (!rdyGlobals.isMobile) {
                $('.site-content').each(function(i, el) {
                    var boxLeft;
                    var boxWidth;
                    var el = $(this);

                    var elWidth = el.outerWidth(),
                        newWidth = 12 * Math.ceil((windowWidth - scrollbarWidth) / 12);
                    boxWidth = newWidth;
                    boxLeft = Math.ceil(((newWidth) - windowWidth) / 2);
                    el.css({ width: boxWidth + 'px', marginLeft: '-' + (boxLeft + (scrollbarWidth / 2)) + 'px' })
                });
            }
        }

        initContent();

        window.addEventListener("resize", function() {
            initContent();
        });*/


        if (rdyGlobals.isMobile && $("rdy-portfolio-container .rdy_portfolio[data-top-bottom]").length) {
            $("rdy-portfolio-container .rdy_portfolio").removeAttr("data-top-bottom data-bottom");
        }


        if ($(".variations select").length) {
            $(".variations select").select2({
                allowClear: true,
                minimumResultsForSearch: -1,
                width: 'style',
                dropdownAutoWidth : true,
                dropdownCssClass: "woo-orderby-dropdown"
            });
        }

        if ($(".woocommerce .orderby").length) {
            $(".orderby").select2({
                allowClear: true,
                minimumResultsForSearch: -1,
                width: 'style',
                dropdownAutoWidth : true,
                dropdownCssClass: "woo-orderby-dropdown"
            });
        }

        if ($(".woocommerce-page.single-product").length) {

            if ($('#woo-images1.owl-carousel').length) {

                var sync1 = $("#woo-images1");
                var sync2 = $("#woo-images2");
                var flag = false;

                var slides = sync1.owlCarousel({
                    autoHeight: !1,
                    dots: !1,
                    nav: !0,
                    navText: ['<i class="gi gi-arrow-left"></i>','<i class="gi gi-arrow-right"></i>'],

                    items: 1,
                    loop: false
                }).on('change.owl.carousel', function(e) {
                    if (e.namespace && e.property.name === 'position' && !flag) {
                        flag = true;
                        sync2
                            .find(".owl-item")
                            .removeClass("synced")
                            .eq(e.relatedTarget.relative(e.property.value))
                            .addClass("synced");
                        sync2.trigger('to.owl.carousel', [e.relatedTarget.relative(e.property.value), 300, true]);
                        flag = false;
                    }
                }).data('owl.carousel');

                var thumbs = sync2.owlCarousel({
                    items : 4,
                    nav: false,
                    dots: !1
                }).on('click', '.owl-item', function(e) {
                    e.preventDefault();
                    sync1.trigger('to.owl.carousel', [$(e.target).parents('.owl-item').index(), 300, true]);
                }).on('change.owl.carousel', function(e) {
                }).data('owl.carousel');
            }


            $("#woo-images1 a").magnificPopup({
                type: "image",
                mainClass: 'mfp-zoom-in',
                gallery: {enabled: !0},
                tLoading: '',
                closeBtnInside: false,
                closeMarkup: '<button title="%title%" type="button" class="mfp-close"></button>',
                removalDelay: 400
            });


            $(document).on( 'found_variation', 'form.cart', function( event, variation ) {
                var $product            = $('.product');
                var $product_img = $product.find( '.images .product-big-image .active img:eq(0)' ),
                    $product_link = $product.find( '.images .product-big-image a.zoom:eq(0)' ),
                    o_src = $product_img.attr( 'data-o_src' ),
                    o_title = $product_img.attr( 'data-o_title' ),
                    o_alt = $product_img.attr( 'data-o_alt' ),
                    o_href = $product_link.attr( 'data-o_href' ),
                    variation_image = variation.image.src,
                    variation_link  = variation.image.full_src,
                    variation_caption = variation.image.caption,
                    variation_title = variation.image.title;

                sync1.trigger("to.owl.carousel", [0, 1, true]);
                sync2.trigger("to.owl.carousel", [0, 1, true]);

                if ( variation_image && variation_image.length > 1 ) {
                    $product_img
                        .attr( 'src', variation_image )
                        .attr( 'alt', variation_title )
                        .attr( 'title', variation_title );
                    $product_link
                        .attr( 'href', variation_link )
                        .attr( 'title', variation_caption );
                } else {
                    $product_img
                        .attr( 'src', o_src )
                        .attr( 'alt', o_alt )
                        .attr( 'title', o_title );
                    $product_link
                        .attr( 'href', o_href )
                        .attr( 'title', o_title );
                }
            });
        }

        if (jQuery('header#header-menu.slidedown-full-layout').length) {

            if (jQuery('header#header-menu.slidedown-full-layout .widget-area').length && !jQuery('header#header-menu.slidedown-full-layout .main-area.widget-right').length ) {
                jQuery('header#header-menu #main-menu').css('padding-bottom', jQuery('header#header-menu.slidedown-full-layout .widget-area').outerHeight() + 40);
            }

            jQuery('#main-menu li:not(.menu-item-has-children) > a').on('click', function (e) {
                // if($(this).attr('href').indexOf("#") === 0) {
                menu_click_evnt();
                // }
            });

            jQuery('#main-menu li.menu-item-has-children > a').on('click', function(e){
                e.preventDefault();

                var $this = $(this),
                    $content = $this.closest('.menu-item').find('> ul.sub-menu');

                if ($this.hasClass("opened")) {
                    // TweenMax.to($content, 0.3, {height: 0});
                    // $content.velocity({opacity: 0}, {
                    //     duration: 300
                    // });
                    // $content.slideUp();
                    $content.velocity("slideUp", { duration: 200 });
                    // .velocity("slideDown", { duration: 1500 })


                    $content.removeClass("opened");
                    $this.removeClass("opened");
                } else {
                    var $elem_to_close;
                    // jQuery('#main-menu ul.sub-menu.opened').each(function(){
                    //     $elem_to_close = $(this);
                    // });

                    if ($elem_to_close) {
                        // TweenMax.to($elem_to_close, 0.3, {height: 0, onComplete: function () {
                        //     TweenMax.set($content, {height: "auto"});
                        //     TweenMax.from($content, 0.3, {height: 0});
                        //     $content.addClass("opened");
                        //     $this.addClass("opened");
                        // }});

                        // $elem_to_close.velocity({}, {
                        //     duration: 300,
                        //     complete: function () {
                        //         // $content.velocity({opacity: 1}, {
                        //         //     duration: 300
                        //         // });
                        //
                        //         $content.addClass("opened");
                        //         $this.addClass("opened");
                        //     }
                        // });
                        // $elem_to_close.slideUp();
                        // $content.slideDown();
                        $elem_to_close.velocity("slideUp", { duration: 200 });
                        $content.velocity("slideDown", { duration: 200 });

                        $content.addClass("opened");
                        $this.addClass("opened");


                        jQuery('#main-menu ul.sub-menu.opened').removeClass("opened");
                        jQuery('#main-menu ul.sub-menu.opened').closest('.menu-item').find('> a').removeClass("opened");
                    } else {
                        // TweenMax.set($content, {height: "auto", 'opacity': 1});
                        // TweenMax.from($content, 0.3, {height: 0});

                        // $content.slideDown();
                        $content.velocity("slideDown", { duration: 200 });
                        // $content.velocity({opacity: 1}, {
                        //     duration: 300
                        // });

                        $content.addClass("opened");
                        $this.addClass("opened");
                    }
                }
            });

        } else {
            jQuery('ul.sf-menu').superfish({
                onBeforeShow: function () {
                    var $this = $(this);
                    var obj = $this.parent('.menu-depth-0');
                    var left_offset;

                    if (obj.length) {
                        left_offset = obj.offset().left;
                    }

                    var right_offset = $(window).width() - $this.width() - left_offset;

                    if (obj.hasClass('wide')) {
                        if (right_offset < 0) {
                            var mm_center = ($(window).width() - $this.width()) / 2;
                            var mm_pos = left_offset - mm_center;
                            jQuery(this).css('width', $this.width());
                            jQuery(this).css('left', '-' + (mm_pos) + 'px');
                        } else {
                            jQuery(this).css('left', '0');
                        }
                    } else {
                        if (right_offset < 0) {
                            jQuery(this).css('left', '-' + ($this.width() - obj.width()) + 'px');
                        }
                    }
                }
            });
        }



        var rdy_header_menu = jQuery('#header-menu'),
            rdy_mobile_menu = jQuery('#mobile-menu'),
            rdy_header_search = jQuery('#header-search');

        var rdy_background_appear = jQuery('#header').data('background-appear');
        var rdy_background_color = jQuery('#header').data('background-color');
        var rdy_menu_items_color = jQuery('#header').data('items-color');
        var rdy_header_line_appear = jQuery('#header').data('line-appear');
        var rdy_header_shadow_appear = jQuery('#header').data('shadow-appear');

        function rdy_background_appear_scroll(){
            if ($(window).scrollTop() > rdy_background_appear) {
                rdy_header_menu.css({'background-color': rdy_background_color});
                if (rdy_menu_items_color) {
                    jQuery('#header, #header-menu').removeClass('mark-' + rdy_menu_items_color + ' mark-logo-' + rdy_menu_items_color);
                }
                if (rdy_header_line_appear) {
                    rdy_header_menu.addClass('show_bottomline');
                }
                if (rdy_header_shadow_appear) {
                    rdy_header_menu.addClass('with-shadow');
                }
            }
            else {
                rdy_header_menu.css('background-color', 'transparent');
                if (rdy_menu_items_color) {
                    jQuery('#header, #header-menu').addClass('mark-' + rdy_menu_items_color + ' mark-logo-' + rdy_menu_items_color);
                }
                if (rdy_header_line_appear) {
                    rdy_header_menu.removeClass('show_bottomline');
                }
                if (rdy_header_shadow_appear) {
                    rdy_header_menu.removeClass('with-shadow');
                }
            }
        }

        if (rdy_background_appear > 0) {
            $(window).scroll(function () {
                rdy_background_appear_scroll();
            });

            jQuery('#header-menu').css('background-color', 'transparent');
            if (rdy_menu_items_color) {
                jQuery('#header, #header-menu').addClass('mark-' + rdy_menu_items_color + ' mark-logo-' + rdy_menu_items_color);
            }

            $(window).load(function () {
                rdy_background_appear_scroll();
            });
        }


        var rdy_cta1 = jQuery('#header-menu .cta-button-1'),
            rdy_cta2 = jQuery('#header-menu .cta-button-2'),
            rdy_cta3 = jQuery('#header-menu .cta-button-3');

        var rdy_cta1_appear = rdy_cta1.data('cta-appear');
        var rdy_cta2_appear = rdy_cta2.data('cta-appear');
        var rdy_cta3_appear = rdy_cta3.data('cta-appear');

        function rdy_cta1_appear_scroll(el, appear){
            if ($(window).scrollTop() > appear) {
                el.addClass('cta_appear');
            } else {
                el.removeClass('cta_appear');
            }
        }

        if (rdy_cta1_appear > 0 || rdy_cta2_appear > 0 || rdy_cta3_appear > 0 ) {

            $(window).scroll(function () {
                if(rdy_cta1_appear){
                    rdy_cta1_appear_scroll(rdy_cta1, rdy_cta1_appear);
                }

                if(rdy_cta2_appear){
                    rdy_cta1_appear_scroll(rdy_cta2, rdy_cta2_appear);
                }
                if(rdy_cta3_appear){
                    rdy_cta1_appear_scroll(rdy_cta3, rdy_cta3_appear);
                }
            });

            $(window).load(function () {
                rdy_cta1_appear_scroll(rdy_cta1);

                if(rdy_cta2_appear){
                    rdy_cta1_appear_scroll(rdy_cta2, rdy_cta2_appear);
                }
                if(rdy_cta3_appear){
                    rdy_cta1_appear_scroll(rdy_cta3, rdy_cta3_appear);
                }
            });
        }


        function menu_click_evnt(e) {

            jQuery('#header').toggleClass('menu-opened');
            rdy_header_menu.toggleClass('menu-opened');

            if (jQuery('html').hasClass('popup_menu_opened')) {
                jQuery('html').removeClass('popup_menu_opened');
            } else {
                jQuery('html').addClass('popup_menu_opened');
            }

            if (rdy_header_menu.hasClass('slidedown-layout')) {
                if (rdy_header_menu.hasClass('menu-opened')) {
                    jQuery('.body-overlay[data-menu="1"]').show(0).fadeTo("fast", 1);

                    rdy_header_menu.velocity("stop");
                    rdy_header_menu.css({clip: 'rect(0px ' + $(window).width() + 'px 0px 0px)'});
                    rdy_header_menu.velocity({clipBottom: rdy_header_menu.height() + 6}, {
                        duration: 700,
                        easing: [0.19, 1, 0.22, 1],
                        complete: function () {
                            rdy_header_menu.css({clip: 'auto'});
                        }
                    });

                } else {
                    rdy_header_menu.velocity("stop");
                    rdy_header_menu.css({clip: 'rect(0px ' + $(window).width() + 'px ' + (rdy_header_menu.height() + 6) + 'px 0px)'});
                    jQuery('.body-overlay[data-menu="1"]').fadeTo("fast", 0, function () {
                        $(this).hide(0);
                    });

                    setTimeout(function () {
                        rdy_header_menu.velocity({clipBottom: 0}, {
                            duration: 800,
                            easing: [0.19, 1, 0.22, 1],
                            queue: false,
                            complete: function () {
                            }
                        });
                    }, 0);

                }
            }

            if ($(window).width() <= 992) {

                jQuery('#mobile-menu').css('padding-top', jQuery('#header').height() + jQuery('#header').position().top + 10);

                // if (jQuery('#mobile-menu.valign-middle.valign-el-bottom').length) {
                //     jQuery('#menu-mobile').css('margin-bottom', jQuery('#mobile-menu .mobile_menu_side').height());
                // }

                var animation = {translateY: "-110%"};
                var animation_out = {translateY:  [ "0%", "-110%" ]};

                if (rdy_mobile_menu.data('menu-animation') === 'slideleft') {
                    animation = {translateX: "-110%"};
                    animation_out = {translateX: ["0%", "-110%"]};
                } else if(rdy_mobile_menu.data('menu-animation') === 'slideright') {
                    animation = {translateX: "110%"};
                    animation_out = {translateX: ["0%", "110%"]};
                } else if(rdy_mobile_menu.data('menu-animation') === 'fadein') {
                    animation = {opacity: "0"};
                    animation_out = {opacity: ["1", "0"]};
                }


                if (rdy_mobile_menu.hasClass('menu-opened')) {
                    $('html').removeClass('no-scroll');

                    if (rdy_mobile_menu.data('menu-items-animation')) {
                        $('.menu-mobile > li, .mobile_socials, #mobile-search', rdy_mobile_menu).velocity("stop").velocity({opacity: 0});
                    }

                    rdy_mobile_menu.velocity("stop").velocity(animation, {
                        duration: 800,
                        easing: [0.19, 1, 0.22, 1],
                        complete: function () {
                            rdy_mobile_menu.css({visibility: 'hidden'});
                        }
                    });
                    rdy_mobile_menu.removeClass('menu-opened');

                    $('.body-overlay').fadeTo("fast", 0, function () {
                        $(this).hide(0);
                    });

                } else {
                    $('html').addClass('no-scroll');

                    rdy_mobile_menu.css({visibility: 'visible'}).velocity("stop").velocity(animation_out, {
                        duration: 900,
                        easing: [0.19, 1, 0.22, 1],
                        queue: false,
                        complete: function () {
                        }
                    });

                    if($('.body-overlay').length === 0) {
                        $('#totop').after('<div class="body-overlay"></div>');
                        jQuery('.body-overlay').click(function (e) {
                            menu_click_evnt();
                        });
                    }
                    $('.body-overlay').show(0).fadeTo("fast", 1);
                    if (rdy_mobile_menu.data('menu-animation') === 'slideleft' || rdy_mobile_menu.data('menu-animation') === 'slideright') {
                        jQuery('.body-overlay').addClass('upper');
                    }

                    rdy_mobile_menu.addClass('menu-opened');

                    var items_animation = '';

                    if (rdy_mobile_menu.data('menu-items-animation') === 'slideleft') {
                        items_animation = 'transition.slideLeftIn';
                    } else if (rdy_mobile_menu.data('menu-items-animation') === 'slideright') {
                        items_animation = 'transition.slideRightIn';
                    } else if (rdy_mobile_menu.data('menu-items-animation') === 'slideup') {
                        items_animation = 'transition.slideUpIn';
                    } else if (rdy_mobile_menu.data('menu-items-animation') === 'slidedown') {
                        items_animation = 'transition.slideDownIn';
                    } else if (rdy_mobile_menu.data('menu-items-animation') === 'fadein') {
                        items_animation = 'transition.fadeIn';
                    }

                    if (items_animation) {
                        $('.cta-button, .menu-mobile > li, .mobile_socials, #mobile-search', rdy_mobile_menu).velocity(items_animation, {
                            delay: 200,
                            stagger: rdy_mobile_menu.data('menu-items-cascade') ? 150 : false,
                            duration: 1000,
                            easing: "ease-in",
                            // complete: function () {
                            //     $('.mobile_menu_side', rdy_mobile_menu).velocity(items_animation, {
                            //         duration: 400,
                            //         easing: "ease-in"
                            //     });
                            // }
                        });
                    }

                }

            }

            if (rdy_header_menu.hasClass('slidedown-full-layout')) {
                var menu_full = jQuery('#header-menu.slidedown-full-layout #main-menu');
                if(jQuery('html').hasClass('popup_menu_opened')){
                    menu_full.delay(100).velocity({
                        opacity: [1, 0]
                    }, 900);
                }else{
                    menu_full.velocity("stop");
                    menu_full.css({'opacity': 0});
                }
            }

            if (e) {
                e.preventDefault();
            }
        }


        $("#mobile-menu li:not('.menu-item-has-children') a").on('click', function(m){

            menu_click_evnt();

        });


        function search_click_evnt(e) {
            jQuery('#header').toggleClass('search-opened');
            rdy_header_search.toggleClass('search-opened');

            if (jQuery('html').hasClass('popup_search_opened')) {
                jQuery('html').removeClass('popup_search_opened');
                rdy_header_search.velocity({translateY: '-' + (rdy_header_search.height() + 2)}, {
                    duration: 500,
                    easing: [0.19, 1, 0.22, 1],
                    complete: function () {
                        $(this).css({'display': 'none'});
                    }
                });
                jQuery('.body-overlay[data-search="1"]').fadeTo("fast", 0, function () {
                    $(this).hide(0);
                });

            } else {
                jQuery('html').addClass('popup_search_opened');
                rdy_header_search.velocity({translateY: [0, '-' + rdy_header_search.height()]}, {
                    duration: 400,
                    display: 'block',
                    easing: [0.19, 1, 0.22, 1],
                    complete: function () {}
                });
                jQuery('.body-overlay[data-search="1"]').show(0).fadeTo("fast", 1, function() {
                    $('input.search-field').focus();
                });

            }

            if (e) {
                e.preventDefault();
            }
        }

        if (rdy_header_menu.hasClass('slidedown-layout')) {
            rdy_header_menu.css({clip: 'rect(0px ' + $(window).width() + 'px 0px 0px)'});
        }

        jQuery('.hamburger-icon, .close_arrow').click(menu_click_evnt);
        jQuery('.search-icon, #header-search .search-close-icon').click(search_click_evnt);

        jQuery('.body-overlay').click(function (e) {
            if (jQuery('html').hasClass('popup_search_opened')) {
                search_click_evnt();
            }

            if (jQuery('html').hasClass('popup_menu_opened')) {
                menu_click_evnt();
            }
        });


        $('.cart-icon').click(function () {
            window.location.href = $(this).data('cart-url');
        });


        $(".no-touch .cart-icon").on("mouseenter", function () {

            if (!$(this).data('init')) {
                $(this).data('init', true);
                var that = jQuery(this);

                jQuery(this).hoverIntent({
                    over: function () {
                        that.find(jQuery('.rdy_minicart_wrapper')).css('z-index', 9999).slideDown(150).show(0);
                        if (!rdyGlobals.isMobile) {
                            $(this).addClass('hover');
                        }
                    },
                    out: function () {
                        that.find(jQuery('.rdy_minicart_wrapper')).css('z-index', 0).slideUp(150);
                        if (!rdyGlobals.isMobile) {
                            $(this).removeClass('hover');
                        }
                    },

                    timeout: 150,
                    interval: 0
                });
                $(this).trigger('mouseenter');
            }
        });


        if (rdyGlobals.isWindowsPhone) {
            $("body").addClass("ie-mobile");
        }


        function doAnimation() {
            //if ($( window ).width() > 992) {
                var $animation_param = {duration: 300, easing: "easeInOut"};

                $(".anm-arrow-left-hv").each(function () {
                    $(this).mouseenter(function() {
                        $(this).velocity("stop").velocity({translateX: -10}, $animation_param);

                        if (!$(this).hasClass('anm-arrow-mout')) {
                           $(this).velocity({translateX: 0}, $animation_param);
                        }
                    });

                    if ($(this).hasClass('anm-arrow-mout')) {
                        $(this).mouseleave(function() {
                            $(this).velocity("stop").velocity({translateX: 0}, $animation_param);
                        });
                    }
                });
                $(".anm-arrow-right-hv").each(function () {
                    $(this).mouseenter(function() {
                        $(this).velocity("stop").velocity({translateX: 10}, $animation_param);

                        if (!$(this).hasClass('anm-arrow-mout')) {
                            $(this).velocity({translateX: 0}, $animation_param);
                        }
                    });

                    if ($(this).hasClass('anm-arrow-mout')) {
                        $(this).mouseleave(function() {
                            $(this).velocity("stop").velocity({translateX: 0}, $animation_param);
                        });
                    }
                });
                $(".anm-arrow-up-hv").each(function () {
                    $(this).mouseenter(function() {
                        $(this).velocity("stop").velocity({translateY: -10}, $animation_param);

                        if (!$(this).hasClass('anm-arrow-mout')) {
                            $(this).velocity({translateY: 0}, $animation_param);
                        }
                    });

                    if ($(this).hasClass('anm-arrow-mout')) {
                        $(this).mouseleave(function() {
                            $(this).velocity("stop").velocity({translateY: 0}, $animation_param);
                        });
                    }
                });

                $(".anm-arrow-down-hv").each(function () {
                    $(this).mouseenter(function() {
                        $(this).velocity("stop").velocity({translateY: 10}, $animation_param);

                        if (!$(this).hasClass('anm-arrow-mout')) {
                            $(this).velocity({translateY: 0}, $animation_param);
                        }
                    });

                    if ($(this).hasClass('anm-arrow-mout')) {
                        $(this).mouseleave(function() {
                            $(this).velocity("stop").velocity({translateY: 0}, $animation_param);
                        });
                    }
                });

                $(".animate-element:not(.start-animation):not(.client-logo)").each(function () {
                    var $this = $(this);

                    $(this).waypoint(function(direction) {
                        if (direction === 'down' && $this.data('animation-class')) {
                            if (!$this.hasClass("start-animation") && !$this.hasClass("animation-triggered")) {
                                $this.addClass("animation-triggered");

                                $this.addClass($this.data('animation-class'));
                                $this.addClass("start-animation animated");
                                $this.css("opacity", "1");
                            }
                        }

                    }, { offset: '100%' });


                    if($(this).hasClass('animate-loop')){
                        $(this).waypoint(function(direction) {
                            if (direction === 'up' && $this.data('animation-class') && $this.hasClass("start-animation")) {
                                $this.removeClass($this.data('animation-class'));
                                $this.removeClass("start-animation animated animation-triggered");
                                $this.css("opacity", "0");
                            }

                        }, { offset: '110%' });
                    }
                });

                $(".rdy-clients-shortcode.with-animation-fadein:not(.is-hover)").each(function () {
                    var $this = $(this);
                    var repeatOnce = true;

                    if ($this.hasClass('animate-loop')) {
                        repeatOnce = false;
                    }

                    $(this).waypoint(function(direction) {
                        if (direction === 'down') {
                            var delay = 0;
                            $this.find('.client-logo').each(function () {
                                $(this).velocity("stop").velocity({opacity: 1}, {
                                    duration: 300,
                                    delay: delay
                                });
                                delay = delay + 300;
                            });

                        }

                    }, { offset: '95%', triggerOnce: repeatOnce });

                    if($this.hasClass('animate-loop')){
                        $(this).waypoint(function(direction) {
                            if (direction === 'up') {
                                $this.find('.client-logo').velocity("stop").css({'opacity': 0});
                            }

                        }, { offset: '110%', triggerOnce: repeatOnce });
                    }

                });


                $(".vc_custom_heading[data-text-animate]").each(function () {
                    var $this = $(this);

                    $(this).waypoint(function(direction) {
                        if (direction === 'down' && !$this.hasClass('text-animation-triggered')) {
                            var delay = 0;

                            if ( $this.data('text-animate-delay') ) {
                                delay = $this.data('text-animate-delay');
                            }

                            var $animation = "transition.fadeIn";

                            if ($this.data('text-animate-type') === 'fadeIn') {
                                $animation = "transition.fadeIn";
                            }
                            else if ($this.data('text-animate-type') === 'slideUpIn') {
                                $animation = "transition.slideUpIn";
                            }

                            var $text_animation_param;

                            if ($this.data('text-animate') === 'char') {
                                $text_animation_param = {
                                    stagger: 250, duration: 550
                                };

                                if ( $this.data('text-animate-speed') === 'fast' ) {
                                    $text_animation_param = {
                                        stagger: 100, duration: 200
                                    };
                                } else if ( $this.data('text-animate-speed') === 'middle' ) {
                                    $text_animation_param = {
                                        stagger: 160, duration: 300
                                    };
                                }

                                $this.find('span').blast({delimiter: "word"});

                                setTimeout(function () {
                                    $this.addClass('text-animation-triggered');
                                    $this.find('.blast-root span.blast').each(function(){
                                        $(this).removeClass('blast');
                                        $(this).blast({ delimiter: "char", tag: "em" });
                                    });
                                    $this.find('.blast-root em.blast').velocity($animation, $text_animation_param);
                                }, delay);
                            }
                            else if($this.data('text-animate') === 'word')
                            {
                                $text_animation_param = {
                                    stagger: 800, duration: 1000
                                };

                                if ( $this.data('text-animate-speed') === 'fast' ) {
                                    $text_animation_param = {
                                        stagger: 250, duration: 500
                                    };
                                } else if ( $this.data('text-animate-speed') === 'middle' ) {
                                    $text_animation_param = {
                                        stagger: 400, duration: 600
                                    };
                                }

                                setTimeout(function () {
                                    $this.addClass('text-animation-triggered');
                                    $this.find('span').blast({delimiter: "word"}).velocity($animation, $text_animation_param);
                                }, delay);

                            }

                        }

                    }, { offset: '100%' });

                });

            /*} else {
                $(".rdy-clients-shortcode.with-animation-fadein:not(.is-hover)").each(function () {
                    $(this).find('.client-logo').velocity("stop").css('opacity', 1);
                });
            }*/

        }

        function doAnimationAlt() {
            if ($( window ).width() > 992) {
                $(".rdy_separator.animate:not(.start-animation)").each(function () {
                    var $this = $(this);
                    var repeatOnce = true;
                    if($this.hasClass('animate-loop')){
                        repeatOnce = false;
                    }

                    $(this).waypoint(function(direction) {

                        if(direction === 'down' && !$this.hasClass("animation-triggered")) {
                            var delay = $this.data('animation-delay') ? $this.data('animation-delay') : 0;

                            if (!$this.hasClass("start-animation") && !$this.hasClass("animation-triggered")) {
                                $this.addClass("animation-triggered");

                                setTimeout(function () {
                                    $this.addClass($this.data('animation-class'));
                                    $this.addClass("start-animation");
                                }, delay);
                            }

                        }

                    }, { offset: '90%', triggerOnce: repeatOnce });

                    if($this.hasClass('animate-loop')) {
                        $(this).waypoint(function (direction) {
                            if (direction === 'up') {
                                $this.removeClass("animation-triggered");
                                $this.removeClass("start-animation");
                            }

                        }, {offset: '110%', triggerOnce: repeatOnce});
                    }
                });
            }
        }

        if (!$("html").hasClass("old-ie")) {
            rdyGlobals.isPhone = false;
            rdyGlobals.isTablet = false;
            rdyGlobals.isDesktop = false;

            var size = window.getComputedStyle(document.body, ":after").getPropertyValue("content");

            if (size.indexOf("phone") !== -1 && rdyGlobals.isMobile) {
                rdyGlobals.isPhone = true;
            } else if (size.indexOf("tablet") !== -1 && rdyGlobals.isMobile) {
                rdyGlobals.isTablet = true;
            } else {
                rdyGlobals.isDesktop = true;
            }

            setTimeout(function () {
                doAnimation();
                doAnimationAlt();
            }, 50);

            if (!rdyGlobals.isMobile && !$("html").hasClass("old-ie")) {
                $(window).on("scroll", function () {
                    doAnimationAlt();
                });
            }
        }


        var rdyResizeTimeout;
        if (rdyGlobals.isMobile && !rdyGlobals.isWindowsPhone) {
            $(window).bind("orientationchange", function (event) {
                clearTimeout(rdyResizeTimeout);
                rdyResizeTimeout = setTimeout(function () {
                    $(window).trigger("debouncedresize");
                }, 200);

            });
        } else {
            $(window).on("resize", function () {
                clearTimeout(rdyResizeTimeout);
                rdyResizeTimeout = setTimeout(function () {
                    $(window).trigger("debouncedresize");
                }, 200);
            });
        }

        $('#mobile-menu .container ul li').each(function(){
            if($(this).find('> ul').length > 0) {
                $(this).addClass('has-ul');
                $(this).find('> a > span').append('<div class="fa-sub-indicator"><i class="fa fa-angle-down"></i></div>');
            }
        });

        $('#mobile-menu .container ul li:has(">ul") > a .fa-sub-indicator').click(function(){
            $(this).parent().parent().parent().toggleClass('open');
            $(this).parent().parent().parent().find('> ul').stop(true,true).slideToggle();
            return false;
        });
        $('#mobile-menu .container ul li.expand:has(">ul") > a').click(function(){
            $(this).parent().toggleClass('open');
            $(this).parent().find('> ul').stop(true,true).slideToggle();
            return false;
        });


        if(!rdyGlobals.isMobile && window.skrollr){
            var s = skrollr.init({
                smoothScrolling: false,
                forceHeight: false,
                mobileCheck: function () {
                    return false;
                }
            });
            s.refresh();

            $(window).resize(function() {
                s.refresh();
            });
        }


        $('body:not(.post-type-archive-rdy_project)').on('click','.section-down-arrow',function(){
            var $offset = $('.fancy-header').height() - $('.fancy-header').offset().top;

            if($(window).width() < 992){
                $offset = $offset + 60;
            }/*else if($('#header').data('background-appear') && $('#header-menu.fixed-layout').length && !$('#header-menu.with-background').length){
                $offset = $offset - $('#header-menu').height();
            }*/

            $('.fancy-header').velocity("stop").velocity('scroll', {
                duration: 1000,
                offset: $offset + 2,
                easing: 'easeInOutCubic'
            });
        });


        var rdy_limit_height;
        var rdy_topbar_height = 0;
        var rdy_has_stiky_mobile = $("#header").hasClass('stiky-mobile');

        function rdy_header_scroll() {

            var isMobileResolution = window.innerWidth <= 992 ? true : false;

            if ( !$('body.with-slide-topbar').length && !isMobileResolution ) {
                return false;
            }

            if ($('#top-bar').exists() && $('#top-bar').css('display') !== 'none') {
                rdy_topbar_height = $('#top-bar').innerHeight();
            } else {
                rdy_topbar_height = 0;
            }

            rdy_limit_height = rdy_topbar_height;

            var rdy_window_y = $(window).scrollTop();
            var wpadminbar_height = 0;
            var top_margin = 0;

            if($("#wpadminbar").exists()){
                wpadminbar_height = top_margin = $("#wpadminbar").height();
                // rdy_limit_height = rdy_limit_height;
            }

            if (rdy_window_y > rdy_limit_height && !isMobileResolution) {
                if (!$("#header").hasClass("m-fixed")) {
                    $("#header, #header-menu").addClass("m-fixed").css({"top": top_margin});
                }

            } else if (rdy_has_stiky_mobile && wpadminbar_height && rdy_window_y > wpadminbar_height && window.innerWidth <= 600 ) {
                $("#header").addClass("m-fixed").css("top", 0, 'important');
                $("#mobile-menu").addClass("m-fixed").css("top", 0, 'important');

            } else if (rdy_has_stiky_mobile && wpadminbar_height && rdy_window_y < wpadminbar_height && window.innerWidth <= 600 ) {
                $("#header").removeClass("m-fixed").css({"top": "auto"});
                $("#mobile-menu").removeClass("m-fixed").css({"top": "auto"});

            } else {
                if ($("#header").hasClass("m-fixed")) {
                    $("#header, #header-menu").removeClass("m-fixed").css({"top": "auto"});
                }
            }

            if ($(window).width() <= 992) {
                $("#mobile-menu").css('max-height', $(window).height());
            }
        }


        rdy_header_scroll();
        var debounce_header_resize = debounce(function () {
            rdy_header_scroll();
        }, 100);
        window.addEventListener("resize", debounce_header_resize);

        var rdy_mobile_scroll_visible = false;
        $(window).scroll(function () {
            if ($(this).scrollTop() > 50) {
                $('.section-down-arrow').addClass('hidden');
            } else {
                $('.section-down-arrow').removeClass('hidden');
            }

            if ($(window).width() > 992) {
                if ($(this).scrollTop() > 500) {
                    $('.scroll-top-main').css('display', 'block').fadeIn(500);
                } else {
                    $('.scroll-top-main').fadeOut(500);
                }

            } else {
                if ($(this).scrollTop() > 300 && ( $('#bottom-bar').length ? $(document).height() - $(window).height() - $('#bottom-bar').height() > $(window).scrollTop() : true) ) {
                    if (!rdy_mobile_scroll_visible) {
                        rdy_mobile_scroll_visible = true;
                        $('.scroll-top-main-mobile').velocity("stop").velocity({translateY: 0}, {
                            duration: 150,
                            easing: [0.19, 1, 0.22, 1],
                            queue: false,
                            complete: function () {
                            }
                        });
                    }

                } else {
                    if (rdy_mobile_scroll_visible) {
                        rdy_mobile_scroll_visible = false;
                        $('.scroll-top-main-mobile').velocity("stop").velocity({translateY: 60}, {
                            duration: 140,
                            easing: [0.19, 1, 0.22, 1],
                            queue: false,
                            complete: function () {
                            }
                        });
                    }
                }
            }
            rdy_header_scroll();
        });

        var midnight_default_height = $('#wpadminbar').length ? 70 : 140;
        $('header#header').midnight({
            otherObjects: '#header-menu',
            otherObjectHeight: $('header#header-menu.slidedown-full-layout').length ? midnight_default_height : false
        });

        $(".scroll-top, .scroll-top-main, .scroll-top-main-mobile").click(function(e) {
            e.preventDefault();
            $("html, body").animate({scrollTop: 0}, {duration: 900, easing: "easeInOutExpo"});
            return false;
        });

        $(".scroll-top").mouseenter(function() {
            $(this).find('.icon').velocity("stop").velocity({translateY: -10, opacity:0.7}, {
                duration: 250, easing: "easeInOut"
            }).velocity({translateY: 0, opacity:1}, {
                duration: 250, easing: "easeInOut"
            });
        });


        if($('body.animated-anchors').length && typeof $('#header-menu a').smoothScroll === 'function'){
            // if(!$('#header-menu.slidedown-full-layout').length){
                $('#header-menu a, #menu-mobile a').smoothScroll({speed: 1000, easing: "easeInOutCubic", animationEngine: 'velocity'});
            // }

            $('.rdy_button, .rev_slider a, .wpb_single_image a, .vc_icon_element a, .wpb_text_column a, .b_icon_with_title a, .vc_column_link, .vc_custom_heading a, .vc_btn3, .vc_icon_element-link, .b_icon_list a').smoothScroll({speed: 1000, easing: "easeInOutCubic", animationEngine: 'velocity'});
        }

        $('#header-menu.slidedown-full-layout').mousewheel(function(event, delta) {
            this.scrollTop -= (delta * 30);
            event.preventDefault();
        });

        var min_w = 1200; // minimum video width allowed
        var vid_w_orig;  // original video dimensions
        var vid_h_orig;

        vid_w_orig = 1280;
        vid_h_orig = 720;


        function resizeVideoToCover() {
            $('.vc_row > video').each(function(){

                var container = $(this).parent('.vc_row'),
                    video = $(this);

                var width = container.outerWidth(),
                    height = container.outerHeight(),
                    pWidth,
                    pHeight,
                    ratio = 1.777777,
                    heightOffset = 0,
                    widthOffset = heightOffset * ratio;

                if (container.data('video-ratio')) {
                    ratio = container.data('video-ratio');
                }

                if (width / ratio < height) {
                    pWidth = Math.ceil((height + heightOffset) * ratio);
                    video.css({
                        width: pWidth + widthOffset + 'px',
                        height: height + heightOffset + 'px',
                        left: ((width - pWidth) / 2) - (widthOffset / 2) + 'px',
                        top: '-' + (heightOffset / 2) + 'px'
                    });

                } else {
                    pHeight = Math.ceil(width / ratio);
                    video.css({
                        width: width + widthOffset + 'px',
                        height: pHeight + heightOffset + 'px',
                        left: '-' + (widthOffset / 2) + 'px',
                        top: ((height - pHeight) / 2) - (heightOffset / 2) + 'px'
                    });

                }

                if (!video.data('show')) {
                    video.css('opacity', 1);
                }

            });

            $('.site-content.project .illustrations-container .illustrations .illustration-inner[data-video="1"]').each(function(i){
                var $containerHeight;
                var $containerWidth;
                var $container = $('.mejs-container', $(this));

                if($(this).parents('#page-header-bg').length > 0) {
                    if($('.container-wrap.auto-height').length > 0) {
                        return false;
                    }
                    $containerHeight = $(this).parents('#page-header-bg').outerHeight();
                    $containerWidth = $(this).parents('#page-header-bg').outerWidth();
                } else if($(this).parents('.illustration').length > 0) {
                    if($('.container-wrap.auto-height').length > 0) {
                        return false;
                    }
                    $containerHeight = $(this).parents('.illustration').outerHeight();
                    $containerWidth = $(this).parents('.illustration').outerWidth();
                } else {
                    $containerHeight = $(this).parents('.wpb_row').outerHeight();
                    $containerWidth = $(this).parents('.wpb_row').outerWidth();
                }

                $container.width($containerWidth);
                $container.height($containerHeight);

                var scale_h = $containerWidth / vid_w_orig;
                var scale_v = ($containerHeight - $containerHeight) / vid_h_orig;
                var scale = scale_h > scale_v ? scale_h : scale_v;

                min_w = 1280/720 * ($containerHeight+40);

                if (scale * vid_w_orig < min_w) {scale = min_w / vid_w_orig;}

                $(this).find('video, .mejs-overlay, .mejs-poster').width(Math.ceil(scale * vid_w_orig +0));
                $(this).find('video, .mejs-overlay, .mejs-poster').height(Math.ceil(scale * vid_h_orig +0));

                $container.css('left', -($(this).find('video').width() - $containerWidth) / 2);
                $container.css('top', -($(this).find('video').height() - ($containerHeight)) / 2);

            });
        }

        setTimeout(function () {
            resizeVideoToCover();
        }, 300);

        jQuery(window).resize(function () {
            resizeVideoToCover();
        });


        $('.vc_progress_bar:not(.open)').waypoint(function () {
            var $bar = $(this);
            setTimeout(function () {
                $bar.addClass('open');
            }, 500);

        }, { offset:'85%' });


        function initUncovering() {
            if ($('body.footer-uncovering').length) {
                if ($(window).width() >= 992) {
                    $('#page').css('margin-bottom', $('footer.site-footer').height());
                } else {
                    $('#page').css('margin-bottom', 0);
                }
            }
        }

        $(window).on('debouncedresize', function() {
            initUncovering();
        });
        initUncovering();


        if ($('.wpcf7-form.style-3').length) {
            $('body').on('focus', '.wpcf7-form.style-3 input, .wpcf7-form.style-3 textarea', function () {
                $(this).parents('.action-form-input').addClass('filled').removeClass('no-text');
            });

            $('body').on('blur','.wpcf7-form.style-3 input, .wpcf7-form.style-3 textarea',function(){
                if($(this).val().length > 0) $(this).parents('.wpcf7-form-control-wrap').addClass('has-text').removeClass('no-text');
                else $(this).parents('.wpcf7-form-control-wrap').removeClass('has-text').addClass('no-text');

                if (!($(this).val().length > 0)) {
                    $(this).parents('.action-form-input').removeClass('filled');
                }
            });
        }

        function convertToActionStyle(el){

            $(el).each(function(){
                if($(this).parent().find('input:not([type="checkbox"]):not([type="hidden"]):not(#search-outer input):not(.adminbar-input):not([type="radio"]):not([type="submit"]):not([type="button"]):not([type="date"]):not([type="color"]):not([type="range"]):not([role="button"]):not([role="combobox"]):not(.select2-focusser):not([name="min_price"]):not([name="max_price"])').length == 1 || $(this).parent().find('textarea').length == 1) {

                    if($(this).parents('.action-form-input').length == 0) {
                        if($(this).next('input').length == 1) {

                            $(this).next('input').andSelf().wrapAll('<div class="action-form-input"/>');
                        } else if($(this).find('.wpcf7-form-control-wrap').length > 0) {
                            var $cloneInput = $(this).find('.wpcf7-form-control-wrap');
                            $(this).find('.wpcf7-form-control-wrap').remove();
                            $cloneInput.insertAfter($(this));
                            $(this).parent().wrapInner('<div class="action-form-input" />');
                        } else {
                            $(this).parent().wrapInner('<div class="action-form-input" />');
                        }
                        $html = $(this).html();
                        $(this)[0].innerHTML = '<span class="text"><span class="text-inner">'+$html+'</span></span>';

                        if($(this).parent().find('textarea').length == 1) $(this).parents('.action-form-input').addClass('textarea');
                    }
                }

            });

            $(el).each(function(){
                if($(this).parents('.action-form-input').length == 1 && $(this).find('.text').length == 0) {
                    $html = $(this).html();
                    $(this)[0].innerHTML = '<span class="text"><span class="text-inner">'+$html+'</span></span>';
                }
            });
        }

        setTimeout(function(){ convertToActionStyle('form.wpcf7-form label'); removeExcessLabels(); checkValueOnLoad(); }, 501);

        function removeExcessLabels() {
            $('.action-form-input').each(function(){
                if($(this).find('label').length > 1) {
                    $lngth = 0;
                    $(this).find('label').each(function(){
                        if($(this).text().length >= $lngth) {
                            $lngth = $(this).text().length;
                            $(this).parents('.action-form-input').find('label').addClass('tbr');
                            $(this).removeClass('tbr');
                        }
                    });
                    $(this).find('label.tbr').remove();
                }
            });
        }
        removeExcessLabels();


        function checkValueOnLoad() {
            $('.action-form-input input, .action-form-input textarea').each(function(){
                if($(this).val().length > 0) $(this).parents('.action-form-input').addClass('has-text').removeClass('no-text');
            });
        }
        checkValueOnLoad();



        function scrollSpyInit(){

            var $headerNavSpace = ($('#header-menu[data-fixed-menu="1"]').length > 0 && $(window).width() > 1000) ? $('#header-menu').outerHeight() : 0;

            /*
            //remove full page URLs from hash if located on same page to fix current menu class
            //if(location.pathname.length > 1) {
            $("#header-outer a[href*='" + location.pathname + "']").each(function(){
                var $href = $(this).attr('href');

                //regular animated anchors
                if($href.indexOf("#") != -1 && $('div'+$href.substr($href.indexOf("#"))).length > 0 ) {

                    $(this).attr('href',$href.substr($href.indexOf("#")));
                    $(this).parent().removeClass('current_page_item').removeClass('current-menu-item');
                }

                //fullpage is a little different
                if($('div[data-fullscreen-anchor-id="'+$href.substr($href.indexOf("#")+1)+'"]').length > 0) {
                    $(this).parent().removeClass('current_page_item').removeClass('current-menu-item');
                }

            });*/
            //}
            var adminBarHeight = ($('#wpadminbar').length > 0) ? $('#wpadminbar').height() : 0; //admin bar

            $target = '#header-menu'; //($('.page-submenu[data-sticky="true"]').length == 0) ? '#header-outer nav': '.page-submenu';
            $('body').scrollspy({
                target: $target,
                offset: $headerNavSpace + adminBarHeight + 40 //130 + 32
            });

        }


        initClientList();
        initOwlSlider();
        initResponsiveVideoIframesInit();
        initFullScreenHeader();
        initParallax();
        initToCounter();
        initCounterRandom();
        initCounterMotion();
        initPieChart();
        initMessages();
        initRdyListAnimation();
        initPortfolioListAnimation();
        initWoocommerce();
        initWoocommerceSpinner();
        initJsHeight();
        magnificPopup();
        initSVGiconAnimation();
        initShare();
        // if($('body.animated-anchors').length > 0) setTimeout(scrollSpyInit,200);

        //initInfiniteScroll();
        jQuery( document.body ).on( 'updated_cart_totals', function() { initWoocommerceSpinner(); } );

        if (jQuery.fn.isotope !== undefined) {
            rdy.isotopeLayout();
        }

        rdy.fxGrainOverlay();
        rdy.fxGlitchOverlay();
        rdy.cascadeAnimation();

        if($.fn.rdyCountdown) {
            $('.rdy-countdown-timer').rdyCountdown();
        }


        var $smoothActive = $('body').attr('data-smooth-scrolling');
        var $smoothCache = ( $smoothActive == 1 ) ? true : false;

        if($smoothCache == false && navigator.platform.toUpperCase().indexOf('MAC') === -1 && !navigator.userAgent.match(/(Android|iPod|iPhone|iPad|IEMobile|Opera Mini)/) && $(window).width() > 690) {
            /*var scroll = new SmoothScroll('a[href*="#"]', {
                speed: 500,
                speedAsDuration: true
            });*/
            /*!function(){function e(){var e=!1;e&&c("keydown",r),v.keyboardSupport&&!e&&u("keydown",r)}function t(){if(document.body){var t=document.body,n=document.documentElement,o=window.innerHeight,r=t.scrollHeight;if(S=document.compatMode.indexOf("CSS")>=0?n:t,w=t,e(),x=!0,top!=self)y=!0;else if(r>o&&(t.offsetHeight<=o||n.offsetHeight<=o)){var a=!1,i=function(){a||n.scrollHeight==document.height||(a=!0,setTimeout(function(){n.style.height=document.height+"px",a=!1},500))};if(n.style.height="auto",setTimeout(i,10),S.offsetHeight<=o){var l=document.createElement("div");l.style.clear="both",t.appendChild(l)}}v.fixedBackground||b||(t.style.backgroundAttachment="scroll",n.style.backgroundAttachment="scroll")}}function n(e,t,n,o){if(o||(o=1e3),d(t,n),1!=v.accelerationMax){var r=+new Date,a=r-C;if(a<v.accelerationDelta){var i=(1+30/a)/2;i>1&&(i=Math.min(i,v.accelerationMax),t*=i,n*=i)}C=+new Date}if(M.push({x:t,y:n,lastX:0>t?.99:-.99,lastY:0>n?.99:-.99,start:+new Date}),!T){var l=e===document.body,u=function(){for(var r=+new Date,a=0,i=0,c=0;c<M.length;c++){var s=M[c],d=r-s.start,f=d>=v.animationTime,h=f?1:d/v.animationTime;v.pulseAlgorithm&&(h=p(h));var m=s.x*h-s.lastX>>0,w=s.y*h-s.lastY>>0;a+=m,i+=w,s.lastX+=m,s.lastY+=w,f&&(M.splice(c,1),c--)}l?window.scrollBy(a,i):(a&&(e.scrollLeft+=a),i&&(e.scrollTop+=i)),t||n||(M=[]),M.length?N(u,e,o/v.frameRate+1):T=!1};N(u,e,0),T=!0}}function o(e){x||t();var o=e.target,r=l(o);if(!r||e.defaultPrevented||s(w,"embed")||s(o,"embed")&&/\.pdf/i.test(o.src))return!0;var a=e.wheelDeltaX||0,i=e.wheelDeltaY||0;return a||i||(i=e.wheelDelta||0),!v.touchpadSupport&&f(i)?!0:(Math.abs(a)>1.2&&(a*=v.stepSize/120),Math.abs(i)>1.2&&(i*=v.stepSize/120),n(r,-a,-i),void e.preventDefault())}function r(e){var t=e.target,o=e.ctrlKey||e.altKey||e.metaKey||e.shiftKey&&e.keyCode!==H.spacebar;if(/input|textarea|select|embed/i.test(t.nodeName)||t.isContentEditable||e.defaultPrevented||o)return!0;if(s(t,"button")&&e.keyCode===H.spacebar)return!0;var r,a=0,i=0,u=l(w),c=u.clientHeight;switch(u==document.body&&(c=window.innerHeight),e.keyCode){case H.up:i=-v.arrowScroll;break;case H.down:i=v.arrowScroll;break;case H.spacebar:r=e.shiftKey?1:-1,i=-r*c*.9;break;case H.pageup:i=.9*-c;break;case H.pagedown:i=.9*c;break;case H.home:i=-u.scrollTop;break;case H.end:var d=u.scrollHeight-u.scrollTop-c;i=d>0?d+10:0;break;case H.left:a=-v.arrowScroll;break;case H.right:a=v.arrowScroll;break;default:return!0}n(u,a,i),e.preventDefault()}function a(e){w=e.target}function i(e,t){for(var n=e.length;n--;)E[A(e[n])]=t;return t}function l(e){var t=[],n=S.scrollHeight;do{var o=E[A(e)];if(o)return i(t,o);if(t.push(e),n===e.scrollHeight){if(!y||S.clientHeight+10<n)return i(t,document.body)}else if(e.clientHeight+10<e.scrollHeight&&(overflow=getComputedStyle(e,"").getPropertyValue("overflow-y"),"scroll"===overflow||"auto"===overflow))return i(t,e)}while(e=e.parentNode)}function u(e,t,n){window.addEventListener(e,t,n||!1)}function c(e,t,n){window.removeEventListener(e,t,n||!1)}function s(e,t){return(e.nodeName||"").toLowerCase()===t.toLowerCase()}function d(e,t){e=e>0?1:-1,t=t>0?1:-1,(k.x!==e||k.y!==t)&&(k.x=e,k.y=t,M=[],C=0)}function f(e){if(e){e=Math.abs(e),D.push(e),D.shift(),clearTimeout(z);var t=h(D[0],120)&&h(D[1],120)&&h(D[2],120);return!t}}function h(e,t){return Math.floor(e/t)==e/t}function m(e){var t,n,o;return e*=v.pulseScale,1>e?t=e-(1-Math.exp(-e)):(n=Math.exp(-1),e-=1,o=1-Math.exp(-e),t=n+o*(1-n)),t*v.pulseNormalize}function p(e){return e>=1?1:0>=e?0:(1==v.pulseNormalize&&(v.pulseNormalize/=m(1)),m(e))}var w,g={frameRate:150,animationTime:500,stepSize:120,pulseAlgorithm:!0,pulseScale:8,pulseNormalize:1,accelerationDelta:20,accelerationMax:1,keyboardSupport:!0,arrowScroll:50,touchpadSupport:!0,fixedBackground:!0,excluded:""},v=g,b=!1,y=!1,k={x:0,y:0},x=!1,S=document.documentElement,D=[120,120,120],H={left:37,up:38,right:39,down:40,spacebar:32,pageup:33,pagedown:34,end:35,home:36},v=g,M=[],T=!1,C=+new Date,E={};setInterval(function(){E={}},1e4);var z,A=function(){var e=0;return function(t){return t.uniqueID||(t.uniqueID=e++)}}(),N=function(){return window.requestAnimationFrame||window.webkitRequestAnimationFrame||function(e,t,n){window.setTimeout(e,n||1e3/60)}}(),K=/chrome/i.test(window.navigator.userAgent),L=null;"onwheel"in document.createElement("div")?L="wheel":"onmousewheel"in document.createElement("div")&&(L="mousewheel"),L&&K&&(u(L,o),u("mousedown",a),u("load",t))}();*/
        }

    });


    jQuery(document).ready(function () {

        // Retina images using srcset polyfill
        window.retinizer = function() {
            if ($("body").hasClass("srcset-enabled")) {
                var $coll = $("img:not(.retinized)").filter("[srcset]"),
                    ratio = window.devicePixelRatio ? window.devicePixelRatio : 1;

                $coll.each(function() {
                    var $this = $(this),
                        srcArray = $this.attr("srcset").split(","),
                        srcMap = [],
                        src = "";

                    srcArray.forEach(function(el, i) {
                        var temp = $.trim(el).split(" ");
                        srcMap[temp[1]] = temp[0];
                    });

                    if (ratio >= 1.5) {
                        if (!(typeof srcMap["2x"] == "undefined")) src = srcMap["2x"];
                        else src = srcMap["1x"];
                    }
                    else {
                        if (!(typeof srcMap["1x"] == "undefined")) src = srcMap["1x"];
                        else src = srcMap["2x"];
                    }

                    $this.attr("src", src).addClass("retinized");
                });

                // Retina logo in floating menu
                if (! (typeof rdyGlobals.logoURL == "undefined")) {
                    var logoArray = rdyGlobals.logoURL.split(","),
                        logoMap = [];

                    logoArray.forEach(function (el, i) {
                        var temp = $.trim(el).split(" ");
                        logoMap[temp[1]] = temp[0];

                    });

                    if (ratio >= 1.5) {
                        if (!(typeof logoMap["2x"] == "undefined")) rdyGlobals.logoURL = logoMap["2x"];
                        else rdyGlobals.logoURL = logoMap["1x"];
                    }
                    else {
                        if (!(typeof logoMap["1x"] == "undefined")) rdyGlobals.logoURL = logoMap["1x"];
                        else rdyGlobals.logoURL = logoMap["2x"];
                    }
                }
            }
        };
        retinizer();

    });


    /* init Functions */

    function initShare() {
        var windowLocation = window.location.href.replace(window.location.hash, '');

        String.prototype.to_rfc3986 = function() {
            var tmp;
            tmp = encodeURIComponent(this);
            return tmp.replace(/[!'()*]/g, function(c) {
                return "%" + c.charCodeAt(0).toString(16);
            });
        };

        var is_encoded = function(str) {
            str = str.to_rfc3986();
            return decodeURIComponent(str) !== str;
        };

        var encode = function(str) {
            if (typeof str === "undefined" || is_encoded(str)) {
                return str;
            } else {
                return str.to_rfc3986();
            }
        };

        var openSharePopup = function(url, params) {
            var k, popup, qs, v;
            if (params == null) {
                params = {};
            }
            popup = {
                width: 500,
                height: 350
            };
            popup.top = (screen.height / 2) - (popup.height / 2);
            popup.left = (screen.width / 2) - (popup.width / 2);
            qs = ((function() {
                var _results;
                _results = [];
                for (k in params) {
                    v = params[k];
                    _results.push("" + k + "=" + (encode(v)));
                }
                return _results;
            }).call(this)).join('&');
            if (qs) {
                qs = "?" + qs;
            }
            return window.open(url + qs, 'targetWindow', "toolbar=no,location=no,status=no,menubar=no,scrollbars=yes,resizable=yes,left=" + popup.left + ",top=" + popup.top + ",width=" + popup.width + ",height=" + popup.height);
        }

        function facebookShare(){
            openSharePopup('https://www.facebook.com/sharer/sharer.php', {
                u: windowLocation
            });

            return false;
        }

        function googlePlusShare(){
            openSharePopup('https://plus.google.com/share', {
                url: windowLocation
            });

            return false;
        }

        function twitterShare(){
            var $pageTitle = encodeURIComponent($(document).find("title").text());
            openSharePopup('https://twitter.com/intent/tweet', {
                text: $pageTitle,
                url: windowLocation
            });

            return false;
        }


        function linkedInShare(){
            var $pageTitle = encodeURIComponent($(document).find("title").text());
            openSharePopup('https://www.linkedin.com/shareArticle', {
                text: $pageTitle,
                url: windowLocation
            });

            return false;
        }

        function pinterestShare(){
            var $pageTitle = encodeURIComponent($(document).find("title").text());
            var $sharingImg = ( $(this).data('featured-image') ) ? $(this).data('featured-image') : '';
            openSharePopup('https://www.pinterest.com/pin/create/button', {
                url: windowLocation,
                media: $sharingImg,
                description: $pageTitle
            });

            return false;
        }

        $('body').on('click','.post-share-buttons .fa-facebook', facebookShare);
        $('body').on('click','.post-share-buttons .fa-google-plus', googlePlusShare);
        $('body').on('click','.post-share-buttons .fa-twitter', twitterShare);
        $('body').on('click','.post-share-buttons .fa-pinterest', pinterestShare);
        $('body').on('click','.post-share-buttons .fa-linkedin', linkedInShare);

    }

    function initNavigationBar() {

        if($('.navigation-bar.type1').length){

            var stickyNav = function(){

                var scrollTop = $(window).scrollTop();
                var stickyNavBottom = 2000;
                if($('#navigation-bar-side').length){
                    stickyNavBottom = $('#navigation-bar-side').offset().top - $(window).height();
                }

                var stickyNavTop = $('.content-area .hentry').offset().top - $(window).height() + 200;

                if (scrollTop > stickyNavTop && scrollTop < stickyNavBottom) {
                    $('.navigation-bar.type1').addClass('sticky');
                } else {
                    $('.navigation-bar.type1').removeClass('sticky');
                }

            };

            if($('.content-area .hentry').length){
                $(window).scroll(function() {
                    stickyNav();
                });
            }

        }

        if($('.navigation-bar.type2').length){
            var navBarVisible = false;
            
            var hideNavBar = function(){
                var scrollTop = $(window).scrollTop();
                if($('#navigation-bar-side').length){
                    var stickyNavBottom = $('#navigation-bar-side').offset().top - $(window).height();
                }
                
                var stickyNavTop = $('.content-area .hentry').offset().top - $(window).height() + 200;

                if (scrollTop > stickyNavTop && scrollTop < stickyNavBottom ) {
                    if(!navBarVisible){
                        navBarVisible = true;
                        $('.navigation-bar.type2').velocity("stop").velocity("fadeIn", {
                            duration: 500
                        });
                    }
                } else if(navBarVisible) {
                    navBarVisible = false;
                    $('.navigation-bar.type2').velocity("stop").velocity("fadeOut", {
                        duration: 500
                    });
                }

            };

            hideNavBar();
            if($('.content-area .hentry').length){
                $(window).scroll(function() {
                    hideNavBar();
                });
            }
        }
    }


    function initRdyListAnimation() {
        $('.b_list').each(function(){
            var that = $(this);
            var $icon = $(this).data('list-icon');
            var $animation = $(this).data('animation');
            var $animation_repeat = $(this).data('animation-repeat') ? true : false;

            if($(this).find('li i').length == 0) {

                if($icon) $(this).find('li').prepend('<i class="'+$icon+ '"></i> ');
                if($animation) {

                    $(this).waypoint(function(direction) {
                        if (direction == 'down') {
                            var li_list = that.find('li');
                            li_list.each(function (i) {
                                jQuery(this).delay(i * 250).animate({
                                    'opacity': '1',
                                    'left': '0'
                                }, 350, 'easeOutCubic');
                            });
                        }
                    }, { offset: '90%', triggerOnce: $animation_repeat ? false : true });

                    if($animation_repeat) {
                        $(this).waypoint(function(direction) {
                            if (direction == 'up') {
                                var li_list = that.find('li');
                                li_list.each(function(i) {
                                    jQuery(this).css({
                                        'opacity': '0',
                                        'left' : '-20px'
                                    });
                                });
                            }

                        }, { offset: '110%' });
                    }
                }

            }

        });
    }


    function initPortfolioListAnimation() {
        $.Velocity.RegisterUI("portfolio.slideLeftIn", {
            defaultDuration: 100,
            calls: [
                [ { opacity: [ 1, 0 ], translateX: [ 0, -30 ], translateZ: 0 }, { easing: "easeOutCubic" }  ]
            ]
        });
        $.Velocity.RegisterUI("portfolio.slideUpIn", {
            defaultDuration: 100,
            calls: [
                [ { opacity: [ 1, 0 ], translateY: [ 0, 30 ], translateZ: 0 }, { easing: "easeOutCubic" }  ]
            ]
        });
        $.Velocity.RegisterUI("portfolio.fadeIn", {
            defaultDuration: 150,
            calls: [
                [ { opacity: [ 1, 0 ] }, { easing: "easeOutCubic" }  ]
            ]
        });

        $('.rdy-portfolio-container.list-animation').each(function(){
            var that = $(this);
            var $animation, $animation_reset;
            var $animation_repeat = $(this).data('animation-repeat') ? true : false;

            if ($(this).data('animation') == 'slideLeftIn') {
                $animation = "portfolio.slideLeftIn";
                $animation_reset = {
                    'opacity': '0',
                    'transform' : 'translateX(-30px)'
                }
            } else if ($(this).data('animation') == 'slideUpIn') {
                $animation = "portfolio.slideUpIn";
                $animation_reset = {
                    'opacity': '0',
                    'transform' : 'translateY(30px)'
                }
            } else if ($(this).data('animation') == 'fadeIn') {
                $animation = "portfolio.fadeIn";
                $animation_reset = {
                    'opacity': '0'
                }
            }

            if($(this).find('.hentry').length > 0 && $animation) {
                $(this).waypoint(function(direction) {
                    if (direction == 'down') {
                        var li_list = that.find('.hentry');
                        li_list.velocity('stop').velocity($animation, { stagger: 300 });
                    }
                }, { offset: '90%', triggerOnce: $animation_repeat ? false : true });

                if($animation_repeat) {
                    $(this).waypoint(function(direction) {
                        if (direction == 'up') {
                            var li_list = that.find('.hentry');
                            li_list.each(function(i) {
                                jQuery(this).css($animation_reset);
                            });
                        }

                    }, { offset: '110%' });
                }

            }

        });
    }


    function initFullScreenHeader(){

        var pageHeaderHeight = parseInt($('#page-header-bg').attr('data-height'), 10);

        if($('#fancy-header').length > 0) {

            var isHeaderFullHeight = $('body #fancy-header.fullscreen-header').length > 0 ? true : false;
            var extraHeight = ($("#wpadminbar").length > 0) ? $("#wpadminbar").height() : 0;
            var fancyHeaderHeight = $('#fancy-header').height();

            pageHeaderHeight = $(window).height() - extraHeight;

            if($(window).width() < 992){
                pageHeaderHeight = pageHeaderHeight -  $('#header').height();
            }else{
                if($('#header-menu.static-layout.with-background').length){
                    pageHeaderHeight = pageHeaderHeight - $('#header-menu').height();
                }

                if($('#header-menu.fixed-layout').length && !$('#header').data('background-appear') && $('#header-menu.with-background').length){
                    pageHeaderHeight = pageHeaderHeight - $('#header-menu').height();
                }
            }

            if(isHeaderFullHeight) {
                fancyHeaderHeight = pageHeaderHeight;
                $('#fancy-header').css({
                    'height': pageHeaderHeight + 'px',
                    'min-height': pageHeaderHeight + 'px'
                }).removeClass('not-loaded');
                $('#fancy-header .col-table').css({'height': (pageHeaderHeight) + 'px'});
            }

            if(!rdyGlobals.isMobile){
                var scrl_anim = $('#fancy-header .scroll-animation');
                if(scrl_anim.data('opacity') && scrl_anim.data('down')){
                    if($('#fancy-header').hasClass('fh-va-bottom')){
                        var offset;

                        if(isHeaderFullHeight){
                            offset = parseInt(fancyHeaderHeight, 10) * 0.25;
                        }else{
                            offset = parseInt(fancyHeaderHeight, 10) * 0.4;
                        }
                    }else{
                        offset = parseInt(fancyHeaderHeight, 10) * 0.5;
                    }

                    setSkrollr(scrl_anim, [[0, 'opacity:1;transform: translateY(0px)'], [parseInt(fancyHeaderHeight, 10), 'opacity:0;transform: translateY('+ (offset) +'px)']]);

                }else if(scrl_anim.data('opacity')){
                    if($('#fancy-header').hasClass('fh-va-bottom')){
                        setSkrollr(scrl_anim, [[0, 'opacity:1;'], [fancyHeaderHeight * 0.7, 'opacity:0;']]);
                    }else{
                        setSkrollr(scrl_anim, [[0, 'opacity:1;'], [fancyHeaderHeight * 0.5, 'opacity:0;']]);
                    }

                }else if(scrl_anim.data('down')){
                    setSkrollr(scrl_anim, [[0, 'transform: translateY(0px)'], [parseInt(pageHeaderHeight, 10), 'transform: translateY('+ (parseInt(pageHeaderHeight, 10)/2) +'px)']]);
                }

                if(window.skrollr) {
                    var s = skrollr.init({
                        smoothScrolling: false,
                        forceHeight: false,
                        mobileCheck: function () {
                            return false;
                        }
                    });
                    s.refresh();
                }

            }

            $("#fancy-header.fullscreen-header").css("opacity", "1");

            $("#fancy-header .background-container:not(.fancy_parallax)").each(function() {//:not(.fancy_parallax)
                var background_load_opt = {};

                if($(this).data('bg_animation')){
                    background_load_opt = {
                        effect : "fadeIn",
                        effectspeed: $('#fancy-header .background-container[data-bg_animation="1"]').length ? 1000 : 0
                    };
                }


                if ($(window).width() < 992) {
                    if($(this).data('original-mobile')){
                        background_load_opt.data_attribute = 'original-mobile';
                        $(this).lazyload(background_load_opt);
                    } else if($(this).data('original')){
                        $(this).lazyload(background_load_opt);
                    }
                } else {
                    if($(this).data('original')){
                        $(this).lazyload(background_load_opt);
                    }
                }


            });

        }

        setTimeout(function(){ $('#fancy-header').css('overflow','hidden') },800);

    }


    /***************** WP Media Embed / External Embed ******************/

    function initResponsiveVideoIframesInit(){
        $(".post-wrapper .video, body.single-post article.video .video-wrap, .rdy_latest_post .boxes_wrapper .video").fitVids();
    }


    function initClientList() {
        "use strict";

        $('.rdy-clients-shortcode.column-style').each(function() {
            var group = $(this),
                list = group.find('li'),
                listStyle = group.find('ul').attr('style'),
                fullRowColumns = group.find('ul:first-of-type li').length,
                viewport = $(window),
                viewportWidth = viewport.innerWidth(),
                breakPoint1 = 960 - 25,
                breakPoint2 = 767 - 25,
                breakPoint3 = 550 - 25;

            if(listStyle == undefined) listStyle = '';

            function recreateGrid() {
                if (viewportWidth > breakPoint1) {
                    list.unwrap();
                    for (var i = 0; i < list.length; i += fullRowColumns) {
                        list.slice(i, i + fullRowColumns)
                            .wrapAll('<ul style="' + listStyle + '"></ul>');
                    }
                } else if (viewportWidth < breakPoint2) {
                    list.unwrap();
                    for (var i = 0; i < list.length; i += 2) {
                        list.slice(i, i + 2).wrapAll('<ul class="rdy-clients-fixed-list" style="' + listStyle + '"></ul>');
                    }
                } else if (viewportWidth < breakPoint1) {
                    list.unwrap();
                    for (var i = 0; i < list.length; i += 3) {
                        list.slice(i, i + 3).wrapAll('<ul class="rdy-clients-fixed-list" style="' + listStyle + '"></ul>');
                    }
                }
            }
            recreateGrid();

            $(window).on('debouncedresize', function() {
                viewportWidth = viewport.innerWidth();
                recreateGrid();
            });

        });
    }


    function initParallax(){
        "use strict";

        if(!window.skrollr) return;

        var parallaxHeader = function () {
            var vcSkrollrOptions,
                callSkrollInit = false;

            $( '#fancy-header .fancy_parallax-inner' ).remove();
            $( '#fancy-header .fancy_parallax' ).each( function () {
                var skrollrSize,
                    $parallaxElement,
                    parallaxImage;

                callSkrollInit = true; // Enable skrollinit;

                skrollrSize = 110;
                if ($(window).width() < 992) {
                    if($(this).data('original-mobile')){
                        skrollrSize = 110;
                        parallaxImage = $( this ).data( 'original-mobile' );
                    }
                }

                if (!parallaxImage) {
                    parallaxImage = $( this ).data( 'vcParallaxImage' );
                }


                var $this = $( this );
                var parallaxImg = new Image;
                parallaxImg.src = parallaxImage;
                parallaxImg.onload = function () {
                    $parallaxElement = $( '<div />').css({opacity: 0}).addClass( 'fancy_parallax-inner' ).appendTo( $this );
                    $parallaxElement.height( skrollrSize + '%' );
                    $parallaxElement.velocity("transition.fadeIn");

                    if ( parallaxImage !== undefined ) {
                        $parallaxElement.css( 'background-image', 'url(' + parallaxImage + ')' );
                    }

                    $parallaxElement.attr( 'data-start', 'top: ' + (-10) + '%' ).attr( 'data-top-bottom', 'top:  ' + 20 + '%' );

                    rdy.fxGlitchOverlayHeader();
                }

            } );

            if ( callSkrollInit && window.skrollr ) {
                /*vcSkrollrOptions = {
                    forceHeight: false,
                    smoothScrolling: false,
                    mobileCheck: function () {
                        return false;
                    }
                };
                var vcParallaxSkroll = skrollr.init( vcSkrollrOptions );
                vcParallaxSkroll.refresh();*/
                window.onload = function() {
                    if(window.skrollr && typeof skrollr.get() != "undefined") { skrollr.get().refresh(); }
                };

            }

            return false;
        };

        parallaxHeader();

    }


    function initCounterRandom(){
        "use strict";

        if($('.b_counter_holder.random').length){
            $('.b_counter_holder.random').each(function() {
                var $counter = $(this).find('.counter .digit');

                if(!$counter.hasClass('executed')){
                    $counter.addClass('executed');

                    var animation = $counter.data('animation'),
                        speed = $counter.data('speed') ? $counter.data('speed') : 2000,
                        delay = $counter.data('delay') ? $counter.data('delay') : 0;
                    var obj_this = this;

                    $counter.waypoint(function(direction) {
                        $(obj_this).css('opacity', '1');
                        $counter.absoluteCounter({
                            speed: speed,
                            fadeInDelay: 1000,
                            onComplete: function() {
                                if(animation) {
                                    $counter.velocity({
                                        scaleX: 1.1,
                                        scaleY: 1.1,
                                        opacity: .8
                                    }, 50, {easing: "easeOutElastic"})
                                        .velocity({scaleX: 1, scaleY: 1, opacity: 1}, 100, {easing: "easeOutElastic"})
                                }
                            }
                        });

                    }, { offset: '90%', triggerOnce: true });
                }
            });
        }
    }


    function initToCounter(){
        "use strict";

        if($('.b_counter_holder.zero').length){
            $('.b_counter_holder.zero').each(function() {
                var $counter = $(this).find('.counter .digit');

                if(!$counter.hasClass('executed')){
                    $counter.addClass('executed');
                    var obj_this = this;
                    var repeatOnce = $counter.data('repeat') ? false : true;

                    var useOnComplete = false,
                        useEasing = true,
                        useGrouping = true,
                        animation = $counter.data('animation'),
                        duration = $counter.data('speed') ? $counter.data('speed')/1000 : 2.5,
                        options = {
                            useEasing : true,
                            useGrouping : true,
                            separator : $counter.data('separator') ? $counter.data('separator') : ''
                            //decimal : '.'
                        };

                    $counter.waypoint(function(direction){
                        if(direction == 'down') {
                            setTimeout(function () {
                                $(obj_this).css('opacity', '1');

                                var numAnim = new CountUp($counter[0], 0, $counter.data('count'), 0, duration, options);
                                numAnim.start(function () {
                                    if (animation) {
                                        $(obj_this).velocity("stop").velocity({
                                                scaleX: 1.1,
                                                scaleY: 1.1
                                            }, {duration: 100, easing: "easeInOut"})
                                            .velocity({scaleX: 1, scaleY: 1}, {duration: 600, easing: [200, 8]});

                                        setTimeout(function () {
                                            $(obj_this).css({opacity: .3}).velocity({
                                                opacity: 1
                                            }, {duration: 1000, queue: false, easing: "easeOutExpo"})
                                        }, 0);

                                    }
                                });
                            }, $(obj_this).data('delay') ? $counter.data('delay') : 0);
                        }
                    }, { offset: '90%', triggerOnce: repeatOnce });

                }
            });
        }
    }


    function initCounterMotion() {
        $('.b_counter_holder.motion').each(function() {
            var $counter = $(this).find('.counter');

            if($counter.is('[data-symbol]')) {
                if ($counter.attr('data-symbol-pos') == 'before') {
                    $counter.find('.digit').prepend('<div class="symbol-wrap"><span class="symbol">'
                        + $counter.attr('data-symbol') + '</span></div>');
                } else {
                    $counter.find('.digit').append('<div class="symbol-wrap"><span class="symbol">'
                        + $counter.attr('data-symbol') + '</span></div>');
                }

                var $symbol_size = ( $counter.attr('data-symbol-size') == $counter.find('.digit').attr('data-number-size') );
                $counter.find('.symbol-wrap').css({'font-size': $symbol_size + 'px', 'line-height': $symbol_size + 'px'});
            }

            $counter.find('.digit').css({
                'font-size': $counter.find('.digit').attr('data-number-size') +'px',
                'line-height': $counter.find('.digit').attr('data-number-size') + 'px'
            });
        });


        if(!$('body').hasClass('mobile')) {

            var $blurCssString = '';
            $('.b_counter_holder.motion').each(function(i){
                var $counter = $(this).find('.counter');

                $counter.addClass('instance-'+i);

                var $currentColor = $counter.find('.digit').css('color');
                var rgb = $currentColor.match(/^rgb\((\d+)\,\s*(\d+)\,\s*(\d+)\)$/);
                var R = rgb[1];
                var G = rgb[2];
                var B = rgb[3];

                var $rgbaColor0 = 'rgba('+R+','+G+','+B+',0.2)';
                var $rgbaColor1 = 'rgba('+R+','+G+','+B+',1)';
                var $numberSize = parseInt($counter.find('.digit').css('font-size'), 10);

                $blurCssString += '@keyframes motion-blur-number-'+i+' { ' +
                    ' 0% { '+
                    'color: '+$rgbaColor0+'; '+
                    'text-shadow: 0 '+$numberSize/20+'px 0 '+$rgbaColor0+', 0 '+$numberSize/10+'px 0 '+$rgbaColor0+', 0 '+$numberSize/6+'px 0 '+$rgbaColor0+', 0 '+$numberSize/5+'px 0 '+$rgbaColor0+', 0 '+$numberSize/4+'px 0 '+$rgbaColor0+', 0 -'+$numberSize/20+'px 0 '+$rgbaColor0+', 0 -'+$numberSize/10+'px 0 '+$rgbaColor0+', 0 -'+$numberSize/6+'px 0 '+$rgbaColor0+', 0 -'+$numberSize/5+'px 0 '+$rgbaColor0+', 0 -'+$numberSize/4+'px 0 '+$rgbaColor0+'; '+
                    'opacity: 0; transform: translateZ(0px) translateY(-100%); -webkit-transform: translateZ(0px) translateY(-100%); '+
                    '} '+
                    '35% { opacity: 1 }' +
                    '100% { '+
                    'color: '+$rgbaColor1+'; '+
                    'text-shadow: none; '+
                    'transform: translateZ(0px) translateY(0px); -webkit-transform: translateZ(0px) translateY(0px); '+
                    '} '+
                    '} '+
                    '@-webkit-keyframes motion-blur-number-'+i+' { ' +
                    ' 0% { '+
                    'color: '+$rgbaColor0+'; '+
                    'text-shadow: 0 '+$numberSize/20+'px 0 '+$rgbaColor0+', 0 '+$numberSize/10+'px 0 '+$rgbaColor0+', 0 '+$numberSize/6+'px 0 '+$rgbaColor0+', 0 '+$numberSize/5+'px 0 '+$rgbaColor0+', 0 '+$numberSize/4+'px 0 '+$rgbaColor0+', 0 -'+$numberSize/20+'px 0 '+$rgbaColor0+', 0 -'+$numberSize/10+'px 0 '+$rgbaColor0+', 0 -'+$numberSize/6+'px 0 '+$rgbaColor0+', 0 -'+$numberSize/5+'px 0 '+$rgbaColor0+', 0 -'+$numberSize/4+'px 0 '+$rgbaColor0+'; '+
                    'opacity: 0; transform: translateZ(0px) translateY(-100%); -webkit-transform: translateZ(0px) translateY(-100%); '+
                    '} '+
                    '35% { opacity: 1 }' +
                    '100% { '+
                    'color: '+$rgbaColor1+'; '+
                    'text-shadow: none; '+
                    'transform: translateZ(0px) translateY(0px); -webkit-transform: translateZ(0px) translateY(0px); '+
                    '} '+
                    '} '+
                    '.b_counter_holder .counter.motion.instance-'+i+' .digit span.in-sight { animation: 0.65s cubic-bezier(0, 0, 0.17, 1) 0s normal backwards 1 motion-blur-number-'+i+'; -webkit-animation: 0.65s cubic-bezier(0, 0, 0.17, 1) 0s normal backwards 1 motion-blur-number-'+i+'; } ';

                var $symbol = $counter.find('.symbol-wrap').clone();
                $counter.find('.symbol-wrap').remove();
                var characters = $counter.find('.digit').text().split("");
                var $this = $counter.find('.digit');
                $this.empty();

                $.each(characters, function (i, el) {
                    if(el == ' ') el = '&nbsp;';
                    $this.append("<span>" + el + "</span>");
                });

                if($counter.has('[data-symbol]')) {
                    if($counter.attr('data-symbol-pos') == 'after') {
                        $this.append($symbol);
                    } else {
                        $this.prepend($symbol);
                    }
                }

            });

            var head = document.head || document.getElementsByTagName('head')[0];
            var style = document.createElement('style');

            style.type = 'text/css';
            if (style.styleSheet){
                style.styleSheet.cssText = $blurCssString;
            } else {
                style.appendChild(document.createTextNode($blurCssString));
            }

            head.appendChild(style);

            $('.b_counter_holder.motion').each(function() {
                var $counter = $(this).find('.counter');

                $(this).css('opacity', 1);
                var $offset = ($counter.hasClass('motion')) ? '90%' : '105%';
                var repeatOnce = $counter.find('.digit').data('repeat') ? false : true;

                $counter.waypoint(function(direction) {
                    if($counter.hasClass('motion') && direction == 'down') {
                        if (!$counter.hasClass("animation-triggered")) {
                            $counter.addClass("animation-triggered");
                            $counter.find('span').each(function (i) {
                                var $that = $(this);
                                setTimeout(function () {
                                    $that.addClass('in-sight');
                                }, 200 * i);

                            });
                        }
                    }

                }, { offset: $offset, triggerOnce: repeatOnce });

                $counter.waypoint(function(direction) {
                    if ($counter.hasClass('motion') && direction == 'up') {
                        $counter.removeClass("animation-triggered");
                        $counter.find('span').removeClass("in-sight");
                    }

                }, { offset: '110%', triggerOnce: repeatOnce });
            });

        }

    }


    function initToCounterPieChart($this){
        "use strict";

        $($this).css('opacity', '1');

        var $max = parseFloat($($this).data('percent'));
        var $animate = 1500;

        if($($this).data('animation-speed') !== "" && $($this).data('animation-speed') != "0"){
            $animate = $($this).data('animation-speed');
        }

        $($this).find('.tocounter').countTo({
            from: 0,
            to: $max,
            speed: $animate,
            refreshInterval: 50
        });
    }


    function initPieChart(){
        "use strict";

        if($('.b_percentage').length){
            $('.b_percentage').each(function() {

                var $barColor =  "#ff0000";

                if($(this).data('active') !== ""){
                    $barColor = $(this).data('active');
                }

                var $trackColor = '#eeeeee';

                if($(this).data('noactive') !== ""){
                    $trackColor = $(this).data('noactive');
                }

                var $line_width = 10;
                var $animate = 1500;

                if($(this).data('linewidth') !== ""){
                    $line_width = $(this).data('linewidth');
                }
                if($(this).data('animation-speed') !== "" && $(this).data('animation-speed') != "0"){
                    $animate = $(this).data('animation-speed');
                }

                var $size = 174;

                if($(this).data('width') !== ""){
                    $size = parseInt($(this).data('width'), 10);
                    if(!($size>30)){
                        $size = 174;
                    }
                }

                var $lineCap = 'butt';

                if($(this).data('round') == "1"){
                    $lineCap = 'round';
                }

                $(this).width($size);
                $(this).height($size);
                $(this).css('line-height', $size+'px');

                var obj_this = this;

                $(this).waypoint(function(direction) {
                    initToCounterPieChart($(obj_this));
                    $(obj_this).parent().css('opacity', '1');

                    $(obj_this).easyPieChart({
                        barColor: $barColor,
                        trackColor: $trackColor,
                        scaleColor: false,
                        lineCap: $lineCap,
                        lineWidth: $line_width,
                        animate: $animate,
                        size: $size
                    });

                }, { offset: '90%', triggerOnce: true });
            });
        }
    }


    function initMessages(){
        "use strict";

        if($('.b_message').length){
            $('.b_message').each(function(){
                $(this).find('.close').click(function(e){
                    e.preventDefault();
                    $(this).parent().parent().fadeOut(500);
                });
            });
        }
    }


    function initOwlSlider(){
        "use strict";

        $('.rdy-owlslider.rdy-clients-shortcode').each(function () {
            $(this).find('.rdy-owl-slides').owlCarousel({
                autoplay: $(this).data('autoplay'),
                smartSpeed: $(this).data('animationSpeed'),
                autoplayTimeout: $(this).data('autoplayTimeout') ? $(this).data('autoplayTimeout') : 4000,
                autoplayHoverPause: $(this).data('pauseonhover'),
                items: $(this).data('maxitems'),
                loop: true,
                responsiveClass: true,
                dots: false,
                nav: false,
                responsive : {
                    0 : {
                        items: 2
                    },
                    768 : {
                        items: $(this).data('maxitems')
                    }
                }
            });
        });

        rdy.carousel($('body'));

        $(".owl-testimonials").each(function() {

            var autoplay = false;
            var autoplaytime = 0;
            var loop = true;
            var nav = true;
            var fade_in = '';
            var fade_out = '';

            if ($(this).data('autoslide')) {
                autoplay = true;
                autoplaytime = $(this).data('autoslide');
            }

            if ($(this).data('animation') == 'fadein') {
                fade_in = 'fadeIn';
                fade_out = '';
            } else if ($(this).data('animation') == 'downflip') {
                fade_in = 'flipInX';
                fade_out = 'fadeOutDown';
            }


            if($( this).find('.item').length == 1){
                loop = false;
                nav = false;
            }

            $( this ).owlCarousel({

                autoplay: autoplay,
                autoplayTimeout: autoplaytime,
                autoplayHoverPause: true,
                themeClass : "owl-testimonials",
                autoHeight: true,
                dots: nav,
                nav: nav,
                navText: ["",""],
                items: 1,
                loop: loop,
                animateIn: fade_in,
                animateOut: fade_out

            });

        });

        $(".owl-slider").each(function() {

            $(this).owlCarousel({

                autoplay: !0,
                navSpeed: 700,
                smartSpeed: 700,
                autoheight: false,
                themeClass : "owl-theme-slider",
                dots: !1,
                nav: !0,
                navText: ["",""],
                items: 1,
                loop: true

            });

        });

        /*$(".owl-posts-slider").each(function() {

            $(this).owlCarousel({

                autoplay: false,
                navSpeed: 700,
                smartSpeed: 700,
                autoheight: false,
                // themeClass : "owl-theme-slider0",
                dots: false,
                nav: false,
                navText: ["",""],
                items: 4,
                loop: true

            });

        });*/

        $(".products.owl-carousel").each(function() {
            var autoplay = false;
            var autoplaytime = 0;
            var nav = false;
            var dots = false;
            var columns = $(this).data('columns') ? $(this).data('columns') : 3;

            if ($(this).data('autoslide')) {
                autoplay = true;
                autoplaytime = $(this).data('autoslide');
            }
            if ($(this).data('slider-dots')) {
                dots = true;
            }
            if ($(this).data('slider-nav')) {
                nav = true;
            }

            $(this).owlCarousel({

                autoplay: autoplay,
                autoplayTimeout: autoplaytime,
                autoplayHoverPause: true,
                autoheight: false,
                themeClass : "owl-theme-slider",
                dots: dots,
                nav: nav,
                navText: ['', ''],
                items: columns,
                loop: false,
                responsive: {
                    0: {
                        items: 1
                    },
                    600: {
                        items: 2
                    },
                    960: {
                        items: columns
                    }
                }

            });

        });
    }


    function magnificPopup() {
        "use strict";

        if ($(".mfp-lightbox").magnificPopup) {
            $(".mfp-lightbox").magnificPopup({
                type: "image",
                mainClass: 'mfp-zoom-in',
                gallery: {enabled: !0},
                tLoading: '',
                closeBtnInside: false,
                closeMarkup: '<button title="%title%" type="button" class="mfp-close"></button>',
                removalDelay: 400
            })
        }

        if ($(".rdy_gallery").magnificPopup) {
            $(".rdy_gallery").each(function () {
                $(this).magnificPopup({
                    delegate: 'figure a.link.lightbox',
                    type: "image",
                    mainClass: 'mfp-zoom-in',
                    gallery: {enabled:!0},
                    tLoading: '',
                    closeBtnInside: false,
                    closeMarkup: '<button title="%title%" type="button" class="mfp-close"></button>',
                    removalDelay: 400
                })
            });
        }

        if ($(".rdy-video-lightbox").magnificPopup) {
            $(".rdy-video-lightbox").magnificPopup({
                type: "iframe",
                mainClass: 'mfp-zoom-in',
                fixedContentPos: false,
                closeBtnInside: false,
                closeMarkup: '<button title="%title%" type="button" class="mfp-close"></button>',
                removalDelay: 400
            });

            $('.rdy-video-lightbox').on('click', function(e){
                return false;
            });
        }
    }


    function resizeImage(container) {
        var canvas = container.find('.fx-motion'),
            img = container.find('.fx-motion img'),
            imgRatio = container.data('imgRatio'),
            containerRatio = container.innerWidth() / container.innerHeight();

        imgRatio > containerRatio ? (
            $(img).css("height", "100%").css("width", "auto"),
            canvas.css("height", "100%").css("width", "auto")
        ) : containerRatio > imgRatio && (
            $(img).css("width", "100%").css("height", "auto"),
            canvas.css("width", "100%").css("height", "auto")
        )
    }


    function debounce(func, wait, immediate) {
        var timeout;

        return function () {
            var context = this, args = arguments, later = function () {
                timeout = null,
                immediate || func.apply(context, args)
            }, callNow = immediate && !timeout;
            clearTimeout(timeout),
            timeout = setTimeout(later, wait),
            callNow && func.apply(context, args)
        }
    }


    function initWoocommerce() {

        if($('body.woocommerce').hasClass('single-product')){
            if ($.isFunction(window.vc_tabsBehaviour)){
                vc_tabsBehaviour();
            }
        }

        if(!rdyGlobals.isMobile) {

            var $easyzoom = $('.product-zoom .easyzoom').easyZoom({ loadingNotice: '' });

            if($('.product-zoom .easyzoom').length > 0) {
                var easyzoom_api = $easyzoom.data('easyZoom');

                $("table.variations").on('change', 'select', function() {
                    easyzoom_api.teardown();
                    easyzoom_api._init();
                });
            }

        }

        if (jQuery.fn.isotope != undefined) {
            var $container = $('.woocommerce .products.products-grid:not(.owl-carousel)');
            $container.each(function () {
                var is_shortcode = $(this).parent('.woocommerce-shortcode').length ? 1 : 0;
                var this_container = $(this);

                this_container.imagesLoaded( function () {
                    if(this_container.hasClass('woo-masonry') && !is_shortcode){
                        this_container.isotope({
                            itemSelector: '.product-item, .shop-item',
                            masonry: {
                            }
                        });

                    }else{
                        this_container.isotope({
                            itemSelector: '.product-item, .shop-item',
                            layoutMode: 'fitRows'
                        });

                    }

                    if(this_container.hasClass('wc_catalog_animation')){
                        this_container.one( 'layoutComplete',
                            function( event, laidOutItems ) {
                                if(window.skrollr) skrollr.get().refresh();
                            }
                        );
                    }
                    this_container.isotope('layout');

                    setTimeout(function(){
                        $(window).trigger('resize');
                    }, 150);
                });

            });

            $(window).on('debouncedresize', function() {
                if(window.skrollr) skrollr.get().refresh();
            });
        }

    }


    function initWoocommerceSpinner() {
        "use strict";

        if($('body').hasClass('woocommerce-page')){
            if(typeof jQuery('.qty').spinner === 'function') {
                jQuery('.qty').spinner({
                    min: 1
                });

                jQuery('.ui-spinner-button.ui-spinner-up').html('+');
                jQuery('.ui-spinner-button.ui-spinner-down').html('-');
                jQuery(".ui-spinner-button.ui-spinner-up, .ui-spinner-button.ui-spinner-down").on("click",function(){
                    jQuery(this).closest(".quantity").find(".input-text").trigger("change");
                });

            }
        }

    }


/*

    function initMasonryPortfolio_Filter() {
        $('.filter_holder .filter').click(function () {
            var $this = $(this);
            var $container = $this.parents('.filter_portfolio').next( '.rdy-portfolio-container' );

            if ($this.hasClass('.current')) {
                return false;
            }

            var $optionSet = $this.parents('.filter_holder');
            $optionSet.find('.current').removeClass('current');
            $this.addClass('current');

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

            $container.isotope({
                filter: ''
            });

            $container.isotope({
                filter: selector
            });

            setTimeout(function () {
                $container.isotope('layout');
            }, 400);

            return false;
        });
    }

    */
/*
    function initInfiniteScroll() {
        var $container = $('.infinite-scroll .iso-container');
        var is_masonry = $('.infinite-scroll .rdy-masonry, .infinite-scroll .rdy-grid').length ? true : false;

        $container.infinitescroll({
                navSelector: '.paginator .page-nav',
                nextSelector: '.paginator .page-nav a:first',
                itemSelector: '.grid-item',
                animate: false,
                maxPage: $('.paginator').data('max-pages'),
                loading: {
                    finishedMsg: "",
                    msg: $('<div class="loader"><div class="circle"></div></div>'),
                    msgText: "",
                    selector: ".infinite-loading",
                    speed: 0
                },
                errorCallback: function () {
                    $(".infinite-loading, .rdy-load-more").hide(0);
                }
            },
            function (newElements) {
                var $newElems = jQuery(newElements);
                $container.append($container.find('.grid-sizer'));

                if (is_masonry) {
                    $newElems.imagesLoaded(function () {
                        $container.isotope('appended', $newElems);

                    });

                    $(window).trigger('resize');
                }

                var $items_animation = $container.data('items-animation');
                if ($items_animation) {
                    $.each($newElems, function (index, val) {
                        if ($(val).hasClass('do-animation')) {
                            $(val).css('opacity', '0');
                            $(val).waypoint(function (direction) {
                                var $animation = "transition.fadeIn";

                                if($items_animation == 'fadeIn'){
                                    $animation = "transition.fadeIn";
                                }else if($items_animation == 'slideUpBigIn'){
                                    $animation = "transition.slideUpBigIn";
                                }else if($items_animation == 'expandIn'){
                                    $animation = "transition.expandIn";
                                }

                                $(this).velocity($animation, {
                                    duration: 600,
                                    delay: 500,
                                    drag: true,
                                    display: 'auto',
                                    easing: [ .17,.67,.83,.67 ]

                                });

                            }, {offset: '85%', triggerOnce: true});
                        }
                    });
                }

                //responsiveVideoIframesInit();
            }
        );

        if ($container.hasClass('load-button-style')) {
            $(window).unbind('.infscr');
            $('.rdy-load-more').click(function (e) {
                e.preventDefault();
                $container.infinitescroll('retrieve');
                return false;
            });
        }

    }
*/

    function initJsHeight(){
        (function($){
            $(".js-height-full").height($(window).height());
        })(jQuery);
    }


    function rdy_guid() {
        function s4() {
            return Math.floor((1 + Math.random()) * 0x10000)
                .toString(16)
                .substring(1);
        }
        return 'u' + s4() + s4() + '-' + s4() + '-' + s4() + '-' +
            s4() + '-' + s4() + s4() + s4();
    }


    function initSVGiconAnimation(){

        var $icon = [];

        $('.vc_icon_element').each(function (i) {
            var $that = $(this);
            var $file = $that.find('.vc_icon_element-icon').data('svg');

            if(typeof $file != 'undefined') {

                if(navigator.userAgent.match(/(Android|iPod|iPhone|iPad|IEMobile|BlackBerry|Opera Mini)/)) $that.attr('svg-animation','false');

                //animation
                $(this).attr('id', 'icon-svg-instance-' + i);
                var $animationSpeed = ($that.is('[data-svg-animation-speed]') && $that.attr('data-svg-animation-speed').length > 0) ? $that.attr('data-svg-animation-speed') : 500;
                var $animationType = $that.is('[data-svg-animation-type]') ? $that.attr('data-svg-animation-type') : 'delayed';

                var $animationTiming = Vivus.LINEAR;
                if ($that.data('svg-animation-timing') == 'EASE') {
                    $animationTiming = Vivus.EASE;
                } else if ($that.data('svg-animation-timing') == 'EASE_OUT') {
                    $animationTiming = Vivus.EASE_OUT;
                } else if ($that.data('svg-animation-timing') == 'EASE_OUT') {
                    $animationTiming = Vivus.EASE_OUT;
                } else if ($that.data('svg-animation-timing') == 'EASE_IN') {
                    $animationTiming = Vivus.EASE_IN;
                } else if ($that.data('svg-animation-timing') == 'EASE_OUT_BOUNCE') {
                    $animationTiming = Vivus.EASE_OUT_BOUNCE;
                }


                if (!$that.data('svg-animation')) {
                    $animationSpeed = 1;
                    $that.css('opacity', '1');
                }

                $icon[i] = new Vivus($that.find( '.vc_icon_element-inner' ).get(0), {
                    type: $animationType,
                    pathTimingFunction: Vivus.EASE_OUT,
                    animTimingFunction: $animationTiming,
                    duration: $animationSpeed,
                    file: $file,
                    onReady: svgInit
                });

                $that.find('span').remove();

                if($animationSpeed !== 1) {

                    var $that = $(this);

                    $(this).waypoint(function(direction) {

                        checkIfReady();
                        $that.addClass('animated-in');

                    }, { offset: '90%', triggerOnce: true });

                } else {
                    checkIfReady();
                }

                function checkIfReady() {
                    var $animationDelay = ($that.data('svg-animation-delay') && $that.data('svg-animation-delay').length > 0 && $that.data('animation') != 'false') ? $that.data('svg-animation-delay') : 0;
                    if ($icon[$that.attr('id').slice(-1)].isReady == true) {
                        $that.css('opacity', '1');
                        setTimeout(function () {
                            $icon[$that.attr('id').slice(-1)].reset().play();
                        }, $animationDelay);
                    } else {
                        setTimeout(checkIfReady, 50);
                    }
                }

                function svgInit(eVivus) {
                    // eVivus.el.setAttribute('class', 'init');
                    $icon[$that.attr('id').slice(-1)].reset().stop();
                }

            }

        });

    }


    var rdy = {};

    function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }

    rdy.PIXI = {};
    rdy.PIXI.Point = function () {
        function Point() {
            var x = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
            var y = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;

            _classCallCheck(this, Point);

            /**
             * @member {number}
             * @default 0
             */
            this.x = x;

            /**
             * @member {number}
             * @default 0
             */
            this.y = y;
        }

        Point.prototype.copy = function copy(p) {
            this.set(p.x, p.y);
        };

        Point.prototype.equals = function equals(p) {
            return p.x === this.x && p.y === this.y;
        };

        Point.prototype.set = function set(x, y) {
            this.x = x || 0;
            this.y = y || (y !== 0 ? this.x : 0);
        };

        return Point;
    }();
    rdy.PIXI.Point.prototype = {
        subtract: function (x, y) {
            this.x -= x;
            this.y -= y;
            return this;
        }
    };
    rdy.PIXI.Point.prototype.constructor = rdy.PIXI.Point;
    rdy.PIXI.Point.subtract = function (a, b, out) {
        if (typeof out === "undefined") { out = new rdy.PIXI.Point(); }

        out.x = a.x - b.x;
        out.y = a.y - b.y;

        return out;
    };

    rdy.cascadeAnimation = function() {
        "use strict";

        $.Velocity.RegisterUI("levelup.slideUpIn", {
            defaultDuration: 900,
            calls: [
                [ { opacity: [ 1, 0 ], translateY: [ 0, 50 ], translateZ: 0 } ]
            ]
        });

        $('.vc_row[data-csd-animation], .wpb_column[data-csd-animation]').each(function(){
            var $obj = $(this);
            var animation = $obj.data('csd-animation') ? $obj.data('csd-animation') : "transition.fadeIn";
            var stagger = $obj.data('csd-animation-delay') ? $obj.data('csd-animation-delay') : 600;
            var duration = $obj.data('csd-animation-duration') ? $obj.data('csd-animation-duration') : 600;

            $(this).waypoint(function(direction) {
                if (direction == 'down' && !$obj.data('vanimated')) {
                    $obj.data('vanimated', 1);

                    if ($obj.hasClass('vc_row')) {
                        $('> .row-container > .row-inner > .wpb_column', $obj).velocity(animation, {
                            display: "flex",
                            delay: 400,
                            stagger: stagger,
                            duration: duration,
                            easing: "ease-in",
                            begin: function(elements) { $(this).css({opacity: 1}) }
                        });
                    } else if ($obj.hasClass('wpb_column')) {
                        $('> .vc_column-inner > .wpb_wrapper > *', $obj).velocity(animation, {
                            delay: 400,
                            stagger: stagger,
                            duration: duration,
                            easing: "ease-in",
                            begin: function(elements) { $(this).css({opacity: 1}) }
                        });
                    }
                }

            }, { offset: '80%' });

        });

    }

    rdy.fxGrainOverlay = function() {
        "use strict";

        $('.vc_row > .row-overlay.filmgrain, .wpb_single_image .img-overlay.filmgrain').each(function(){
            var uid = rdy_guid();
            var $this = $(this);
            $(this).prepend('<canvas id="' + uid + '"></canvas>');

            var canvas = document.getElementById(uid);

            var viewWidth,
                viewHeight,
                ctx;

            var patternSize = 100,
                patternScaleX = 1,
                patternScaleY = 1,
                patternRefreshInterval = 5,
                patternAlpha = 60;

            var patternPixelDataLength = patternSize * patternSize * 4,
                patternCanvas,
                patternCtx,
                patternData,
                frame = 0;

            function initCanvas() {
                viewWidth = canvas.width = canvas.clientWidth;
                viewHeight = canvas.height = canvas.clientHeight;
                ctx = canvas.getContext('2d');
                ctx.scale(patternScaleX, patternScaleY);
            }


            function initGrain() {
                patternCanvas = document.createElement('canvas');
                patternCanvas.width = patternSize;
                patternCanvas.height = patternSize;
                patternCtx = patternCanvas.getContext('2d');
                patternData = patternCtx.createImageData(patternSize, patternSize);
            }

            function update() {
                var value;

                for (var i = 0; i < patternPixelDataLength; i += 4) {
                    value = (Math.random() * 255) | 0;

                    patternData.data[i    ] = value;
                    patternData.data[i + 1] = value;
                    patternData.data[i + 2] = value;
                    patternData.data[i + 3] = patternAlpha;
                }

                patternCtx.putImageData(patternData, 0, 0);
            }


            function draw() {
                if (ctx) {
                    ctx.clearRect(0, 0, viewWidth, viewHeight);
                    ctx.fillStyle = ctx.createPattern(patternCanvas, 'repeat');
                    ctx.fillRect(0, 0, viewWidth, viewHeight);
                }
            }

            function loop() {
                if (++frame % patternRefreshInterval === 0) {
                    update();
                    draw();
                }

                requestAnimationFrame(loop);
            }

            $(this).imagesLoaded( function () {
                initCanvas();
                initGrain();
                requestAnimationFrame(loop);
            });

            function resizeCanvas() {
                viewWidth = canvas.width = $this.width();
                viewHeight = canvas.height = $this.height();
                draw();
            }

            window.addEventListener('resize', resizeCanvas, false);
            $(this).resize(resizeCanvas);
        })
    }

    rdy.fxGlitchOverlay = function() {
        "use strict";

        $('.wpb_single_image .img-overlay.glitch').each(function(){

            var glitch = new GlitchFx();
             glitch.setImagePath($(this).data('img-src'), false);
            $(this).append(glitch.domElement);

        })


        $('#fancy-header .background-container.glitch').each(function(){

            if ($(this).hasClass('background-container') && !$(this).hasClass('fancy_parallax')) {
                var glitch = new GlitchFx();
                glitch.setImagePath($(this).data('original'), false);

                $(this).append(glitch.domElement);
            }

        })
    }

    rdy.fxGlitchOverlayHeader = function() {
        "use strict";

        $('#fancy-header .background-container.glitch').each(function(){

            var glitch = new GlitchFx();
            glitch.setImagePath($(this).data('original'), false);

            if ($(this).hasClass('background-container') && $(this).hasClass('fancy_parallax')) {
                $('.fancy_parallax-inner', $(this)).append(glitch.domElement);
            } else {
                $(this).append(glitch.domElement);
            }

        })
    }

    rdy.isotopeLayout = function() {
        "use strict";

        if ($('.iso-container').length > 0) {

            var itemQueue = [];
            var delayQueue = 300;
            var timerQueue;

            var isotopeContainersArray = [],
                filterItems = [];

            $('[class*="iso-container"]').each(function() {
                var isoData = $(this).data();
               isotopeContainersArray.push($(this));
            });


            var init_isotope = function() {

                for (var i = 0, len = isotopeContainersArray.length; i < len; i++) {
                    var $container = $(isotopeContainersArray[i]);

                    if($container.hasClass('type-height')) {
                        itemsAnimation($('.grid-item', $container), 0, false, $container);
                        continue
                    }

                    var this_container = $container;
                    init_isotope_container(this_container);
                }
            },
            init_isotope_container = function(this_container){
                imagesLoaded( this_container, function () {
                    var transitionDuration = this_container.data('items-animation') ? 0 : '0.4s';

                    if(this_container.hasClass('grid-blog') || this_container.hasClass('rdy-grid')){
                        this_container.isotope({
                            transitionDuration: transitionDuration,
                            itemSelector: '.grid-item',
                            layoutMode: 'fitRows',
                            fitRows: {
                                columnWidth: '.grid-sizer'
                            }
                        }).on('layoutComplete', onLayout(this_container, 0));
                    }else if(this_container.hasClass('rdy-masonry')){
                        this_container.isotope({
                            transitionDuration: transitionDuration,
                            itemSelector: '.grid-item',
                            masonry: {
                            }
                        }).on('layoutComplete', onLayout(this_container, 0));
                    }

                    /*if($('.rdy-portfolio-container').length && !rdyGlobals.isMobile){

                     this_container.one('layoutComplete',
                     function (event, laidOutItems) {
                     if(typeof pJSDom == 'object' && pJSDom.length){
                     jQuery.each(pJSDom, function(index, value) {
                     this.pJS.fn.particlesRefresh();
                     });
                     }
                     }
                     );

                     }*/

                    if(this_container.find('video').length){
                        this_container.find('video').on('loadedmetadata', function(){
                            this_container.isotope('layout');
                        })
                    }
                    this_container.isotope('layout');

                    setTimeout(function(){
                        $(window).trigger('resize');
                    }, 150);
                });

                //});

                $(window).on('debouncedresize', function() {
                    if(window.skrollr) skrollr.get().refresh();
                });
            },
            init_isotope_adv = function(){
                if( $('.rdy-portfolio-container.rdy-masonry-adv').length > 0 ){
                    var isInitIsotope = false;
                    var $container = $('.rdy-portfolio-container.rdy-masonry-adv');
                    $container.each(function () {
                        var this_container = $(this);

                        this_container.imagesLoaded( function () {

                            this_container.isotope({
                                transitionDuration: 0,
                                itemSelector: '.grid-item',
                                gutter: 0,
                                masonry: {
                                    columnWidth: '.grid-sizer'
                                }
                            }).on('layoutComplete', onLayout(this_container, 0));

                            isInitIsotope = true;
                            if(this_container.find('video').length){
                                this_container.find('video').on('loadedmetadata', function(){
                                    this_container.isotope('layout');
                                })
                            }
                            this_container.isotope('layout');

                        });


                        $(window).on( 'resize', function () {
                            var winWidth = window.innerWidth;
                            var columnNumb = 1;
                            var portfolioGutter = this_container.data('gutter') ? this_container.data('gutter') : 0;
                            var no_gutter = this_container.hasClass('no-gutter') ? 1 : 0;

                            var attr_col = this_container.attr('data-col');

                            var portfolioWidth = this_container.parent('.rdy_portfolio_wrap')[0].getBoundingClientRect().width;

                            if (portfolioGutter) {
                                this_container.parent('.rdy_portfolio_wrap').css({
                                    'margin-left': -(portfolioGutter + 15),
                                    'margin-right': -(portfolioGutter + 15),
                                })
                            }

                            if (winWidth >= 1466) {
                                if (typeof attr_col !== typeof undefined && attr_col !== false) {
                                    columnNumb = attr_col;
                                } else columnNumb = 3;

                                var postWidth = Math.floor(portfolioWidth / columnNumb);
                                this_container.find('.grid-item').each(function () {
                                    $(this).css( {
                                        width : postWidth - portfolioGutter * 2 + 'px',
                                        height : postWidth * 0.75 - portfolioGutter * 2 + 'px',
                                        margin : portfolioGutter + 'px'
                                    });
                                    if(no_gutter) $(this).css( {
                                        width : postWidth  + 'px',
                                        height : postWidth * 0.75  + 'px',
                                        margin : 0 + 'px'
                                    });
                                    if($(this).is('.wide')) $(this).css( {
                                        width : postWidth * 2 - portfolioGutter * 2 + 'px'
                                    });
                                    if(no_gutter && $(this).is('.wide')) $(this).css( {
                                        width : postWidth * 2 + 'px'
                                    });
                                    if($(this).is('.tall')) $(this).css( {
                                        height : postWidth * 1.5 - portfolioGutter * 2 + 'px'
                                    });
                                    if(no_gutter && $(this).is('.tall')) $(this).css( {
                                        height : postWidth * 1.5  + 'px'
                                    });
                                    if($(this).is('.wide-tall')) $(this).css( {
                                        width : postWidth * 2 - portfolioGutter * 2 + 'px',
                                        height : postWidth * 1.5 - portfolioGutter * 2 + 'px'
                                    });
                                    if(no_gutter && $(this).is('.wide-tall')) $(this).css( {
                                        width : postWidth * 2 + 'px',
                                        height : postWidth * 1.5  + 'px'
                                    });
                                });

                            } else if (winWidth > 1024) {
                                if (typeof attr_col !== typeof undefined && attr_col !== false) {
                                    columnNumb = attr_col;
                                } else columnNumb = 3;

                                postWidth = Math.floor(portfolioWidth / columnNumb)

                                this_container.find('.grid-item').each(function () {
                                    $(this).css( {
                                        width : postWidth - portfolioGutter * 2 + 'px',
                                        height : postWidth * 0.75 - portfolioGutter * 2 + 'px',
                                        margin : portfolioGutter + 'px'
                                    });
                                    if(no_gutter) $(this).css( {
                                        width : postWidth  + 'px',
                                        height : postWidth * 0.75  + 'px',
                                        margin : 0 + 'px'
                                    });
                                    if($(this).is('.wide')) $(this).css( {
                                        width : postWidth * 2 - portfolioGutter * 2 + 'px'
                                    });
                                    if(no_gutter && $(this).is('.wide')) $(this).css( {
                                        width : postWidth * 2 + 'px'
                                    });
                                    if($(this).is('.tall')) $(this).css( {
                                        height : postWidth * 1.5 - portfolioGutter * 2 + 'px'
                                    });
                                    if(no_gutter && $(this).is('.tall')) $(this).css( {
                                        height : postWidth * 1.5  + 'px'
                                    });
                                    if($(this).is('.wide-tall')) $(this).css( {
                                        width : postWidth * 2 - portfolioGutter * 2 + 'px',
                                        height : postWidth * 1.5 - portfolioGutter * 2 + 'px'
                                    });
                                    if(no_gutter && $(this).is('.wide-tall')) $(this).css( {
                                        width : postWidth * 2 + 'px',
                                        height : postWidth * 1.5  + 'px'
                                    });
                                });

                            } else if (winWidth > 767) {
                                var columnNumb = 3;
                                postWidth = Math.floor(portfolioWidth / columnNumb)
                                this_container.find('.grid-item').each(function () {
                                    $(this).css( {
                                        width : postWidth - portfolioGutter * 2 + 'px',
                                        height : postWidth * 0.75 - portfolioGutter * 2 + 'px',
                                        margin : portfolioGutter + 'px'
                                    });
                                    if(no_gutter) $(this).css( {
                                        width : postWidth  + 'px',
                                        height : postWidth * 0.75  + 'px',
                                        margin : 0 + 'px'
                                    });
                                    if($(this).is('.wide')) $(this).css( {
                                        width : postWidth * 2 - portfolioGutter * 2 + 'px'
                                    });
                                    if(no_gutter && $(this).is('.wide')) $(this).css( {
                                        width : postWidth * 2 + 'px'
                                    });
                                    if($(this).is('.tall')) $(this).css( {
                                        height : postWidth * 1.5 - portfolioGutter * 2 + 'px'
                                    });
                                    if(no_gutter && $(this).is('.tall')) $(this).css( {
                                        height : postWidth * 1.5  + 'px'
                                    });
                                    if($(this).is('.wide-tall')) $(this).css( {
                                        width : postWidth * 2 - portfolioGutter * 2 + 'px',
                                        height : postWidth * 1.5 - portfolioGutter * 2 + 'px'
                                    });
                                    if(no_gutter && $(this).is('.wide-tall')) $(this).css( {
                                        width : postWidth * 2 + 'px',
                                        height : postWidth * 1.5  + 'px'
                                    });
                                });

                            }	else if (winWidth > 479) {
                                var columnNumb = 1;
                                postWidth = Math.floor(portfolioWidth / columnNumb)
                                this_container.find('.grid-item').each(function () {
                                    $(this).css( {
                                        width : postWidth - portfolioGutter * 2 + 'px',
                                        height : postWidth * 0.75 - portfolioGutter * 2 + 'px',
                                        margin : portfolioGutter + 'px'
                                    });
                                    if(no_gutter) $(this).css( {
                                        width : postWidth  + 'px',
                                        height : postWidth * 0.75  + 'px',
                                        margin : 0 + 'px'
                                    });
                                    if($(this).is('.wide')) $(this).css( {
                                        width : postWidth - portfolioGutter * 2 + 'px'
                                    });
                                    if(no_gutter && $(this).is('.wide')) $(this).css( {
                                        width : postWidth + 'px'
                                    });
                                    if($(this).is('.tall')) $(this).css( {
                                        height : postWidth * 1.5 - portfolioGutter * 2 + 'px'
                                    });
                                    if(no_gutter && $(this).is('.tall')) $(this).css( {
                                        height : postWidth * 1.5  + 'px'
                                    });
                                    if($(this).is('.wide-tall')) $(this).css( {
                                        width : postWidth - portfolioGutter * 2 + 'px',
                                        height : postWidth * 0.75 - portfolioGutter * 2 + 'px'
                                    });
                                    if(no_gutter && $(this).is('.wide-tall')) $(this).css( {
                                        width : postWidth  + 'px',
                                        height : postWidth * 0.75  + 'px'
                                    });
                                });

                            }

                            else if (winWidth <= 479) {
                                var columnNumb = 1;
                                postWidth = Math.floor(portfolioWidth / columnNumb)
                                this_container.find('.grid-item').each(function () {
                                    $(this).css( {
                                        width : postWidth - portfolioGutter * 2 + 'px',
                                        height : postWidth * 0.75 - portfolioGutter * 2 + 'px',
                                        margin : portfolioGutter + 'px'
                                    });
                                    if(no_gutter) $(this).css( {
                                        width : postWidth  + 'px',
                                        height : postWidth * 0.75  + 'px',
                                        margin : 0 + 'px'
                                    });
                                    if($(this).is('.wide')) $(this).css( {
                                        width : postWidth - portfolioGutter * 2 + 'px'
                                    });
                                    if(no_gutter && $(this).is('.wide')) $(this).css( {
                                        width : postWidth + 'px'
                                    });
                                    if($(this).is('.tall')) $(this).css( {
                                        height : postWidth * 1.5 - portfolioGutter * 2 + 'px'
                                    });
                                    if(no_gutter && $(this).is('.tall')) $(this).css( {
                                        height : postWidth * 1.5  + 'px'
                                    });
                                    if($(this).is('.wide-tall')) $(this).css( {
                                        width : postWidth - portfolioGutter * 2 + 'px',
                                        height : postWidth * 0.75 - portfolioGutter * 2 + 'px'
                                    });
                                    if(no_gutter && $(this).is('.wide-tall')) $(this).css( {
                                        width : postWidth + 'px',
                                        height : postWidth * 0.75  + 'px'
                                    });
                                });

                            }

                            if(isInitIsotope){
                                if(this_container.find('video').length){
                                    this_container.find('video').on('loadedmetadata', function(){
                                        this_container.isotope('layout');
                                    })
                                }
                                this_container.isotope('layout');
                            }

                            return columnNumb;

                        }).resize();
                    });
                }
            },
            itemEffectAnimate = function ($item, $fx, $queue) {
                var $animation = "transition.fadeIn";

                if ($fx == 'fadeIn') {
                    $animation = "transition.fadeIn";
                } else if ($fx == 'slideUpBigIn') {
                    $animation = "transition.slideUpBigIn";
                } else if ($fx == 'expandIn') {
                    $animation = "transition.expandIn";
                }

                var speed;

                if ($queue) {
                    var duration = 750;
                    var delay = 0;
                } else {
                    var duration = 600;
                    var delay = 500;

                    if (speed == 'fast') {
                        duration = 900;
                        delay = 300;
                    }
                }

                $('> .hentry', $item).removeClass('fade-out').addClass('start_animation');
                $('> .hentry', $item).velocity('stop').velocity($animation, {
                    duration: duration,
                    delay: delay,
                    drag: true,
                    display: 'auto',
                    easing: [.17, .67, .83, .67]
                });
            },
            itemEffectQueue = function($fx){
                if (timerQueue) return
                timerQueue = window.setInterval(function () {
                    if (!itemQueue.length){
                        window.clearInterval(timerQueue)
                        timerQueue = null
                    }

                    if (itemQueue.length) {
                        var $item = $(itemQueue.shift());
                        itemEffectAnimate($item, $fx, true)
                        itemEffectQueue($fx)
                    }
                }, delayQueue)
            },

            setWaypoint = function($item, $type_animation, $queue, offset){
                $item.waypoint(function (direction) {
                    if ($queue) {
                        itemQueue.push(this)
                        itemEffectQueue($type_animation)
                    } else {
                        itemEffectAnimate($(this), $type_animation, false)
                    }
                }, {offset: offset, triggerOnce: true});
            },

            onLayout = function (container, startIndex, speed) {

                var $type_animation = container.data('items-animation');
                var $type_animation_queue = container.data('items-animation-queue');

                if ($type_animation) {
                    if($type_animation_queue){
                        var offset = '95%';
                    }else{
                        var offset = '85%';
                    }

                    $.each(container.find('.grid-item'), function (index, val) {
                        if ($(val).hasClass('do-animation')) {
                            setWaypoint($(val), $type_animation, $type_animation_queue, offset)

                        }
                    });
                }
            },

            itemsAnimation = function(items, startIndex, arrange, container) {
                var $allItems = items.length - startIndex,
                    showed = 0,
                    index = 0;

                var $type_animation = container.data('items-animation');
                var $type_animation_queue = container.data('items-animation-queue');

                if ($type_animation) {
                    if ($type_animation_queue) {
                        var offset = '95%';
                    } else {
                        var offset = '85%';
                    }

                    $.each(items, function (index, val) {
                        var $el;

                        if (arrange) {
                            $el = $(val.element)
                        } else {
                            $el = $(val)
                        }

                        setWaypoint($el, $type_animation, $type_animation_queue, offset)
                    });
                }
            },
            init_infinite = function(){
                var $containers = $('.infinite-scroll .iso-container');
                var is_masonry = $('.infinite-scroll .rdy-masonry, .infinite-scroll .rdy-grid').length ? true : false;
                var $container;

                if($containers.length > 0) {
                    $container = $($containers[0])

                    $container.infinitescroll({
                            navSelector: '.paginator .page-nav',
                            nextSelector: '.paginator .page-nav a:first',
                            itemSelector: '.grid-item',
                            animate: false,
                            maxPage: $('.paginator').data('max-pages'),
                            loading: {
                                finishedMsg: "",
                                msg: $('<div class="loader"><div class="circle"></div></div>'),
                                msgText: "",
                                selector: ".infinite-loading",
                                speed: 0
                            },
                            errorCallback: function () {
                                $(".infinite-loading, .rdy-load-more").hide(0);
                            }
                        },
                        function (newElements) {
                            var $newElems = jQuery(newElements);
                            $container.append($container.find('.grid-sizer'));

                            if (is_masonry) {
                                $newElems.imagesLoaded(function () {
                                    $container.isotope('appended', $newElems);
                                });

                                $(window).trigger('resize');
                            }

                            itemsAnimation(newElements, 0, false, $container);

                        }
                    );

                    if ($container.hasClass('load-button-style')) {
                        $(window).unbind('.infscr');
                        $('.rdy-load-more').click(function (e) {
                            e.preventDefault();
                            $container.infinitescroll('retrieve');
                            return false;
                        });
                    }
                }

            };

            $('.filter_portfolio').on('click', '.filter', function (event) {
                var $this = $(this),
                    filterItems = [];
                var $container = $this.parents('.filter_portfolio').next('.rdy-portfolio-container');
                var transitionDuration = $container.data().isotope.options.transitionDuration

                if (!$this.hasClass('.current')) {

                    window.clearInterval(timerQueue);
                    timerQueue = null
                    itemQueue = [];

                    $('> .grid-item', $container).waypoint('destroy')
                    $.each($('> .grid-item > .hentry', $container), function(index, val) {

                        if (transitionDuration == 0) {
                            $(val).velocity('stop').velocity('transition.expandOut', {
                                duration: 300,
                                drag: true,
                                display: 'auto',
                                easing: [.17, .67, .83, .67]
                            });
                        }
                    });


                    var $optionSet = $this.parents('.filter_holder');
                    $optionSet.find('.current').removeClass('current');
                    $this.addClass('current');

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

                    setTimeout(function() {
                        $container.isotope({
                            filter: function() {
                                var block = $(this),
                                    filterable = (selector == '*') || block.hasClass(selector);
                                if (filterable) {
                                    filterItems.push(block);
                                }
                                return filterable;
                            }
                        });
                    }, 300);

                    if (transitionDuration == 0) {
                        $container.one('arrangeComplete', function( event, filteredItems ) {
                            setTimeout(function() {
                                itemsAnimation(filteredItems, 0, true, $container);
                            }, 100);
                        });
                    }

                    /*setTimeout(function () {
                        $container.isotope('layout');
                    }, 400);*/

                }

                event.preventDefault();
            });

            $('.rdy_gallery.hover-elem-cross .grid-item').hover(
                function() {
                    var $animation = { duration: 750, easing: [.19, 1, .22, 1], queue: false, }

                    $(this).find('.hover-element rect:eq(0)').velocity('stop').velocity(
                        {translateY: ['20px', 0]}, $animation
                    );
                    $(this).find('.hover-element rect:eq(1)').velocity('stop').velocity(
                        {translateX: ['-20px', 0]}, $animation
                    );
                    $(this).find('.hover-element rect:eq(2)').velocity('stop').velocity(
                        {translateY: ['-20px', 0]}, $animation
                    );
                    $(this).find('.hover-element rect:eq(3)').velocity('stop').velocity(
                        {translateX: ['20px', 0]}, $animation
                    );


                }, function() {
                    var $animation = { duration: 450, easing: [.19, 1, .22, 1], queue: false, }

                    $(this).find('.hover-element rect:eq(0)').velocity('stop').velocity(
                        {translateY: '0px'}, $animation
                    );
                    $(this).find('.hover-element rect:eq(1)').velocity('stop').velocity(
                        {translateX: '0px'}, $animation
                    );
                    $(this).find('.hover-element rect:eq(2)').velocity('stop').velocity(
                        {translateY: '0px'}, $animation
                    );
                    $(this).find('.hover-element rect:eq(3)').velocity('stop').velocity(
                        {translateX: '0px'}, $animation
                    );

                }
            );

            init_isotope();
            init_isotope_adv();
            init_infinite();
        }
    }

    rdy.can = {

        init: function(heightOverride){
            this.webGLTrue = !1;
            window.WebGLRenderingContext && (this.webGLTrue = !0);

            var canvasAsset = jQuery('.vc_row.rdy-canvas-effect');

            canvasAsset.each(function () {
                var $mobile_hide = false;
                if( $(this).data('fx-hide') == 'md' && window.innerWidth <= 992 ) {
                    $mobile_hide = true;
                } else if( $(this).data('fx-hide') == 'xs' && window.innerWidth < 768 ) {
                    $mobile_hide = true;
                }


                var uid = rdy_guid();
                if ($(this).data('type') === "motion") {
                    var ob = $(this).find('.fx-motion').prepend('<canvas id="' + uid + '"></canvas>');
                } else if ($(this).data('type') === 'shapes') {
                    var ob = $('<div class="row-canvas"><canvas id="' + uid + '"></canvas></div>');
                } else {
                    var ob = $('<div class="row-canvas" id="' + uid + '"></div>');
                }

                $(this).append(ob);

                if( !$mobile_hide ) {

                    if (!Detector.webgl && ($(this).data('type') === "particles" || $(this).data('type') === "motion")) {

                        if ($(this).data('fx-image')) {
                            ob.css('background-image', 'url(' + $(this).data('fx-image') + ')');
                        }

                    }else{

                        if ($(this).data('type') === "waves") {
                            rdy.can.initCircles(uid, ob, $(this), heightOverride);

                        } else if ($(this).data('type') === "spiderweb") {
                            rdy.can.initGeometry(uid, ob, $(this), heightOverride);

                        } else if ($(this).data('type') === "particles") {
                            rdy.can.initParticles(uid, ob, $(this), heightOverride);

                        } else if ($(this).data('type') === "sine_waves") {
                            rdy.can.initSineWaves(uid, ob, $(this), heightOverride);

                        } else if ($(this).data('type') === "motion") {
                            rdy.can.initMotion(uid, ob, $(this), heightOverride);

                            var debounceAdjust = debounce(function () {
                                if($(".vc_row.rdy-canvas-effect[data-type=\"motion\"]").length && this.webGLTrue) {
                                    $('.vc_row.rdy-canvas-effect[data-type=\"motion\"]').each( function () {
                                        resizeImage($(this));
                                    });
                                }
                            }, 50);
                            window.addEventListener("resize", debounceAdjust);

                        } else if ($(this).data('type') === 'shapes') {
                            rdy.can.initFlyingShapes(uid, ob, $(this), heightOverride);

                        }

                    }

                }
            });
        },

        initSineWaves: function(uid, ob, canvas, heightOverride) {
            var fx_preset = canvas.data('fx-preset') ? canvas.data('fx-preset') : "";
            var fx_color1 = canvas.data('fx-color1') ? canvas.data('fx-color1') : "";
            var fx_color2 = canvas.data('fx-color2') ? canvas.data('fx-color2') : "";
            var fx_color3 = canvas.data('fx-color3') ? canvas.data('fx-color3') : "";

            ob.append('<canvas></canvas>');

            container = document.getElementById( uid );

            var waves = [
                {
                    timeModifier: 3,
                    lineWidth: 1,
                    amplitude: -25,
                    wavelength: 125,

                },
                {
                    timeModifier: 2,
                    lineWidth: .72,
                    amplitude: -15,
                    wavelength: 75
                },
                {
                    timeModifier: 1,
                    lineWidth: .51,
                    amplitude: -20,
                    wavelength: 70
                },
                {
                    timeModifier: 0.5,
                    lineWidth: .51,
                    amplitude: -170,
                    wavelength: 200
                },
                {
                    timeModifier: 0.25,
                    lineWidth: .52,
                    amplitude: -100,
                    wavelength: 200
                }
            ];

            if (fx_preset == 'preset2') {
                waves = [
                    {
                        timeModifier: 3,
                        lineWidth: 3,
                        amplitude: -25,
                        wavelength: 125,

                    },
                    {
                        timeModifier: 2,
                        lineWidth: 1.72,
                        amplitude: -15,
                        wavelength: 75
                    },
                    {
                        timeModifier: 1,
                        lineWidth: 2.51,
                        amplitude: -20,
                        wavelength: 70
                    },
                    {
                        timeModifier: 0.5,
                        lineWidth: 1.51,
                        amplitude: -170,
                        wavelength: 200
                    },
                    {
                        timeModifier: 0.25,
                        lineWidth: 3.52,
                        amplitude: -100,
                        wavelength: 200
                    }
                ];
            }
            else if (fx_preset == 'preset3') {
                waves = [
                    {
                        timeModifier: 1.6,
                        lineWidth: 10,
                        amplitude: -60,
                        wavelength: 200,
                        segmentLength: 10,

                    }
                ];
            }

            var waves = new SineWaves({
                el: $('canvas', container).get(0),
                speed: 3,
                width: function() {
                    return $(container).width();
                },
                height: function() {
                    return $(container).height();
                },
                ease: 'SineInOut',
                wavesWidth: '106%',
                /*waves: ,*/
                waves: waves,

                // Called on window resize
                resizeEvent: function() {
                    var gradient = '';

                    if (fx_color1 && (fx_color2 || fx_color3)) {
                        gradient = this.ctx.createLinearGradient(0, 0, this.width, 0);

                        if (fx_color1) {
                            gradient.addColorStop(0, fx_color1);
                        }

                        if (fx_color2 && fx_color3) {
                            gradient.addColorStop(0.5, fx_color2);
                            gradient.addColorStop(1, fx_color3);
                        } else if (fx_color2) {
                            gradient.addColorStop(1, fx_color2);
                        } else if (fx_color3) {
                            gradient.addColorStop(1, fx_color3);
                        }
                    } else {
                        gradient = fx_color1 ? fx_color1 : fx_color2 ? fx_color2 : fx_color3 ? fx_color3 : '';
                    }

                    var index = -1;
                    var length = this.waves.length;
                    while(++index < length){
                        this.waves[index].strokeStyle = gradient;
                    }

                    // Clean Up
                    index = void 0;
                    length = void 0;
                    gradient = void 0;
                }
            });

        },

        initParticles: function(uid, ob, canvas, heightOverride) {

            var fx_auto = canvas.data('fx-auto') ? true : false;
            var fx_color = canvas.data('fx-color') ? canvas.data('fx-color') : "#ffffff";
            var fx_fog_color = canvas.data('fx-fog-color') ? canvas.data('fx-fog-color') : "#ffffff";
            var fx_mm_disable = false;

            container = document.getElementById( uid );

            var container, stats;
            var camera, scene, renderer, group, particle;
            var mouseX = 0, mouseY = 0;

            var windowHalfX = window.innerWidth / 2;
            var windowHalfY = window.innerHeight / 2;

            var WIDTH = $(container).width(),
                HEIGHT = $(container).height();
            var ANGLE = 45,
                ASPECT = WIDTH / HEIGHT,
                NEAR = 1,
                FAR = 3000,
                FIELD_OF_VIEW = 60,
                PARTICLES = fx_auto ? 1600 : 5000,
                PARTICLES_TOUCH = 3000,
                CAMERA_Z = 1300,
                // CAMERA_Z = 1000,
                FOG_DENSITY = 0.0008,
                HALF_HEIGHT = HEIGHT / 2,
                HALF_WIDTH = WIDTH / 2,
                BASE_PARTICLE_SIZE = 12,
                MOBILE_PARTICLE_SIZE = 14,
                PARTICLE_COUNT = rdyGlobals.isMobile ? PARTICLES_TOUCH : PARTICLES,
                PARTICLE_SIZE = rdyGlobals.isMobile ? MOBILE_PARTICLE_SIZE : BASE_PARTICLE_SIZE;


            init();
            animate();

            /*var particlesVS;
            var particlesPS;

            SHADER_LOADER.load({
                vertexShaders: [{name: 'particles', src: levelup_js_vars.themePath + "/assets/images/shaders/particles.vs"}],
                fragmentShaders: [{name: 'particles', src: levelup_js_vars.themePath + "/assets/images/shaders/particles.ps"}],
            },
                function (data)
                {
                    particlesVS = data.particles.vertex;
                    particlesPS = data.particles.fragment;

                    init();
                    animate();
                }
            );*/

            function init() {

                materials = [];
                positions = [];

                oddTick = false;
                camera = new THREE.PerspectiveCamera( ANGLE, ASPECT, NEAR, FAR );
                camera.position.z = CAMERA_Z;

                scene = new THREE.Scene();
                scene.fog = new THREE.FogExp2( fx_fog_color, FOG_DENSITY );

                geometry = new THREE.Geometry();
                var sprite = new THREE.TextureLoader().load( levelup_js_vars.themePath + "/assets/images/particle.png" );

                for ( var i = 0; i < PARTICLE_COUNT; i ++ ) {
                    var vertex = new THREE.Vector3();
                    vertex.x = Math.random() * 2200 - 1100;
                    vertex.y = Math.random() * 2200 - 1100;
                    vertex.z = Math.random() * 2200 - 1100;
                    // vertex.x = Math.random() * 2000 - 1000;
                    // vertex.y = Math.random() * 2000 - 1000;
                    // vertex.z = Math.random() * 2000 - 1000;

                    geometry.vertices.push( vertex );
                }

                parameters = [
                    [ 1 ]
                ];

                if (fx_auto) {
                    parameters = [
                        [5],
                        [4],
                        [3],
                        [2],
                        [1]
                    ];
                }

                for ( i = 0; i < parameters.length; i ++ ) {
                    color = fx_color;
                    materials[i] = new THREE.PointsMaterial( {
                        color: fx_color,
                        size: PARTICLE_SIZE,
                        map: sprite,
                        // alphaTest: 0.5,
                        blending: THREE.AdditiveBlending,
                        depthTest: false,
                        transparent: true
                    } );

                    particles = new THREE.Points( geometry, materials[i] );
                    particles.rotation.x = Math.random() * 3;
                    particles.rotation.y = Math.random() * 3;
                    particles.rotation.z = Math.random() * 3;
                    scene.add( particles );
                }

                renderer = new THREE.WebGLRenderer( { alpha: true } );
                renderer.setPixelRatio( window.devicePixelRatio );
                renderer.setSize( WIDTH, HEIGHT );
                container.appendChild( renderer.domElement );

                if(rdyGlobals.isMobile) {
                    window.addEventListener("deviceorientation", function (e) {
                        var x = e.gamma,
                            y = e.beta;

                        if (0 == window.orientation) {
                            mouseX = x * 30;
                            mouseY = (y - 30) * 30;
                        } else if (90 == window.orientation) {
                            mouseX = -y * 30;
                            mouseY = (-x - 30) * 30;
                        } else if (-90 == window.orientation) {
                            mouseX = y * 30;
                            mouseY = (x - 30) * 30;
                        }

                    });
                }

                if(!fx_mm_disable){
                    document.addEventListener( 'mousemove', onDocumentMouseMove, false );
                }

                window.addEventListener( 'resize', onWindowResize, false );

            }

            function onWindowResize() {
                container = document.getElementById( uid );
                var scene_width = $(container).width();
                var scene_height = $(container).height();

                windowHalfX = window.innerWidth / 2;
                windowHalfY = window.innerHeight / 2;
                sceneHalfX = scene_width / 2;
                sceneHalfY = scene_height / 2;

                camera.aspect = scene_width / scene_height;
                camera.updateProjectionMatrix();

                renderer.setSize( scene_width , scene_height );
            }

            function onDocumentMouseMove( event ) {
                mouseX = event.clientX - (window.innerWidth / 2);
                mouseY = event.clientY - (window.innerHeight / 2);
            }

            function animate() {
                requestAnimationFrame( animate );
                render();
            }

            function render() {

                var time = Date.now() * 0.00005;

                camera.position.x += ( mouseX - camera.position.x ) * 0.05;
                camera.position.y += ( - mouseY - camera.position.y ) * 0.05;
                camera.lookAt( scene.position );

                if (fx_auto) {
                    for (i = 0; i < scene.children.length; i++) {
                        var object = scene.children[i];
                        if (object instanceof THREE.Points) {
                            object.rotation.y += 0.001;
                        }
                    }
                }

                renderer.render(scene, camera);

            }

        },

        initCircles: function(uid, ob, canvas, heightOverride) {
            var fx_color = canvas.data('fx-color') ? canvas.data('fx-color') : "#ffffff";
            var fx_mm_disable = canvas.data('fx-mm-disable') ? true : false;

            container = document.getElementById( uid );

            var scene_width = $(container).width();
            var scene_height = $(container).height();

            var SEPARATION = 120, AMOUNTX = 50, AMOUNTY = 50;
            var camera, scene, renderer;
            var particles, particle, count = 0;
            var mouseX = 0, mouseY = 0;

            //if(fx_mm_disable){
            //    mouseX = -300;
            //    mouseY = -500;
            //}

            var windowHalfX = window.innerWidth / 2;
            var windowHalfY = window.innerHeight / 2;
            var sceneHalfX = scene_width / 2;
            var sceneHalfY = scene_height / 2;

            init();
            animate();


            function init(){
                camera = new THREE.PerspectiveCamera( 55, scene_width / scene_height, 1, 10000 );
                camera.position.z = 1000;
                scene = new THREE.Scene();
                particles = new Array();

                var PI2 = Math.PI * 2;
                var material = new THREE.SpriteCanvasMaterial( {
                    color: fx_color,
                    program: function ( context ) {
                        context.beginPath();
                        context.arc( 0, 0, 0.4, 0, PI2, true );
                        context.fill();
                    }
                } );

                var i = 0;

                for ( var ix = 0; ix < AMOUNTX; ix ++ ) {
                    for ( var iy = 0; iy < AMOUNTY; iy ++ ) {
                        particle = particles[ i ++ ] = new THREE.Sprite( material );
                        particle.position.x = ix * SEPARATION - ( ( AMOUNTX * SEPARATION ) / 2 );
                        particle.position.z = iy * SEPARATION - ( ( AMOUNTY * SEPARATION ) / 2 );
                        scene.add( particle );
                    }
                }

                renderer = new THREE.CanvasRenderer( { alpha: true } );
                renderer.setPixelRatio( window.devicePixelRatio );
                renderer.setSize( scene_width, scene_height );
                container.appendChild( renderer.domElement );

                if (rdyGlobals.isMobile) {
                    window.addEventListener("deviceorientation", function (e) {
                        var x = e.gamma,
                            y = e.beta;

                        if (0 == window.orientation) {
                            mouseX = x * 30;
                            mouseY = y * 10 - windowHalfY * 2;
                        } else if (90 == window.orientation) {
                            mouseX = -y * 30;
                            mouseY = (-x * 10) - windowHalfY * 2;
                        } else if (-90 == window.orientation) {
                            mouseX = y * 30;
                            mouseY = (x * 10) - windowHalfY * 2;
                        }

                    });
                }

                if(fx_mm_disable) {
                    camera.position.x = -400;
                    camera.position.y = 800;
                    camera.lookAt(scene.position);
                }

                if(!fx_mm_disable){
                    document.addEventListener( 'mousemove', onDocumentMouseMoveWave, false );
                }

                window.addEventListener( 'resize', onWindowResize, false );

            }

            function onWindowResize() {
                container = document.getElementById( uid );
                var scene_width = $(container).width();
                var scene_height = $(container).height();

                windowHalfX = window.innerWidth / 2;
                windowHalfY = window.innerHeight / 2;
                sceneHalfX = scene_width / 2;
                sceneHalfY = scene_height / 2;

                camera.aspect = scene_width / scene_height;
                camera.updateProjectionMatrix();

                renderer.setSize( scene_width , scene_height );
            }


            function onDocumentMouseMoveWave( event ) {
                mouseX = event.clientX - windowHalfX;
                mouseY = event.clientY - windowHalfY * 2.5;
            };


            function animate() {
                requestAnimationFrame( animate );
                render();
            };

            function render() {

                if(!fx_mm_disable) {
                    camera.position.x += ( mouseX - camera.position.x ) * .05;
                    camera.position.y += ( -mouseY - camera.position.y ) * .05;
                    camera.lookAt(scene.position);
                }

                var i = 0;

                for ( var ix = 0; ix < AMOUNTX; ix ++ ) {
                    for ( var iy = 0; iy < AMOUNTY; iy ++ ) {
                        particle = particles[ i++ ];
                        particle.position.y = ( Math.sin( ( ix + count ) * 0.3 ) * 50 ) +
                            ( Math.sin( ( iy + count ) * 0.5 ) * 50 );
                        particle.scale.x = particle.scale.y = ( Math.sin( ( ix + count ) * 0.3 ) + 1 ) * 4 +
                            ( Math.sin( ( iy + count ) * 0.5 ) + 1 ) * 4;
                    }
                }

                renderer.render( scene, camera );
                count += 0.1;
            }

        },

        initGeometry: function(uid, ob, canvas, heightOverride) {
            var fx_color = canvas.data('fx-color') ? canvas.data('fx-color') : "#ffffff";
            var fx_mm_disable = canvas.data('fx-mm-disable') ? true : false;

            particlesJS(uid, {
                "particles": {
                    "number": {
                        "value": 75,
                        "density": {
                            "enable": true,
                            "value_area": 800
                        }
                    },
                    "color": {
                        "value": fx_color
                    },
                    "shape": {
                        "type": "circle",
                        "stroke": {
                            "width": 0,
                            "color": "#000000"
                        },
                        "polygon": {
                            "nb_sides": 5
                        }
                    },
                    "opacity": {
                        "value": 0.3,
                        "random": false,
                        "anim": {
                            "enable": false,
                            "speed": 1,
                            "opacity_min": 0.1,
                            "sync": false
                        }
                    },
                    "size": {
                        "value": 3,
                        "random": true,
                        "anim": {
                            "enable": false,
                            "speed": 40,
                            "size_min": 0.1,
                            "sync": false
                        }
                    },
                    "line_linked": {
                        "enable": true,
                        "distance": 150,
                        "color": fx_color,
                        "opacity": 0.3,
                        "width": 1
                    },
                    "move": {
                        "enable": true,
                        "speed": 3,
                        "direction": "none",
                        "random": false,
                        "straight": false,
                        "out_mode": "out",
                        "bounce": false,
                        "attract": {
                            "enable": false,
                            "rotateX": 600,
                            "rotateY": 1200
                        }
                    }
                },
                "interactivity": {
                    "detect_on": "row",
                    "events": {
                        "onhover": {
                            "enable": fx_mm_disable ? false : true,
                            "mode": "grab"
                        },
                        "onclick": {
                            "enable": false,
                            "mode": "push"
                        },
                        "resize": true
                    },
                    "modes": {
                        "grab": {
                            "distance": 200,
                            "line_linked": {
                                "opacity": 0.5
                            }
                        },
                        "bubble": {
                            "distance": 400,
                            "size": 40,
                            "duration": 2,
                            "opacity": 8,
                            "speed": 3
                        },
                        "repulse": {
                            "distance": 200,
                            "duration": 0.4
                        },
                        "push": {
                            "particles_nb": 4
                        },
                        "remove": {
                            "particles_nb": 2
                        }
                    }
                },
                "retina_detect": true
            });

        },

        initMotion: function(uid, ob, container, heightOverride){

            function canvasWorkers() {
                workerPurpleX.postMessage({cmd: "start", value: -20}),
                    workerPurpleY.postMessage({cmd: "start", value: 20}),
                    workerGreenX.postMessage({cmd: "start", value: 0}),
                    workerGreenY.postMessage({cmd: "start", value: -30}),
                scale1 == seriously.transform("2d") || scale2 == seriously.transform("2d")
                || (
                    workerPurpleX.addEventListener("message", function (e) {
                        purpleTranslate[0] = e.data,
                            scale2.translate(purpleTranslate[0], purpleTranslate[1])
                    }, !1),

                        workerPurpleY.addEventListener("message", function (e) {
                            purpleTranslate[1] = e.data
                        }, !1),

                        workerGreenX.addEventListener("message", function (e) {
                            greenTranslate[0] = e.data,
                                scale1.translate(greenTranslate[0], greenTranslate[1])
                        }, !1),

                        workerGreenY.addEventListener("message", function (e) {
                            greenTranslate[1] = e.data
                        }, !1)
                )
            }

            function killWorkers() {
                workerPurpleX.postMessage({cmd: "stop"}),
                    workerPurpleY.postMessage({cmd: "stop"}),
                    workerGreenX.postMessage({cmd: "stop"}),
                    workerGreenY.postMessage({cmd: "stop"})
            }


            if(container.data('type') == 'motion'){
                img = container.find('.fx-motion img')[0];
                var seriousImg = new Image;
                seriousImg.src = img.src;

                $this = this;
                //seriousImg.onload = function(){
                    var canvas,
                        imgRatio,
                        seriously,
                        sourceImage,
                        layers,
                        edge,
                        blend1,
                        linearGreen,
                        scale1,
                        blend2,
                        linearPurple,
                        scale2,
                        blend3,
                        blend4,
                        blend5, target,
                        screenCaptured = !1,
                        animateable = !0,
                        popstate = !1,
                        isFourOhFour = !1,
                        inputReady = !0,
                        glitchExists = !1,
                        purpleTranslate = [],
                        position_old = .5,
                        workerPurpleX = new Worker(levelup_js_vars.themePath + "/assets/js/fx/worker_layer2X.js"),
                        workerPurpleY = new Worker(levelup_js_vars.themePath + "/assets/js/fx/worker_layer2Y.js"),
                        greenTranslate = [],
                        workerGreenX = new Worker(levelup_js_vars.themePath + "/assets/js/fx/worker_layer1X.js"),
                        workerGreenY = new Worker(levelup_js_vars.themePath + "/assets/js/fx/worker_layer1Y.js");

                    var imgLoaded, canvas, imgRatio;

                    canvas = document.getElementById(uid);

                    if (
                        seriously = new Seriously,
                            sourceImage = seriously.source(seriousImg),
                            target = seriously.target(canvas),
                            seriousImg.onload = function () {
                                imgLoaded = true;
                                imgRatio = img.width / img.height;
                                container.data('imgRatio', imgRatio);
                                resizeImage(container);
                                container.find('.fx-motion').addClass('loaded');

                                target.width = sourceImage.width;
                                target.height = sourceImage.height;
                                layers = seriously.effect("layers", 6);
                                layers.source0 = sourceImage;

                                if(container.data('fx-preset') == 'purple') {
                                    edge = seriously.effect("edge"),
                                        blend1 = seriously.effect("blend"),
                                        edge.source = sourceImage,
                                        blend1.bottom = layers.source0,
                                        blend1.top = edge,
                                        blend1.opacity = "0.15",
                                        blend1.mode = "overlay",
                                        layers.source1 = blend1,
                                        linearGreen = seriously.effect("linear-transfer"),
                                        scale1 = seriously.transform("2d"),
                                        blend2 = seriously.effect("blend"),
                                        linearGreen.source = sourceImage,
                                        linearGreen.intercept = [0, .45, .1, 0],
                                        scale1.source = linearGreen,
                                        scale1.scale(1.4),
                                        scale1.translate(0, -30),
                                        blend2.bottom = layers.source1,
                                        blend2.top = scale1,
                                        blend2.opacity = "0.7",
                                        blend2.mode = "normal",
                                        layers.source2 = blend2,
                                        linearPurple = seriously.effect("linear-transfer"),
                                        scale2 = seriously.transform("2d"),
                                        blend3 = seriously.effect("blend"),
                                        linearPurple.source = sourceImage,
                                        linearPurple.intercept = [.5, -.1, .7, 0],
                                        scale2.source = linearPurple,
                                        scale2.scale(1.125),
                                        scale2.translate(-20, 20),
                                        blend3.bottom = layers.source2,
                                        blend3.top = scale2,
                                        blend3.opacity = "0.5",
                                        blend3.mode = "normal",
                                        layers.source3 = blend3,
                                        blend4 = seriously.effect("blend"),
                                        blend4.bottom = layers.source3,
                                        blend4.top = linearPurple,
                                        blend4.opacity = "0.5",
                                        blend4.mode = "hardlight",
                                        layers.source4 = blend4,
                                        blend5 = seriously.effect("blend"),
                                        blend5.bottom = layers.source4,
                                        blend5.top = edge,
                                        blend5.opacity = "0.1",
                                        blend5.mode = "overlay",
                                        layers.source5 = blend5,
                                        target.source = layers,
                                        seriously.go()

                                }else if(container.data('fx-preset') == 'cooling_80'){
                                    var effect = seriously.effect('tone');
                                    effect.source = sourceImage;
                                    effect.light = [.70,1,1.90, 1];
                                    effect.dark = [0, .082,.2, 1];
                                    effect.toned = .6;
                                    effect.desat = 0;

                                }else if(container.data('fx-preset') == 'orange'){
                                    var effect = seriously.effect('tone');
                                    effect.source = sourceImage;
                                    effect.light = [1.3,.85,.45, 1];
                                    effect.dark = [.15,.08, .02, 1];
                                    effect.toned = .6;
                                    effect.desat = 0;

                                }else if(container.data('fx-preset') == 'green'){
                                    var effect = seriously.effect('tone');
                                    effect.source = sourceImage;
                                    effect.light = [0.7,1.1,.5, 1];
                                    effect.dark = [.01,.18, .01, 1];
                                    effect.toned = .6;
                                    effect.desat = 0;

                                }else if(container.data('fx-preset') == 'red'){
                                    var effect = seriously.effect('tone');
                                    effect.source = sourceImage;
                                    effect.light = [1.6,0.85, .95, 1];
                                    effect.dark = [.18, .01,.01, 1];
                                    effect.toned = .6;
                                    effect.desat = 0;

                                }else if(container.data('fx-preset') == 'deep_blue'){
                                    var effect = seriously.effect('tone');
                                    effect.source = sourceImage;
                                    effect.light = [.8,.98,1.65, 1];
                                    effect.dark = [.04, .05,.09, 1];
                                    effect.toned = .6;
                                    effect.desat = 0;

                                }else if(container.data('fx-preset') == 'underwatter'){
                                    var effect = seriously.effect('tone');
                                    effect.source = sourceImage;
                                    effect.light = [.75,1.1,1.05, 1];
                                    effect.dark = [.02, .06,.05, 1];
                                    effect.toned = .6;
                                    effect.desat = 0;

                                }else if(container.data('fx-preset') == 'grayscale'){
                                    var effect = seriously.effect('hue-saturation');
                                    effect.source = sourceImage;
                                    effect.saturation = -1;

                                }else if(container.data('fx-preset') == 'original'){
                                    var effect = sourceImage;
                                }

                                if(container.data('fx-preset') != 'purple') {
                                    layers.source1 = effect;

                                    scale1 = seriously.transform("2d");
                                    blend1 = seriously.effect("blend");

                                    scale1.source = effect,
                                        scale1.scale(1.1),
                                        scale1.translate(-40, 0),
                                        blend1.bottom = layers.source1,
                                        blend1.top = scale1,
                                        blend1.opacity = "0.14",
                                        blend1.mode = "normal",
                                        layers.source2 = blend1;

                                    scale2 = seriously.transform("2d"),
                                        blend2 = seriously.effect("blend"),
                                        scale2.source = effect,
                                        scale2.scale(1.2),
                                        scale2.translate(20, 10),
                                        blend2.bottom = layers.source2,
                                        blend2.top = scale2,
                                        blend2.opacity = "0.1",
                                        blend2.mode = "normal",
                                        layers.source3 = blend2;

                                    target.source = layers;
                                    seriously.go();
                                }

                            }, //canvasWorkers(),
                        !rdyGlobals.isMobile && $this.webGLTrue
                    ){
                        var purpleX, purpleY, greenX, greenY;

                        container.mousemove(function (e) {
                            if(!imgLoaded) return;

                            var x = e.clientX,
                                y = e.clientY,
                                halfWidth = img.width / 2,
                                halfHeight = img.height / 2;

                            purpleX = -15 * (x / halfWidth - 1) - 20;
                            purpleY = 15 * (y / halfHeight - 1) + 20;
                            greenX = 40 * (x / halfWidth - 1);
                            greenY = -40 * (y / halfHeight - 1) - 30;
                            workerPurpleX.postMessage({cmd: "stop"});
                            workerPurpleY.postMessage({cmd: "stop"});
                            workerGreenX.postMessage({cmd: "stop"});
                            workerGreenY.postMessage({cmd: "stop"});
                            scale1.translate(greenX, greenY);
                            scale2.translate(purpleX, purpleY);

                        });

                        $(canvas).mouseout(function (e) {
                            workerPurpleX.postMessage({cmd: "start", value: purpleX});
                            workerPurpleY.postMessage({cmd: "start", value: purpleY});
                            workerGreenX.postMessage({cmd: "start", value: greenX});
                            workerGreenY.postMessage({cmd: "start", value: greenY});

                        })

                    } else rdyGlobals.isMobile && window.DeviceOrientationEvent && this.webGLTrue && (killWorkers(),
                        window.addEventListener("deviceorientation", function (e) {
                            var x = e.gamma,
                                y = e.beta;

                            0 == window.orientation ? (scale1.translate(1.5 * x, 1.5 * y),
                                scale2.translate(.75 * x, .75 * y)) : 90 == window.orientation ? (scale1.translate(1.6 * y, -1.6 * x),
                                scale2.translate(.8 * y, x * -.8)) : -90 == window.orientation && (scale1.translate(-1.6 * y, 1.6 * x),
                                scale2.translate(y * -.8, .8 * x))
                        })),
                        window.addEventListener("orientationchange", function() {
                            resizeImage(container);
                        }, false);

                //} // onload
            }

        },
        
        initFlyingShapes: function (uid, ob, container, heightOverride) {
            "use strict";

            // PIXI.Point.subtract = function (a, b, out) {
            //
            //     if (typeof out === "undefined") { out = new PIXI.Point(); }
            //
            //     out.x = a.x - b.x;
            //     out.y = a.y - b.y;
            //
            //     return out;
            //
            // };

            var getClient = function () {
                var a, b = navigator.userAgent, c = b.match(/(opera|chrome|safari|firefox|msie|trident(?=\/))\/?\s*(\d+)/i) || [];
                return /trident/i.test(c[1]) ? (a = /\brv[ :]+(\d+)/g.exec(b) || [], "IE " + (a[1] || "")) : "Chrome" === c[1] && (a = b.match(/\b(OPR|Edge)\/(\d+)/), null != a) ? a.slice(1).join(" ").replace("OPR", "Opera") : (c = c[2] ? [c[1], c[2]] : [navigator.appName, navigator.appVersion, "-?"], null != (a = b.match(/version\/(\d+)/i)) && c.splice(1, 1, a[1]), c)
            }
            function shuffle(a) {
                for (var b, c, d = a.length; d; b = Math.floor(Math.random() * d), c = a[--d], a[d] = a[b], a[b] = c);
                return a
            }

            window.requestAnimFrame = function () {
                return window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.oRequestAnimationFrame || window.msRequestAnimationFrame || function (interval) { window.setTimeout(interval, 1e3 / 60) }
            }();

            window.cancelAnimationFrame = function () {
                return window.cancelAnimationFrame || window.mozCancelAnimationFrame
            }();

            var throttle = function (wait, func) {
                var c = null,
                    d = wait;
                !function () {
                    var a = func || this,
                        e = arguments,
                        f = Date.now();
                    (!c || f - c >= d) && (c = f, func.apply(a, e))
                }()
            }


            var canvasAnim = function (el, shapeColor, preset, size, speed, type) {
                this.canvasId = el,
                this.canvas = document.getElementById(this.canvasId),
                this.context = this.canvas.getContext("2d"),
                this.container = $(this.canvas).parent(),
                this.contHeight = this.container.height(),
                this.startPosY = this.contHeight + 100,
                this.client = getClient()[0].toLowerCase(),
                this.endPosY = -100,
                this.shapeColor = shapeColor ? shapeColor : '',
                this.preset = preset ? preset : '';
                this.size = size ? size : '';
                this.speed = speed ? speed : '';
                this.isSupportSVG = ("chrome" == this.client || "safari" == this.client) ? true : false;

                var $this = this;
                this.shapes = [],
                this.maxShapes = 15,//"chrome" == this.client ? 12 : 6,
                this.growSpeed = 10,
                this.maxwidth = 0,
                this.maxheight = 0,

                this.shapeDataPresets = {
                    'preset1': ["rectangle", "rectangle2", "triangle", "triangle2", "arc", "circle", "circle2", "cross", "line", "polygon", "zigzag", "tilda", "arc", "design1", "design2", "design3", "design4",  "design5", "design6", "design7"],//3
                    'preset2': ["rectangle", "rectangle2", "triangle", "triangle2", "arc", "circle", "circle2", "cross", "line", "polygon", "zigzag", "tilda", "arc", "ball", "bottle", "bug", "gift",  "heard", "horse"],
                    'preset3': ["rectangle", "rectangle2", "triangle", "triangle2", "arc", "circle", "circle2", "cross", "line", "polygon", "zigzag", "tilda", "arc", "camera", "game", "headphones", "projector",  "watch", "webcamera"],
                },
                this.svgImages = {
                    cross: { svg: "cross.svg", obj: new Image },
                    line: { svg: "line.svg", obj: new Image },
                    polygon: { svg: "polygon.svg", obj: new Image },
                    zigzag: { svg: "zig-zag.svg", obj: new Image },
                    tilda: { svg: "tilda.svg", obj: new Image },

                    design1: { svg: "design/design01.svg", obj: new Image },
                    design2: { svg: "design/design02.svg", obj: new Image },
                    design3: { svg: "design/design03.svg", obj: new Image },
                    design4: { svg: "design/design04.svg", obj: new Image },
                    design5: { svg: "design/design05.svg", obj: new Image },
                    design6: { svg: "design/design06.svg", obj: new Image },
                    design7: { svg: "design/design07.svg", obj: new Image },

                    ball: { svg: "kids/ball.svg", obj: new Image },
                    bottle: { svg: "kids/bottle.svg", obj: new Image },
                    bug: { svg: "kids/bug.svg", obj: new Image },
                    gift: { svg: "kids/gift.svg", obj: new Image },
                    heard: { svg: "kids/heard.svg", obj: new Image },
                    horse: { svg: "kids/horse.svg", obj: new Image },

                    camera: { svg: "fun/camera.svg", obj: new Image },
                    game: { svg: "fun/game.svg", obj: new Image },
                    headphones: { svg: "fun/headphones.svg", obj: new Image },
                    projector: { svg: "fun/projector.svg", obj: new Image },
                    watch: { svg: "fun/watch.svg", obj: new Image },
                    webcamera: { svg: "fun/webcamera.svg", obj: new Image },

                },
                this.order = [],
                this.type = type ? type : '';

                // Load shapes
                $.each(this.svgImages, function( index, value ) {
                    if ( "chrome" == $this.client || "safari" == $this.client ) {
                        if (value.svg) {
                            $.get(levelup_js_vars.themePath + "/assets/images/shapes/" + value.svg, function (a) {
                                var data = (new XMLSerializer).serializeToString(a);
                                value.obj.src = "data:image/svg+xml;charset=utf-8," + data;
                                value.obj = $this.changeSVGColor(value.obj, index);
                            });
                        }
                    } else {
                        if (value.img) {//value.path.indexOf(".png") > -1
                            value.obj.src = levelup_js_vars.themePath + "/assets/images/shapes/" + value.img;
                        }
                    }

                });

                for (var i = 0; this.maxShapes > i; i++)
                    this.order.push(i);

                this.order = shuffle(this.order),
                $(window).on("resize", function () {
                    throttle( 50, function () {
                        $this.respondCanvas()
                    })
                }),
                this.random = new PIXI.RandomDataGenerator,
                // this.renderer = new PIXI.CanvasRenderer(this.container.width(), this.container.height(), {view: this.canvas, antialias: true, transparent: true }),
                // this.stage = new PIXI.Container();
                // this.stage.interactive = true;

                // for (var i = 0; this.maxShapes > i; i++)
                //     this.addNewShape();
                this.addNewShape();
                this.respondCanvas();
                this.animate(!1)


            };

            canvasAnim.prototype = {
                init: function () {
                }, reset: function () {
                    this.shapes = [],
                    this.addNewShape(),
                    this.animate(!0)
                }, changeSVGColor: function (obj, shape) {
                    if ("" !== obj.src) {
                        var svg = $(obj.src.toString().replace("data:image/svg+xml;charset=utf-8,", "")),
                            paths = svg.find("path"),
                            rects = svg.find("rect");
                        // "polygon" == shape.shape ? paths.attr("stroke", this.tweenColor(tweenColor, 1)) : paths.attr("fill", this.tweenColor(tweenColor, 1));
                        // paths.attr("stroke", this.tweenColor(1, 1));
                        if (shape == "polygon") {
                            paths.attr("stroke", this.tweenColor(1, 1));
                        } else {
                            paths.attr("fill", this.tweenColor(1, 1));
                            rects.attr("fill", this.tweenColor(1, 1));
                        }

                        var image = new Image;
                        image.src = "data:image/svg+xml;charset=utf-8," + svg.prop("outerHTML")
                        obj = image
                    }
                    return obj;
                }, respondCanvas: function () {
                    var $this = this;
                    $(this.canvas).attr("width", $this.container.width()),
                    $(this.canvas).attr("height", $this.container.height()),
                    this.container = $(this.canvas).parent(),
                    this.contHeight = this.container.height(),
                    this.startPosY = this.contHeight + 100
                }, roundNum: function (a) {
                    return a = a > 1 ? 1 : a, a = 0 > a ? 0 : a, a.toFixed(2)
                }, tweenColor: function (a, hex) {
                    if (this.shapeColor)
                        return this.shapeColor;
                    var red, green, blue;
                    a = Math.abs(a - 1),
                    red = 165, green =122, blue = 235
                    var color = "rgba(" + red + "," + green + "," + blue + ",1)";
                    return 1 == hex && (color = this.rgbToHex(red, green, blue)), color
                }, componentToHex: function (color) {
                    var colorHex = color.toString(16);
                    return 1 == colorHex.length ? "0" + colorHex : colorHex
                }, rgbToHex: function (red, green, blue) {
                    return "#" + this.componentToHex(red) + this.componentToHex(green) + this.componentToHex(blue)
                }, drawSVGObj: function (shape, obj, context, rotation) {
                    context.translate(shape.x - shape.maxwidth / 2 * shape.scale, shape.y - shape.maxheight / 2 * shape.scale),
                    context.translate(shape.maxwidth / 2 * shape.scale, shape.maxheight / 2 * shape.scale),
                    context.rotate(rotation / 3.14),
                    context.drawImage(obj, -shape.maxwidth / 2 * shape.scale, -shape.maxheight / 2 * shape.scale, shape.maxwidth * shape.scale, shape.maxheight * shape.scale),

                    shape.scale < shape.maxscale && (shape.scale += shape.growth),
                    shape.scale > shape.maxscale && (shape.scale = shape.maxscale),
                    context.setTransform(1, 0, 0, 1, 0, 0)
                }, drawTriangle: function (shape, context, rotation) {
                    var d = shape.width * Math.sqrt(3) / 2;
                    context.translate(shape.x - shape.width / 2, shape.y),
                    context.translate(shape.width / 2, d / 2),
                    context.rotate(rotation / 3.14),
                    context.beginPath(),
                    context.moveTo(-shape.width / 2, -d / 2),
                    context.lineTo(shape.width / 2, -d / 2),
                    context.lineTo(0, d / 2),
                    context.lineTo(-shape.width / 2, -d / 2),
                    context.closePath();

                    var tweenColor = (shape.y / this.contHeight / 12 + .02, shape.y / this.contHeight);
                    context.lineWidth = shape.borderWidth,
                    context.strokeStyle = this.tweenColor(tweenColor),
                    context.stroke(),
                    context.setTransform(1, 0, 0, 1, 0, 0);

                    var shapeDimensions = shape;
                    shapeDimensions.height < shapeDimensions.maxheight && (shapeDimensions.height += shapeDimensions.growth),
                    shapeDimensions.width < shapeDimensions.maxwidth && (shapeDimensions.width += shapeDimensions.growth),
                    shapeDimensions.height > shapeDimensions.maxheight && (shapeDimensions.height = shapeDimensions.maxheight),
                    shapeDimensions.width > shapeDimensions.maxwidth && (shapeDimensions.width = shapeDimensions.maxheight)
                }, drawRectangle: function (shape, context, rotation) {
                    context.translate(shape.x - shape.width / 2, shape.y),
                    context.translate(shape.width / 2, shape.height / 2),
                    context.rotate(rotation / 3.14),
                    context.beginPath(),
                    context.rect(-shape.width / 2, -shape.height / 2, shape.width, shape.height),
                    context.lineWidth = shape.borderWidth;

                    var tweenColor = (shape.y / this.contHeight / 12 + .02, shape.y / this.contHeight);
                    context.strokeStyle = this.tweenColor(tweenColor), context.stroke(), context.setTransform(1, 0, 0, 1, 0, 0);

                    var shapeDimensions = shape;
                    shapeDimensions.height < shapeDimensions.maxheight && (shapeDimensions.height += shapeDimensions.growth),
                    shapeDimensions.width < shapeDimensions.maxwidth && (shapeDimensions.width += shapeDimensions.growth),
                    shapeDimensions.height > shapeDimensions.maxheight && (shapeDimensions.height = shapeDimensions.maxheight),
                    shapeDimensions.width > shapeDimensions.maxwidth && (shapeDimensions.width = shapeDimensions.maxheight)
                }, canvasAnim: function (shape, context, rotation) {
                    var d = shape.width * Math.sqrt(3) / 2;
                    context.translate(shape.x - shape.width / 2, shape.y),
                    context.translate(shape.width / 2, d / 2),
                    context.rotate(rotation / 3.14),
                    context.beginPath(),
                    context.moveTo(-shape.width / 2, -d / 2),
                    context.lineTo(shape.width / 2, -d / 2),
                    context.lineTo(0, d / 2),
                    context.lineTo(-shape.width / 2, -d / 2),
                    context.closePath();
                    shape.y / this.contHeight / 12 + .02;
                    context.lineWidth = shape.borderWidth;

                    var e = shape.y / this.contHeight;
                    context.strokeStyle = this.tweenColor(e),
                    context.stroke(),
                    context.setTransform(1, 0, 0, 1, 0, 0);

                    var shapeDimensions = shape;
                    shapeDimensions.height < shapeDimensions.maxheight && (shapeDimensions.height += shapeDimensions.growth),
                    shapeDimensions.width < shapeDimensions.maxwidth && (shapeDimensions.width += shapeDimensions.growth),
                    shapeDimensions.height > shapeDimensions.maxheight && (shapeDimensions.height = shapeDimensions.maxheight),
                    shapeDimensions.width > shapeDimensions.maxwidth && (shapeDimensions.width = shapeDimensions.maxheight)
                }, drawArc: function (shape, context, rotation) {
                    var d = shape.width / 2, e = 0, f = .8 * Math.PI, g = !1;
                    context.translate(shape.x - shape.width / 2, shape.y),
                    context.translate(shape.width / 3, shape.width / 4),
                    context.rotate(rotation / 3.14),
                    context.beginPath(),
                    context.arc(-shape.width / 3, -shape.width / 4, d, e, f, g);

                    shape.y / this.contHeight / 12 + .02;
                    context.lineWidth = shape.borderWidth;

                    var h = shape.y / this.contHeight;
                    context.strokeStyle = this.tweenColor(h),
                    context.stroke(),
                    context.setTransform(1, 0, 0, 1, 0, 0);

                    var shapeDimensions = shape;
                    shapeDimensions.height < shapeDimensions.maxheight && (shapeDimensions.height += shapeDimensions.growth),
                    shapeDimensions.width < shapeDimensions.maxwidth && (shapeDimensions.width += shapeDimensions.growth),
                    shapeDimensions.height > shapeDimensions.maxheight && (shapeDimensions.height = shapeDimensions.maxheight),
                    shapeDimensions.width > shapeDimensions.maxwidth && (shapeDimensions.width = shapeDimensions.maxheight)
                }, drawCircle: function (shape, context) {
                    var radius = shape.width,
                        startAngle = 0,
                        endAngle = Math.PI + 3 * Math.PI / 2,
                        anticlockwise = !1;
                    context.beginPath(),
                    context.arc(shape.x - shape.width / 2, shape.y, radius, startAngle, endAngle, anticlockwise);
                    shape.y / this.contHeight / 12 + .02;
                    context.lineWidth = shape.borderWidth;
                    var tweenColor = this.roundNum(shape.y / this.contHeight);
                    context.strokeStyle = this.tweenColor(tweenColor), context.stroke();
                    var shapeDimensions = shape;
                    shapeDimensions.height < shapeDimensions.maxheight && (shapeDimensions.height += shapeDimensions.growth),
                    shapeDimensions.width < shapeDimensions.maxwidth && (shapeDimensions.width += shapeDimensions.growth),
                    shapeDimensions.height > shapeDimensions.maxheight && (shapeDimensions.height = shapeDimensions.maxheight),
                    shapeDimensions.width > shapeDimensions.maxwidth && (shapeDimensions.width = shapeDimensions.maxheight)
                }, animate: function (loop) {
                    var $this = this;

                    this.context.clearRect(0, 0, this.canvas.width, this.canvas.height);
                    for (var i = 0; this.shapes.length > i; i++) {
                        var shape = this.shapes[i];

                        if(this.type == 'type2'){

                            var particlePositionVector = new rdy.PIXI.Point(shape.x, shape.y),
                                particleSpawnVector = new rdy.PIXI.Point(shape.spawn.x, shape.spawn.y),
                                distanceToSpawn = rdy.PIXI.Point.subtract(particlePositionVector, particleSpawnVector),
                                translationSpeed = .1,
                                maxDistance = 50;

                            if (1 === shape.direction.x) {
                                if (distanceToSpawn.x > maxDistance) {
                                    shape.direction.x = 0
                                } else {
                                    shape.x = shape.x + $this.random.realInRange(0, translationSpeed)
                                }
                            } else {
                                if (distanceToSpawn.x < -maxDistance) {
                                    shape.direction.x = 1
                                } else {
                                    shape.x = shape.x - $this.random.realInRange(0, translationSpeed)
                                }

                            }

                            if (1 === shape.direction.y) {
                                if (distanceToSpawn.y > maxDistance) {
                                    shape.direction.y = 0
                                } else {
                                    shape.y = shape.y + $this.random.realInRange(0, translationSpeed)
                                }
                            } else {
                                if(distanceToSpawn.y < -maxDistance){
                                    shape.direction.y = 1
                                } else {
                                    shape.y = shape.y - $this.random.realInRange(0, translationSpeed)
                                }
                            }


                            if (this.shapes[i].y > this.endPosY) {
                                // this.shapes[i].y = this.shapes[i].y - this.shapes[i].travelSpeed,
                                this.shapes[i].rotation = this.shapes[i].rotation + this.shapes[i].rotationSpeed * this.shapes[i].rotationDirection
                            } else {
                                // this.shapes[i].y = this.startPosY,
                                // this.shapes[i].x = Math.floor(Math.random() * this.container.width()),
                                this.shapes[i].rotation = Math.random()
                            }

                        } else {

                            if (this.shapes[i].y > this.endPosY) {
                                this.shapes[i].y = this.shapes[i].y - this.shapes[i].travelSpeed,
                                    this.shapes[i].rotation = this.shapes[i].rotation + this.shapes[i].rotationSpeed * this.shapes[i].rotationDirection
                            } else {
                                this.shapes[i].y = this.startPosY,
                                    this.shapes[i].x = Math.floor(Math.random() * this.container.width()),
                                    this.shapes[i].rotation = Math.random()
                            }

                        }


                        if ("rectangle" == this.shapes[i].shape)
                            this.drawRectangle(this.shapes[i], this.context, this.shapes[i].rotation)

                        else if ("rectangle2" == this.shapes[i].shape)
                            this.drawRectangle(this.shapes[i], this.context, this.shapes[i].rotation)

                        else if ("triangle" == this.shapes[i].shape)
                            this.drawTriangle(this.shapes[i], this.context, this.shapes[i].rotation)

                        else if ("triangle2" == this.shapes[i].shape)
                            this.drawTriangle(this.shapes[i], this.context, this.shapes[i].rotation)

                        else if ("arc" == this.shapes[i].shape)
                            this.drawArc(this.shapes[i], this.context, this.shapes[i].rotation)

                        else if ("circle" == this.shapes[i].shape)
                            this.drawCircle(this.shapes[i], this.context, this.shapes[i].rotation)

                        else if ("circle2" == this.shapes[i].shape)
                            this.drawCircle(this.shapes[i], this.context, this.shapes[i].rotation)

                        else if (!this.isSupportSVG) {
                            if (typeof $this.svgImages[this.shapes[i].shape].obj.naturalWidth !== "undefined" && $this.svgImages[this.shapes[i].shape].obj.naturalWidth > 0) {
                                this.drawSVGObj(this.shapes[i], $this.svgImages[this.shapes[i].shape].obj, this.context, this.shapes[i].rotation);
                            }
                        } else {
                            if (typeof $this.svgImages[this.shapes[i].shape] !== 'undefined') {
                                this.drawSVGObj(this.shapes[i], $this.svgImages[this.shapes[i].shape].obj, this.context, this.shapes[i].rotation);
                            }
                        }

                    }

                    this.shapes.length < this.maxShapes && this.addNewShape(),
                    loop || requestAnimFrame(function () {
                        $this.animate()
                    })
                }, addNewShape: function () {
                    var //count = 13,//"chrome" == this.client ? 13 : 4,
                        num = this.shapes.length,
                        rnd,
                        //rnd = Math.floor(Math.random() * count),
                        shape = "",
                        maxwidth = 0,
                        maxheight = 0,
                        borderWidth = 14,
                        maxscale = 1,
                        y = this.container.height() / this.maxShapes,
                        x = this.container.width() / this.maxShapes;

                    if (this.preset && typeof this.shapeDataPresets[this.preset] != "undefined") {
                        rnd = Math.floor(Math.random() * this.shapeDataPresets[this.preset].length);
                        shape = this.shapeDataPresets[this.preset][rnd];
                    } else {
                        // shape = this.shapeData[rnd].shape ? this.shapeData[rnd].shape : shape;
                        rnd = Math.floor(Math.random() * this.shapeDataPresets["preset1"].length);
                        shape = this.shapeDataPresets["preset1"][rnd];
                    }

                    var size_1 = 50;
                    var size_2 = 40;

                    if (this.size == 'large') {
                        size_1 = 70;
                        size_2 = 40;
                    }
                    var p_size_1 = 20;
                    var p_size_2 = 20;

                    if (this.size == 'large') {
                        p_size_1 = 30;
                        p_size_2 = 30;
                    }


                    if (shape == "rectangle") {
                        maxwidth = p_size_2 * Math.random() + p_size_1, maxheight = maxwidth, borderWidth = 3
                    }
                    else if (shape == "rectangle2") {
                        maxwidth = p_size_2 * Math.random() + p_size_1, maxheight = maxwidth
                    }
                    else if (shape == "triangle") {
                        maxwidth = p_size_2 * Math.random() + p_size_1, maxheight = maxwidth
                    }
                    else if (shape == "triangle2") {
                        maxwidth = p_size_2 * Math.random() + p_size_1, maxheight = maxwidth, borderWidth = 3
                    }
                    else if (shape == "arc") {
                        maxwidth = p_size_2 * Math.random() + p_size_1, maxheight = maxwidth
                    }
                    else if (shape == "circle") {
                        maxwidth = p_size_2 * Math.random() + p_size_1, maxheight = maxwidth, borderWidth = 18
                    }
                    else if (shape == "circle2") {
                        maxwidth = p_size_2 * Math.random() + p_size_1, maxheight = maxwidth, borderWidth = 3
                    }
                    else if (shape == "cross") {
                        maxwidth = 10 * Math.random() + 24, maxheight = maxwidth, borderWidth = 18
                    }
                    else if (shape == "line") {
                        maxwidth = 10 * Math.random() + 30, maxheight = .75 * maxwidth, borderWidth = 18
                    }
                    else if (shape == "polygon") {
                        maxwidth = 38 * Math.random() + 60, maxheight = .94898 * maxwidth, borderWidth = 18
                    }
                    else if (shape == "tilda") {
                        maxwidth = 10 * Math.random() + 23, maxheight = .3939393939393939 * maxwidth, borderWidth = 18
                    }
                    else if (shape == "zigzag") {
                        maxwidth = 20 * Math.random() + 43, maxheight = .619 * maxwidth, borderWidth = 18
                    }

                    else if (shape == "design3") {
                        maxwidth = 20 * Math.random() + 35, maxheight = maxwidth, borderWidth = 18
                    }
                    else if (shape == "design5") {
                        maxwidth = 20 * Math.random() + 50, maxheight = maxwidth, borderWidth = 18
                    }
                    else if (shape == "design6") {
                        maxwidth = 20 * Math.random() + 40, maxheight = maxwidth, borderWidth = 18
                    }
                    else if ([ 'design1', 'design2', 'design3', 'design4', 'design5', 'design6', 'design7',
                            "ball", "bottle", "bug", "gift",  "heard", "horse",
                            "camera", "game", "headphones", "projector", "watch", "webcamera" ].indexOf(shape) >= 0) {
                        maxwidth = size_2 * Math.random() + size_1, maxheight = maxwidth, borderWidth = 18
                    }


                    var travelSpeed;

                    if (this.speed == 'fast') {
                        travelSpeed = Math.random() / 1 + .1;
                    } else {
                        travelSpeed = Math.random() / 5 + .1;
                    }


                    var xx = num * x + 50;
                    var yy = this.order[num] * y + 50;


                    var shape = {
                        x: xx,
                        y: yy,
                        shape: shape,
                        rotation: 10 * Math.random() + 1,
                        width: 0,
                        height: 0,
                        scale: 0,
                        maxscale: maxscale,
                        maxwidth: maxwidth,
                        maxheight: maxheight,
                        borderWidth: borderWidth,
                        growth: Math.random() * this.growSpeed,
                        rotationSpeed: Math.random() / 80 + .01,
                        rotationDirection: 1 - 2 * Math.floor(Math.random()),
                        travelSpeed: travelSpeed,
                        particle: '',
                        direction: {
                            x: Math.round(Math.random()),
                            y: Math.round(Math.random())
                        },
                        spawn: {x: xx, y: yy}
                    }

                    this.shapes.push(shape);
                }
            }

            var canvasObj = new canvasAnim(uid, container.data('fx-color'), container.data('fx-preset'), container.data('fx-shape-size'), container.data('fx-shape-speed'), container.data('fx-shape-type'));

            if (container.data('lb-opacity')) {
                var opacity = container.data('lb-opacity') ? container.data('lb-opacity') : '.5';
                $('canvas', ob).css('opacity', opacity);
            }

        }

    };

    rdy.carousel = function (container) {
        var $owlSelector = $('[class*="owl-carousel"]:not(.owl-testimonials):not(.products)', container),
            params = {},
            tempTimeStamp,
            currentIndex;

        $owlSelector.each(function () {
            var params = {};
            var itemID = $(this).attr('id'),
                $elSelector = $(this);
            params['id'] = itemID;
            params['items'] = 4;
            params['columns'] = 3;
            params['fade'] = false;
            params['nav'] = false;
            params['navmobile'] = false;
            params['navskin'] = 'light';
            params['navspeed'] = 400;
            params['dots'] = false;
            params['dotsmobile'] = false;
            params['loop'] = false;
            params['autoplay'] = false;
            params['timeout'] = 3000;
            params['autoheight'] = false;
            params['hoverpause'] = false;
            params['margin'] = 0;
            params['lg'] = 1;
            params['md'] = 1;
            params['sm'] = 1;

            $.each($(this).data(), function (i, v) {
                params[i] = v;
            });

            $elSelector.on('initialized.owl.carousel', function (event) {

                var thiis = $(event.currentTarget);

                if ($(event.currentTarget).data('autoplay')) {
                    $(event.currentTarget).trigger('play.owl.autoplay');
                }

                setTimeout(function () {
                    animate_thumb($('.t-inside', el), event);
                }, 400);


                var currentItem = $(event.currentTarget).find("> .owl-stage-outer > .owl-stage > .owl-item")[event.item.index],
                    currentIndex = $(currentItem).attr('data-index');

                $.each($('.owl-item:not(.active)', event.currentTarget), function (index, val) {
                    if ($(val).attr('data-index') != currentIndex) {
                        $('.start_animation:not(.t-inside)', val).removeClass('start_animation');
                    }
                    if ($(val).attr('data-index') == currentIndex) {
                        $('.animate_when_almost_visible:not(.t-inside)', val).addClass('start_animation');
                    }
                });

                var el = $(event.currentTarget);

            });


            $elSelector.on('translated.owl.carousel', function (event) {

                var currentItem = $(event.currentTarget).find("> .owl-stage-outer > .owl-stage > .owl-item")[event.item.index],
                    currentIndex = $(currentItem).attr('data-index');

                setTimeout(function () {
                    var lastDelayElems = animate_elems($('.owl-item.active', event.currentTarget));
                    var lastDelayThumb = animate_thumb($('.owl-item.active .t-inside', event.currentTarget), event);

                    if ($(event.currentTarget).closest('.owl-slider').length && $(event.currentTarget).data('autoplay')) {
                        if (lastDelayElems == undefined) lastDelayElems = 0;
                        if (lastDelayThumb == undefined) lastDelayThumb = 0;
                        var maxDelay = Math.max(lastDelayElems, lastDelayThumb);
                        $(event.currentTarget).trigger('stop.owl.autoplay');
                        setTimeout(function () {
                            if (!$(event.currentTarget).hasClass('owl-mouseenter') && $(event.currentTarget).data('stopped') != 'true') $(event.currentTarget).trigger('play.owl.autoplay');
                        }, maxDelay);
                    }
                }, 200);

                $.each($('.owl-item:not(.active) .start_animation', $(event.target)), function (index, val) {
                    if ($(val).closest('.owl-slider').length) {
                        $(val).removeClass('start_animation');
                    }
                });

                $.each($('.owl-item:not(.active)', event.currentTarget), function (index, val) {
                    if ($(val).attr('data-index') != currentIndex) {
                        $('.start_animation:not(.t-inside)', val).removeClass('start_animation');
                    }
                    if ($(val).attr('data-index') == currentIndex) {
                        $('.animate_when_almost_visible:not(.t-inside)', val).addClass('start_animation');
                    }
                });

            });


            $elSelector.owlCarousel({
                items: params['items'],
                animateOut: (params['fade'] == true) ? 'fadeOut' : null,
                nav: params['nav'],
                dots: params['dots'],
                loop: params['loop'],
                margin: 0,
                video: true,
                autoWidth: false,
                autoplay: false,
                autoplayTimeout: params['timeout'],
                autoplaySpeed: params['navspeed'],
                autoplayHoverPause: params['hoverpause'],
                autoHeight: ($(this).hasClass('owl-height-equal') || $(this).hasClass('owl-height-auto')) ? true : params['autoheight'],
                rtl: $('body').hasClass('rtl') ? true : false,
                fluidSpeed: true,
                navSpeed: params['navspeed'],
                navContainer: params['nav'] ? $elSelector : false,
                responsiveClass: true,
                responsive: {
                    0: {
                        items: params['sm'],
                        nav: params['navmobile'],
                        dots: params['dotsmobile']
                    },
                    480: {
                        items: params['sm'],
                        nav: params['navmobile'],
                        dots: params['dotsmobile']
                    },
                    570: {
                        items: params['md'],
                        nav: params['navmobile'],
                        dots: params['dotsmobile']
                    },
                    960: {
                        items: params['lg']
                    }
                },
            });

        });

        function animate_elems($this) {
            var lastDelay;
            $.each($('.animate_when_almost_visible:not(.t-inside)', $this), function (index, val) {
                var element = $(val),
                    delayAttr = element.attr('data-delay');
                if (delayAttr == undefined) delayAttr = 0;
                setTimeout(function () {
                    element.addClass('start_animation');
                }, delayAttr);
                lastDelay = delayAttr;
            });
            return lastDelay;
        }

        function animate_thumb(items, event) {
            var lastDelay,
                itemIndex,
                tempIndex = ($(event.currentTarget).data('tempIndex') == undefined) ? $('.owl-item.active', event.currentTarget).first().index() : $(event.currentTarget).data('tempIndex'),
                numActives = $('.owl-item.active', event.currentTarget).length;
            $(event.currentTarget).data('tempIndex', event.item.index);
            $.each(items, function (index, val) {
                var parent = $(val).closest('.owl-item');
                if (!$(val).hasClass('start_animation')) {
                    if (parent.hasClass('active')) {

                        $(val).waypoint(function (direction) {
                            var element = $(this),
                                delayAttr = parseInt(element.attr('data-delay')),
                                itemIndex = element.closest('.owl-item').index() + 1,
                                diffItem = Math.abs(itemIndex - tempIndex) - 1;
                            if (itemIndex > tempIndex) {
                                $(event.currentTarget).data('tempIndex', itemIndex);
                            }
                            if (isNaN(delayAttr)) delayAttr = 100;
                            $('.owl-item.cloned[data-index="' + (element.closest('.owl-item').data('index')) + '"] .t-inside', event.currentTarget).addClass('start_animation');
                            var objTimeout = setTimeout(function () {
                                element.addClass('start_animation');
                            }, diffItem * delayAttr);
                            lastDelay = diffItem * delayAttr;
                            parent.data('objTimeout', objTimeout);

                        }, {offset: '90%', triggerOnce: true});

                    }
                }
            });
            return lastDelay;
        }
    };

})(jQuery);

Zerion Mini Shell 1.0