/home/arranoyd/gazehome/wp-content/themes/uncode/library/js/init.js
/**
 * Load utils - BEGIN
 */
/*
 CSS Browser Selector 1.0
 Originally written by Rafael Lima (http://rafael.adm.br)
 http://rafael.adm.br/css_browser_selector
 License: http://creativecommons.org/licenses/by/2.5/

 Co-maintained by:
 https://github.com/ridjohansen/css_browser_selector
 https://github.com/wbruno/css_browser_selector
 */

"use strict";

window.requestAnimFrame = (function() {
	return  window.requestAnimationFrame	   ||
			window.webkitRequestAnimationFrame ||
			window.mozRequestAnimationFrame	||
			window.oRequestAnimationFrame	  ||
			window.msRequestAnimationFrame	 ||
			function(/* function */ callback, /* DOMElement */ element){
				window.setTimeout(callback, 1000 / 60);
			};
})();

window.requestTimeout = function(fn, delay) {
	if( !window.requestAnimationFrame	  	&&
		!window.webkitRequestAnimationFrame &&
		!(window.mozRequestAnimationFrame && window.mozCancelRequestAnimationFrame) && // Firefox 5 ships without cancel support
		!window.oRequestAnimationFrame	  &&
		!window.msRequestAnimationFrame)
			return window.setTimeout(fn, delay);

	var start = new Date().getTime(),
		handle = new Object();

	function loop(){
		var current = new Date().getTime(),
			delta = current - start;

		delta >= delay ? fn.call() : handle.value = requestAnimFrame(loop);
	};

	handle.value = requestAnimFrame(loop);
	return handle;
};

window.clearRequestTimeout = function(handle) {
	if ( typeof handle !== 'undefined' ) {
		window.cancelAnimationFrame ? window.cancelAnimationFrame(handle.value) :
		window.webkitCancelAnimationFrame ? window.webkitCancelAnimationFrame(handle.value) :
		window.webkitCancelRequestAnimationFrame ? window.webkitCancelRequestAnimationFrame(handle.value) : /* Support for legacy API */
		window.mozCancelRequestAnimationFrame ? window.mozCancelRequestAnimationFrame(handle.value) :
		window.oCancelRequestAnimationFrame	? window.oCancelRequestAnimationFrame(handle.value) :
		window.msCancelRequestAnimationFrame ? window.msCancelRequestAnimationFrame(handle.value) :
		clearTimeout(handle);
	}
};

var uaInfo = {
	ua: '',
	is: function(t) {
		return RegExp(t, "i").test(uaInfo.ua);
	},
	version: function(p, n) {
		n = n.replace(".", "_");
		var i = n.indexOf('_'),
			ver = "";
		while (i > 0) {
			ver += " " + p + n.substring(0, i);
			i = n.indexOf('_', i + 1);
		}
		ver += " " + p + n;
		return ver;
	},
	getBrowser: function() {
		var g = 'gecko',
			w = 'webkit',
			c = 'chrome',
			f = 'firefox',
			s = 'safari',
			o = 'opera',
			a = 'android',
			bb = 'blackberry',
			dv = 'device_',
			ua = uaInfo.ua,
			is = uaInfo.is;
		return [
			(!(/opera|webtv/i.test(ua)) && /msie\s(\d+)/.test(ua)) ? ('ie ie' + (/trident\/4\.0/.test(ua) ? '8' : RegExp.$1))
			: is('edge\/') ? 'edge ie' + (/edge\/(\d+)\.(\d+)/.test(ua) ? RegExp.$1 + ' ie' + RegExp.$1 + '_' + RegExp.$2 : '') // IE Edge
			: is('trident\/') ? 'ie ie'+ (/trident\/.+rv:(\d+)/i.test(ua) ? RegExp.$1 : '') //ie11+
			: is('firefox/') ? g + " " + f + (/firefox\/((\d+)(\.(\d+))(\.\d+)*)/.test(ua) ? ' ' + f + RegExp.$2 + ' ' + f + RegExp.$2 + "_" + RegExp.$4 : '')
			: is('gecko/') ? g
			: is('opera') ? o + (/version\/((\d+)(\.(\d+))(\.\d+)*)/.test(ua) ? ' ' + o + RegExp.$2 + ' ' + o + RegExp.$2 + "_" + RegExp.$4 : (/opera(\s|\/)(\d+)\.(\d+)/.test(ua) ? ' ' + o + RegExp.$2 + " " + o + RegExp.$2 + "_" + RegExp.$3 : ''))
			: is('konqueror') ? 'konqueror'
			: is('blackberry') ? (bb + (/Version\/(\d+)(\.(\d+)+)/i.test(ua) ? " " + bb + RegExp.$1 + " " + bb + RegExp.$1 + RegExp.$2.replace('.', '_') : (/Blackberry ?(([0-9]+)([a-z]?))[\/|;]/gi.test(ua) ? ' ' + bb + RegExp.$2 + (RegExp.$3 ? ' ' + bb + RegExp.$2 + RegExp.$3 : '') : ''))) // blackberry
			: is('android') ? (a + (/Version\/(\d+)(\.(\d+))+/i.test(ua) ? " " + a + RegExp.$1 + " " + a + RegExp.$1 + RegExp.$2.replace('.', '_') : '') + (/Android (.+); (.+) Build/i.test(ua) ? ' ' + dv + ((RegExp.$2).replace(/ /g, "_")).replace(/-/g, "_") : '')) //android
			: is('chrome') ? w + ' ' + c + (/chrome\/((\d+)(\.(\d+))(\.\d+)*)/.test(ua) ? ' ' + c + RegExp.$2 + ((RegExp.$4 > 0) ? ' ' + c + RegExp.$2 + "_" + RegExp.$4 : '') : '')
			: is('iron') ? w + ' iron'
			: is('applewebkit/') ? (w + ' ' + s + (/version\/((\d+)(\.(\d+))(\.\d+)*)/.test(ua) ? ' ' + s + RegExp.$2 + " " + s + RegExp.$2 + RegExp.$3.replace('.', '_') : (/ Safari\/(\d+)/i.test(ua) ? ((RegExp.$1 == "419" || RegExp.$1 == "417" || RegExp.$1 == "416" || RegExp.$1 == "412") ? ' ' + s + '2_0' : RegExp.$1 == "312" ? ' ' + s + '1_3' : RegExp.$1 == "125" ? ' ' + s + '1_2' : RegExp.$1 == "85" ? ' ' + s + '1_0' : '') : ''))) //applewebkit
			: is('mozilla/') ? g : ''
		];
	},
	getPlatform : function() {
		var wp = 'winphone',
			a  = 'android',
			bb = 'blackberry',
			dv = 'device_',

			ua = uaInfo.ua,
			version = uaInfo.version,
			is = uaInfo.is;

		return [
			is('j2me') ? 'j2me'
			:is('windows phone') ? (wp + (/Windows Phone (\d+)(\.(\d+))+/i.test(ua) ? " " + wp + RegExp.$1 + " " + wp + RegExp.$1 + RegExp.$2.replace('.', '_') : (/Windows Phone OS (\d+)(\.(\d+))+/i.test(ua) ? " " + wp + RegExp.$1 + " " + wp + RegExp.$1 + RegExp.$2.replace('.', '_') : ''))) // Windows Phone
			:is('blackberry') ? (bb + (/Version\/(\d+)(\.(\d+)+)/i.test(ua) ? " " + bb + RegExp.$1 + " " + bb + RegExp.$1 + RegExp.$2.replace('.', '_') : (/Blackberry ?(([0-9]+)([a-z]?))[\/|;]/gi.test(ua) ? ' ' + bb + RegExp.$2 + (RegExp.$3 ? ' ' + bb + RegExp.$2 + RegExp.$3 : '') : ''))) // blackberry
			:is('android') ? (a + (/Version\/(\d+)(\.(\d+))+/i.test(ua) ? " " + a + RegExp.$1 + " " + a + RegExp.$1 + RegExp.$2.replace('.', '_') : '') + (/Android (.+); (.+) Build/i.test(ua) ? ' ' + dv + ((RegExp.$2).replace(/ /g, "_")).replace(/-/g, "_") : '')) //android
			:is('ipad|ipod|iphone') ? (
			(/CPU( iPhone)? OS (\d+[_|\.]\d+([_|\.]\d+)*)/i.test(ua) ? 'ios' + version('ios', RegExp.$2) : '') + ' ' + (/(ip(ad|od|hone))/gi.test(ua) ? RegExp.$1 : "")) //'iphone'
			//:is('ipod')?'ipod'
			//:is('ipad')?'ipad'
			:is('playbook') ? 'playbook'
			:is('kindle|silk') ? 'kindle'
			:is('playbook') ? 'playbook'
			:is('mac') ? 'mac' + (/mac os x ((\d+)[.|_](\d+))/.test(ua) ? (' mac' + (RegExp.$2) + ' mac' + (RegExp.$1).replace('.', "_")) : '')
			:is('win') ? 'win' + (is('windows nt 10.0') ? ' win10'
			:is('windows nt 6.3') ? ' win8_1'
			:is('windows nt 6.2') ? ' win8'
			:is('windows nt 6.1') ? ' win7'
			:is('windows nt 6.0') ? ' vista'
			:is('windows nt 5.2') || is('windows nt 5.1') ? ' win_xp'
			:is('windows nt 5.0') ? ' win_2k'
			:is('windows nt 4.0') || is('WinNT4.0') ? ' win_nt' : '')
			:is('freebsd') ? 'freebsd'
			:is('x11|linux') ? 'linux' : ''
		];
	},
	getMobile: function() {
		var is = uaInfo.is;
		return [
			is("android|mobi|mobile|j2me|iphone|ipod|ipad|blackberry|playbook|kindle|silk") ? 'mobile' : ''
		];
	},
	getIpadApp: function() {
		var is = uaInfo.is;
		return [
			(is('ipad|iphone|ipod') && !is('safari')) ? 'ipad_app' : ''
		];
	},
	getLang: function() {
		var ua = uaInfo.ua;
		return [/[; |\[](([a-z]{2})(\-[a-z]{2})?)[)|;|\]]/i.test(ua) ? ('lang_' + RegExp.$2).replace("-", "_") + (RegExp.$3 != '' ? (' ' + 'lang_' + RegExp.$1).replace("-", "_") : '') : ''];
	}
}
var screenInfo = {
	width: (window.outerWidth || document.documentElement.clientWidth) - 15,
	height: window.outerHeight || document.documentElement.clientHeight,
	screens: [0, 768, 980, 1200],
	screenSize: function() {
		screenInfo.width = (window.outerWidth || document.documentElement.clientWidth) - 15;
		screenInfo.height = window.outerHeight || document.documentElement.clientHeight;
		var screens = screenInfo.screens,
			i = screens.length,
			arr = [],
			maxw,
			minw;
		while (i--) {
			if (screenInfo.width >= screens[i]) {
				if (i) {
					arr.push("minw_" + screens[(i)]);
				}
				if (i <= 2) {
					arr.push("maxw_" + (screens[(i) + 1] - 1));
				}
				break;
			}
		}
		return arr;
	},
	getOrientation: function() {
		return screenInfo.width < screenInfo.height ? ["orientation_portrait"] : ["orientation_landscape"];
	},
	getInfo: function() {
		var arr = [];
		arr = arr.concat(screenInfo.screenSize());
		arr = arr.concat(screenInfo.getOrientation());
		return arr;
	},
	getPixelRatio: function() {
		var arr = [],
			pixelRatio = window.devicePixelRatio ? window.devicePixelRatio : 1;
		if (pixelRatio > 1) {
			arr.push('retina_' + parseInt(pixelRatio) + 'x');
			arr.push('hidpi');
		} else {
			arr.push('no-hidpi');
		}
		return arr;
	}
}
var dataUriInfo = {
	data: new Image(),
	div: document.createElement("div"),
	isIeLessThan9: false,
	getImg: function() {
		dataUriInfo.data.src = "";
		dataUriInfo.div.innerHTML = "<!--[if lt IE 9]><i></i><![endif]-->";
		dataUriInfo.isIeLessThan9 = dataUriInfo.div.getElementsByTagName("i").length == 1;
		return dataUriInfo.data;
	},
	checkSupport: function() {
		if (dataUriInfo.data.width != 1 || dataUriInfo.data.height != 1 || dataUriInfo.isIeLessThan9) {
			return ["no-datauri"];
		} else {
			return ["datauri"];
		}
	}
}

function css_browser_selector(u, ns) {
		var html = document.documentElement,
			b = []
		ns = ns ? ns : "";
		/* ua */
		uaInfo.ua = u.toLowerCase();
		var browser = uaInfo.getBrowser();
		if (browser == 'gecko') browser = (!(window.ActiveXObject) && "ActiveXObject" in window) ? 'ie ie11' : browser;
		var pattTouch = /no-touch/g;
		if (pattTouch.test(html.className)) b = b.concat('no-touch');
		else b = b.concat('touch');
		var pattAdmin = /admin-mode/g;
		if (pattAdmin.test(html.className)) b = b.concat('admin-mode');
		b = b.concat(browser);
		b = b.concat(uaInfo.getPlatform());
		b = b.concat(uaInfo.getMobile());
		b = b.concat(uaInfo.getIpadApp());
		b = b.concat(uaInfo.getLang());
		/* js */
		b = b.concat(['js']);
		/* pixel ratio */
		b = b.concat(screenInfo.getPixelRatio());
		/* screen */
		b = b.concat(screenInfo.getInfo());
		var updateScreen = function() {
			html.className = html.className.replace(/ ?orientation_\w+/g, "").replace(/ [min|max|cl]+[w|h]_\d+/g, "");
			html.className = html.className + ' ' + screenInfo.getInfo().join(' ');
		}
		window.addEventListener('resize', updateScreen);
		window.addEventListener('orientationchange', updateScreen);
		/* dataURI */
		var data = dataUriInfo.getImg();
		data.onload = data.onerror = function() {
				html.className += ' ' + dataUriInfo.checkSupport().join(' ');
			}
			/* removendo itens invalidos do array */
		b = b.filter(function(e) {
			return e;
		});
		/* prefixo do namespace */
		b[0] = ns ? ns + b[0] : b[0];
		html.className = b.join(' ' + ns);
		return html.className;
	}
	// define css_browser_selector_ns before loading this script to assign a namespace
var css_browser_selector_ns = css_browser_selector_ns || "";
// init
css_browser_selector(navigator.userAgent, css_browser_selector_ns);
/**
 * skip-link-focus-fix.js
 *
 * Helps with accessibility for keyboard only users.
 *
 * Learn more: https://github.com/Automattic/_s/pull/136
 */
(function() {
	var is_webkit = navigator.userAgent.toLowerCase().indexOf('webkit') > -1,
		is_opera = navigator.userAgent.toLowerCase().indexOf('opera') > -1,
		is_ie = navigator.userAgent.toLowerCase().indexOf('msie') > -1;
	if ((is_webkit || is_opera || is_ie) && document.getElementById && window.addEventListener) {
		window.addEventListener('hashchange', function() {
			var id = location.hash.substring(1),
				element;
			if (!(/^[A-z0-9_-]+$/.test(id))) {
				return;
			}
			element = document.getElementById(id);
			if (element) {
				if (!(/^(?:a|select|input|button|textarea)$/i.test(element.tagName))) {
					element.tabIndex = -1;
				}
				element.focus();
			}
		}, false);
	}
})();
// Polyfill for creating CustomEvents on IE9/10/11
// code pulled from:
// https://github.com/d4tocchini/customevent-polyfill
// https://developer.mozilla.org/en-US/docs/Web/API/CustomEvent#Polyfill
try {
	new CustomEvent("test");
} catch (e) {
	var CustomEvent = function(event, params) {
		var evt;
		params = params || {
			bubbles: false,
			cancelable: false,
			detail: undefined
		};
		evt = document.createEvent("CustomEvent");
		evt.initCustomEvent(event, params.bubbles, params.cancelable, params.detail);
		return evt;
	};
	CustomEvent.prototype = window.Event.prototype;
	window.CustomEvent = CustomEvent; // expose definition to window
}
// Evento - v1.0.0
// by Erik Royall <erikroyalL@hotmail.com> (http://erikroyall.github.io)
// Dual licensed under MIT and GPL
// Array.prototype.indexOf shim
// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/indexOf
Array.prototype.indexOf || (Array.prototype.indexOf = function(n) {
	"use strict";
	if (null == this) throw new TypeError;
	var t, e, o = Object(this),
		r = o.length >>> 0;
	if (0 === r) return -1;
	if (t = 0, arguments.length > 1 && (t = Number(arguments[1]), t != t ? t = 0 : 0 != t && 1 / 0 != t && t != -1 / 0 && (t = (t > 0 || -1) * Math.floor(Math.abs(t)))), t >= r) return -1;
	for (e = t >= 0 ? t : Math.max(r - Math.abs(t), 0); r > e; e++)
		if (e in o && o[e] === n) return e;
	return -1
});
var evento = function(n) {
	var t, e, o, r = n,
		i = r.document,
		f = {};
	return t = function() {
		return "function" == typeof i.addEventListener ? function(n, t, e) {
			n.addEventListener(t, e, !1), f[n] = f[n] || {}, f[n][t] = f[n][t] || [], f[n][t].push(e)
		} : "function" == typeof i.attachEvent ? function(n, t, e) {
			n.attachEvent(t, e), f[n] = f[n] || {}, f[n][t] = f[n][t] || [], f[n][t].push(e)
		} : function(n, t, e) {
			n["on" + t] = e, f[n] = f[n] || {}, f[n][t] = f[n][t] || [], f[n][t].push(e)
		}
	}(), e = function() {
		return "function" == typeof i.removeEventListener ? function(n, t, e) {
			n.removeEventListener(t, e, !1), Helio.each(f[n][t], function(o) {
				o === e && (f[n] = f[n] || {}, f[n][t] = f[n][t] || [], f[n][t][f[n][t].indexOf(o)] = void 0)
			})
		} : "function" == typeof i.detachEvent ? function(n, t, e) {
			n.detachEvent(t, e), Helio.each(f[n][t], function(o) {
				o === e && (f[n] = f[n] || {}, f[n][t] = f[n][t] || [], f[n][t][f[n][t].indexOf(o)] = void 0)
			})
		} : function(n, t, e) {
			n["on" + t] = void 0, Helio.each(f[n][t], function(o) {
				o === e && (f[n] = f[n] || {}, f[n][t] = f[n][t] || [], f[n][t][f[n][t].indexOf(o)] = void 0)
			})
		}
	}(), o = function(n, t) {
		f[n] = f[n] || {}, f[n][t] = f[n][t] || [];
		for (var e = 0, o = f[n][t].length; o > e; e += 1) f[n][t][e]()
	}, {
		add: t,
		remove: e,
		trigger: o,
		_handlers: f
	}
}(this);
/*
 * OKVideo by OKFocus v2.3.2
 * http://okfoc.us
 *
 * Copyright 2014, OKFocus
 * Licensed under the MIT license.
 *
 */
var player, OKEvents, options, videoWidth, videoHeight, YTplayers, youtubePlayers = new Array();
// youtube player ready
function onYouTubeIframeAPIReady() {
	YTplayers = new Array();
	jQuery('.no-touch .uncode-video-container.video').each(function() {
		var playerY;
		if (jQuery(this).attr('data-provider') == 'youtube') {
			var id = jQuery(this).attr('data-id');
			options = jQuery(window).data('okoptions-' + id);
			options.time = jQuery(this).attr('data-t');
			playerY = new YT.Player('okplayer-' + id, {
				videoId: options.video ? options.video.id : null,
				playerVars: {
					'autohide': 1,
					'autoplay': 0, //options.autoplay,
					'disablekb': options.keyControls,
					'cc_load_policy': options.captions,
					'controls': options.controls,
					'enablejsapi': 1,
					'fs': 0,
					'modestbranding': 1,
					'origin': window.location.origin || (window.location.protocol + '//' + window.location.hostname),
					'iv_load_policy': options.annotations,
					'loop': options.loop,
					'showinfo': 0,
					'rel': 0,
					'wmode': 'opaque',
					'hd': options.hd,
					'mute': 1
				},
				events: {
					'onReady': OKEvents.yt.ready,
					'onStateChange': OKEvents.yt.onStateChange,
					'onError': OKEvents.yt.error
				}
			});
			YTplayers[id] = playerY;
			playerY.videoId = id;
		}
	});
}
// vimeo player ready
function vimeoPlayerReady(id) {
	options = jQuery(window).data('okoptions-' + id);
	var jIframe = options.jobject,
	iframe = jIframe[0];
	jIframe.attr('src', jIframe.data('src'));
	var playerV = $f(iframe);
	// hide player until Vimeo hides controls...
	playerV.addEvent('ready', function(e) {
		OKEvents.v.onReady(iframe);
		var carouselContainer = jQuery(iframe).closest('.owl-carousel');
		if (carouselContainer.length) {
			UNCODE.owlPlayVideo(carouselContainer);
		}
		// "Do not try to add listeners or call functions before receiving this event."
		if (OKEvents.utils.isMobile()) {
			// mobile devices cannot listen for play event
			OKEvents.v.onPlay(playerV);
		} else {
			playerV.addEvent('play', OKEvents.v.onPlay(playerV));
			playerV.addEvent('pause', OKEvents.v.onPause);
			playerV.addEvent('finish', OKEvents.v.onFinish);
		}
		if (options.time != null) {
			playerV.api('seekTo', (options.time).replace('t=', ''));
		}

		playerV.api('play');
		jQuery(iframe).css({
			visibility: 'visible',
			opacity: 1
		});
		jQuery(iframe).closest('.uncode-video-container').css('opacity', '1');
		jQuery(iframe).closest('#page-header').addClass('video-started');
		jQuery(iframe).closest('.background-wrapper').find('.block-bg-blend-mode.not-ie').css('opacity', '1');

	});
}
OKEvents = {
	yt: {
		ready: function(event) {
			var id = event.target.videoId;
			youtubePlayers[id] = event.target;
			event.target.setVolume(options.volume);
			if (options.autoplay === 1) {
				if (options.playlist.list) {
					player.loadPlaylist(options.playlist.list, options.playlist.index, options.playlist.startSeconds, options.playlist.suggestedQuality);
				} else {
					var inCarousel = jQuery('#okplayer-' + id).closest('.owl-item');
					if (!inCarousel.length || (inCarousel.length && inCarousel.hasClass('active'))) {
						if (options.time != null) {
							event.target.seekTo(parseInt(options.time));
						}
						event.target.playVideo();
					} else {
						event.target.pauseVideo();
					}
				}
			}
			OKEvents.utils.isFunction(options.onReady) && options.onReady(event.target);
		},
		onStateChange: function(event) {
			var id = event.target.videoId;
			switch (event.data) {
				case -1:
					OKEvents.utils.isFunction(options.unstarted) && options.unstarted();
					break;
				case 0:
					OKEvents.utils.isFunction(options.onFinished) && options.onFinished();
					options.loop && event.target.playVideo();
					break;
				case 1:
					OKEvents.utils.isFunction(options.onPlay) && options.onPlay();
					setTimeout(function() {
						UNCODE.initVideoComponent(document.body, '.uncode-video-container.video, .uncode-video-container.self-video');
						jQuery('#okplayer-' + id).closest('.uncode-video-container').css('opacity', '1');
						jQuery('#okplayer-' + id).closest('#page-header').addClass('video-started');
						jQuery('#okplayer-' + id).closest('.background-wrapper').find('.block-bg-blend-mode.not-ie').css('opacity', '1');
					}, 300);
					break;
				case 2:
					OKEvents.utils.isFunction(options.onPause) && options.onPause();
					break;
				case 3:
					OKEvents.utils.isFunction(options.buffering) && options.buffering();
					break;
				case 5:
					OKEvents.utils.isFunction(options.cued) && options.cued();
					break;
				default:
					throw "OKVideo: received invalid data from YT player.";
			}
		},
		error: function(event) {
			throw event;
		}
	},
	v: {
		onReady: function(target) {
			OKEvents.utils.isFunction(options.onReady) && options.onReady(target);
		},
		onPlay: function(player) {
			if (!OKEvents.utils.isMobile()) player.api('setVolume', options.volume);
			OKEvents.utils.isFunction(options.onPlay) && options.onPlay();
			jQuery(player.element).closest('.uncode-video-container').css('opacity', '1');
			jQuery(player.element).closest('#page-header').addClass('video-started');
			jQuery(player.element).closest('.background-wrapper').find('.block-bg-blend-mode.not-ie').css('opacity', '1');
		},
		onPause: function() {
			OKEvents.utils.isFunction(options.onPause) && options.onPause();
		},
		onFinish: function() {
			OKEvents.utils.isFunction(options.onFinish) && options.onFinish();
		}
	},
	utils: {
		isFunction: function(func) {
			if (typeof func === 'function') {
				return true;
			} else {
				return false;
			}
		},
		isMobile: function() {
			if (navigator.userAgent.match(/(iPhone|iPod|iPad|Android|BlackBerry)/)) {
				return true;
			} else {
				return false;
			}
		}
	}
};
// DOM class helper
(function(window) {
	'use strict';
	// class helper functions from bonzo https://github.com/ded/bonzo
	function classReg(className) {
			return new RegExp("(^|\\s+)" + className + "(\\s+|$)");
		}
		// classList support for class management
		// altho to be fair, the api sucks because it won't accept multiple classes at once
	var hasClass, addClass, removeClass;
	if ('classList' in document.documentElement) {
		hasClass = function(elem, c) {
			if ( elem !== null && typeof elem.classList !== 'undefined' ) return elem.classList.contains(c);
		};
		addClass = function(elem, c) {
			if ( elem !== null && typeof elem.classList !== 'undefined' ) elem.classList.add(c);
		};
		removeClass = function(elem, c) {
			if ( elem !== null && typeof elem.classList !== 'undefined' ) elem.classList.remove(c);
		};
	} else {
		hasClass = function(elem, c) {
			if (elem !== null) return classReg(c).test(elem.className);
		};
		addClass = function(elem, c) {
			if (!hasClass(elem, c)) {
				if (elem !== null) elem.className = elem.className + ' ' + c;
			}
		};
		removeClass = function(elem, c) {
			if (elem !== null) elem.className = elem.className.replace(classReg(c), ' ');
		};
	}

	function toggleClass(elem, c) {
		var fn = hasClass(elem, c) ? removeClass : addClass;
		fn(elem, c);
	}
	var classie = {
		// full names
		hasClass: hasClass,
		addClass: addClass,
		removeClass: removeClass,
		toggleClass: toggleClass,
		// short names
		has: hasClass,
		add: addClass,
		remove: removeClass,
		toggle: toggleClass
	};
	// transport
	if (typeof define === 'function' && define.amd) {
		// AMD
		define(classie);
	} else {
		// browser global
		window.classie = classie;
	}

	window.wrap = function(wrapper, elms) {
		if (!elms.length) {
			elms = [elms];
		}

		for (var i = elms.length - 1; i >= 0; i--) {
			var child = (i > 0) ? wrapper.cloneNode(true) : wrapper;
			var el    = elms[i];

			var parent  = el.parentNode;
			var sibling = el.nextSibling;

			child.appendChild(el);

			if (sibling) {
				parent.insertBefore(child, sibling);
			} else {
				parent.appendChild(child);
			}
		}
	};

	window.wrapAll = function(wrapper, nodes) {
		var parent = nodes[0].parentNode;
		var previousSibling = nodes[0].previousSibling;

		for (var i = 0; nodes.length - i; wrapper.firstChild === nodes[0] && i++) {
			wrapper.appendChild(nodes[i]);
		}

		var nextSibling = previousSibling ? previousSibling.nextSibling : parent.firstChild;
		parent.insertBefore(wrapper, nextSibling);

		return wrapper;
	};
})(window);
/* From Modernizr */
function whichTransitionEvent() {
		var t;
		var el = document.createElement('fakeelement');
		var transitions = {
			'transition': 'transitionend',
			'OTransition': 'oTransitionEnd',
			'MozTransition': 'transitionend',
			'WebkitTransition': 'webkitTransitionEnd'
		}
		for (t in transitions) {
			if (el.style[t] !== undefined) {
				return transitions[t];
			}
		}
	}
function whichAnimationEvent() {
		var t;
		var el = document.createElement('fakeelement');
		var animations = {
			'animation': 'animationend',
			'OAnimation': 'oAnimationEnd',
			'MozAnimation': 'animationend',
			'WebkitAnimation': 'webkitAnimationEnd'
		}
		for (t in animations) {
			if (el.style[t] !== undefined) {
				return animations[t];
			}
		}
	}
/**
 * Load utils - END
 */

/**
 * Start main js
 */
(function(window, undefined) {
	'use strict';

	// Init variables
	var bodyTop,
		scrollbarWidth = false,
		noScroll = false,
		boxEvent = new CustomEvent('boxResized'),
		menuClose = new CustomEvent('menuClose'),
		menuOpen = new CustomEvent('menuOpen'),
		bodyBorder = 0,
		adminBarHeight = 0,
		boxWidth = 0,
		boxLeft = 0,
		parallaxRows,
		parallaxCols,
		parallaxHeaders,
		kenburnsHeaders,
		kenburnsRows,
		kenburnsCols,
		backwashHeaders,
		backwashRows,
		backwashCols,
		visibleRows,
		headerWithOpacity,
		speedDivider = SiteParameters.parallax_factor,
		adminBar,
		pageHeader,
		headerVideo,
		masthead,
		mastheadMobile,
		mastheadMobilePaddingTop = 0,
		maincontainer,
		menuwrapper,
		menuhide,
		menusticky,
		menuHeight = 0,
		menuMobileHeight = 0,
		mainmenu = new Array(),
		secmenu = new Array(),
		secmenuHeight = 0,
		transmenuHeight = 0,
		header,
		transmenuel,
		logo,
		logoel,
		logolink,
		logoMinScale,
		lastScrollValue = 0,
		wwidth = window.innerWidth || document.documentElement.clientWidth,
		wheight = window.innerHeight || document.documentElement.clientHeight,
		boxWrapper,
		docheight = 0,
		isMobile = classie.hasClass(document.documentElement, 'touch') ? true : false,
		isIE = classie.hasClass(document.documentElement, 'ie') || classie.hasClass(document.documentElement, 'opera12') ? true : false,
		isFF = classie.hasClass(document.documentElement, 'firefox') ? true : false,
		isFullPage,
		isFullPageSnap,
		isFrontEndEditor,
		transitionEvent = whichTransitionEvent(),
		animationEvent = whichAnimationEvent(),
		footerScroller = false,
		mediaQuery = 959,
		mediaQueryMobile = 569,
		menuOpened = false,
		overlayOpened = false,
		menuMobileTriggerEvent = new CustomEvent('menuMobileTrigged'),
		resizeTimer_,
		resizeTimer,
		hidingTimer,
		isSplitMenu = false,
		mainNavMenu,
		mainNavWrapper,
		isMobileTransparent = false,
		isMobileParallaxAllowed = SiteParameters.mobile_parallax_allowed,
		loadedFonts = new Array(),
		already_font = false,
		scrollRowHeight_fix = window.pageYOffset,

	checkVisible = function( elm ) {
		var rect = elm.getBoundingClientRect();
		var viewHeight = Math.max(document.documentElement.clientHeight, window.innerHeight);
		return !(rect.bottom < 0 || rect.top - viewHeight >= 0);
	},
	initBox = function() {
			var bodyBorderDiv = document.querySelectorAll('.body-borders .top-border');
			if (bodyBorderDiv.length) {
				bodyBorder = outerHeight(bodyBorderDiv[0]);
			} else bodyBorder = 0;
			UNCODE.isRTL = classie.hasClass(document.body, 'rtl') ? true : false,
			UNCODE.bodyBorder = bodyBorder;
			UNCODE.isFrontEndEditor = classie.hasClass(document.body, 'compose-mode') && classie.hasClass(document.body, 'vc_editor');
			UNCODE.isFullPage = !UNCODE.isFrontEndEditor && classie.hasClass(document.body, 'uncode-fullpage-slide') && !( UNCODE.isMobile && classie.hasClass(document.body, 'uncode-fp-mobile-disable') && window.innerWidth < 570 );
			UNCODE.isFullPageSnap = !UNCODE.isFrontEndEditor && classie.hasClass(document.body, 'uncode-scroll-snap');
			if (bodyBorder != 0) {
				if ( !UNCODE.isFullPage ) {
					document.documentElement.style.paddingTop = bodyBorder + 'px';
				}
				wheight = (window.innerHeight || document.documentElement.clientHeight) - (bodyBorder * 2);
			}
			if (!isMobile && !scrollbarWidth) {
				// 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 (!isMobile) {
				forEachElement('.box-container', function(el, i) {
					if (!classie.hasClass(el, 'limit-width')) {
						var elWidth = outerWidth(el),
							newWidth = 12 * Math.ceil((wwidth - scrollbarWidth) / 12);
						boxWidth = newWidth - (bodyBorder * 2);
						boxLeft = (wwidth - boxWidth - scrollbarWidth) / 2;
						el.style.width = boxWidth + 'px';
						if ( UNCODE.isRTL )
							el.style.marginRight = boxLeft + 'px';
						else
							el.style.marginLeft = boxLeft + 'px';
						if (mainmenu != undefined && mainmenu[0] != undefined) {
							mainmenu[0].style.width = boxWidth + 'px';
						}
					}
				});
			}

			if (classie.hasClass(document.body, 'menu-mobile-transparent')) isMobileTransparent = true;

			if (!isMobileTransparent) {
				if (wwidth > mediaQuery && classie.hasClass(document.body, 'menu-force-opacity')) classie.removeClass(document.body, 'menu-force-opacity');
				if (wwidth < mediaQuery && !classie.hasClass(document.body, 'menu-force-opacity')) classie.addClass(document.body, 'menu-force-opacity');
			}

		},
		fixMenuHeight = function() {
			if (!classie.hasClass(document.body, 'vmenu')) noScroll = true;

			menuwrapper = document.querySelectorAll(".menu-wrapper");
			masthead = document.getElementById("masthead");
			if (classie.hasClass(document.body, 'hmenu-center-split')) {
				mastheadMobile = new Array(document.getElementById("logo-container-mobile"), document.getElementById("main-logo").parentNode);
			} else mastheadMobile = document.getElementById("logo-container-mobile");
			menuhide = document.querySelector('#masthead .menu-hide, .main-header .menu-hide, #masthead .menu-hide-vertical');
			menusticky = document.querySelectorAll('.menu-sticky, .menu-sticky-vertical');
			transmenuel = document.querySelectorAll('.menu-transparent:not(.vmenu-container)');
			var menuItemsButton = document.querySelectorAll('.menu-item-button .menu-btn-table');
			logo = document.querySelector('#main-logo');
			if (logo != undefined) logolink = (logo.firstElementChild || logo.firstChild);
			if (logolink != undefined) logoMinScale = logolink.getAttribute("data-minheight");
			logoel = document.querySelectorAll('.menu-shrink .logo-container');
			mainmenu = document.querySelectorAll('.vmenu .vmenu-container, .menu-primary .menu-container');
			if (classie.hasClass(document.body, 'hmenu-center')) {
				var mainmenucenter = document.querySelectorAll('.hmenu-center .menu-container-mobile');
				var first_array = Array.prototype.slice.call(mainmenu);
				var second_array = Array.prototype.slice.call(mainmenucenter);
				mainmenu = first_array.concat(second_array);
			}
			secmenu = document.querySelectorAll('.menu-secondary');
			calculateMenuHeight(true);
			for (var k = 0; k < menuItemsButton.length; k++) {
				var a_item = menuItemsButton[k].parentNode,
					buttonHeight = outerHeight(menuItemsButton[k]);
				a_item.style.height = buttonHeight + 'px';
			}
			if (classie.hasClass(document.body, 'hmenu-center-split')) {
				mainNavMenu = document.querySelector('#masthead .navbar-main .menu-primary-inner');
				mainNavWrapper = document.querySelector('#masthead > .menu-container');
				isSplitMenu = true;
			}
			fixMenu();
		},
		calculateMenuHeight = function(first) {
			menuHeight = transmenuHeight = secmenuHeight = 0;

			if (mastheadMobile != null) {
				if (mastheadMobile.length === 2) {
					if (wwidth > mediaQuery) {
						UNCODE.menuMobileHeight = outerHeight(mastheadMobile[1]);
						mastheadMobilePaddingTop = parseFloat(getComputedStyle(mastheadMobile[1]).paddingTop);
					} else {
						UNCODE.menuMobileHeight = outerHeight(mastheadMobile[0]);
						mastheadMobilePaddingTop = parseFloat(getComputedStyle(mastheadMobile[0]).paddingTop);
					}
				} else {
					UNCODE.menuMobileHeight = outerHeight(mastheadMobile);
					mastheadMobilePaddingTop = parseFloat(getComputedStyle(mastheadMobile).paddingTop);
				}
			}

			if (wwidth > mediaQuery) {
				for (var i = 0; i < mainmenu.length; i++) {
					if (classie.hasClass(document.body, 'hmenu-center') && i === 1) continue;
					if (!classie.hasClass(masthead, 'masthead-vertical')) {
						menuHeight = menuHeight + outerHeight(mainmenu[i]);
					} else menuHeight = 0;

					if (isIE && first) {
						getDivChildren(mainmenu[i], '.menu-horizontal-inner', function(innerMenu, i) {
							innerMenu.style.height = menuHeight + 'px';
						});
					}

					if (classie.hasClass(mainmenu[i].parentNode, 'menu-transparent')) {
						transmenuHeight += menuHeight;
					}
				}

				for (var j = 0; j < secmenu.length; j++) {
					secmenuHeight += outerHeight(secmenu[j]);
				}
				menuHeight += secmenuHeight;
			} else {
				menuHeight = UNCODE.menuMobileHeight;
				if (isMobileTransparent) {
					for (var i = 0; i < mainmenu.length; i++) {
						if (classie.hasClass(mainmenu[i].parentNode, 'menu-transparent')) {
							transmenuHeight += menuHeight;
						}
					}
				}
				var search_box = document.querySelectorAll('.search-icon .drop-menu');
				for (var i = 0; i < search_box.length; i++) {
					search_box[i].removeAttribute('style');
				}
			}


			if (classie.hasClass(document.documentElement, 'admin-mode')) {
				adminBar = document.getElementById("wpadminbar");
				if (wwidth > 600) {
					if (adminBar != null) adminBarHeight = outerHeight(adminBar);
					else {
						if (wwidth > 782) adminBarHeight = 32;
						else adminBarHeight = 46;
					}
				} else adminBarHeight = 0;
			}
			UNCODE.adminBarHeight = adminBarHeight;
			UNCODE.menuHeight = menuHeight;

			if ( UNCODE.isFullPage && ! UNCODE.isFrontEndEditor ) {
				if ( UNCODE.adminBarHeight > 0 )
					document.body.style.marginTop = ( ( UNCODE.adminBarHeight + UNCODE.bodyBorder ) * -1 ) + 'px';

				document.body.style.paddingTop = ( UNCODE.adminBarHeight + UNCODE.bodyBorder ) + 'px';
			} else {
				document.body.style.marginTop = 0;
				document.body.style.paddingTop = 0;
			}

			if (masthead != undefined) {
				//masthead.parentNode.style.height = menuHeight + 'px';
				if (classie.hasClass(masthead, 'menu-transparent')) {
					if (wwidth > mediaQuery) masthead.parentNode.style.height = '0px';
				}
			}

			if (typeof menuhide == 'object' && menuhide != null && mainmenu[0] != undefined) {
				var sticky_element = (typeof mainmenu.item === 'undefined' ? ((wwidth > mediaQuery) ? mainmenu[0] : mainmenu[1]) : mainmenu[0]);
				if (sticky_element.style.top != '') {
					sticky_element.style.top = UNCODE.bodyBorder + 'px'
				}
			}

		},
		centerSplitMenu = function() {
			if (wwidth > mediaQuery && mainNavMenu) {
				if (mainNavMenu.style.left == '') {
					mainNavMenu.style.left = '0px';
					var logoPos = logo.parentNode.getBoundingClientRect();
					mainNavMenu.style.left = (wwidth / 2) - (logoPos.left + (logoPos.width / 2) ) + 'px';
					mainNavWrapper.style.opacity = '1';
				}
				mainNavWrapper.style.opacity = '1';
			}
		},
		initHeader = function() {
			UNCODE.adaptive();
			headerHeight('.header-wrapper');

			parallaxHeaders = document.querySelectorAll('.header-parallax > .header-bg-wrapper');
			header = document.querySelectorAll('.header-wrapper.header-uncode-block, .header-wrapper.header-revslider, .header-wrapper.header-layerslider, .header-basic .header-wrapper, .header-uncode-block > .row-container:first-child > .row > .row-inner > .col-lg-12 > .uncol, .header-uncode-block .uncode-slider .owl-carousel > .row-container:first-child .column_child .uncoltable');
			headerWithOpacity = document.querySelectorAll('.header-scroll-opacity');
			pageHeader = document.getElementById("page-header");
			if ( typeof pageHeader === 'object' && pageHeader !== null  ) {
				headerVideo = pageHeader.querySelectorAll('.uncode-video-container');
				kenburnsHeaders = pageHeader.querySelectorAll('.with-kburns > .header-bg-wrapper');
				backwashHeaders = pageHeader.querySelectorAll('.with-zoomout > .header-bg-wrapper');
				if ( headerVideo.length ) {
					classie.addClass(pageHeader, 'has-video');
				}
			}
			if (pageHeader != undefined) {
				var backs = pageHeader.querySelectorAll('.header-bg'),
					backsCarousel = pageHeader.querySelectorAll('.header-uncode-block .background-inner'),
					uri_pattern = /\b((?:[a-z][\w-]+:(?:\/{1,3}|[a-z0-9%])|www\d{0,3}[.]|[a-z0-9.\-]+[.][a-z]{2,4}\/)(?:[^\s()<>]+|\(([^\s()<>]+|(\([^\s()<>]+\)))*\))+(?:\(([^\s()<>]+|(\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:'".,<>?«»“”‘’]))/ig;
				if (backs.length == 0 && backsCarousel.length == 0) {
					pageHeader.setAttribute('data-imgready', 'true');
				} else {
					if (backsCarousel.length) {
						for (var j = 0; j < backsCarousel.length; j++) {
							if (j == 0) {
								if (!!backsCarousel[j].style.backgroundImage && backsCarousel[j].style.backgroundImage !== void 0) {
									var url = (backsCarousel[j].style.backgroundImage).match(uri_pattern),
										image = new Image();
									image.onload = function() {
										pageHeader.setAttribute('data-imgready', 'true');
									};
									image.src = url[0];
								} else {
									pageHeader.setAttribute('data-imgready', 'true');
								}
							}
						}
					} else {
						for (var i = 0; i < backs.length; i++) {
							if (i == 0) {
								if (!!backs[i].style.backgroundImage && backs[i].style.backgroundImage !== void 0) {
									var url = (backs[i].style.backgroundImage).match(uri_pattern),
										image = new Image();
									image.onload = function() {
										pageHeader.setAttribute('data-imgready', 'true');
									};
									image.src = url[0];
								} else {
									pageHeader.setAttribute('data-imgready', 'true');
								}
							}
						}
					}
				}
			}

			if (masthead != undefined && !classie.hasClass(masthead, 'masthead-vertical')) {
				if (header.length) {
					masthead.parentNode.style.height = menuHeight + 'px';
					if (menuwrapper[0] != undefined) classie.addClass(menuwrapper[0], 'with-header');
					for (var j = 0; j < header.length; j++) {
						var headerel = header[j],
							closestStyle = getClosest(headerel, 'style-light');
						if (closestStyle != null && classie.hasClass(closestStyle, 'style-light')) {
							switchColorsMenu(0, 'light');
						} else if (getClosest(headerel, 'style-dark') != null) {
							switchColorsMenu(0, 'dark');
						}
						else {
							if (masthead.style.opacity !== 1) masthead.style.opacity = 1;
						}
						if (classie.hasClass(masthead, 'menu-transparent')) {
							if (isMobileTransparent || wwidth > mediaQuery) {
								masthead.parentNode.style.height = '0px';
								if (classie.hasClass(masthead, 'menu-add-padding')) {
									var headerBlock = getClosest(headerel, 'header-uncode-block');
									if (headerBlock != null) {
										var innerRows = headerel.querySelectorAll('.column_parent > .uncol > .uncoltable > .uncell > .uncont, .uncode-slider .column_child > .uncol > .uncoltable > .uncell > .uncont');
										for (var k = 0; k < innerRows.length; k++) {
											if (innerRows[k] != undefined) {
												if (wwidth > mediaQuery) innerRows[k].style.paddingTop = transmenuHeight + 'px';
												else innerRows[k].style.paddingTop = (transmenuHeight - mastheadMobilePaddingTop) + 'px';
											}
										}
									} else {
										getDivChildren(headerel, '.header-content', function(headerContent, i) {
											if (wwidth > mediaQuery) headerContent.style.paddingTop = transmenuHeight + 'px';
											else headerContent.style.paddingTop = (transmenuHeight - mastheadMobilePaddingTop) + 'px';
										});
									}
								}
							}
						}
						if (classie.hasClass(headerel, 'uncoltable')) {
							break;
						}
					}
				} else {
					if (menuwrapper[0] != undefined) classie.addClass(menuwrapper[0], 'no-header');
					classie.removeClass(masthead, 'menu-transparent');
					transmenuHeight = 0;
					isMobileTransparent = false;
				}
			} else {
				isMobileTransparent = false;
			}
			if (typeof transmenuel === 'undefined' || !transmenuel.length) isMobileTransparent = false;
			bodyTop = document.documentElement['scrollTop'] || document.body['scrollTop'];
			UNCODE.bodyTop = bodyTop;
			if (!classie.hasClass(document.body, 'vmenu'))
				initBox();
			scrollFunction();
			showHideScrollup(bodyTop);

			if ( UNCODE.isMobile ) {

				var eventName = 'loadedmetadata';
				eventName = eventName.replace(/^on/, '');
				var elt = document.createElement('video'[eventName]);
				var eventIsSupported = ('on'+eventName in elt);
				elt = null;
				if ( ! eventIsSupported) {
					classie.addClass(document.body, 'video-not-supported');
				}
			}
		},
		initRow = function(currentRow) {
			UNCODE.adaptive();
			var el = typeof currentRow.parentNode !== 'undefined' && currentRow.parentNode.parentNode.getAttribute("data-parent") == 'true' ? currentRow.parentNode : ( currentRow.getAttribute("data-parent") == 'true' ? currentRow.querySelector('.row-parent') : currentRow.parentNode.parentNode ),
				rowParent = el.parentNode,
				rowInner = currentRow.parentNode,
				percentHeight = el.getAttribute("data-height-ratio"),
				minHeight = el.getAttribute("data-minheight"),
				calculateHeight,
				calculatePadding = 0,
				isHeader = false,
				isFirst = false,
				uri_pattern = /\b((?:[a-z][\w-]+:(?:\/{1,3}|[a-z0-9%])|www\d{0,3}[.]|[a-z0-9.\-]+[.][a-z]{2,4}\/)(?:[^\s()<>]+|\(([^\s()<>]+|(\([^\s()<>]+\)))*\))+(?:\(([^\s()<>]+|(\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:'".,<>?«»“”‘’]))/ig;

			/** Add class to the row when contains responsive column size */
			getDivChildren(el.parentNode, '.column_parent, .column_child', function(obj, i, total) {
				if ((obj.className).indexOf("col-md-") > - 1) {
					classie.addClass(obj.parentNode, 'cols-md-responsive');
				}
				obj.className = obj.className.replace(/vc_col-sm-(\d{1,2})/g, "");
				if ((obj.className).indexOf("col-sm-") > - 1 && (obj.className).indexOf("col-sm-clear") == - 1) {
					classie.addClass(obj.parentNode, 'cols-sm-responsive');
				}
			});

			setRowHeight(el);

			var elements = 0;
			getDivChildren(el, '.row-internal .background-inner', function(obj, i, total) {
				elements++;
				if (i == 0) {
					if (!!obj.style.backgroundImage && obj.style.backgroundImage !== void 0) {
						var url = (obj.style.backgroundImage).match(uri_pattern),
							image = new Image();
						image.onload = function() {
							el.setAttribute('data-imgready', 'true');
							el.dispatchEvent(new CustomEvent('imgLoaded'));
						};
						image.src = url[0];
					} else {
						el.setAttribute('data-imgready', 'true');
						el.dispatchEvent(new CustomEvent('imgLoaded'));
					}
				}
			});
			if (elements == 0) {
				el.setAttribute('data-imgready', 'true');
			}

			/** init parallax is not mobile */
			if ( ! UNCODE.isFullPage ) {
				bodyTop = document.documentElement['scrollTop'] || document.body['scrollTop'];
				kenburnsRows = el.parentNode.parentNode.querySelectorAll('.with-kburns > .row-background > .background-wrapper, .with-kburns > .fp-tableCell > .row-background > .background-wrapper, .with-kburns > .fp-tableCell > .fp-scrollable > .fp-scroller > .row-background > .background-wrapper');
				kenburnsCols = el.querySelectorAll('.with-kburns > .column-background > .background-wrapper');
				backwashRows = el.parentNode.parentNode.querySelectorAll('.with-zoomout > .row-background > .background-wrapper, .with-zoomout > .fp-tableCell > .row-background > .background-wrapper, .with-zoomout > .fp-tableCell > .fp-scrollable > .fp-scroller > .row-background > .background-wrapper');
				backwashCols = el.querySelectorAll('.with-zoomout > .column-background > .background-wrapper');
				if (isMobileParallaxAllowed || !UNCODE.isMobile) {
					parallaxRows = el.parentNode.parentNode.querySelectorAll('.with-parallax > .row-background > .background-wrapper, .with-parallax > .fp-tableCell > .row-background > .background-wrapper, .with-parallax > .fp-tableCell > .fp-scrollable > .fp-scroller > .row-background > .background-wrapper');
					parallaxCols = el.querySelectorAll('.with-parallax > .column-background > .background-wrapper');
					visibleRows = el.parentNode.parentNode;
					parallaxRowCol(bodyTop);
					visibleRowCol(bodyTop);
				} else {
					if (UNCODE.isMobile) {
						kenburnsHeader(bodyTop);
						kenburnsRowCol(bodyTop);
						backwashHeader(bodyTop);
						backwashRowCol(bodyTop);
					}
				}
			}

			shapeDivider();

			var wrapLinesWw = wwidth;

			//Text animation, automatic lines and highlights
			var setWrap;

			function word_for_lines(event, $parent_el){

				if ( typeof $parent_el === 'undefined' || $parent_el === null ) {
					$parent_el = document.body;
				}

				var $headings = $parent_el.querySelectorAll('.heading-text');

				for (var head_k = 0; head_k < $headings.length; head_k++) {
					var $heading = $headings[head_k],
						heading_cont = $heading.innerHTML,
						$row = $heading.closest('.row-parent'),
						$owl_carousel = $heading.closest('.owl-carousel-wrapper'),
						$owl_item = $heading.closest('.owl-item'),
						$words = $heading.querySelectorAll('.split-word'),
						setWrap;

					if ( ! $words.length ) {
						if ( $owl_item !== null )
							continue;
					}

					if ( $owl_carousel === null && typeof event !== 'undefined' && event !== 'resize' && event !== false ) {
						continue;
					}

					if ( $owl_carousel !== null ) {
						if (
							( $owl_item === null )
							||
							( $owl_item !== null && classie.hasClass($owl_item, 'active') && $owl_item.getAttribute('data-index') !== '1' )
							||
							( $owl_item !== null && classie.hasClass($owl_item, 'active') && $owl_item.getAttribute('data-index') === '1' && $owl_item.getAttribute('data-already-reached') === 'true' )
						) {
							continue;
						}
					}

					$heading.innerHTML = heading_cont;
					$words = $heading.querySelectorAll('.split-word');
					var lineArray = [],
						lineIndex = 0,
						lineStart = true,
						lineEnd = false,
						$text_highlight = $heading.querySelectorAll('.heading-text-highlight'),
						$line_wraps = $heading.querySelectorAll('.heading-line-wrap');

					if ( $line_wraps.length && typeof event === 'undefined' ) {
						continue;
					}

					var lettering = function(){
						var $wraps = $parent_el.querySelectorAll('.animate_inner_when_almost_visible.curtain, .animate_inner_when_almost_visible.curtain-words, .animate_inner_when_almost_visible.typewriter, .animate_inner_when_almost_visible.single-curtain, .animate_inner_when_almost_visible.single-slide, .animate_inner_when_almost_visible.single-slide-opposite');

						for (var i = 0; i < $wraps.length; i++) {
							var $wrap = $wraps[i],
								$lines = $wrap.querySelectorAll('.heading-line-wrap'),
								$words =  $wrap.querySelectorAll('.split-word'),
								containerDelay = $wrap.getAttribute('data-delay'),
								containerSpeed = $wrap.getAttribute('data-speed'),
								containerSpeed_val = typeof containerSpeed !== 'undefined' && containerSpeed !== null ? parseFloat(containerSpeed) : 400,
								containerInterval = typeof $wrap.getAttribute('data-interval') !== 'undefined' && $wrap.getAttribute('data-interval') !== null ? $wrap.getAttribute('data-interval') : 0,
								delayAttr = (containerDelay != undefined) ? containerDelay : 0;

							if ( classie.hasClass($wrap, 'already-animated') ) {
								continue;
							}

							if ( classie.hasClass($wrap, 'curtain') ) {

								for (var il = 0; il < $lines.length; il++) {
									var $line = $lines[il],
										$spans = $line.querySelectorAll('.split-word-inner');

									for (var is = 0; is < $spans.length; is++) {

										var $span = $spans[is];

										$span.setAttribute('data-delay', ( parseFloat(delayAttr) + ( ( parseFloat(containerInterval) + 100 ) * il ) ) );

										if (typeof containerSpeed_val !== 'undefined' ) {
											$span.setAttribute('data-speed', containerSpeed_val);
										}

										classie.addClass($span, 'animate_when_parent_almost_visible');
										classie.addClass($span, 'text-bottom-t-top');

										if ( is+1 === $spans.length && il+1 === $lines.length ) {
											classie.addClass($span, 'anim-tot-checker');
										}
									}

								}

							} else if ( classie.hasClass($wrap, 'single-curtain') ) {

								var $spans = $wrap.querySelectorAll('.split-char');

								for (var is = 0; is < $spans.length; is++) {
									var $span = $spans[is];

									$span.setAttribute('data-delay', ( parseFloat(delayAttr) + ( ( parseFloat(containerInterval) + 20 ) * is ) ) );

									if (typeof containerSpeed_val !== 'undefined' ) {
										$span.setAttribute('data-speed', containerSpeed_val);
									}

									classie.addClass($span, 'animate_when_parent_almost_visible');
									classie.addClass($span, 'text-bottom-t-top');

									if ( is+1 == $spans.length ) {
										classie.addClass($span, 'anim-tot-checker');
									}
								};

							} else if ( classie.hasClass($wrap, 'typewriter') ) {

								var $spans = $wrap.querySelectorAll('.split-char');

								for (var is = 0; is < $spans.length; is++) {
									var $span = $spans[is];

									$span.setAttribute('data-delay', ( parseFloat(delayAttr) + ( ( parseFloat(containerInterval) + 20 ) * is ) ) );

									if (typeof containerSpeed_val !== 'undefined' ) {
										$span.setAttribute('data-speed', containerSpeed_val);
									}

									classie.addClass($span, 'animate_when_parent_almost_visible');
									classie.addClass($span, 'typewriter');

									if ( is+1 == $spans.length ) {
										classie.addClass($span, 'anim-tot-checker');
									}

								}

							} else if ( classie.hasClass($wrap, 'single-slide') ) {

								var $spans = $wrap.querySelectorAll('.split-word-inner');

								for (var is = 0; is < $spans.length; is++) {
									var $span = $spans[is];

									$span.setAttribute('data-delay', ( parseFloat(delayAttr) + ( ( parseFloat(containerInterval) + 50 ) * is ) ) );

									if (typeof containerSpeed_val !== 'undefined' ) {
										$span.setAttribute('data-speed', containerSpeed_val);
									}

									classie.addClass($span, 'animate_when_parent_almost_visible');
									if ( classie.hasClass(document.body, 'rtl') ) {
										classie.addClass($span, 'text-left-t-right');
									} else {
										classie.addClass($span, 'text-right-t-left');
									}

									if ( is+1 == $spans.length ) {
										classie.addClass($span, 'anim-tot-checker');
									}
								}

							} else if ( classie.hasClass($wrap, 'single-slide-opposite') ) {

								var $spans = $wrap.querySelectorAll('.split-word-inner');

								for (var is = 0; is < $spans.length; is++) {
									var $span = $spans[is];

									$span.setAttribute('data-delay', ( parseFloat(delayAttr) + ( ( parseFloat(containerInterval) + 50 ) * is ) ) );

									if (typeof containerSpeed_val !== 'undefined' ) {
										$span.setAttribute('data-speed', containerSpeed_val);
									}

									classie.addClass($span, 'animate_when_parent_almost_visible');
									if ( classie.hasClass(document.body, 'rtl') ) {
										classie.addClass($span, 'text-left-t-right');
									} else {
										classie.addClass($span, 'text-right-t-left');
									}

									if ( is+1 == $spans.length ) {
										classie.addClass($span, 'anim-tot-checker');
									}
								}

							} else if ( classie.hasClass($wrap, 'curtain-words') ) {

								var $spans = $wrap.querySelectorAll('.split-word-inner');

								for (var is = 0; is < $spans.length; is++) {
									var $span = $spans[is];

									$span.setAttribute('data-delay', ( parseFloat(delayAttr) + ( ( parseFloat(containerInterval) + 50 ) * is ) ) );

									if (typeof containerSpeed_val !== 'undefined' ) {
										$span.setAttribute('data-speed', containerSpeed_val);
									}

									classie.addClass($span, 'animate_when_parent_almost_visible');
									classie.addClass($span, 'text-bottom-t-top');

									if ( is+1 == $spans.length ) {
										classie.addClass($span, 'anim-tot-checker');
									}
								}
							}

						}
					}

					var removeOldLines = function(){

						for (var wrap_k = 0; wrap_k < $line_wraps.length; wrap_k++) {
							var $line_wrap = $line_wraps[wrap_k];
							var $parent_wrap = $line_wrap.parentNode;
							while ( $line_wrap.firstChild ) {
								$parent_wrap.insertBefore($line_wrap.firstChild, $line_wrap);
							}
							$parent_wrap.removeChild($line_wrap);
						}

					}

					var createHighlightSpans = function(){
						for (var high_k = 0; high_k < $text_highlight.length; high_k++) {
							var $highlight = $text_highlight[high_k],
								atts = $highlight.getAttribute('data-atts'),
								objAtts,
								styleEl = '',
								classEl = '',
								animation = false,
								hexRe = /(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i,
								$h_words = $highlight.querySelectorAll('.split-word');

							if ( typeof atts !== 'undefined' && atts != '' ) {
								objAtts = JSON.parse(atts);
								if ( typeof objAtts.bg != 'undefined' ) {
									if ( hexRe.test(objAtts.bg)) {
										styleEl += 'background-color:' + objAtts.bg + ';';
									} else {
										classEl += ' ' + objAtts.bg;
									}
								}
								if ( typeof objAtts.color != 'undefined' ) {
									if ( hexRe.test(objAtts.color)) {
										styleEl += 'color:' + objAtts.color + ';';
									} else {
										var classChild = objAtts.color;
									}
								}
								if ( typeof objAtts.height != 'undefined' ) {
									styleEl += 'height:' + objAtts.height + ';';
								}
								if ( typeof objAtts.offset != 'undefined' ) {
									styleEl += 'bottom:' + objAtts.offset + ';';
								}
								if ( typeof objAtts.opacity != 'undefined' ) {
									styleEl += 'opacity:' + objAtts.opacity + ';';
								}
								if ( objAtts.animated == 'yes' ) {
									animation = true;
								}

							}

							for (var h_words_k = 0; h_words_k < $h_words.length; h_words_k++) {
								var $word = $h_words[h_words_k],
									$new_el = document.createElement('span');

								if ( typeof classChild !== 'undefined' ) {
									classie.addClass($word, objAtts.color);
								}

								if ( h_words_k === 0 ) {
									classie.addClass($word, 'first-highlight');
								} else if ( (h_words_k+1) === $h_words.length ) {
									classie.addClass($word, 'last-highlight');
								}

								$new_el.className = 'heading-text-highlight-inner' + classEl;
								if ( styleEl !== '' ) {
									$new_el.setAttribute('style', styleEl);
								}

								if ( animation ) {
									$new_el.setAttribute('data-animated', 'yes');
								}

								$word.appendChild($new_el);

							};

							var $parent_highlight = $highlight.parentNode;
							while ( $highlight.firstChild ) {
								$parent_highlight.insertBefore($highlight.firstChild, $highlight);
							}
							$parent_highlight.removeChild($highlight);

						}

					}

					var createNewLines = function(){
						for (var word_k = 0; word_k < $words.length; word_k++) {
							var $word = $words[word_k],
								top = $word.offsetTop,
								elH = $word.offsetHeight,
								$next = typeof $words[(word_k+1)] !== 'undefined' ? $words[(word_k+1)] : null,
								nextTop = $next !== null ? $next.offsetTop : null;

							if (lineStart) {
								lineArray[lineIndex] = [word_k];

								if (nextTop !== null && nextTop > (top + elH/2)) {
									lineArray[lineIndex].push(word_k);
									lineIndex++;
									lineStart = true;
								} else {
									lineStart = false;
								}
							} else {
								if (nextTop !== null && nextTop > (top + elH/2)) {//tollerance
									lineArray[lineIndex].push(word_k);
									lineIndex++;
									lineStart = true;
								} else if ( nextTop === null ) {
									lineArray[lineIndex].push(word_k);
								}
							}
						}

						for (var i = 0; i < lineArray.length; i++) {
							var start = lineArray[i][0],
								end = lineArray[i][1] + 1;

							var spanWrap = document.createElement('span');
							spanWrap.className = 'heading-line-wrap';

							if (!end) {
								window.wrap(spanWrap, $words[start]);
							} else {
								for (var _i = start; _i < end; _i++) {
									if ( typeof $words[_i] !== 'undefined' && $words[_i] !==  null ) {
										classie.addClass($words[_i], 'heading-temp');
										$words[_i].style.zIndex = end - _i;
									}
								}
								var $towrap = $heading.querySelectorAll('.heading-temp');
								if ( typeof $towrap[0] !== 'undefined' && $towrap[0] !==  null ) {
									window.wrapAll(spanWrap, $towrap);
									for (var _i = 0; _i < $towrap.length; _i++) {
										classie.removeClass($towrap[_i], 'heading-temp');
									}
								}
							}

							if ( (i+1) == lineArray.length ) {
								classie.addClass($row, 'loaded-split-word');
							}

							classie.addClass($heading, 'heading-lined');
						}
						lettering();

					}

					removeOldLines();
					createHighlightSpans();
					createNewLines();

					$parent_el.addEventListener("owl-carousel-changed", function() {
						removeOldLines();
						createHighlightSpans();
						createNewLines();
					});

					if ( event !== 'resize' ) {
						document.body.dispatchEvent(new CustomEvent('uncode_waypoints'));
					}

				}
			}

			var $h_markup = document.body.querySelectorAll('.font-obs'),
				fontArr = new Array();

			for (var i = 0; i < $h_markup.length; i++) {
				var font_to_check = $h_markup[i].getAttribute("data-font");

				if ( font_to_check === null ) {
					word_for_lines(false, el);
				} else {
					var font_weight = $h_markup[i].getAttribute("data-weight");
					var font_style = $h_markup[i].getAttribute("data-style");

					if ( font_weight === null ) {
						font_weight = 'normal';
					}

					if ( font_style === null ) {
						font_style = 'normal';
					}

					font_to_check = font_to_check.split(',');

					var font_val = font_to_check[0].replace(/['"]+/g, ''),
						font_key = '\''+font_val+'_'+font_weight+'_'+font_style+'\'';

					if ( fontArr.indexOf( font_val+'_'+font_weight ) === -1  ) {
						fontArr[font_key] = {'family':font_val,'weight':font_weight,'style':font_style };
					}
				}
			}

			var counter = 0;

			for (var key in fontArr) {
				if (fontArr.hasOwnProperty(key)) {
					var font = new FontFaceObserver(fontArr[key].family, { weight: fontArr[key].weight, style: fontArr[key].style } );

					font.load(null, 10000).then(function (font) {
						counter++;
						if ( counter == Object.keys(fontArr).length ) {
							already_font = true;
							requestTimeout(function(){
								word_for_lines(false, el);
							}, 10);
						}
					}, function (error) {
						word_for_lines(false, el);
					});
				}
			}

			el.addEventListener("owl-carousel-initialized", function() {
				word_for_lines("owl-carousel-initialized", el);
			});

			el.addEventListener("vc-shortcodeView-updated", function() {
				word_for_lines(false, el);
			});

			window.addEventListener("resize", function() {
				if ( wwidth != wrapLinesWw ) {
					clearRequestTimeout(setWrap);
					setWrap = requestTimeout( function(){
						wrapLinesWw = wwidth;
						word_for_lines('resize');
					}, 100 );
				}
			});

			scrollFunction();

			if ( uaInfo.is('chrome') ) {

				var videos = document.querySelectorAll('.wp-video-shortcode');
				for (var i = 0; i < videos.length; i++) {
					var video = videos[i];
					if ( typeof video.getAttribute('autoplay') !== 'undefined' && video.getAttribute('autoplay') !== null && ( typeof video.getAttribute('muted') === 'undefined' || video.getAttribute('muted') === null )  ) {
						video.oncanplay = function(e) {
							video.muted = true;
							video.play();
						};
						break;
					}
				}

			}
		},
		setRowHeight = function(container, forced, resized) {
			var currentTallest = 0,
				percentHeight = 0,
				minHeight = 0,
				el,
				child,
				hasSubCols = false;
			if (container.length == undefined) {
				container = [container];
			}
			// Loop for each container element to match their heights
			for (var i = 0; i < container.length; i++) {
				var el = container[i],
					$row = el,
					totalHeight = 0,
					colsArray = new Array(),
					calculatePadding = 0,
					$rowParent = $row.parentNode,
					isHeader = false,
					isFirst = false;
				$row.oversized = false;
				percentHeight = el.getAttribute("data-height-ratio");
				minHeight = el.getAttribute("data-minheight");
				child = (el.firstElementChild || el.firstChild);
				var childHeight = outerHeight(child);
				/** window height without header **/
				if (!!percentHeight || !!minHeight || forced || (isIE && classie.hasClass(el, 'unequal')) ) {
					child.style.height = '';
					if (!!percentHeight) {
						if (percentHeight == 'full') {
							currentTallest = parseInt(wheight);
						} else {
							currentTallest = parseInt((wheight * percentHeight) / 100);
						}
					} else {
						currentTallest = el.clientHeight;
					}

					if (!!minHeight) {
						if (currentTallest < minHeight || currentTallest == undefined) currentTallest = parseInt(minHeight);
					}

					if (getClosest(el, 'header-uncode-block') != null) {
						el.setAttribute('data-row-header', 'true');
						isHeader = true;
					} else {
						if (pageHeader == null) {
							var prevRow = $rowParent.previousSibling;
							if (prevRow != null && prevRow.innerText == 'UNCODE.initHeader();') {
								isFirst = true;
							}
						}
					}

					if (classie.hasClass(el, 'row-slider')) {
						percentHeight = el.getAttribute("data-height-ratio");
						minHeight = el.getAttribute("data-minheight");
						if (percentHeight == 'full') {
							currentTallest = parseInt(wheight);
						} else {
							currentTallest = parseInt((wheight * percentHeight) / 100);
						}

						var computedStyleRow = getComputedStyle(el),
							computedStyleRowParent = getComputedStyle($rowParent);
						calculatePadding -= (parseFloat(computedStyleRow.paddingTop) + parseFloat(computedStyleRowParent.paddingTop));
						calculatePadding -= (parseFloat(computedStyleRow.paddingBottom) + parseFloat(computedStyleRowParent.paddingBottom));

						if (isHeader || isFirst) {
							if (isMobileTransparent || wwidth > mediaQuery) currentTallest -= menuHeight - transmenuHeight;
							else currentTallest -= menuHeight - secmenuHeight;
							currentTallest += calculatePadding;
						} else {
							if (isMobileTransparent || wwidth > mediaQuery) currentTallest += calculatePadding;
							else currentTallest = 'auto';
						}

						getDivChildren(el, '.owl-carousel', function(owl, i) {
							owl.style.height = (currentTallest == 'auto' ? 'auto' : currentTallest + 'px');
							if (isIE) {
								getDivChildren(owl, '.owl-stage', function(owlIn, i) {
									owlIn.style.height = (currentTallest == 'auto' ? '100%' : currentTallest + 'px');
								});
							}
						});
						if ( UNCODE.isFullPageSnap || classie.hasClass(masthead, 'menu-transparent') )
							continue;
						else {
							if ( classie.hasClass(document.body, 'uncode-fp-menu-hide') ) {
								$rowParent.parentNode.style.paddingTop = menuHeight + 'px';
							}
						}
					} else {
						if (isHeader || isFirst || UNCODE.isFullPage ) {
							if ( !( UNCODE.isFullPage && !classie.hasClass(masthead, 'menu-transparent') && classie.hasClass(document.body, 'uncode-fp-menu-hide') && !isHeader && !isFirst ) ) {
								if (isMobileTransparent || wwidth > mediaQuery) currentTallest -= menuHeight - transmenuHeight;
								else currentTallest -= menuHeight - secmenuHeight;
							}
							if ( UNCODE.isFullPage && classie.hasClass(document.body, 'uncode-scroll-safe-padding') && classie.hasClass(masthead, 'menu-transparent') && !classie.hasClass(document.body, 'uncode-fp-menu-hide') ) {
								var safeMenuHeight = parseFloat(document.body.getAttribute("data-additional-padding")) + parseFloat(menuHeight);
								if ( (" " + child.parentNode.className + " ").replace(/[\n\t]/g, " ").indexOf("-top-padding ") < 0 || classie.hasClass(child.parentNode, 'single-top-padding') ) {
									classie.addClass(child.parentNode, 'fp-safe-padding-top');
									child.parentNode.style.paddingTop = safeMenuHeight + 'px';
								}
								if ( (" " + child.parentNode.className + " ").replace(/[\n\t]/g, " ").indexOf("-bottom-padding ") < 0 || classie.hasClass(child.parentNode, 'single-bottom-padding') ) {
									classie.addClass(child.parentNode, 'fp-safe-padding-bottom');
									child.parentNode.style.paddingBottom = safeMenuHeight + 'px';
								}
							}
							if ( !classie.hasClass(masthead, 'menu-transparent') && classie.hasClass(document.body, 'uncode-fp-menu-hide') && ( isFirst || isHeader ) )
								$rowParent.parentNode.style.paddingTop = menuHeight + 'px';

							var computedStyleRow = getComputedStyle(el),
								computedStyleRowParent = getComputedStyle($rowParent);
							calculatePadding -= (parseFloat(computedStyleRow.paddingTop) + parseFloat(computedStyleRowParent.paddingTop));
							calculatePadding -= (parseFloat(computedStyleRow.paddingBottom) + parseFloat(computedStyleRowParent.paddingBottom));

							currentTallest += calculatePadding;

						} else {

							var computedStyleRow = getComputedStyle(el),
								computedStyleRowParent = getComputedStyle($rowParent);
							calculatePadding -= (parseFloat(computedStyleRow.paddingTop) + parseFloat(computedStyleRowParent.paddingTop));
							calculatePadding -= (parseFloat(computedStyleRow.paddingBottom) + parseFloat(computedStyleRowParent.paddingBottom));

							if (wwidth > mediaQuery) currentTallest += calculatePadding;
							else currentTallest = 'auto';

						}
					}
					if ( UNCODE.isFullPage ) {
						currentTallest -= UNCODE.adminBarHeight;
					}
					if (!!minHeight) {
						if (currentTallest < minHeight || currentTallest == 'auto') currentTallest = parseInt(minHeight);
					}

					child.style.height = (currentTallest == 'auto' ? 'auto' : currentTallest + 'px');
				} else {
					currentTallest = 0;
					if ( UNCODE.isFrontEndEditor && child !== null ) {

						child.style.height = '';

						getDivChildren(el, '.owl-carousel', function(owl, i) {
							owl.style.height = '';
							if (isIE) {
								getDivChildren(owl, '.owl-stage', function(owlIn, i) {
									owlIn.style.height = '';
								});
							}
						});
					}
				}

				if (wwidth > mediaQuery) {

					getDivChildren(el, '.column_parent', function(col, i, total) {
						var $col = col,
							$colHeight = 0,
							$colDiff = 0,
							$colPercDiff = 100;
						$col.oversized = false;
						$col.forceHeight = currentTallest;
						currentTallest = child.clientHeight;
						if ((isHeader || isFirst) && currentTallest != 'auto') currentTallest -= transmenuHeight;
						var getFirstCol = null,
						getMargin = 0,
						getSubMargin = 0;
						getDivChildren(col, '.row-child', function(obj, i, total) {
							var $colChild = obj,
								$colParent = $colChild.parentNode,
								computedStyleCol = getComputedStyle($colParent);
							parseFloat(computedStyleCol.marginTop);
							getSubMargin += parseFloat(computedStyleCol.marginTop);
						});
						currentTallest += getSubMargin;
						getDivChildren(col, '.row-child', function(obj, i, total) {
							var $colChild = obj,
								$colInner,
								$colParent = $colChild.parentNode,
								$uncont = $colParent.parentNode;
							for (var it = 0; it < $colChild.childNodes.length; it++) {
								if ( ! classie.hasClass($colChild.childNodes[it], 'uncode-divider-wrap') ) {
									$colInner = $colChild.childNodes[it];
									break;
								}
							}
							if (i == 0 && total > 1) getFirstCol = $colInner;
							$colChild.oversized = false;
							percentHeight = $colChild.getAttribute("data-height");
							minHeight = $colChild.getAttribute("data-minheight");
							if (percentHeight != null || minHeight != null) {
								if ( ! classie.hasClass($colInner, 'uncode-divider-wrap') )
									$colInner.style.height = '';
								$colParent.style.height = 'auto';
								$uncont.style.height = '100%';
								$colChild.removeAttribute("style");
								var newHeight = (percentHeight != null) ? Math.ceil((currentTallest) * (percentHeight / 100)) : parseInt(minHeight);
								var computedStyleCol = getComputedStyle($colParent);
								getMargin = parseFloat(computedStyleCol.marginTop);
								newHeight -= (getMargin);
								$colPercDiff -= (percentHeight != null) ? percentHeight : 0;
								if (currentTallest > newHeight) {
									var getColHeight = outerHeight($colChild);
									if (getColHeight > newHeight) {
										$colHeight += getColHeight;
										$colDiff += getColHeight;
										$colChild.oversized = true;
										$col.oversized = true;
										$row.oversized = true;
									} else {
										$colHeight += newHeight;
										if ( ! classie.hasClass($colInner, 'uncode-divider-wrap') )
											$colInner.style.height = newHeight + 'px';
									}
								}
							} else {
								$colHeight += outerHeight($colChild);
							}
						});
						if (getFirstCol != null) {
							getFirstCol.style.height = (parseFloat(getFirstCol.style.height) - getMargin) + 'px';
						}
						colsArray.push({
							colHeight: $colHeight,
							colDiv: $col
						});
						$col.colDiff = $colDiff;
						$col.colPercDiff = $colPercDiff;
					});

					if ($row.oversized) {
						child.style.height = '';
						colsArray.sort(function(a, b) {
							if (a.colHeight < b.colHeight) return 1;
							if (a.colHeight > b.colHeight) return -1;
							return 0;
						});
						var $totalHeight = 0;
						colsArray.forEach(function(col) {
							var $col = col.colDiv,
								$colHeight = col.colHeight;
							getDivChildren($col, '.row-child', function(obj, i, total) {
								var $colChild = obj,
									$colInner = $colChild.children[0],
									percentHeight = $colChild.getAttribute("data-height"),
									$colParent = $colChild.parentNode,
									$uncont = $colParent.parentNode,
									newHeight;

								$colHeight = $col.forceHeight - $col.colDiff;
								if (percentHeight != null) {
									if ($colHeight > 0) {
										if ($col.oversized) {
											if (!$colChild.oversized) {
												newHeight = Math.ceil(($colHeight) * (percentHeight / $col.colPercDiff));
												if (i == total - 1 && total > 1) {
													$uncont.style.height = 'auto';
													$colChild.style.display = 'none';
													newHeight = outerHeight($col.parentNode) - outerHeight($uncont);
													$uncont.style.height = '100%';
													$colChild.style.display = 'table';
												}
												if (newHeight == 0) newHeight = Math.ceil(($col.forceHeight) * (percentHeight / 100));
												$colInner.style.height = newHeight + 'px';
											}
										} else {
											if ($totalHeight == 0) newHeight = Math.ceil(($colHeight) * (percentHeight / $col.colPercDiff));
											else {
												newHeight = Math.ceil(($totalHeight) * (percentHeight / $col.colPercDiff));
											}
											if (i == total - 1 && total > 1) {
												$uncont.style.height = 'auto';
												$colChild.style.display = 'none';
												newHeight = outerHeight($col.parentNode) - outerHeight($uncont);
												$uncont.style.height = '100%';
												$colChild.style.display = 'table';
											}
											$colInner.style.height = newHeight + 'px';
										}
									} else {
										if ($colChild.oversized) {
											if ($totalHeight == 0) newHeight = Math.ceil(($colHeight) * (percentHeight / $col.colPercDiff));
											else {
												if ($col.colPercDiff == 0) $col.colPercDiff = 100;
												newHeight = Math.ceil(($totalHeight) * (percentHeight / $col.colPercDiff));
											}
											if (i == total - 1 && total > 1) {
												$uncont.style.height = 'auto';
												$colChild.style.display = 'none';
												newHeight = outerHeight($col.parentNode) - outerHeight($uncont);
												$uncont.style.height = '100%';
												$colChild.style.display = 'table';
											}
											$colInner.style.height = newHeight + 'px';
										}
									}
								}
							});
							var uncell = $col.getElementsByClassName('uncell');
							if (uncell[0] != undefined && $totalHeight == 0) $totalHeight = outerHeight(uncell[0]);
						});
					}
					if (isFF) {
						getDivChildren(el, '.uncoltable', function(col, i, total) {
							if (col.style.minHeight != '') {
								col.style.height = '';
							}
						});
					}
					if (resized) {
						getDivChildren(el, '.row-child > .row-inner', function(obj, k, total) {
							if (obj.style.height == '') {
								if (wwidth > mediaQueryMobile) {
									var getStyle = (window.getComputedStyle((obj.parentNode), null)),
									getInnerHeight = (parseInt(obj.parentNode.clientHeight) - parseInt(getStyle.paddingTop) - parseInt(getStyle.paddingBottom));
									obj.style.height = getInnerHeight + 'px';
									//obj.style.marginBottom = '-1px';
								}
							}
						});
						getDivChildren(el, '.row-parent > .row-inner', function(obj, k, total) {
							if (obj.style.height != '') {
								var getStyle = (window.getComputedStyle((obj.parentNode), null)),
								getInnerHeight = (parseInt(obj.parentNode.clientHeight) - parseInt(getStyle.paddingTop) - parseInt(getStyle.paddingBottom)),
								getTempHeight = parseInt(obj.style.height);
								if (getInnerHeight > getTempHeight) {
									obj.style.height = getInnerHeight + 'px';
									//obj.style.marginBottom = '-1px';
								}
							}
						});
					}
				} else {
					if (isFF) {
						getDivChildren(el, '.uncoltable', function(col, i, total) {
							if (col.style.minHeight != '') {
								col.style.height = '';
								col.style.height = outerHeight(col.parentNode) + 'px';
							}
						});
					}
					if (isIE && (wwidth > mediaQueryMobile)) {
						if (child.style.height == 'auto') {
							child.style.height = outerHeight(child) + 'px';
						}
					}
				}
				if (isFF) {
					var sliderColumnFix = document.querySelector('.uncode-slider .row-inner > .column_child:only-child');
					if (sliderColumnFix != null) {
						if (wwidth > mediaQuery) {
							sliderColumnFix.style.setProperty("height", "");
						} else {
							sliderColumnFix.style.setProperty("height", "");
							sliderColumnFix.style.setProperty("height", outerHeight(sliderColumnFix.parentNode) + "px", "important");
						}
					}
				}
			};
			window.scroll(0, scrollRowHeight_fix);
		},
		headerHeight = function(container) {
			forEachElement(container, function(el, i) {
				var getHeight = el.getAttribute("data-height"),
					newHeight = ((wheight * getHeight) / 100);
				if (getHeight != 'fixed' && newHeight != 0) {
					if (isMobileTransparent || wwidth > mediaQuery) newHeight -= menuHeight - transmenuHeight;
					else newHeight -= menuHeight - secmenuHeight;
					el.style.height = newHeight + 'px';
				}
			});
			if (masthead != undefined) {
				masthead.parentNode.style.height = menuHeight + 'px';
				if (header != undefined && header.length) {
					if (classie.hasClass(masthead, 'menu-transparent')) {
						if (isMobileTransparent || wwidth > mediaQuery) {
							masthead.parentNode.style.height = '0px';
							if (classie.hasClass(masthead, 'menu-add-padding')) {
								for (var j = 0; j < header.length; j++) {
									var headerel = header[j];
									var headerBlock = getClosest(headerel, 'header-uncode-block');
									if (headerBlock != null) {
										var innerRows = headerel.querySelectorAll('.column_parent > .uncol > .uncoltable > .uncell > .uncont, .uncode-slider .column_child > .uncol > .uncoltable > .uncell > .uncont');
										for (var k = 0; k < innerRows.length; k++) {
											if (innerRows[k] != undefined) {
												if (wwidth > mediaQuery) innerRows[k].style.paddingTop = transmenuHeight + 'px';
												else innerRows[k].style.paddingTop = (transmenuHeight - mastheadMobilePaddingTop) + 'px';
											}
										}
									} else {
										getDivChildren(headerel, '.header-content', function(headerContent, i) {
											if (wwidth > mediaQuery) headerContent.style.paddingTop = transmenuHeight + 'px';
											else headerContent.style.paddingTop = (transmenuHeight - mastheadMobilePaddingTop) + 'px';
										});
									}
								}
							}
						}
					}
				}
			}
		},
		initVideoComponent = function(container, classTarget) {
			if ( UNCODE.isFrontEndEditor )
				return;
			getDivChildren(container, classTarget, function(el, i) {
				var width = outerWidth(el),
					pWidth, // player width, to be defined
					height = outerHeight(el),
					pHeight, // player height, tbd
					$tubularPlayer = (el.getElementsByTagName('iframe').length == 1) ? el.getElementsByTagName('iframe') : el.getElementsByTagName('video'),
					ratio = (el.getAttribute("data-ratio") != null) ? Number(el.getAttribute("data-ratio")) : typeof $tubularPlayer[0] !== 'undefined' ? $tubularPlayer[0].getAttribute("data-ratio") : '1.8',
					heightOffset = 80,
					widthOffset = heightOffset * ratio;
				// when screen aspect ratio differs from video, video must center and underlay one dimension
				if ($tubularPlayer[0] != undefined) {
					if (width / ratio < height) { // if new video height < window height (gap underneath)
						pWidth = Math.ceil((height + heightOffset) * ratio); // get new player width
						$tubularPlayer[0].style.width = pWidth + widthOffset + 'px';
						$tubularPlayer[0].style.height = height + heightOffset + 'px';
						$tubularPlayer[0].style.left = ((width - pWidth) / 2) - (widthOffset / 2) + 'px';
						$tubularPlayer[0].style.top = '-' + (heightOffset / 2) + 'px';
						$tubularPlayer[0].style.position = 'absolute';
					} else { // new video width < window width (gap to right)
						pHeight = Math.ceil(width / ratio); // get new player height
						$tubularPlayer[0].style.width = width + widthOffset + 'px';
						$tubularPlayer[0].style.height = pHeight + heightOffset + 'px';
						$tubularPlayer[0].style.left = '-' + (widthOffset / 2) + 'px';
						$tubularPlayer[0].style.top = ((height - pHeight) / 2) - (heightOffset / 2) + 'px';
						$tubularPlayer[0].style.position = 'absolute';
					}
				}
			});
		},
		init_overlay = function() {
			if ( UNCODE.isFrontEndEditor )
				return;
			var triggerButton,
			closeButtons = new Array();
			function toggleOverlay(btn) {
				Array.prototype.forEach.call(document.querySelectorAll('div.overlay'), function(overlay) {
					if (btn.getAttribute('data-area') == overlay.getAttribute('data-area')) {
						var container = document.querySelector('div.' + btn.getAttribute('data-container')),
							inputField = overlay.querySelector('.search-field');
						if (classie.has(overlay, 'open')) {
							window.dispatchEvent(menuClose);
							overlayOpened = false;
							classie.remove(overlay, 'open');
							classie.remove(container, 'overlay-open');
							classie.add(overlay, 'close');
							classie.remove(overlay, 'open-items');
							var onEndTransitionFn = function(ev) {
								if (transitionEvent) {
									if (ev.propertyName !== 'visibility') return;
									this.removeEventListener(transitionEvent, onEndTransitionFn);
								}
								classie.remove(overlay, 'close');
							};
							if (transitionEvent) {
								overlay.addEventListener(transitionEvent, onEndTransitionFn);
							} else {
								onEndTransitionFn();
							}
						} else if (!classie.has(overlay, 'close')) {
							window.dispatchEvent(menuOpen);
							overlayOpened = true;
							classie.add(overlay, 'open');
							classie.add(container, 'overlay-open');
							if (jQuery('body.menu-overlay').length == 0) {
								setTimeout(function() {
									inputField.focus();
								}, 1000);
							}
							setTimeout(function() {
								if (classie.has(overlay, 'overlay-sequential')) classie.add(overlay, 'open-items');
							}, 800);
						}
					}
				});

				if (classie.hasClass(btn, 'search-icon') || classie.hasClass(btn, 'menu-close-search')) return;

				if (classie.hasClass(triggerButton, 'close')) {
					UNCODE.menuOpened = false;
					classie.removeClass(triggerButton, 'close');
					classie.addClass(triggerButton, 'closing');
					Array.prototype.forEach.call(closeButtons, function(closeButton) {
						if (!classie.hasClass(closeButton, 'menu-close-search')) {
							classie.removeClass(closeButton, 'close');
							classie.addClass(closeButton, 'closing');
						}
					});
					setTimeout(function() {
						classie.removeClass(triggerButton, 'closing');
						triggerButton.style.opacity = 1;
						Array.prototype.forEach.call(closeButtons, function(closeButton) {
							if (!classie.hasClass(closeButton, 'menu-close-search')) {
								classie.removeClass(closeButton, 'closing');
								closeButton.style.opacity = 0;
							}
						});
					}, 800);
				} else {
					UNCODE.menuOpened = true;
					triggerButton.style.opacity = 0;
					var getBtnRect = !classie.hasClass(triggerButton, 'search-icon') ? triggerButton.getBoundingClientRect() : null;
					Array.prototype.forEach.call(closeButtons, function(closeButton) {
						if (!classie.hasClass(closeButton, 'menu-close-search')) {
							classie.addClass(triggerButton, 'close');
							if (getBtnRect != null) closeButton.setAttribute('style', 'top:' + getBtnRect.top + 'px; left:'+ getBtnRect.left + 'px !important');
							classie.addClass(closeButton, 'close');
							closeButton.style.opacity = 1;
						}
					});
					window.addEventListener("resize", function() {
						positionCloseBtn(triggerButton, closeButtons);
					});
				}
			}
			function positionCloseBtn(triggerButton, closeButtons){
				var getBtnRect = !classie.hasClass(triggerButton, 'search-icon') ? triggerButton.getBoundingClientRect() : null;
				Array.prototype.forEach.call(closeButtons, function(closeButton) {
					if (!classie.hasClass(closeButton, 'menu-close-search')) {
						if (getBtnRect != null) closeButton.setAttribute('style', 'top:' + getBtnRect.top + 'px; left:'+ getBtnRect.left + 'px !important');
						closeButton.style.opacity = 1;
					}
				});
			}
			(function bindEscape() {
				document.onkeydown = function(evt) {
				evt = evt || window.event;
				var isEscape = false;
				if ("key" in evt) {
				   isEscape = (evt.key == "Escape" || evt.key == "Esc");
				} else {
				  isEscape = (evt.keyCode == 27);
				}
				if (isEscape && overlayOpened) {
				  Array.prototype.forEach.call(closeButtons, function(closeButton) {
				  	if (classie.hasClass(closeButton, 'overlay-close') && classie.hasClass(closeButton, 'menu-button-overlay')) {
				  		closeButton.click();
				  	}
				  });
				}
				};
			})();
			Array.prototype.forEach.call(document.querySelectorAll('.trigger-overlay'), function(triggerBttn) {
				if (UNCODE.menuOpened) return;
				triggerBttn.addEventListener('click', function(e) {
					triggerButton = e.currentTarget;
					if (wwidth < mediaQuery && classie.hasClass(triggerButton, 'search-icon')) {
						return true;
					} else {
						e.stopPropagation();
						if (wwidth > mediaQuery) toggleOverlay(triggerButton);
						else {
							if (classie.addClass(triggerButton, 'search-icon')) return true;
						}
						e.preventDefault();
						return false;
					}
				}, false);
			});
			Array.prototype.forEach.call(document.querySelectorAll('.overlay-close'), function(closeBttn) {
				closeButtons.push(closeBttn);
				closeBttn.addEventListener('click', function(e) {
					if (wwidth > mediaQuery) toggleOverlay(closeBttn);
					e.preventDefault();
					return false;
				}, false);
			});
		},
		/** All scrolling functions - Begin */
		/** Shrink menu **/
		shrinkMenu = function(bodyTop) {
			if ( UNCODE.isFrontEndEditor )
				return;
			var logoShrink,
				offset = 100;
			for (var i = 0; i < logoel.length; i++) {
				if (((secmenuHeight == 0) ? bodyTop > menuHeight : bodyTop > secmenuHeight + offset) && !classie.hasClass(logoel[i], 'shrinked') && (wwidth > mediaQuery)) {
					classie.addClass(logoel[i], 'shrinked');
					if (logoMinScale != undefined) {
						logoShrink = logolink.children;
						Array.prototype.forEach.call(logoShrink, function(singleLogo) {
							singleLogo.style.height = logoMinScale + 'px';
							singleLogo.style.lineHeight = logoMinScale + 'px';
							if (classie.hasClass(singleLogo, 'text-logo')) singleLogo.style.fontSize = logoMinScale + 'px';
						});
					}
					setTimeout(function() {
						calculateMenuHeight(false);
						//window.dispatchEvent(new Event('resize'));
					}, 300);
				} else if ((((secmenuHeight == 0) ? bodyTop == 0 : bodyTop <= secmenuHeight + offset) || (wwidth < mediaQuery)) && classie.hasClass(logoel[i], 'shrinked')) {
					classie.removeClass(logoel[i], 'shrinked');
					if (logoMinScale != undefined) {
						logoShrink = logolink.children;
						Array.prototype.forEach.call(logoShrink, function(singleLogo) {
							singleLogo.style.height = singleLogo.getAttribute('data-maxheight') + 'px';
							singleLogo.style.lineHeight = singleLogo.getAttribute('data-maxheight') + 'px';
							if (classie.hasClass(singleLogo, 'text-logo')) singleLogo.style.fontSize = singleLogo.getAttribute('data-maxheight') + 'px';
						});
					}
					setTimeout(function() {
						calculateMenuHeight(false);
						//window.dispatchEvent(new Event('resize'));
					}, 300);
				}
			}
		},
		/** Switch colors menu **/
		switchColorsMenu = function(bodyTop, style) {
			for (var i = 0; i < transmenuel.length; i++) {
				if (masthead.style.opacity !== 1) masthead.style.opacity = 1;
				if ((secmenuHeight == 0) ? bodyTop > menuHeight / 2 : bodyTop > secmenuHeight) {
					if (classie.hasClass(masthead, 'style-dark-original')) {
						logo.className = logo.className.replace("style-light", "style-dark");
					}
					if (classie.hasClass(masthead, 'style-light-original')) {
						logo.className = logo.className.replace("style-dark", "style-light");
					}
					if (style != undefined) {
						if (style == 'dark') {
							classie.removeClass(transmenuel[i], 'style-light-override');
						}
						if (style == 'light') {
							classie.removeClass(transmenuel[i], 'style-dark-override');
						}
						classie.addClass(transmenuel[i], 'style-' + style + '-override');
					}
				} else {
					if (style != undefined) {
						if (style == 'dark') {
							classie.removeClass(transmenuel[i], 'style-light-override');
						}
						if (style == 'light') {
							classie.removeClass(transmenuel[i], 'style-dark-override');
						}
						classie.addClass(transmenuel[i], 'style-' + style + '-override');
					}
				}
			}
			if (pageHeader != undefined) {
				if (style != undefined) {
					if (classie.hasClass(pageHeader, 'header-style-dark')) {
						classie.removeClass(pageHeader, 'header-style-dark');
					}
					if (classie.hasClass(pageHeader, 'header-style-light')) {
						classie.removeClass(pageHeader, 'header-style-light');
					}
					classie.addClass(pageHeader, 'header-style-' + style);
				}
			}
		},
		/** VisibleRows **/
		visibleRowCol = function(bodyTop) {
			if ( typeof visibleRows == 'object') {
				for (var i = 0; i < visibleRows.length; i++) {
					var section = visibleRows[i],
						sectionHeight = outerHeight(section),
						offSetTop = bodyTop + ( section != null ? section.getBoundingClientRect().top : 0 ),
						offSetPosition = wheight + bodyTop - offSetTop;
					if (offSetPosition > 0 && offSetPosition < (sectionHeight + wheight)) {
						classie.addClass($kenburnsInner[0], 'uncode-scroll-visible');
						visibleRows[i].dispatchEvent(new CustomEvent('enter-row'));
					} else {
						classie.removeClass($kenburnsInner[0], 'uncode-scroll-visible');
						visibleRows[i].dispatchEvent(new CustomEvent('exit-row'));
					}
				}
			}
		},
		/** KenBurns **/
		kenburnsHeader = function(bodyTop) {
			var value;
			if ( typeof kenburnsHeaders == 'object' && kenburnsHeaders.length ) {
				for (var i = 0; i < kenburnsHeaders.length; i++) {
					var section = kenburnsHeaders[i].parentNode,
						sectionHeight = outerHeight(section),
						offSetTop = bodyTop + (section != null ? (classie.hasClass(section.parentNode.parentNode, 'owl-carousel') ? section.parentNode.parentNode.getBoundingClientRect().top : section.getBoundingClientRect().top) : 0),
						offSetPosition = wheight + bodyTop - offSetTop,
						$kenburnsInner = kenburnsHeaders[i].querySelectorAll('.header-bg');
					if (classie.hasClass(kenburnsHeaders[i], 'header-carousel-wrapper')) {
						$kenburnsInner = kenburnsHeaders[i].querySelectorAll('.t-background-cover');
					}
					if (offSetPosition > 0 && offSetPosition < (sectionHeight + wheight)) {
						for (var i = 0; i < $kenburnsInner.length; i++) {
							classie.addClass($kenburnsInner[i], 'uncode-kburns');
							$kenburnsInner[i].dispatchEvent(new CustomEvent('enter-kburns'));
						}
					} else {
						for (var i = 0; i < $kenburnsInner.length; i++) {
							classie.removeClass($kenburnsInner[i], 'uncode-kburns');
							$kenburnsInner[i].dispatchEvent(new CustomEvent('exit-kburns'));
						}
					}
				}
			}
		},
		kenburnsRowCol = function(bodyTop) {
			var value;
			if ( UNCODE.isFrontEndEditor ) {
				kenburnsRows = document.querySelectorAll('.with-kburns > .row-background > .background-wrapper, .with-kburns > .fp-tableCell > .row-background > .background-wrapper, .with-kburns > .fp-tableCell > .fp-scrollable > .fp-scroller > .row-background > .background-wrapper');
			}
			if ( typeof kenburnsRows == 'object' && kenburnsRows.length ) {
				for (var i = 0; i < kenburnsRows.length; i++) {
					var section = kenburnsRows[i].parentNode,
						sectionHeight = outerHeight(section),
						offSetTop = bodyTop + (section != null ? (classie.hasClass(section.parentNode.parentNode, 'owl-carousel') ? section.parentNode.parentNode.getBoundingClientRect().top : section.getBoundingClientRect().top) : 0),
						offSetPosition = wheight + bodyTop - offSetTop,
						$kenburnsInner = kenburnsRows[i].querySelectorAll('.background-inner, .header-bg');
					if (offSetPosition > 0 && offSetPosition < (sectionHeight + wheight)) {
						classie.addClass($kenburnsInner[0], 'uncode-kburns');
						$kenburnsInner[0].dispatchEvent(new CustomEvent('enter-kburns'));
					} else {
						classie.removeClass($kenburnsInner[0], 'uncode-kburns');
						$kenburnsInner[0].dispatchEvent(new CustomEvent('exit-kburns'));
					}
				}
			}
			if ( UNCODE.isFrontEndEditor ) {
				kenburnsCols = document.querySelectorAll('.with-kburns > .column-background > .background-wrapper');
			}
			if ( typeof kenburnsCols == 'object' && kenburnsCols.length ) {
				for (var j = 0; j < kenburnsCols.length; j++) {
					var elm = kenburnsCols[j],
						$kenburnsInner = elm.querySelectorAll('.background-inner');
					if (checkVisible(elm)) {
						classie.addClass($kenburnsInner[0], 'uncode-kburns');
						$kenburnsInner[0].dispatchEvent(new CustomEvent('enter-kburns'));
					} else {
						classie.removeClass($kenburnsInner[0], 'uncode-kburns');
						$kenburnsInner[0].dispatchEvent(new CustomEvent('exit-kburns'));
					}
				}
			}
		},
		/** Zoom Out BackWash **/
		backwashHeader = function(bodyTop) {
			var value;
			var onEndAnimationFn = function(ev){
				if (animationEvent) {
					if (ev.animationName !== 'backwash') {
						return;
					}
					this.removeEventListener(animationEvent, onEndAnimationFn);
				}
				classie.addClass(ev.target, 'uncode-zoomout-already');
			}
			if ( typeof backwashHeaders == 'object' && backwashHeaders.length ) {
				for (var i = 0; i < backwashHeaders.length; i++) {
					var section = backwashHeaders[i].parentNode,
						sectionHeight = outerHeight(section),
						offSetTop = bodyTop + (section != null ? (classie.hasClass(section.parentNode.parentNode, 'owl-carousel') ? section.parentNode.parentNode.getBoundingClientRect().top : section.getBoundingClientRect().top) : 0),
						offSetPosition = wheight + bodyTop - offSetTop,
						$backwashInner = backwashHeaders[i].querySelectorAll('.header-bg');

					if ( classie.hasClass($backwashInner[0], 'uncode-video-container') ) {
						continue;
					}

					if (classie.hasClass(backwashHeaders[i], 'header-carousel-wrapper')) {
						$backwashInner = backwashHeaders[i].querySelectorAll('.t-background-cover');
					}

					if (offSetPosition > 0 && offSetPosition < (sectionHeight + wheight)) {
						for (var i = 0; i < $backwashInner.length; i++) {
							classie.addClass($backwashInner[i], 'uncode-zoomout');
							$backwashInner[i].dispatchEvent(new CustomEvent('enter-zoomout'));
						}
					} else {
						for (var i = 0; i < $backwashInner.length; i++) {
							classie.removeClass($backwashInner[i], 'uncode-zoomout');
							$backwashInner[i].dispatchEvent(new CustomEvent('exit-zoomout'));
						}
					}
					for (var i = 0; i < $backwashInner.length; i++) {
						$backwashInner[i].addEventListener(animationEvent, onEndAnimationFn);
					}
				}
			}
		},
		backwashRowCol = function(bodyTop) {
			var value;
			var onEndAnimationFn = function(ev){
				if (animationEvent) {
					if (ev.animationName !== 'backwash') {
						return;
					}
					this.removeEventListener(animationEvent, onEndAnimationFn);
				}
				classie.addClass(ev.target, 'uncode-zoomout-already');
			}
			if ( UNCODE.isFrontEndEditor ) {
				backwashRows = document.querySelectorAll('.with-zoomout > .row-background > .background-wrapper, .with-zoomout > .fp-tableCell > .row-background > .background-wrapper, .with-zoomout > .fp-tableCell > .fp-scrollable > .fp-scroller > .row-background > .background-wrapper');
			}
			if ( typeof backwashRows == 'object' && backwashRows.length ) {
				for (var i = 0; i < backwashRows.length; i++) {
					var section = backwashRows[i].parentNode,
						sectionHeight = outerHeight(section),
						offSetTop = bodyTop + (section != null ? (classie.hasClass(section.parentNode.parentNode, 'owl-carousel') ? section.parentNode.parentNode.getBoundingClientRect().top : section.getBoundingClientRect().top) : 0),
						offSetPosition = wheight + bodyTop - offSetTop,
						$backwashInner = backwashRows[i].querySelectorAll('.background-inner');

					if ( classie.hasClass($backwashInner[0], 'uncode-video-container') ) {
						continue;
					}

					if (offSetPosition > 0 && offSetPosition < (sectionHeight + wheight) ) {
						classie.addClass($backwashInner[0], 'uncode-zoomout');
						$backwashInner[0].dispatchEvent(new CustomEvent('enter-zoomout'));
					} else {
						classie.removeClass($backwashInner[0], 'uncode-zoomout');
						$backwashInner[0].dispatchEvent(new CustomEvent('exit-zoomout'));
					}
					$backwashInner[0].addEventListener(animationEvent, onEndAnimationFn);
				}

			}
			if ( UNCODE.isFrontEndEditor ) {
				backwashCols = document.querySelectorAll('.with-zoomout > .column-background > .background-wrapper');
			}
			if ( typeof backwashCols == 'object' && backwashCols.length ) {
				for (var j = 0; j < backwashCols.length; j++) {
					var elm = backwashCols[j],
						$backwashInner = elm.querySelectorAll('.background-inner');
					if (checkVisible(elm)) {
						classie.addClass($backwashInner[0], 'uncode-zoomout');
						$backwashInner[0].dispatchEvent(new CustomEvent('enter-zoomout'));
					} else {
						classie.removeClass($backwashInner[0], 'uncode-zoomout');
						$backwashInner[0].dispatchEvent(new CustomEvent('exit-zoomout'));
					}
					$backwashInner[0].addEventListener(animationEvent, onEndAnimationFn);
				}
			}
		},
		/** Parallax Rows **/
		parallaxRowCol = function(bodyTop) {
			var value;
			if ( UNCODE.isFrontEndEditor ) {
				parallaxRows = document.querySelectorAll('.with-parallax > .row-background > .background-wrapper, .with-parallax > .fp-tableCell > .row-background > .background-wrapper, .with-parallax > .fp-tableCell > .fp-scrollable > .fp-scroller > .row-background > .background-wrapper');
			}
			if (typeof parallaxRows == 'object') {
				for (var i = 0; i < parallaxRows.length; i++) {
					var section = parallaxRows[i].parentNode,
						thisHeight = outerHeight(parallaxRows[i]),
						sectionHeight = outerHeight(section),
						offSetTop = bodyTop + (section != null ? (classie.hasClass(section.parentNode.parentNode, 'owl-carousel') ? section.parentNode.parentNode.getBoundingClientRect().top : section.getBoundingClientRect().top) : 0),
						offSetPosition = wheight + bodyTop - offSetTop;
					if (offSetPosition > 0 && offSetPosition < (sectionHeight + wheight)) {
						value = ((offSetPosition - wheight) * speedDivider);
						if (Math.abs(value) < (thisHeight - sectionHeight)) {
							translateElement(parallaxRows[i], Math.floor(value));
						} else {
							translateElement(parallaxRows[i], Math.floor(thisHeight - sectionHeight));
						}
					}
				}
			}
			if ( UNCODE.isFrontEndEditor ) {
				parallaxCols = document.querySelectorAll('.with-parallax > .column-background > .background-wrapper');
			}
			if (typeof parallaxCols == 'object') {
				for (var j = 0; j < parallaxCols.length; j++) {
					var section = parallaxCols[j].parentNode,
						thisHeight = outerHeight(parallaxCols[j]),
						sectionHeight = outerHeight(section),
						offSetTop = bodyTop + (section != null ? section.getBoundingClientRect().top : 0),
						offSetPosition = wheight + bodyTop - offSetTop;
					if (offSetPosition > 0 && offSetPosition < (sectionHeight + wheight)) {
						value = ((offSetPosition - wheight) * speedDivider);
						value *= .8;
						if (Math.abs(value) < (thisHeight - sectionHeight)) {
							translateElement(parallaxCols[j], Math.floor(value));
						} else {
							translateElement(parallaxCols[j], Math.floor(thisHeight - sectionHeight));
						}
					}
				}
			}
		},
		/** Parallax Headers **/
		parallaxHeader = function(bodyTop) {
			var value;
			if (typeof parallaxHeaders == 'object') {
				for (var i = 0; i < parallaxHeaders.length; i++) {
					var section = parallaxHeaders[i].parentNode,
						thisSibling = section.nextSibling,
						thisHeight,
						sectionHeight,
						offSetTop,
						offSetPosition;
					if (classie.hasClass(parallaxHeaders[i], 'header-carousel-wrapper')) {
						getDivChildren(parallaxHeaders[i], '.t-entry-visual-cont', function(item, l, total) {
							thisHeight = outerHeight(item);
							sectionHeight = outerHeight(section);
							offSetTop = bodyTop + section.getBoundingClientRect().top;
							offSetPosition = wheight + bodyTop - offSetTop;
							if (offSetPosition > 0 && offSetPosition < (sectionHeight + wheight)) {
								value = ((offSetPosition - wheight) * speedDivider);
								if (Math.abs(value) < (thisHeight - sectionHeight)) {
									translateElement(item, Math.floor(value));
								}
							}
						});
					} else {
						thisHeight = outerHeight(parallaxHeaders[i]);
						sectionHeight = outerHeight(section);
						offSetTop = bodyTop + section.getBoundingClientRect().top;
						offSetPosition = wheight + bodyTop - offSetTop;
						if (offSetPosition > 0 && offSetPosition < (sectionHeight + wheight)) {
							value = ((offSetPosition - wheight) * speedDivider);
							if (Math.abs(value) < (thisHeight - sectionHeight)) {
								translateElement(parallaxHeaders[i], Math.floor(value));
							}
						}
					}
				}
			}
		},
		/** Header opacity **/
		headerOpacity = function(bodyTop) {
			if ( UNCODE.isFrontEndEditor ) {
				return;
			}
			if (headerWithOpacity && headerWithOpacity.length) {
				var thisHeight = outerHeight(headerWithOpacity[0]);
				if (bodyTop > thisHeight / 8) {
					if (pageHeader != undefined) classie.addClass(pageHeader, 'header-scrolled');
				} else {
					if (pageHeader != undefined) classie.removeClass(pageHeader, 'header-scrolled');
				}
			}
		},
		/** Show hide scroll top arrow **/
		showHideScrollup = function(bodyTop) {
			if ( bodyTop != 0 ) {
				if (bodyTop > wheight || ((bodyTop + wheight) >= docheight) && docheight > 0) {
					classie.addClass(document.body, 'window-scrolled');
					classie.removeClass(document.body, 'hide-scrollup');
					if (footerScroller && footerScroller[0] != undefined) {
						footerScroller[0].style.display = '';
					}
				} else {
					if (classie.hasClass(document.body, 'window-scrolled')) classie.addClass(document.body, 'hide-scrollup');
					classie.removeClass(document.body, 'window-scrolled');
				}
			}
		},
		/** Fix menu **/
		fixMenu = function(){
			if ( UNCODE.isFrontEndEditor )
				return;
			menuwrapper = document.querySelectorAll(".menu-wrapper");
			if ( ! classie.hasClass(document.body, 'vmenu') && UNCODE.isFullPage && !UNCODE.isFullPageSnap && classie.hasClass(document.body, 'uncode-fp-menu-hide') ) {
				menuwrapper = document.querySelector(".menu-wrapper");
				pageHeader = document.getElementById("page-header");
				menuwrapper.style.position = 'fixed';
				menuwrapper.style.zIndex = '5';
			}
		},
		/** Hide Menu **/
		hideMenu = function(bodyTop) {
			if ( UNCODE.isFrontEndEditor )
				return;
			if (UNCODE.menuOpened || bodyTop < 0) return;
			if (classie.hasClass(document.body, 'vmenu')) {
				if (wwidth < mediaQuery) menuhide = document.querySelector('#masthead .menu-hide-vertical');
				else menuhide = null;
			}
			if (classie.hasClass(document.body, 'hmenu-center')) {
				if (wwidth > mediaQuery) menuhide = document.querySelector('#masthead .menu-hide');
				else menuhide = document.querySelector('.menu-container-mobile.menu-hide');
			}
			if (typeof menuhide == 'object' && menuhide != null && mainmenu[0] != undefined) {
				var translate,
				scrollingDown = true;
				/** fix for hmenu-center **/
				var sticky_element = (typeof mainmenu.item === 'undefined' ? ((wwidth > mediaQuery) ? mainmenu[0] : mainmenu[1]) : mainmenu[0]);
				if (lastScrollValue == bodyTop) return;

				if (lastScrollValue > bodyTop) scrollingDown = false;
				else scrollingDown = true;
				lastScrollValue = bodyTop;

				if (!scrollingDown) {
					if (!UNCODE.scrolling) {
						if ((secmenuHeight == 0) ? bodyTop == 0 : bodyTop < secmenuHeight) {
							classie.removeClass(sticky_element.parentNode, 'is_stuck');
							if (classie.hasClass(masthead, 'menu-transparent')) {
								if ((isMobileTransparent || wwidth > mediaQuery) && !classie.hasClass(masthead.parentNode, 'no-header')) masthead.parentNode.style.height = '0px';
							}
							if (wwidth < mediaQuery) sticky_element.style.position = 'fixed';
							else sticky_element.style.position = '';
							hideMenuReset(sticky_element);
							clearTimeout(hidingTimer);
						}

						if (classie.hasClass(menuhide, 'menu-hided')) {
							classie.removeClass(menuhide, 'menu-hided');
							hidingTimer = setTimeout(function() {
								classie.addClass(sticky_element.parentNode, 'is_stuck');
								hideMenuReset(sticky_element);
							}, 400);
						}
					}
				} else {
					if (menusticky.length == 0 && bodyTop < wheight / 3) {
						if (sticky_element.style.position == 'fixed') sticky_element.style.position = '';
					}
					if (bodyTop > wheight / 2) {
						clearTimeout(hidingTimer);
						if (!classie.hasClass(menuhide, 'menu-hided')) {
							classie.addClass(menuhide, 'menu-hided');
							classie.addClass(sticky_element.parentNode, 'is_stuck');
							if (sticky_element.style.position != 'fixed') {
								sticky_element.style.visibility = 'hidden';
								sticky_element.style.position = 'fixed';
								sticky_element.style.top = '0px';
							}
							translateElement(menuhide, -UNCODE.menuMobileHeight - 1);
						}
					}
				}
			}
		},
		hideMenuReset = function(sticky_element) {
			var topOffset = 0;
			if (sticky_element.style.visibility == 'hidden') sticky_element.style.visibility = '';
			if (bodyBorder > 0) topOffset += bodyBorder;
			if (adminBar != null && window.getComputedStyle(adminBar,null).getPropertyValue("position") != 'fixed') adminBarHeight = 0;
			if (adminBarHeight > 0) topOffset += adminBarHeight;
			//sticky_element.style.top = topOffset + 'px';
			if (!classie.hasClass(document.body, 'boxed-width') && boxWidth > 0) sticky_element.style.width = boxWidth + 'px';
			translateElement(menuhide, 0);
		},
		/** Stick Menu **/
		stickMenu = function(bodyTop) {
			if (header && mainmenu[0] != undefined) {
				if (classie.hasClass(mainmenu[0], 'vmenu-container') && wwidth > mediaQuery) return;
				/** fix for hmenu-center **/
				var sticky_element = (typeof mainmenu.item === 'undefined' ? ((isMobileTransparent || wwidth > mediaQuery) ? mainmenu[0] : mainmenu[1]) : mainmenu[0]);
				if ((secmenuHeight == 0 && (isMobileTransparent || wwidth > mediaQuery)) ? bodyTop > (0 + adminBarHeight)  : bodyTop > (secmenuHeight + adminBarHeight)) {
					if (!classie.hasClass(sticky_element.parentNode, 'is_stuck')) {
						classie.addClass(sticky_element.parentNode, 'is_stuck');
						sticky_element.style.position = 'fixed';
						var getAnchorTop = bodyBorder;
						if (adminBar != null && window.getComputedStyle(adminBar,null).getPropertyValue("position") != 'fixed') adminBarHeight = 0;
						if (adminBarHeight > 0) getAnchorTop += adminBarHeight;
						sticky_element.style.top = getAnchorTop + 'px';
						if (!classie.hasClass(document.body, 'boxed-width') && boxWidth > 0) sticky_element.style.width = boxWidth + 'px';
					}
				} else {
					clearTimeout(hidingTimer);
					classie.removeClass(sticky_element.parentNode, 'is_stuck');
					sticky_element.style.position = 'fixed';
					if (isMobileTransparent || wwidth > mediaQuery) sticky_element.style.position = '';
					if (classie.hasClass(document.body, 'hmenu-center')) sticky_element.style.position = 'absolute';
					sticky_element.style.top = '';
				}
			}
		},
		translateElement = function(element, valueY) {
			var translate = 'translate3d(0, ' + valueY + 'px' + ', 0)';
			element.style['-webkit-transform'] = translate;
			element.style['-moz-transform'] = translate;
			element.style['-ms-transform'] = translate;
			element.style['-o-transform'] = translate;
			element.style['transform'] = translate;
		},
		setScrollPosition,
		scrollFunction = function() {
			if ( ! UNCODE.isFullPage ) {
				kenburnsHeader(bodyTop);
				kenburnsRowCol(bodyTop);
				backwashHeader(bodyTop);
				backwashRowCol(bodyTop);
				if (logoel != undefined && logoel.length && !isMobile) shrinkMenu(bodyTop);
				if (menusticky != undefined && menusticky.length) stickMenu(bodyTop);
					hideMenu(bodyTop);
				if (isMobileParallaxAllowed || !isMobile) {
					if (header && menusticky != undefined && menusticky.length)
						switchColorsMenu(bodyTop);
					parallaxRowCol(bodyTop);
					parallaxHeader(bodyTop);
					headerOpacity(bodyTop);
					visibleRowCol(bodyTop);
				}
				clearRequestTimeout(setScrollPosition);
				setScrollPosition = requestTimeout( function(){
					scrollRowHeight_fix = window.pageYOffset;
				}, 100 );
			}
		},
		/** Shape Dividers **/
		shapeDivider = function() {
			var $shape = '.uncode-divider-wrap';

			forEachElement($shape, function($el, i) {
				var elH = parseInt( $el.getAttribute('data-height') ),
					elHunit = $el.getAttribute('data-unit'),
					newEl,
					$parent = $el.parentNode,
					parentH,
					$svg = $el.getElementsByTagName('svg')[0];

				if ( elHunit == 'px' ) {

					switch (true) {
						case (wwidth < 1500 && wwidth >= 1180):
							newEl = elH*0.8;
							break;

						case (wwidth < 1180 && wwidth >= 960):
							newEl = elH*0.65;
							break;

						case (wwidth < 960 && wwidth >= 570):
							newEl = elH*0.5;
							break;

						case (wwidth < 570):
							newEl = elH*0.25;
							break;

						default:
							newEl = elH;
					}

					$el.style.height = newEl + elHunit;
				}


				if ( classie.hasClass($el, 'uncode-divider-preserve-ratio') && ( window.navigator.userAgent.indexOf('MSIE ') !== -1 || window.navigator.userAgent.indexOf('Trident/') !== -1 ) ) {

					$svg.setAttribute('preserveAspectRatio','none');

					var sizes = $svg.getAttribute('viewBox').split(' '),
						svgW = sizes[2],
						svgH = sizes[3],
						newSvgW;

					newSvgW = newEl * ( svgW / svgH );

					$svg.style.width = newSvgW + 'px';

				}
			});
		};
	if (!noScroll && document.body == null) {
		window.addEventListener('scroll', function(e) {
			if ( ! UNCODE.isFullPage ) {
				bodyTop = document.documentElement.scrollTop || document.body.scrollTop;
				scrollFunction();
				showHideScrollup(bodyTop);
			}
		}, false);
	}
	/** All scrolling functions - End */
	/** help functions */
	function getClosest(el, tag) {
		do {
			if (el.className != undefined && el.className.indexOf(tag) > -1) return el;
		} while (el = el.parentNode);
		// not found :(
		return null;
	}

	function outerHeight(el, includeMargin) {
		if (el != null) {
			var height = el.offsetHeight;
			if (includeMargin) {
				var style = el.currentStyle || getComputedStyle(el);
				height += parseInt(style.marginTop) + parseInt(style.marginBottom);
			}
			return height;
		}
	}

	function outerWidth(el, includeMargin) {
			var width = el.offsetWidth;
			if (includeMargin) {
				var style = el.currentStyle || getComputedStyle(el);
				width += parseInt(style.marginLeft) + parseInt(style.marginRight);
			}
			return width;
		}
		// Replicate jQuery .each method
	function forEachElement(selector, fn) {
		var elements = document.querySelectorAll(selector);
		for (var i = 0; i < elements.length; i++) fn(elements[i], i);
	}

	function getDivChildren(containerId, selector, fn) {
		if (containerId !== null) {
			var elements = containerId.querySelectorAll(selector);
			for (var i = 0; i < elements.length; i++) fn(elements[i], i, elements.length);
		}
	}

	function hideFooterScroll() {
		if (classie.hasClass(document.body, 'hide-scrollup')) footerScroller[0].style.display = "none";
	}
	document.addEventListener("DOMContentLoaded", function(event) {
		UNCODE.adaptive();
		boxWrapper = document.querySelectorAll('.box-wrapper');
		docheight = boxWrapper[0] != undefined ? boxWrapper[0].offsetHeight : 0;
		if (!classie.hasClass(document.body, 'vmenu') && !classie.hasClass(document.body, 'menu-offcanvas')) init_overlay();
		kenburnsRows = document.querySelectorAll('.with-kburns > .row-background > .background-wrapper, .with-kburns > .fp-tableCell > .row-background > .background-wrapper, .with-kburns > .fp-tableCell > .fp-scrollable > .fp-scroller > .row-background > .background-wrapper');
		kenburnsCols = document.querySelectorAll('.with-kburns > .column-background > .background-wrapper');
		backwashRows = document.querySelectorAll('.with-zoomout > .row-background > .background-wrapper, .with-zoomout > .fp-tableCell > .row-background > .background-wrapper, .with-zoomout > .fp-tableCell > .fp-scrollable > .fp-scroller > .row-background > .background-wrapper');
		backwashCols = document.querySelectorAll('.with-zoomout > .column-background > .background-wrapper');
		if (!UNCODE.isMobile || isMobileParallaxAllowed) {
			parallaxRows = document.querySelectorAll('.with-parallax > .row-background > .background-wrapper, .with-parallax > .fp-tableCell > .row-background > .background-wrapper, .with-parallax > .fp-tableCell > .fp-scrollable > .fp-scroller > .row-background > .background-wrapper');
			parallaxCols = document.querySelectorAll('.with-parallax > .column-background > .background-wrapper');
		}
		footerScroller = document.querySelectorAll('.footer-scroll-top');
		if (footerScroller && footerScroller[0] != undefined) {
			if (transitionEvent) {
				footerScroller[0].addEventListener(transitionEvent, hideFooterScroll);
			}
		}
		Array.prototype.forEach.call(document.querySelectorAll('.row-inner'), function(el) {
			el.style.height = '';
			el.style.marginBottom = '';
		});
		setRowHeight(document.querySelectorAll('.page-wrapper .row-parent, footer .row-parent'));
	});
	/** On resize events **/
	window.addEventListener("vc-resize", function() {
		scrollRowHeight_fix = window.pageYOffset;
		Array.prototype.forEach.call(document.querySelectorAll('.row-inner'), function(el) {
			el.style.height = '';
			el.style.marginBottom = '';
		});
		setRowHeight(document.querySelectorAll('.page-wrapper .row-parent, footer .row-parent'), false, true);
	});
	window.addEventListener("resize", function() {
		scrollRowHeight_fix = window.pageYOffset;
		docheight = (boxWrapper != undefined && boxWrapper[0] != undefined) ? boxWrapper[0].offsetHeight : 0;
		var oldWidth = wwidth;
		UNCODE.wwidth = wwidth = window.innerWidth || document.documentElement.clientWidth;
		UNCODE.wheight = wheight = (window.innerHeight || document.documentElement.clientHeight) - (bodyBorder * 2);
		if ( isSplitMenu && typeof resizeTimer_ === 'undefined' ) centerSplitMenu();
		if (isMobile && (oldWidth == wwidth)) return false;
		calculateMenuHeight(false);
		initBox();
		headerHeight('.header-wrapper');
		window.dispatchEvent(boxEvent);
		scrollFunction();
		shapeDivider();
		showHideScrollup(bodyTop);
		clearTimeout(resizeTimer_);
		resizeTimer_ = setTimeout(function() {
			if (isSplitMenu) centerSplitMenu();
		}, 10);
		clearTimeout(resizeTimer);
		resizeTimer = setTimeout(function() {
			UNCODE.wheight = wheight = (window.innerHeight || document.documentElement.clientHeight) - (bodyBorder * 2);
			Array.prototype.forEach.call(document.querySelectorAll('.row-inner'), function(el) {
				el.style.height = '';
				el.style.marginBottom = '';
			});
			setRowHeight(document.querySelectorAll('.page-wrapper .row-parent, footer .row-parent'), false, true);
			if (!isMobile) {
				initVideoComponent(document.body, '.uncode-video-container.video, .uncode-video-container.self-video');
			}
		}, 500);
	});

	/**
	 * On DOM ready
	 */
	window.addEventListener("load", function(){
		if (!UNCODE.isMobile) {
			setTimeout(function() {
				window.dispatchEvent(UNCODE.boxEvent);
				Waypoint.refreshAll();
			}, 2000);
		}
		//repeat it for mobile since it changes layout on carousel after DOM loading
		if (UNCODE.isMobile && !isMobileParallaxAllowed) {
			kenburnsHeader(bodyTop);
			kenburnsRowCol(bodyTop);
		}
		backwashHeader(bodyTop);
		backwashRowCol(bodyTop);
		showHideScrollup(bodyTop);
		if (document.createEvent) { // W3C
			var ev = document.createEvent('Event');
			ev.initEvent('resize', true, true);
			window.dispatchEvent(ev);
		} else { // IE
			document.fireEvent('onresize');
		}
	}, false);

	var UNCODE = {
		bodyTop: bodyTop,
		boxEvent: boxEvent,
		bodyBorder: bodyBorder,
		initBox: initBox,
		adminBarHeight: 0,
		menuHeight: 0,
		menuMobileHeight: 0,
		fixMenuHeight: fixMenuHeight,
		initHeader: initHeader,
		initRow: initRow,
		setRowHeight: setRowHeight,
		switchColorsMenu: switchColorsMenu,
		isMobile: isMobile,
		scrolling: false,
		menuHiding: false,
		menuOpened: false,
		menuMobileTriggerEvent: menuMobileTriggerEvent,
		mediaQuery: mediaQuery,
		initVideoComponent: initVideoComponent,
		hideMenu: hideMenu,
		wwidth: wwidth,
		wheight: wheight,
	};
	// transport
	if (typeof define === 'function' && define.amd) {
		// AMD
		define(UNCODE);
	} else {
		// browser global
		window.UNCODE = UNCODE;
	}

	UNCODE.adaptive = function() {
		var images = new Array(),
			getImages = document.querySelectorAll('.adaptive-async:not(.adaptive-fetching)');
		for (var i = 0; i < getImages.length; i++) {
			var imageObj = {},
				el = getImages[i];
			classie.addClass(el, 'adaptive-fetching');
			imageObj.unique = el.getAttribute('data-uniqueid');
			imageObj.url = el.getAttribute('data-guid');
			imageObj.path = el.getAttribute('data-path');
			imageObj.singlew = el.getAttribute('data-singlew');
			imageObj.singleh = el.getAttribute('data-singleh');
			imageObj.origwidth = el.getAttribute('data-width');
			imageObj.origheight = el.getAttribute('data-height');
			imageObj.crop = el.getAttribute('data-crop');
			imageObj.fixed = el.getAttribute('data-fixed') == undefined ? null : el.getAttribute('data-fixed');
			imageObj.screen = window.uncodeScreen;
			imageObj.images = window.uncodeImages;
			images.push(imageObj);
		}

		var post_data = {
			images: JSON.stringify(images),
			action: 'get_adaptive_async',
			nonce_adaptive_images: SiteParameters.nonce_adaptive_images
		};

		if (images.length > 0) {
			var xhr = new XMLHttpRequest();
			xhr.open('POST', SiteParameters.ajax_url, true);
			xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=UTF-8');
			xhr.setRequestHeader('X-Requested-With', 'XMLHttpRequest');

			xhr.onreadystatechange = function() {
				if (xhr.readyState == XMLHttpRequest.DONE) {
					if (xhr.status == 200 && xhr.responseText) {
						var jsonResponse = JSON.parse(xhr.responseText);

						if (jsonResponse.success && jsonResponse.data.images) {
							var images = jsonResponse.data.images;

							for (var i = 0; i < images.length; i++) {
								var val = images[i],
									getImage = document.querySelectorAll('[data-uniqueid="'+val.unique+'"]');
								for (var j = 0; j < getImage.length; j++) {
									var attrScr = getImage[j].getAttribute('src'),
									replaceImg = new Image();
									replaceImg.source = attrScr;
									replaceImg.el = getImage[j];

									classie.removeClass(getImage[j], 'adaptive-async');
									classie.removeClass(getImage[j], 'adaptive-fetching');

									replaceImg.onload = function () {

										var _this = this,
											parentNode = (_this.el).parentNode,
											placeH;

										//Workaround for lazy-load flickering on Firefox
										if ( typeof parentNode.prepend == 'undefined') {
											if (_this.source !== null) {
												(_this.el).src = _this.src;
											} else {
												(_this.el).style.backgroundImage = 'url("'+_this.src+'")';
											}

											classie.addClass(_this.el, 'async-done');
										} else {
											if (_this.source !== null) {
												placeH = document.createElement("IMG");
												placeH.setAttribute('class', 'placeH');
												placeH.src = _this.src;
												placeH.style.position = 'absolute';
												placeH.style.opacity = '0';
											} else {
												placeH = document.createElement("DIV");
												placeH.setAttribute('style', _this.el.getAttribute('style'));
												placeH.setAttribute('class', 'placeH ' + _this.el.getAttribute('class'));
												placeH.style.backgroundImage = 'url("'+_this.src+'")';
												placeH.style.backgroundSize = 'cover';
												placeH.style.backgroundPosition = 'center';
												placeH.style.position = 'absolute';
												placeH.style.top = '0';
												placeH.style.width = '100%';
												placeH.style.height = '100%';
											}

											if ( !classie.hasClass( _this.el, 'box-wrapper') ) {
												parentNode.prepend(placeH);
											}

											requestTimeout(function(){
												if (_this.source !== null) {
													(_this.el).src = _this.src;
												} else {
													(_this.el).style.backgroundImage = 'url("'+_this.src+'")';
												}
												if ( !classie.hasClass( _this.el, 'box-wrapper') ) {
													parentNode.removeChild(placeH);
												}
												classie.addClass(_this.el, 'async-done');
											}, 250);
										}
									}
									replaceImg.src = val.url;
								}
							}

						} else {
							if (SiteParameters.enable_debug == true) {
								// This console log is disabled by default
								// So nothing is printed in a typical installation
								//
								// It can be enabled for debugging purposes setting
								// the 'uncode_enable_debug_on_js_scripts' filter to true
								console.log('There was an error: bad response');
							}
						}

					} else if (xhr.status == 400) {
						if (SiteParameters.enable_debug == true) {
							// This console log is disabled by default
							// So nothing is printed in a typical installation
							//
							// It can be enabled for debugging purposes setting
							// the 'uncode_enable_debug_on_js_scripts' filter to true
							console.log('There was an error 400');
						}
					} else {
						if (SiteParameters.enable_debug == true) {
							// This console log is disabled by default
							// So nothing is printed in a typical installation
							//
							// It can be enabled for debugging purposes setting
							// the 'uncode_enable_debug_on_js_scripts' filter to true
							console.log('Something else other than 200 was returned');
						}
					}
				}
			}

			// Serialize our data
			var queryString = "",
				arrayLength = Object.keys(post_data).length,
				arrayCounter = 0;

			for (var key in post_data) {
				queryString += key + "=" + post_data[key];

				if (arrayCounter < arrayLength - 1) {
					queryString += "&";
				}

				arrayCounter++;
			}

			xhr.send(queryString);
		}
	};

})(window);

/**
 * vivus - JavaScript library to make drawing animation on SVG
 * @version v0.4.4
 * @link https://github.com/maxwellito/vivus
 * @license MIT
 */

'use strict';

(function () {

  'use strict';

/**
 * Pathformer
 * Beta version
 *
 * Take any SVG version 1.1 and transform
 * child elements to 'path' elements
 *
 * This code is purely forked from
 * https://github.com/Waest/SVGPathConverter
 */

/**
 * Class constructor
 *
 * @param {DOM|String} element Dom element of the SVG or id of it
 */
function Pathformer(element) {
  // Test params
  if (typeof element === 'undefined') {
	throw new Error('Pathformer [constructor]: "element" parameter is required');
  }

  // Set the element
  if (element.constructor === String) {
	element = document.getElementById(element);
	if (!element) {
	  throw new Error('Pathformer [constructor]: "element" parameter is not related to an existing ID');
	}
  }
  if (element instanceof window.SVGElement ||
	  element instanceof window.SVGGElement ||
	  /^svg$/i.test(element.nodeName)) {
	this.el = element;
  } else {
	throw new Error('Pathformer [constructor]: "element" parameter must be a string or a SVGelement');
  }

  // Start
  this.scan(element);
}

/**
 * List of tags which can be transformed
 * to path elements
 *
 * @type {Array}
 */
Pathformer.prototype.TYPES = ['line', 'ellipse', 'circle', 'polygon', 'polyline', 'rect'];

/**
 * List of attribute names which contain
 * data. This array list them to check if
 * they contain bad values, like percentage.
 *
 * @type {Array}
 */
Pathformer.prototype.ATTR_WATCH = ['cx', 'cy', 'points', 'r', 'rx', 'ry', 'x', 'x1', 'x2', 'y', 'y1', 'y2'];

/**
 * Finds the elements compatible for transform
 * and apply the liked method
 *
 * @param  {object} options Object from the constructor
 */
Pathformer.prototype.scan = function (svg) {
  var fn, element, pathData, pathDom,
	  elements = svg.querySelectorAll(this.TYPES.join(','));

  for (var i = 0; i < elements.length; i++) {
	element = elements[i];
	fn = this[element.tagName.toLowerCase() + 'ToPath'];
	pathData = fn(this.parseAttr(element.attributes));
	pathDom = this.pathMaker(element, pathData);
	element.parentNode.replaceChild(pathDom, element);
  }
};


/**
 * Read `line` element to extract and transform
 * data, to make it ready for a `path` object.
 *
 * @param  {DOMelement} element Line element to transform
 * @return {object}			 Data for a `path` element
 */
Pathformer.prototype.lineToPath = function (element) {
  var newElement = {},
	  x1 = element.x1 || 0,
	  y1 = element.y1 || 0,
	  x2 = element.x2 || 0,
	  y2 = element.y2 || 0;

  newElement.d = 'M' + x1 + ',' + y1 + 'L' + x2 + ',' + y2;
  return newElement;
};

/**
 * Read `rect` element to extract and transform
 * data, to make it ready for a `path` object.
 * The radius-border is not taken in charge yet.
 * (your help is more than welcomed)
 *
 * @param  {DOMelement} element Rect element to transform
 * @return {object}             Data for a `path` element
 */
Pathformer.prototype.rectToPath = function (element) {
  var newElement = {},
      x      = parseFloat(element.x)      || 0,
      y      = parseFloat(element.y)      || 0,
      width  = parseFloat(element.width)  || 0,
      height = parseFloat(element.height) || 0;

  if (element.rx || element.ry) {
    var rx = parseInt(element.rx, 10) || -1,
        ry = parseInt(element.ry, 10) || -1;
    rx = Math.min(Math.max(rx < 0 ? ry : rx, 0), width/2);
    ry = Math.min(Math.max(ry < 0 ? rx : ry, 0), height/2);

    newElement.d = 'M ' + (x + rx) + ',' + y + ' ' +
                   'L ' + (x + width - rx) + ',' + y + ' ' +
                   'A ' + rx + ',' + ry + ',0,0,1,' + (x + width) + ',' + (y + ry) + ' ' +
                   'L ' + (x + width) + ',' + (y + height - ry) + ' ' +
                   'A ' + rx + ',' + ry + ',0,0,1,' + (x + width - rx) + ',' + (y + height) + ' ' +
                   'L ' + (x + rx) + ',' + (y + height) + ' ' +
                   'A ' + rx + ',' + ry + ',0,0,1,' + x + ',' + (y + height - ry) + ' ' +
                   'L ' + x + ',' + (y + ry) + ' ' +
                   'A ' + rx + ',' + ry + ',0,0,1,' + (x + rx) + ',' + y;
  }
  else {
    newElement.d = 'M' + x + ' ' + y + ' ' +
                   'L' + (x + width) + ' ' + y + ' ' +
                   'L' + (x + width) + ' ' + (y + height) + ' ' +
                   'L' + x + ' ' + (y + height) + ' Z';
  }
  return newElement;
};

/**
 * Read `polyline` element to extract and transform
 * data, to make it ready for a `path` object.
 *
 * @param  {DOMelement} element Polyline element to transform
 * @return {object}             Data for a `path` element
 */
Pathformer.prototype.polylineToPath = function (element) {
  var newElement = {},
      points = element.points.trim().split(' '),
      i, path;

  // Reformatting if points are defined without commas
  if (element.points.indexOf(',') === -1) {
    var formattedPoints = [];
    for (i = 0; i < points.length; i+=2) {
      formattedPoints.push(points[i] + ',' + points[i+1]);
    }
    points = formattedPoints;
  }

  // Generate the path.d value
  path = 'M' + points[0];
  for(i = 1; i < points.length; i++) {
    if (points[i].indexOf(',') !== -1) {
      path += 'L' + points[i];
    }
  }
  newElement.d = path;
  return newElement;
};

/**
 * Read `polygon` element to extract and transform
 * data, to make it ready for a `path` object.
 * This method rely on polylineToPath, because the
 * logic is similar. The path created is just closed,
 * so it needs an 'Z' at the end.
 *
 * @param  {DOMelement} element Polygon element to transform
 * @return {object}             Data for a `path` element
 */
Pathformer.prototype.polygonToPath = function (element) {
  var newElement = Pathformer.prototype.polylineToPath(element);

  newElement.d += 'Z';
  return newElement;
};

/**
 * Read `ellipse` element to extract and transform
 * data, to make it ready for a `path` object.
 *
 * @param  {DOMelement} element ellipse element to transform
 * @return {object}             Data for a `path` element
 */
Pathformer.prototype.ellipseToPath = function (element) {
  var newElement = {},
      rx = parseFloat(element.rx) || 0,
      ry = parseFloat(element.ry) || 0,
      cx = parseFloat(element.cx) || 0,
      cy = parseFloat(element.cy) || 0,
      startX = cx - rx,
      startY = cy,
      endX = parseFloat(cx) + parseFloat(rx),
      endY = cy;

  newElement.d = 'M' + startX + ',' + startY +
                 'A' + rx + ',' + ry + ' 0,1,1 ' + endX + ',' + endY +
                 'A' + rx + ',' + ry + ' 0,1,1 ' + startX + ',' + endY;
  return newElement;
};

/**
 * Read `circle` element to extract and transform
 * data, to make it ready for a `path` object.
 *
 * @param  {DOMelement} element Circle element to transform
 * @return {object}             Data for a `path` element
 */
Pathformer.prototype.circleToPath = function (element) {
  var newElement = {},
      r  = parseFloat(element.r)  || 0,
      cx = parseFloat(element.cx) || 0,
      cy = parseFloat(element.cy) || 0,
      startX = cx - r,
      startY = cy,
      endX = parseFloat(cx) + parseFloat(r),
      endY = cy;

  newElement.d =  'M' + startX + ',' + startY +
                  'A' + r + ',' + r + ' 0,1,1 ' + endX + ',' + endY +
                  'A' + r + ',' + r + ' 0,1,1 ' + startX + ',' + endY;
  return newElement;
};

/**
 * Create `path` elements form original element
 * and prepared objects
 *
 * @param  {DOMelement} element  Original element to transform
 * @param  {object} pathData     Path data (from `toPath` methods)
 * @return {DOMelement}          Path element
 */
Pathformer.prototype.pathMaker = function (element, pathData) {
  var i, attr, pathTag = document.createElementNS('http://www.w3.org/2000/svg','path');
  for(i = 0; i < element.attributes.length; i++) {
    attr = element.attributes[i];
    if (this.ATTR_WATCH.indexOf(attr.name) === -1) {
      pathTag.setAttribute(attr.name, attr.value);
    }
  }
  for(i in pathData) {
    pathTag.setAttribute(i, pathData[i]);
  }
  return pathTag;
};

/**
 * Parse attributes of a DOM element to
 * get an object of attribute => value
 *
 * @param  {NamedNodeMap} attributes Attributes object from DOM element to parse
 * @return {object}                  Object of attributes
 */
Pathformer.prototype.parseAttr = function (element) {
  var attr, output = {};
  for (var i = 0; i < element.length; i++) {
    attr = element[i];
    // Check if no data attribute contains '%', or the transformation is impossible
    if (this.ATTR_WATCH.indexOf(attr.name) !== -1 && attr.value.indexOf('%') !== -1) {
      throw new Error('Pathformer [parseAttr]: a SVG shape got values in percentage. This cannot be transformed into \'path\' tags. Please use \'viewBox\'.');
    }
    output[attr.name] = attr.value;
  }
  return output;
};

  'use strict';

var setupEnv, requestAnimFrame, cancelAnimFrame, parsePositiveInt;

/**
 * Vivus
 * Beta version
 *
 * Take any SVG and make the animation
 * to give give the impression of live drawing
 *
 * This in more than just inspired from codrops
 * At that point, it's a pure fork.
 */

/**
 * Class constructor
 * option structure
 *   type: 'delayed'|'sync'|'oneByOne'|'script' (to know if the items must be drawn synchronously or not, default: delayed)
 *   duration: <int> (in frames)
 *   start: 'inViewport'|'manual'|'autostart' (start automatically the animation, default: inViewport)
 *   delay: <int> (delay between the drawing of first and last path)
 *   dashGap <integer> whitespace extra margin between dashes
 *   pathTimingFunction <function> timing animation function for each path element of the SVG
 *   animTimingFunction <function> timing animation function for the complete SVG
 *   forceRender <boolean> force the browser to re-render all updated path items
 *   selfDestroy <boolean> removes all extra styling on the SVG, and leaves it as original
 *
 * The attribute 'type' is by default on 'delayed'.
 *  - 'delayed'
 *    all paths are draw at the same time but with a
 *    little delay between them before start
 *  - 'sync'
 *    all path are start and finish at the same time
 *  - 'oneByOne'
 *    only one path is draw at the time
 *    the end of the first one will trigger the draw
 *    of the next one
 *
 * All these values can be overwritten individually
 * for each path item in the SVG
 * The value of frames will always take the advantage of
 * the duration value.
 * If you fail somewhere, an error will be thrown.
 * Good luck.
 *
 * @constructor
 * @this {Vivus}
 * @param {DOM|String}   element  Dom element of the SVG or id of it
 * @param {Object}       options  Options about the animation
 * @param {Function}     callback Callback for the end of the animation
 */
function Vivus (element, options, callback) {

  setupEnv();

  // Setup
  this.isReady = false;
  this.setElement(element, options);
  this.setOptions(options);
  this.setCallback(callback);

  if (this.isReady) {
    this.init();
  }
}

/**
 * Timing functions
 **************************************
 *
 * Default functions to help developers.
 * It always take a number as parameter (between 0 to 1) then
 * return a number (between 0 and 1)
 */
Vivus.LINEAR          = function (x) {return x;};
Vivus.EASE            = function (x) {return -Math.cos(x * Math.PI) / 2 + 0.5;};
Vivus.EASE_OUT        = function (x) {return 1 - Math.pow(1-x, 3);};
Vivus.EASE_IN         = function (x) {return Math.pow(x, 3);};
Vivus.EASE_OUT_BOUNCE = function (x) {
  var base = -Math.cos(x * (0.5 * Math.PI)) + 1,
    rate = Math.pow(base,1.5),
    rateR = Math.pow(1 - x, 2),
    progress = -Math.abs(Math.cos(rate * (2.5 * Math.PI) )) + 1;
  return (1- rateR) + (progress * rateR);
};


/**
 * Setters
 **************************************
 */

/**
 * Check and set the element in the instance
 * The method will not return anything, but will throw an
 * error if the parameter is invalid
 *
 * @param {DOM|String}   element  SVG Dom element or id of it
 */
Vivus.prototype.setElement = function (element, options) {
  var onLoad, self;

  // Basic check
  if (typeof element === 'undefined') {
    throw new Error('Vivus [constructor]: "element" parameter is required');
  }

  // Set the element
  if (element.constructor === String) {
    element = document.getElementById(element);
    if (!element) {
      throw new Error('Vivus [constructor]: "element" parameter is not related to an existing ID');
    }
  }
  this.parentEl = element;

  // Load the SVG with XMLHttpRequest and extract the SVG
  if (options && options.file) {
    var self = this;
    onLoad = function (e) {
      var domSandbox = document.createElement('div');
      domSandbox.innerHTML = this.responseText;

      var svgTag = domSandbox.querySelector('svg');
      if (!svgTag) {
        throw new Error('Vivus [load]: Cannot find the SVG in the loaded file : ' + options.file);
      }

      self.el = svgTag
      self.el.setAttribute('width', '100%');
      self.el.setAttribute('height', '100%');
      self.parentEl.appendChild(self.el)
      self.isReady = true;
      self.init();
      self = null;
    }

    var oReq = new window.XMLHttpRequest();
    oReq.addEventListener('load', onLoad);
    oReq.open('GET', options.file);
    oReq.send();
    return;
  }

  switch (element.constructor) {
  case window.SVGSVGElement:
  case window.SVGElement:
  case window.SVGGElement:
    this.el = element;
    this.isReady = true;
    break;

  case window.HTMLObjectElement:
    self = this;
    onLoad = function (e) {
      if (self.isReady) {
        return;
      }
      self.el = element.contentDocument && element.contentDocument.querySelector('svg');
      if (!self.el && e) {
        throw new Error('Vivus [constructor]: object loaded does not contain any SVG');
      }
      else if (self.el) {
        if (element.getAttribute('built-by-vivus')) {
          self.parentEl.insertBefore(self.el, element);
          self.parentEl.removeChild(element);
          self.el.setAttribute('width', '100%');
          self.el.setAttribute('height', '100%');
        }
        self.isReady = true;
        self.init();
        self = null;
      }
    };

    if (!onLoad()) {
      element.addEventListener('load', onLoad);
    }
    break;

  default:
    throw new Error('Vivus [constructor]: "element" parameter is not valid (or miss the "file" attribute)');
  }
};

/**
 * Set up user option to the instance
 * The method will not return anything, but will throw an
 * error if the parameter is invalid
 *
 * @param  {object} options Object from the constructor
 */
Vivus.prototype.setOptions = function (options) {
  var allowedTypes = ['delayed', 'sync', 'async', 'nsync', 'oneByOne', 'scenario', 'scenario-sync'];
  var allowedStarts =  ['inViewport', 'manual', 'autostart'];

  // Basic check
  if (options !== undefined && options.constructor !== Object) {
    throw new Error('Vivus [constructor]: "options" parameter must be an object');
  }
  else {
    options = options || {};
  }

  // Set the animation type
  if (options.type && allowedTypes.indexOf(options.type) === -1) {
    throw new Error('Vivus [constructor]: ' + options.type + ' is not an existing animation `type`');
  }
  else {
    this.type = options.type || allowedTypes[0];
  }

  // Set the start type
  if (options.start && allowedStarts.indexOf(options.start) === -1) {
    throw new Error('Vivus [constructor]: ' + options.start + ' is not an existing `start` option');
  }
  else {
    this.start = options.start || allowedStarts[0];
  }

  this.isIE         = (window.navigator.userAgent.indexOf('MSIE') !== -1 || window.navigator.userAgent.indexOf('Trident/') !== -1 || window.navigator.userAgent.indexOf('Edge/') !== -1 );
  this.duration     = parsePositiveInt(options.duration, 120);
  this.delay        = parsePositiveInt(options.delay, null);
  //Uncode addition
  this.delayStart   = parsePositiveInt(options.delayStart, null);
  //#END
  this.dashGap      = parsePositiveInt(options.dashGap, 1);
  this.forceRender  = options.hasOwnProperty('forceRender') ? !!options.forceRender : this.isIE;
  this.reverseStack = !!options.reverseStack;
  this.selfDestroy  = !!options.selfDestroy;
  this.onReady      = options.onReady;
  this.map          = [];
  this.frameLength  = this.currentFrame = this.delayUnit = this.speed = this.handle = null;

  this.ignoreInvisible = options.hasOwnProperty('ignoreInvisible') ? !!options.ignoreInvisible : false;

  this.animTimingFunction = options.animTimingFunction || Vivus.LINEAR;
  this.pathTimingFunction = options.pathTimingFunction || Vivus.LINEAR;

  if (this.delay >= this.duration) {
    throw new Error('Vivus [constructor]: delay must be shorter than duration');
  }
};

/**
 * Set up callback to the instance
 * The method will not return enything, but will throw an
 * error if the parameter is invalid
 *
 * @param  {Function} callback Callback for the animation end
 */
Vivus.prototype.setCallback = function (callback) {
  // Basic check
  if (!!callback && callback.constructor !== Function) {
    throw new Error('Vivus [constructor]: "callback" parameter must be a function');
  }
  this.callback = callback || function () {};
};


/**
 * Core
 **************************************
 */

/**
 * Map the svg, path by path.
 * The method return nothing, it just fill the
 * `map` array. Each item in this array represent
 * a path element from the SVG, with informations for
 * the animation.
 *
 * ```
 * [
 *   {
 *     el: <DOMobj> the path element
 *     length: <number> length of the path line
 *     startAt: <number> time start of the path animation (in frames)
 *     duration: <number> path animation duration (in frames)
 *   },
 *   ...
 * ]
 * ```
 *
 */
Vivus.prototype.mapping = function () {
  var i, paths, path, pAttrs, pathObj, totalLength, lengthMeter, timePoint;
  timePoint = totalLength = lengthMeter = 0;
  paths = this.el.querySelectorAll('path');

  for (i = 0; i < paths.length; i++) {
    path = paths[i];
    if (this.isInvisible(path)) {
      continue;
    }
    pathObj = {
      el: path,
      length: Math.ceil(path.getTotalLength())
    };
    // Test if the path length is correct
    if (isNaN(pathObj.length)) {
      if (window.console && console.warn) {
        console.warn('Vivus [mapping]: cannot retrieve a path element length', path);
      }
      continue;
    }
    this.map.push(pathObj);
    path.style.strokeDasharray  = pathObj.length + ' ' + (pathObj.length + this.dashGap * 2);
    path.style.strokeDashoffset = pathObj.length + this.dashGap;
    pathObj.length += this.dashGap;
    totalLength += pathObj.length;

    this.renderPath(i);
  }

  totalLength = totalLength === 0 ? 1 : totalLength;
  this.delay = this.delay === null ? this.duration / 3 : this.delay;
  this.delayUnit = this.delay / (paths.length > 1 ? paths.length - 1 : 1);

  // Reverse stack if asked
  if (this.reverseStack) {
    this.map.reverse();
  }

  for (i = 0; i < this.map.length; i++) {
    pathObj = this.map[i];

    switch (this.type) {
    case 'delayed':
      pathObj.startAt = this.delayUnit * i;
      pathObj.duration = this.duration - this.delay;
      break;

    case 'oneByOne':
      pathObj.startAt = lengthMeter / totalLength * this.duration;
      pathObj.duration = pathObj.length / totalLength * this.duration;
      break;

    case 'sync':
    case 'async':
    case 'nsync':
      pathObj.startAt = 0;
      pathObj.duration = this.duration;
      break;

    case 'scenario-sync':
      path = pathObj.el;
      pAttrs = this.parseAttr(path);
      pathObj.startAt = timePoint + (parsePositiveInt(pAttrs['data-delay'], this.delayUnit) || 0);
      pathObj.duration = parsePositiveInt(pAttrs['data-duration'], this.duration);
      timePoint = pAttrs['data-async'] !== undefined ? pathObj.startAt : pathObj.startAt + pathObj.duration;
      this.frameLength = Math.max(this.frameLength, (pathObj.startAt + pathObj.duration));
      break;

    case 'scenario':
      path = pathObj.el;
      pAttrs = this.parseAttr(path);
      pathObj.startAt = parsePositiveInt(pAttrs['data-start'], this.delayUnit) || 0;
      pathObj.duration = parsePositiveInt(pAttrs['data-duration'], this.duration);
      this.frameLength = Math.max(this.frameLength, (pathObj.startAt + pathObj.duration));
      break;
    }
    lengthMeter += pathObj.length;
    this.frameLength = this.frameLength || this.duration;
  }
};

/**
 * Interval method to draw the SVG from current
 * position of the animation. It update the value of
 * `currentFrame` and re-trace the SVG.
 *
 * It use this.handle to store the requestAnimationFrame
 * and clear it one the animation is stopped. So this
 * attribute can be used to know if the animation is
 * playing.
 *
 * Once the animation at the end, this method will
 * trigger the Vivus callback.
 *
 */
Vivus.prototype.drawer = function () {
  var self = this;
  this.currentFrame += this.speed;

  if (this.currentFrame <= 0) {
    this.stop();
    this.reset();
  } else if (this.currentFrame >= this.frameLength) {
    this.stop();
    this.currentFrame = this.frameLength;
    this.trace();
    if (this.selfDestroy) {
      this.destroy();
    }
  } else {
    this.trace();
    this.handle = requestAnimFrame(function () {
      self.drawer();
    });
    return;
  }

  this.callback(this);
  if (this.instanceCallback) {
    this.instanceCallback(this);
    this.instanceCallback = null;
  }
};

/**
 * Draw the SVG at the current instant from the
 * `currentFrame` value. Here is where most of the magic is.
 * The trick is to use the `strokeDashoffset` style property.
 *
 * For optimisation reasons, a new property called `progress`
 * is added in each item of `map`. This one contain the current
 * progress of the path element. Only if the new value is different
 * the new value will be applied to the DOM element. This
 * method save a lot of resources to re-render the SVG. And could
 * be improved if the animation couldn't be played forward.
 *
 */
Vivus.prototype.trace = function () {
  var i, progress, path, currentFrame;
  currentFrame = this.animTimingFunction(this.currentFrame / this.frameLength) * this.frameLength;
  for (i = 0; i < this.map.length; i++) {
    path = this.map[i];
    progress = (currentFrame - path.startAt) / path.duration;
    progress = this.pathTimingFunction(Math.max(0, Math.min(1, progress)));
    if (path.progress !== progress) {
      path.progress = progress;
      path.el.style.strokeDashoffset = Math.floor(path.length * (1 - progress));
      this.renderPath(i);
    }
  }
};

/**
 * Method forcing the browser to re-render a path element
 * from it's index in the map. Depending on the `forceRender`
 * value.
 * The trick is to replace the path element by it's clone.
 * This practice is not recommended because it's asking more
 * ressources, too much DOM manupulation..
 * but it's the only way to let the magic happen on IE.
 * By default, this fallback is only applied on IE.
 *
 * @param  {Number} index Path index
 */
Vivus.prototype.renderPath = function (index) {
  if (this.forceRender && this.map && this.map[index]) {
    var pathObj = this.map[index],
        newPath = pathObj.el.cloneNode(true);
    pathObj.el.parentNode.replaceChild(newPath, pathObj.el);
    pathObj.el = newPath;
  }
};

/**
 * When the SVG object is loaded and ready,
 * this method will continue the initialisation.
 *
 * This this mainly due to the case of passing an
 * object tag in the constructor. It will wait
 * the end of the loading to initialise.
 *
 */
Vivus.prototype.init = function () {
  // Set object variables
  this.frameLength = 0;
  this.currentFrame = 0;
  this.map = [];

  // Start
  new Pathformer(this.el);
  this.mapping();
  this.starter();

  if (this.onReady) {
    this.onReady(this);
  }
};

/**
 * Trigger to start of the animation.
 * Depending on the `start` value, a different script
 * will be applied.
 *
 * If the `start` value is not valid, an error will be thrown.
 * Even if technically, this is impossible.
 *
 */
Vivus.prototype.starter = function () {
  switch (this.start) {
  case 'manual':
    return;

  case 'autostart':
    this.play();
    break;

  case 'inViewport':
    var self = this,
    listener = function () {
      if (self.isInViewport(self.parentEl, 1)) {
        self.play();
        window.removeEventListener('scroll', listener);
        //Uncode addition
        window.removeEventListener('fp-slide-changed', listener);
        window.removeEventListener('fp-slide-scroll', listener);
        //#END
      }
    };
    window.addEventListener('scroll', listener);
    //Uncode addition
    window.addEventListener('fp-slide-changed', listener);
    window.addEventListener('fp-slide-scroll', listener);
    //#END
    listener();
    break;
  }
};


/**
 * Controls
 **************************************
 */

/**
 * Get the current status of the animation between
 * three different states: 'start', 'progress', 'end'.
 * @return {string} Instance status
 */
Vivus.prototype.getStatus = function () {
  return this.currentFrame === 0 ? 'start' : this.currentFrame === this.frameLength ? 'end' : 'progress';
};

/**
 * Reset the instance to the initial state : undraw
 * Be careful, it just reset the animation, if you're
 * playing the animation, this won't stop it. But just
 * make it start from start.
 *
 */
Vivus.prototype.reset = function () {
  return this.setFrameProgress(0);
};

/**
 * Set the instance to the final state : drawn
 * Be careful, it just set the animation, if you're
 * playing the animation on rewind, this won't stop it.
 * But just make it start from the end.
 *
 */
Vivus.prototype.finish = function () {
  return this.setFrameProgress(1);
};

/**
 * Set the level of progress of the drawing.
 *
 * @param {number} progress Level of progress to set
 */
Vivus.prototype.setFrameProgress = function (progress) {
  progress = Math.min(1, Math.max(0, progress));
  this.currentFrame = Math.round(this.frameLength * progress);
  this.trace();
  return this;
};

/**
 * Play the animation at the desired speed.
 * Speed must be a valid number (no zero).
 * By default, the speed value is 1.
 * But a negative value is accepted to go forward.
 *
 * And works with float too.
 * But don't forget we are in JavaScript, se be nice
 * with him and give him a 1/2^x value.
 *
 * @param  {number} speed Animation speed [optional]
 */
Vivus.prototype.play = function (speed, callback) {
  this.instanceCallback = null;

  if (speed && typeof speed === 'function') {
    this.instanceCallback = speed; // first parameter is actually the callback function
    speed = null;
  }
  else if (speed && typeof speed !== 'number') {
    throw new Error('Vivus [play]: invalid speed');
  }
  // if the first parameter wasn't the callback, check if the seconds was
  if (callback && typeof(callback) === 'function' && !this.instanceCallback) {
    this.instanceCallback = callback;
  }


  this.speed = speed || 1;
  //Uncode addition
  if (!this.handle) {
    var $this = this,
    delay = (this.delayStart != null) ? this.delayStart : 0;
    setTimeout(function() {
      $this.drawer();
    }, delay);
  }
  //#END
  return this;
};

/**
 * Stop the current animation, if on progress.
 * Should not trigger any error.
 *
 */
Vivus.prototype.stop = function () {
  if (this.handle) {
    cancelAnimFrame(this.handle);
    this.handle = null;
  }
  return this;
};

/**
 * Destroy the instance.
 * Remove all bad styling attributes on all
 * path tags
 *
 */
Vivus.prototype.destroy = function () {
  this.stop();
  var i, path;
  for (i = 0; i < this.map.length; i++) {
    path = this.map[i];
    path.el.style.strokeDashoffset = null;
    path.el.style.strokeDasharray = null;
    this.renderPath(i);
  }
};


/**
 * Utils methods
 * include methods from Codrops
 **************************************
 */

/**
 * Method to best guess if a path should added into
 * the animation or not.
 *
 * 1. Use the `data-vivus-ignore` attribute if set
 * 2. Check if the instance must ignore invisible paths
 * 3. Check if the path is visible
 *
 * For now the visibility checking is unstable.
 * It will be used for a beta phase.
 *
 * Other improvments are planned. Like detecting
 * is the path got a stroke or a valid opacity.
 */
Vivus.prototype.isInvisible = function (el) {
  var rect,
    ignoreAttr = el.getAttribute('data-ignore');

  if (ignoreAttr !== null) {
    return ignoreAttr !== 'false';
  }

  if (this.ignoreInvisible) {
    rect = el.getBoundingClientRect();
    return !rect.width && !rect.height;
  }
  else {
    return false;
  }
};

/**
 * Parse attributes of a DOM element to
 * get an object of {attributeName => attributeValue}
 *
 * @param  {object} element DOM element to parse
 * @return {object}         Object of attributes
 */
Vivus.prototype.parseAttr = function (element) {
  var attr, output = {};
  if (element && element.attributes) {
    for (var i = 0; i < element.attributes.length; i++) {
      attr = element.attributes[i];
      output[attr.name] = attr.value;
    }
  }
  return output;
};

/**
 * Reply if an element is in the page viewport
 *
 * @param  {object} el Element to observe
 * @param  {number} h  Percentage of height
 * @return {boolean}
 */
Vivus.prototype.isInViewport = function (el, h) {
  var scrolled   = this.scrollY(),
    viewed       = scrolled + this.getViewportH(),
    elBCR        = el.getBoundingClientRect(),
    elHeight     = elBCR.height,
    elTop        = scrolled + elBCR.top,
    elBottom     = elTop + elHeight;

  // if 0, the element is considered in the viewport as soon as it enters.
  // if 1, the element is considered in the viewport only when it's fully inside
  // value in percentage (1 >= h >= 0)
  h = h || 0;

  return (elTop + elHeight * h) <= viewed && (elBottom) >= scrolled;
};


/**
 * Get the viewport height in pixels
 *
 * @return {integer} Viewport height
 */
Vivus.prototype.getViewportH = function () {
  var client = this.docElem.clientHeight,
    inner = window.innerHeight;

  if (client < inner) {
    return inner;
  }
  else {
    return client;
  }
};

/**
 * Get the page Y offset
 *
 * @return {integer} Page Y offset
 */
Vivus.prototype.scrollY = function () {
  return window.pageYOffset || this.docElem.scrollTop;
};

setupEnv = function () {

  if (Vivus.prototype.docElem) {
    return;
  }

  /**
   * Alias for document element
   *
   * @type {DOMelement}
   */
  Vivus.prototype.docElem = window.document.documentElement;

  /**
   * Alias for `requestAnimationFrame` or
   * `setTimeout` function for deprecated browsers.
   *
   */
  requestAnimFrame = (function () {
    return (
      window.requestAnimationFrame       ||
      window.webkitRequestAnimationFrame ||
      window.mozRequestAnimationFrame    ||
      window.oRequestAnimationFrame      ||
      window.msRequestAnimationFrame     ||
      function(/* function */ callback){
        return window.setTimeout(callback, 1000 / 60);
      }
    );
  })();

  /**
   * Alias for `cancelAnimationFrame` or
   * `cancelTimeout` function for deprecated browsers.
   *
   */
  cancelAnimFrame = (function () {
    return (
      window.cancelAnimationFrame       ||
      window.webkitCancelAnimationFrame ||
      window.mozCancelAnimationFrame    ||
      window.oCancelAnimationFrame      ||
      window.msCancelAnimationFrame     ||
      function(id){
        return window.clearTimeout(id);
      }
    );
  })();
};

/**
 * Parse string to integer.
 * If the number is not positive or null
 * the method will return the default value
 * or 0 if undefined
 *
 * @param {string} value String to parse
 * @param {*} defaultValue Value to return if the result parsed is invalid
 * @return {number}
 *
 */
parsePositiveInt = function (value, defaultValue) {
  var output = parseInt(value, 10);
  return (output >= 0) ? output : defaultValue;
};


  if (typeof define === 'function' && define.amd) {
    // AMD. Register as an anonymous module.
    define([], function() {
      return Vivus;
    });
  } else if (typeof exports === 'object') {
    // Node. Does not work with strict CommonJS, but
    // only CommonJS-like environments that support module.exports,
    // like Node.
    module.exports = Vivus;
  } else {
    // Browser globals
    window.Vivus = Vivus;
  }

}());

(function(global){var startY=0;var enabled=false;var supportsPassiveOption=false;try{var opts=Object.defineProperty({},"passive",{get:function(){supportsPassiveOption=true}});window.addEventListener("test",null,opts)}catch(e){}var handleTouchmove=function(evt){var el=evt.target;while(el!==document.body&&el!==document){var style=window.getComputedStyle(el);if(!style){break}if(el.nodeName==="INPUT"&&el.getAttribute("type")==="range"){return}var scrolling=style.getPropertyValue("-webkit-overflow-scrolling");var overflowY=style.getPropertyValue("overflow-y");var height=parseInt(style.getPropertyValue("height"),10);var isScrollable=scrolling==="touch"&&(overflowY==="auto"||overflowY==="scroll");var canScroll=el.scrollHeight>el.offsetHeight;if(isScrollable&&canScroll){var curY=evt.touches?evt.touches[0].screenY:evt.screenY;var isAtTop=startY<=curY&&el.scrollTop===0;var isAtBottom=startY>=curY&&el.scrollHeight-el.scrollTop===height;if(isAtTop||isAtBottom){evt.preventDefault()}return}el=el.parentNode}evt.preventDefault()};var handleTouchstart=function(evt){startY=evt.touches?evt.touches[0].screenY:evt.screenY};var enable=function(){window.addEventListener("touchstart",handleTouchstart,supportsPassiveOption?{passive:false}:false);window.addEventListener("touchmove",handleTouchmove,supportsPassiveOption?{passive:false}:false);enabled=true};var disable=function(){window.removeEventListener("touchstart",handleTouchstart,false);window.removeEventListener("touchmove",handleTouchmove,false);enabled=false};var isEnabled=function(){return enabled};var testDiv=document.createElement("div");document.documentElement.appendChild(testDiv);testDiv.style.WebkitOverflowScrolling="touch";var scrollSupport="getComputedStyle"in window&&window.getComputedStyle(testDiv)["-webkit-overflow-scrolling"]==="touch";document.documentElement.removeChild(testDiv);if(scrollSupport){enable()}var iNoBounce={enable:enable,disable:disable,isEnabled:isEnabled};if(typeof module!=="undefined"&&module.exports){module.exports=iNoBounce}if(typeof global.define==="function"){(function(define){define("iNoBounce",[],function(){return iNoBounce})})(global.define)}else{global.iNoBounce=iNoBounce}})(this);
iNoBounce.disable();

/* Font Face Observer v2.1.0 - © Bram Stein. License: BSD-3-Clause */(function(){function l(a,b){document.addEventListener?a.addEventListener("scroll",b,!1):a.attachEvent("scroll",b)}function m(a){document.body?a():document.addEventListener?document.addEventListener("DOMContentLoaded",function c(){document.removeEventListener("DOMContentLoaded",c);a()}):document.attachEvent("onreadystatechange",function k(){if("interactive"==document.readyState||"complete"==document.readyState)document.detachEvent("onreadystatechange",k),a()})};function t(a){this.a=document.createElement("div");this.a.setAttribute("aria-hidden","true");this.a.appendChild(document.createTextNode(a));this.b=document.createElement("span");this.c=document.createElement("span");this.h=document.createElement("span");this.f=document.createElement("span");this.g=-1;this.b.style.cssText="max-width:none;display:inline-block;position:absolute;height:100%;width:100%;overflow:scroll;font-size:16px;";this.c.style.cssText="max-width:none;display:inline-block;position:absolute;height:100%;width:100%;overflow:scroll;font-size:16px;";
this.f.style.cssText="max-width:none;display:inline-block;position:absolute;height:100%;width:100%;overflow:scroll;font-size:16px;";this.h.style.cssText="display:inline-block;width:200%;height:200%;font-size:16px;max-width:none;";this.b.appendChild(this.h);this.c.appendChild(this.f);this.a.appendChild(this.b);this.a.appendChild(this.c)}
function u(a,b){a.a.style.cssText="max-width:none;min-width:20px;min-height:20px;display:inline-block;overflow:hidden;position:absolute;width:auto;margin:0;padding:0;top:-999px;white-space:nowrap;font-synthesis:none;font:"+b+";"}function z(a){var b=a.a.offsetWidth,c=b+100;a.f.style.width=c+"px";a.c.scrollLeft=c;a.b.scrollLeft=a.b.scrollWidth+100;return a.g!==b?(a.g=b,!0):!1}function A(a,b){function c(){var a=k;z(a)&&a.a.parentNode&&b(a.g)}var k=a;l(a.b,c);l(a.c,c);z(a)};function B(a,b){var c=b||{};this.family=a;this.style=c.style||"normal";this.weight=c.weight||"normal";this.stretch=c.stretch||"normal"}var C=null,D=null,E=null,F=null;function G(){if(null===D)if(J()&&/Apple/.test(window.navigator.vendor)){var a=/AppleWebKit\/([0-9]+)(?:\.([0-9]+))(?:\.([0-9]+))/.exec(window.navigator.userAgent);D=!!a&&603>parseInt(a[1],10)}else D=!1;return D}function J(){null===F&&(F=!!document.fonts);return F}
function K(){if(null===E){var a=document.createElement("div");try{a.style.font="condensed 100px sans-serif"}catch(b){}E=""!==a.style.font}return E}function L(a,b){return[a.style,a.weight,K()?a.stretch:"","100px",b].join(" ")}
B.prototype.load=function(a,b){var c=this,k=a||"BESbswy",r=0,n=b||3E3,H=(new Date).getTime();return new Promise(function(a,b){if(J()&&!G()){var M=new Promise(function(a,b){function e(){(new Date).getTime()-H>=n?b(Error(""+n+"ms timeout exceeded")):document.fonts.load(L(c,'"'+c.family+'"'),k).then(function(c){1<=c.length?a():setTimeout(e,25)},b)}e()}),N=new Promise(function(a,c){r=setTimeout(function(){c(Error(""+n+"ms timeout exceeded"))},n)});Promise.race([N,M]).then(function(){clearTimeout(r);a(c)},
b)}else m(function(){function v(){var b;if(b=-1!=f&&-1!=g||-1!=f&&-1!=h||-1!=g&&-1!=h)(b=f!=g&&f!=h&&g!=h)||(null===C&&(b=/AppleWebKit\/([0-9]+)(?:\.([0-9]+))/.exec(window.navigator.userAgent),C=!!b&&(536>parseInt(b[1],10)||536===parseInt(b[1],10)&&11>=parseInt(b[2],10))),b=C&&(f==w&&g==w&&h==w||f==x&&g==x&&h==x||f==y&&g==y&&h==y)),b=!b;b&&(d.parentNode&&d.parentNode.removeChild(d),clearTimeout(r),a(c))}function I(){if((new Date).getTime()-H>=n)d.parentNode&&d.parentNode.removeChild(d),b(Error(""+
n+"ms timeout exceeded"));else{var a=document.hidden;if(!0===a||void 0===a)f=e.a.offsetWidth,g=p.a.offsetWidth,h=q.a.offsetWidth,v();r=setTimeout(I,50)}}var e=new t(k),p=new t(k),q=new t(k),f=-1,g=-1,h=-1,w=-1,x=-1,y=-1,d=document.createElement("div");d.dir="ltr";u(e,L(c,"sans-serif"));u(p,L(c,"serif"));u(q,L(c,"monospace"));d.appendChild(e.a);d.appendChild(p.a);d.appendChild(q.a);document.body.appendChild(d);w=e.a.offsetWidth;x=p.a.offsetWidth;y=q.a.offsetWidth;I();A(e,function(a){f=a;v()});u(e,
L(c,'"'+c.family+'",sans-serif'));A(p,function(a){g=a;v()});u(p,L(c,'"'+c.family+'",serif'));A(q,function(a){h=a;v()});u(q,L(c,'"'+c.family+'",monospace'))})})};"object"===typeof module?module.exports=B:(window.FontFaceObserver=B,window.FontFaceObserver.prototype.load=B.prototype.load);}());