$(function(){
	$("#menu").tabs("#menu .sub_section", {tabs: 'h2', effect: 'slide', onClick: function(){ }});
	$("#photocontainer_home").photoCycle();
	$("a[rel='example1']").colorbox({opacity:0.9});
	//$("a[rel='example1']").colorbox();
	$("a[rel='example2']").colorbox({transition:"fade"});
});


function aboutBG(show) {
	if (show) {
		$("#navabout").addClass("overlap");
	} else {
		$("#navabout").removeClass("overlap");
	}
	
}


/*****************
 * BEGIN PLUGINS *
 *****************/

/**
* jQuery Google Map Helper
**/
(function(c){c.fn.googleMap=function(a){var e={address:!1,LatLng:[0,0],zoom:8,icon:!1,alt:!1,mapType:"roadmap",onGeocodeError:function(){}},a=c.extend(e,a);return this.each(function(){var f=c(this)[0],g=new google.maps.LatLng(a.LatLng[0],a.LatLng[1]),b;switch(a.mapType){case "roadmap":b=google.maps.MapTypeId.ROADMAP;break;case "satellite":b=google.maps.MapTypeId.SATELLITE;break;case "hybrid":b=google.maps.MapTypeId.HYBRID;break;case "terrain":b=google.maps.MapTypeId.TERRAIN}var d=new google.maps.Map(f, {zoom:a.zoom,center:g,mapTypeId:b});a.address&&(new google.maps.Geocoder).geocode({address:a.address},function(b,c){c==google.maps.GeocoderStatus.OK?(d.setCenter(b[0].geometry.location),a.icon?new google.maps.Marker({map:d,position:b[0].geometry.location,icon:a.icon}):new google.maps.Marker({map:d,position:b[0].geometry.location})):c==google.maps.GeocoderStatus.ZERO_RESULTS&&e.onGeocodeError.call(this)})})}})(jQuery);

/**
 * OTHER PLUG-INS
 */

/*
 * jQuery Tools 1.2.5 - The missing UI library for the Web
 * 
 * [tabs, tooltip, scrollable, overlay, toolbox.expose]
 * 
 * NO COPYRIGHTS OR LICENSES. DO WHAT YOU LIKE.
 * 
 * http://flowplayer.org/tools/
 * 
 * File generated: Wed Jan 12 21:20:57 GMT 2011
 */
(function(a){a.tools=a.tools||{version:"v1.2.5"},a.tools.tabs={conf:{tabs:"a",current:"current",onBeforeClick:null,onClick:null,effect:"default",initialIndex:0,event:"click",rotate:!1,history:!1},addEffect:function(a,c){b[a]=c}};var b={"default":function(a,b){this.getPanes().hide().eq(a).show(),b.call()},fade:function(a,b){var c=this.getConf(),d=c.fadeOutSpeed,e=this.getPanes();d?e.fadeOut(d):e.hide(),e.eq(a).fadeIn(c.fadeInSpeed,b)},slide:function(a,b){this.getPanes().slideUp(200),this.getPanes().eq(a).slideDown(400,b)},ajax:function(a,b){this.getPanes().eq(0).load(this.getTabs().eq(a).attr("href"),b)}},c;a.tools.tabs.addEffect("horizontal",function(b,d){c||(c=this.getPanes().eq(0).width()),this.getCurrentPane().animate({width:0},function(){a(this).hide()}),this.getPanes().eq(b).animate({width:c},function(){a(this).show(),d.call()})});function d(c,d,e){var f=this,g=c.add(this),h=c.find(e.tabs),i=d.jquery?d:c.children(d),j;h.length||(h=c.children()),i.length||(i=c.parent().find(d)),i.length||(i=a(d)),a.extend(this,{click:function(c,d){var i=h.eq(c);typeof c=="string"&&c.replace("#","")&&(i=h.filter("[href*="+c.replace("#","")+"]"),c=Math.max(h.index(i),0));if(e.rotate){var k=h.length-1;if(c<0)return f.click(k,d);if(c>k)return f.click(0,d)}if(!i.length){if(j>=0)return f;c=e.initialIndex,i=h.eq(c)}if(c===j)return f;d=d||a.Event(),d.type="onBeforeClick",g.trigger(d,[c]);if(!d.isDefaultPrevented()){b[e.effect].call(f,c,function(){d.type="onClick",g.trigger(d,[c])}),j=c,h.removeClass(e.current),i.addClass(e.current);return f}},getConf:function(){return e},getTabs:function(){return h},getPanes:function(){return i},getCurrentPane:function(){return i.eq(j)},getCurrentTab:function(){return h.eq(j)},getIndex:function(){return j},next:function(){return f.click(j+1)},prev:function(){return f.click(j-1)},destroy:function(){h.unbind(e.event).removeClass(e.current),i.find("a[href^=#]").unbind("click.T");return f}}),a.each("onBeforeClick,onClick".split(","),function(b,c){a.isFunction(e[c])&&a(f).bind(c,e[c]),f[c]=function(b){b&&a(f).bind(c,b);return f}}),e.history&&a.fn.history&&(a.tools.history.init(h),e.event="history"),h.each(function(b){a(this).bind(e.event,function(a){f.click(b,a);return a.preventDefault()})}),i.find("a[href^=#]").bind("click.T",function(b){f.click(a(this).attr("href"),b)}),location.hash&&e.tabs=="a"&&c.find("[href="+location.hash+"]").length?f.click(location.hash):(e.initialIndex===0||e.initialIndex>0)&&f.click(e.initialIndex)}a.fn.tabs=function(b,c){var e=this.data("tabs");e&&(e.destroy(),this.removeData("tabs")),a.isFunction(c)&&(c={onBeforeClick:c}),c=a.extend({},a.tools.tabs.conf,c),this.each(function(){e=new d(a(this),b,c),a(this).data("tabs",e)});return c.api?e:this}})(jQuery);




/**
 * BEGIN PHOTO CYCLE
 */
(function($) {  
	$.fn.photoCycle = function() {
		return this.each(function() {
			var limit = $(".photo").size();
			var delay = 5000;
			var timeoutDelay = 5000;
			var current = limit-1;
			var count = 0;
			var isForced = false;	
			var isPaused = false;
			var isAfterForced = false;
			var rotate;
			var timeout;
			var timeoutStatus;
			var currentPhoto;
			var nextPhoto;	
			
			if(limit > 1){
				$("#photo_nav_container a").bind("click", forceSwapPhoto);
				$("#icon_playpause").bind("click", toggleTimer);
			$("#photomove .photo").addClass("position2");
			createTimer();
			swapPhoto();
			} else {
				$("#icon_playpause").addClass("current");
				$("#photo_nav_container a:eq(0)").addClass("current");
				$("#photo_nav_container a").bind("click", function(){ return false; });
				$("#icon_playpause").bind("click", function(){ return false; });	
			}
			$("#photomove .photo .videolink").bind("click", swapVideo);

			function swapVideo(event){
				if(!isPaused){
					$("#icon_playpause").trigger("click");
				}
				var obj = $(event.currentTarget);
				obj.hide();
				obj.next().show();
				
				return false;
				}


			function swapPhoto() {
				currentPhoto = $("#photomove .photo:eq("+current+")");
				nextPhoto = $("#photomove .photo:eq("+count+")");
				currentPhoto.removeClass("position2").addClass("position0");
				nextPhoto.removeClass("position2").addClass("position1");
				$("#photo_nav_container a.current").removeClass("current");	
				$("#photo_nav_container a:eq("+count+")").addClass("current");				
				animatePhoto();
			}
			
			function forceSwapPhoto(event){
				delayTimer();
				var obj = $(event.currentTarget);
				var index = $("#photo_nav_container a").index(obj);
				if(count !== index){
					$("#photo_nav_container a").unbind("click", forceSwapPhoto);
					$("#photo_nav_container a").bind("click", function(){ return false; });
					isForced = true;
					current = count;
					count = index;
					swapPhoto();
					obj.blur();
				}
				return false;
			}
			
			function autoSwapPhoto() {
				controlCurrent("up");
				swapPhoto();
			}
			
			function animatePhoto(){
				$("#photomove").stop(true, true);
				$("#photomove").animate({"right":"444px"}, updatePosition);
			}
			
			function updatePosition(){
				$("#photomove").css({"right":"0"});
				nextPhoto.removeClass("position1").addClass("position0");
				currentPhoto.removeClass("position0").addClass("position2");
				if(isForced) {
					$("#photo_nav_container a").unbind("click");
					$("#photo_nav_container a").bind("click", forceSwapPhoto);	
					isForced = false;
					isAfterForced = true;
				}
				$("#photomove .photo").find(".videolink").show();
				$("#photomove .photo").find(".videoembed").hide();
			}
						
			function createTimer(){
				rotate = setInterval(autoSwapPhoto,delay);
			}
			
			function stopTimer(){
					clearInterval(rotate);
					if(typeof(timeout) != 'undefined'){
						clearTimeout(timeout);
					}
			}
			
			function delayTimer(){
				stopTimer();
				if(!isPaused){
					timeout = setTimeout(createTimer, timeoutDelay);
				}
			}
			
			function toggleTimer(event){
				var obj = $(event.currentTarget);				
				if(isPaused){
					createTimer();
					isPaused = false;	
					obj.removeClass("current");
				} else {
					stopTimer();
					isPaused = true;
					obj.addClass("current");
				}
				obj.blur();
				
				return false;
			}
			
			function controlCurrent(dir) {
				if(isAfterForced){
					current = count;
					count = current + 1;
					if(current == limit-1){
						count = 0;	
					}
					isAfterForced = false;
				} else if (current == limit-1 && dir == "up") {
					current = 0;
					count = 1;
				} else {
					current++;
					if(dir == "up" && current == 0){
						count = 1;
					} else if(dir == "up" && current == limit-1){
						count = 0;	
					} else if(dir == "up" && current > 0 && current < limit-1){
						count = current+1;
					}
				}
			}
		});
	}
})(jQuery);
/**
 * END PHOTO CYCLE
 */



/**
 * BEGIN FEATURED SCROLL
 */
(function($) {  
	$.fn.featureScroll = function(options) {
		defaults = {
			listDisplayUp: 1,
			navDisplayUp: 4,
			listScrollRate: 496,
			navScrollRate: 56,
			scrollInterval:5000,
			pauseTimeout:10000,
			offClass: "fade",
			nextBtn: "p.forward",
			prevBtn: "p.backward",
			prefix: "featured"
		}
		var options = $.extend(defaults, options);
		
		var listIndex = 0;
		var navIndex = 0;
		var moveIndex = 0;
		var total = $("#" + options.prefix + "-list td").length;
		var moveTotal = total-options.navDisplayUp;
		var intervalID;
		var timerID;
		
		var obj;
		var listDiv;
		var navDiv;
		
		return this.each(function() {
			obj = $(this);
			listDiv = obj.find("#" + options.prefix + "-list");
			navDiv = obj.find("#" + options.prefix + "-nav-list");
			
			obj.find("#" + options.prefix + "-nav").show();
			listDiv.css("overflow","hidden");
			listDiv.scrollLeft(0);
			navDiv.scrollLeft(0);
			obj.find(options.prevBtn).addClass(options.offClass);
			obj.find(options.nextBtn).addClass(options.offClass);
			
			navDiv.find("img").addClass(options.offClass);
			navDiv.find("img:eq(0)").removeClass(options.offClass);
			makeAutoScrollGo();
			navListControl();
			if(moveTotal>0){
				obj.find(options.nextBtn).removeClass(options.offClass);
			}
		});
		
		function makeAutoScrollGo(){
			intervalID = setInterval(autoMoveFeatured, options.scrollInterval);	
		}
		
		function autoMoveFeatured(){
			(listIndex < total-options.listDisplayUp) ? (listIndex++):(listIndex = 0);
			(navIndex < total-1) ? (navIndex++):(navIndex = 0);
			var listScrollAmount = options.listScrollRate*listIndex;
			var navScrollAmount = options.navScrollRate*navIndex;
			
			navDiv.find("img").addClass(options.offClass);
			navDiv.find("img:eq("+navIndex+")").removeClass(options.offClass);
			listDiv.animate({scrollLeft: listScrollAmount});
			navDiv.animate({scrollLeft: navScrollAmount});
			moveIndex = navIndex;
			checkArrows();
		}
		
		function checkArrows(){
			if(moveIndex > 0){
				obj.find(options.prevBtn).removeClass(options.offClass);	
			} else {
				obj.find(options.prevBtn).addClass(options.offClass);	
			}
			if(moveIndex >= moveTotal){
				moveIndex = moveTotal;
				obj.find(options.nextBtn).addClass(options.offClass);
			} else {
				obj.find(options.nextBtn).removeClass(options.offClass);	
			}
			if(moveTotal <= 0){
				obj.find(options.prevBtn).addClass(options.offClass);	
				obj.find(options.nextBtn).addClass(options.offClass);	

			}
		}
		
		function navListControl(){
			checkArrows();			
			navDiv.find("img").click(
				function(){
					clearTimeout(timerID);
					clearInterval(intervalID);
					timerID = setTimeout(makeAutoScrollGo,options.pauseTimeout);
					var clickIndex = navDiv.find("img").index(this);
					var clickListScrollAmount = options.listScrollRate * clickIndex;
					var clickNavScrollAmount = options.navScrollRate * clickIndex;
					
					navDiv.find("img").addClass(options.offClass);
					navDiv.find("img:eq("+clickIndex+")").removeClass(options.offClass);
					listDiv.animate({scrollLeft: clickListScrollAmount});
					navDiv.animate({scrollLeft: clickNavScrollAmount});
					
					listIndex = clickIndex;
					navIndex = clickIndex;
					moveIndex = clickIndex;
					checkArrows();
				}
			);
			obj.find(options.prevBtn).click(
				function(){
					moveNavList("previous");
				}
			);
			obj.find(options.nextBtn).click(
				function(){
					moveNavList("next");					
				}
			);
			function moveNavList(direction){
				clearTimeout(timerID);
				clearInterval(intervalID);
				timerID = setTimeout(makeAutoScrollGo,options.pauseTimeout);
				switch(direction){
					case "previous":
						obj.find(options.nextBtn).removeClass(options.offClass);
						(moveIndex > 0) ? (moveIndex--):(moveIndex = 0);
						if(moveIndex == 0){
							obj.find(options.prevBtn).addClass(options.offClass);	
						}
						break;
					case "next":
						obj.find(options.prevBtn).removeClass(options.offClass);
						(moveIndex < moveTotal) ?(moveIndex++):(moveIndex = moveTotal);
						if(moveIndex == moveTotal){
							obj.find(options.nextBtn).addClass(options.offClass);	
						}
						break;
				}
				var moveNavScrollAmount = options.navScrollRate * moveIndex;
				navDiv.animate({scrollLeft: moveNavScrollAmount});
				checkArrows();
			}
		}

	}
})(jQuery);  
/**
 * END FEATURED SCROLL
 */
 
 /**
  * Collapsable
  */
 (function($) {  
	$.fn.pressReadMore = function() {
		return this.each(function() {
		var obj = $(this);					  
		
		if(obj.height() > 120){
			obj.addClass("collapse");
			obj.after("<p class='readmore'>SHOW MORE</p><div class='clear'></div>");
			obj.next().bind("click", pressReadMore);
		}
		
		function pressReadMore(event){
			var currObj = $(event.currentTarget);
			var display = currObj.prev();
			if(display.hasClass("collapse")){
				display.removeClass("collapse");
				currObj.text("SHOW LESS");
			} else {
				display.addClass("collapse");
				currObj.text("SHOW MORE");	
			}
		}
	  });
	}
})(jQuery);
/**
  * END Collapsable
  */

/**
 * BEGIN PHOTO SCROLL
 */
(function($) {  
	$.fn.photoScroll = function(options) {
		var defaults = {
			scrollCount: 1, // Items to scroll per click, use this number to determine pages
			pxPerItem: 444, // the width of each item -- kev wants to calculate this
			displayUp: 1, // how many to display at a time
			totalOffset: 0, // This number represents any additional td tags that exist in photo scroll, but are not links
			offClass: "fade",
			nextBtn: ".forward",
			prevBtn: ".backward"
		}
		var options = $.extend(defaults, options);
		var obj;
		var scrollDiv;
		var index = 0;
		var total;
		var pages;
		var page;
		var pageIndex = 1;
		var photos; // holds all the photos
		return this.each(function() {
			
			photos = $("#photocontainer a");
			
			obj = $(this);
			scrollDiv = obj.find("#photocontainer");
			// total number of items
			total = obj.find("#photocontainer td").size()-options.totalOffset;
			// get total number of pages
			pages = Math.max(1, Math.ceil((total - (options.displayUp - options.scrollCount)) / options.scrollCount));
			// Make sure page number is within valid range.
			pageIndex = Math.max(1, pageIndex);
			pageIndex = Math.min(pages, pageIndex);

			scrollDiv.scrollLeft(0);
			scrollDiv.css("overflow","hidden");
			
			// disable prev and next nav items by default
			obj.find(options.prevBtn).addClass(options.offClass);
			obj.find(options.nextBtn).addClass(options.offClass);
			
			// check if prev and next nav items might be necessary
			if (pages > 1) {
				
				obj.find(options.nextBtn).removeClass(options.offClass);
				obj.find(options.prevBtn).click(
					function(){
						moveScroll("previous");
						$(this).blur();
						return false;
					}
				);
				obj.find(options.nextBtn).click(
					function(){
						moveScroll("next");
						$(this).blur();
						return false;
					}
				)
			}
		});
		function moveScroll(direction) {
			switch (direction) {
				case "previous":
					obj.find(options.nextBtn).removeClass(options.offClass);
					(pageIndex > 1) ? (pageIndex--) : (pageIndex = 1);
					if (pageIndex == 1) {
						obj.find(options.prevBtn).addClass(options.offClass);	
					}
					break;
				case "next":
					obj.find(options.prevBtn).removeClass(options.offClass);
					(pageIndex < pages) ? (pageIndex++) : (pageIndex = pages);
					if(pageIndex == pages){
						obj.find(options.nextBtn).addClass(options.offClass);	
					}
					
					// need to loop thru images to check if the a tag is empty
					// get start and end point
					start = (pageIndex * 6);
					end = start + 6;
					if (end > photos.size()) end = photos.size();
					
					for (i = start; i < end; i++) {
						if ($(photos[i]).children("img").size() == 0) {
							curid = $(photos[i]).attr("id");
							$(photos[i]).html("<img src=\"" + curid + "\" border=\"0\" width=\"118\" height=\"118\" class=\"thumb\">");
						}
					}
					
					break;
			}
			
			scrollAmount = (options.scrollCount * options.pxPerItem) * (pageIndex - 1);
			scrollDiv.animate({scrollLeft: scrollAmount},150 * options.scrollCount);
		}
	}
})(jQuery);
/**
 * END PHOTO SCROLL
 */
 
 
 
 
// ColorBox v1.3.17.2 - a full featured, light-weight, customizable lightbox based on jQuery 1.3+
// Copyright (c) 2011 Jack Moore - jack@colorpowered.com
// Licensed under the MIT license: http://www.opensource.org/licenses/mit-license.php
(function(a,b,c){function bc(b){if(!U){P=b,_(),y=a(P),Q=0,K.rel!=="nofollow"&&(y=a("."+g).filter(function(){var b=a.data(this,e).rel||this.rel;return b===K.rel}),Q=y.index(P),Q===-1&&(y=y.add(P),Q=y.length-1));if(!S){S=T=!0,r.show();if(K.returnFocus)try{P.blur(),a(P).one(l,function(){try{this.focus()}catch(a){}})}catch(c){}q.css({opacity:+K.opacity,cursor:K.overlayClose?"pointer":"auto"}).show(),K.w=Z(K.initialWidth,"x"),K.h=Z(K.initialHeight,"y"),X.position(),o&&z.bind("resize."+p+" scroll."+p,function(){q.css({width:z.width(),height:z.height(),top:z.scrollTop(),left:z.scrollLeft()})}).trigger("resize."+p),ba(h,K.onOpen),J.add(D).hide(),I.html(K.close).show()}X.load(!0)}}function bb(){var a,b=f+"Slideshow_",c="click."+f,d,e,g;K.slideshow&&y[1]?(d=function(){F.text(K.slideshowStop).unbind(c).bind(j,function(){if(Q<y.length-1||K.loop)a=setTimeout(X.next,K.slideshowSpeed)}).bind(i,function(){clearTimeout(a)}).one(c+" "+k,e),r.removeClass(b+"off").addClass(b+"on"),a=setTimeout(X.next,K.slideshowSpeed)},e=function(){clearTimeout(a),F.text(K.slideshowStart).unbind([j,i,k,c].join(" ")).one(c,d),r.removeClass(b+"on").addClass(b+"off")},K.slideshowAuto?d():e()):r.removeClass(b+"off "+b+"on")}function ba(b,c){c&&c.call(P),a.event.trigger(b)}function _(b){K=a.extend({},a.data(P,e));for(b in K)a.isFunction(K[b])&&b.substring(0,2)!=="on"&&(K[b]=K[b].call(P));K.rel=K.rel||P.rel||"nofollow",K.href=K.href||a(P).attr("href"),K.title=K.title||P.title,typeof K.href=="string"&&(K.href=a.trim(K.href))}function $(a){return K.photo||/\.(gif|png|jpg|jpeg|bmp)(?:\?([^#]*))?(?:#(\.*))?$/i.test(a)}function Z(a,b){return Math.round((/%/.test(a)?(b==="x"?z.width():z.height())/100:1)*parseInt(a,10))}function Y(c,d,e){e=b.createElement("div"),c&&(e.id=f+c),e.style.cssText=d||"";return a(e)}var d={transition:"elastic",speed:300,width:!1,initialWidth:"600",innerWidth:!1,maxWidth:!1,height:!1,initialHeight:"450",innerHeight:!1,maxHeight:!1,scalePhotos:!0,scrolling:!0,inline:!1,html:!1,iframe:!1,fastIframe:!0,photo:!1,href:!1,title:!1,rel:!1,opacity:.9,preloading:!0,current:"image {current} of {total}",previous:"previous",next:"next",close:"close",open:!1,returnFocus:!0,loop:!0,slideshow:!1,slideshowAuto:!0,slideshowSpeed:2500,slideshowStart:"start slideshow",slideshowStop:"stop slideshow",onOpen:!1,onLoad:!1,onComplete:!1,onCleanup:!1,onClosed:!1,overlayClose:!0,escKey:!0,arrowKey:!0,top:!1,bottom:!1,left:!1,right:!1,fixed:!1,data:!1},e="colorbox",f="cbox",g=f+"Element",h=f+"_open",i=f+"_load",j=f+"_complete",k=f+"_cleanup",l=f+"_closed",m=f+"_purge",n=a.browser.msie&&!a.support.opacity,o=n&&a.browser.version<7,p=f+"_IE6",q,r,s,t,u,v,w,x,y,z,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X;X=a.fn[e]=a[e]=function(b,c){var f=this;b=b||{};if(!f[0]){if(f.selector)return f;f=a("<a/>"),b.open=!0}c&&(b.onComplete=c),f.each(function(){a.data(this,e,a.extend({},a.data(this,e)||d,b)),a(this).addClass(g)}),(a.isFunction(b.open)&&b.open.call(f)||b.open)&&bc(f[0]);return f},X.init=function(){z=a(c),r=Y().attr({id:e,"class":n?f+(o?"IE6":"IE"):""}),q=Y("Overlay",o?"position:absolute":"").hide(),s=Y("Wrapper"),t=Y("Content").append(A=Y("LoadedContent","width:0; height:0; overflow:hidden"),C=Y("LoadingOverlay").add(Y("LoadingGraphic")),D=Y("Title"),E=Y("Current"),G=Y("Next"),H=Y("Previous"),F=Y("Slideshow").bind(h,bb),I=Y("Close")),s.append(Y().append(Y("TopLeft"),u=Y("TopCenter"),Y("TopRight")),Y(!1,"clear:left").append(v=Y("MiddleLeft"),t,w=Y("MiddleRight")),Y(!1,"clear:left").append(Y("BottomLeft"),x=Y("BottomCenter"),Y("BottomRight"))).children().children().css({"float":"left"}),B=Y(!1,"position:absolute; width:9999px; visibility:hidden; display:none"),a("body").prepend(q,r.append(s,B)),t.children().hover(function(){a(this).addClass("hover")},function(){a(this).removeClass("hover")}).addClass("hover"),L=u.height()+x.height()+t.outerHeight(!0)-t.height(),M=v.width()+w.width()+t.outerWidth(!0)-t.width(),N=A.outerHeight(!0),O=A.outerWidth(!0),r.css({"padding-bottom":L,"padding-right":M}).hide(),G.click(function(){X.next()}),H.click(function(){X.prev()}),I.click(function(){X.close()}),J=G.add(H).add(E).add(F),t.children().removeClass("hover"),q.click(function(){K.overlayClose&&X.close()}),a(b).bind("keydown."+f,function(a){var b=a.keyCode;S&&K.escKey&&b===27&&(a.preventDefault(),X.close()),S&&K.arrowKey&&y[1]&&(b===37?(a.preventDefault(),H.click()):b===39&&(a.preventDefault(),G.click()))})},X.remove=function(){r.add(q).remove(),a("."+g).removeData(e).removeClass(g)},X.position=function(a,c){function g(a){u[0].style.width=x[0].style.width=t[0].style.width=a.style.width,C[0].style.height=C[1].style.height=t[0].style.height=v[0].style.height=w[0].style.height=a.style.height}var d=0,e=0;z.unbind("resize."+f),r.hide(),K.fixed&&!o?r.css({position:"fixed"}):(d=z.scrollTop(),e=z.scrollLeft(),r.css({position:"absolute"})),K.right!==!1?e+=Math.max(z.width()-K.w-O-M-Z(K.right,"x"),0):K.left!==!1?e+=Z(K.left,"x"):e+=Math.round(Math.max(z.width()-K.w-O-M,0)/2),K.bottom!==!1?d+=Math.max(b.documentElement.clientHeight-K.h-N-L-Z(K.bottom,"y"),0):K.top!==!1?d+=Z(K.top,"y"):d+=Math.round(Math.max(b.documentElement.clientHeight-K.h-N-L,0)/2),r.show(),a=r.width()===K.w+O&&r.height()===K.h+N?0:a||0,s[0].style.width=s[0].style.height="9999px",r.dequeue().animate({width:K.w+O,height:K.h+N,top:d,left:e},{duration:a,complete:function(){g(this),T=!1,s[0].style.width=K.w+O+M+"px",s[0].style.height=K.h+N+L+"px",c&&c(),setTimeout(function(){z.bind("resize."+f,X.position)},1)},step:function(){g(this)}})},X.resize=function(a){if(S){a=a||{},a.width&&(K.w=Z(a.width,"x")-O-M),a.innerWidth&&(K.w=Z(a.innerWidth,"x")),A.css({width:K.w}),a.height&&(K.h=Z(a.height,"y")-N-L),a.innerHeight&&(K.h=Z(a.innerHeight,"y"));if(!a.innerHeight&&!a.height){var b=A.wrapInner("<div style='overflow:auto'></div>").children();K.h=b.height(),b.replaceWith(b.children())}A.css({height:K.h}),X.position(K.transition==="none"?0:K.speed)}},X.prep=function(b){function h(){K.h=K.h||A.height(),K.h=K.mh&&K.mh<K.h?K.mh:K.h;return K.h}function g(){K.w=K.w||A.width(),K.w=K.mw&&K.mw<K.w?K.mw:K.w;return K.w}if(!!S){var c,d=K.transition==="none"?0:K.speed;A.remove(),A=Y("LoadedContent").append(b),A.hide().appendTo(B.show()).css({width:g(),overflow:K.scrolling?"auto":"hidden"}).css({height:h()}).prependTo(t),B.hide(),a(R).css({"float":"none"}),o&&a("select").not(r.find("select")).filter(function(){return this.style.visibility!=="hidden"}).css({visibility:"hidden"}).one(k,function(){this.style.visibility="inherit"}),c=function(){function o(){n&&r[0].style.removeAttribute("filter")}var b,c,g,h,i=y.length,k,l;!S||(l=function(){clearTimeout(W),C.hide(),ba(j,K.onComplete)},n&&R&&A.fadeIn(100),D.html(K.title).add(A).show(),i>1?(typeof K.current=="string"&&E.html(K.current.replace("{current}",Q+1).replace("{total}",i)).show(),G[K.loop||Q<i-1?"show":"hide"]().html(K.next),H[K.loop||Q?"show":"hide"]().html(K.previous),b=Q?y[Q-1]:y[i-1],g=Q<i-1?y[Q+1]:y[0],K.slideshow&&F.show(),K.preloading&&(h=a.data(g,e).href||g.href,c=a.data(b,e).href||b.href,h=a.isFunction(h)?h.call(g):h,c=a.isFunction(c)?c.call(b):c,$(h)&&(a("<img/>")[0].src=h),$(c)&&(a("<img/>")[0].src=c))):J.hide(),K.iframe?(k=a("<iframe/>").addClass(f+"Iframe")[0],K.fastIframe?l():a(k).one("load",l),k.name=f+ +(new Date),k.src=K.href,K.scrolling||(k.scrolling="no"),n&&(k.frameBorder=0,k.allowTransparency="true"),a(k).appendTo(A).one(m,function(){k.src="//about:blank"})):l(),K.transition==="fade"?r.fadeTo(d,1,o):o())},K.transition==="fade"?r.fadeTo(d,0,function(){X.position(0,c)}):X.position(d,c)}},X.load=function(b){var c,d,e=X.prep;T=!0,R=!1,P=y[Q],b||_(),ba(m),ba(i,K.onLoad),K.h=K.height?Z(K.height,"y")-N-L:K.innerHeight&&Z(K.innerHeight,"y"),K.w=K.width?Z(K.width,"x")-O-M:K.innerWidth&&Z(K.innerWidth,"x"),K.mw=K.w,K.mh=K.h,K.maxWidth&&(K.mw=Z(K.maxWidth,"x")-O-M,K.mw=K.w&&K.w<K.mw?K.w:K.mw),K.maxHeight&&(K.mh=Z(K.maxHeight,"y")-N-L,K.mh=K.h&&K.h<K.mh?K.h:K.mh),c=K.href,W=setTimeout(function(){C.show()},100),K.inline?(Y().hide().insertBefore(a(c)[0]).one(m,function(){a(this).replaceWith(A.children())}),e(a(c))):K.iframe?e(" "):K.html?e(K.html):$(c)?(a(R=new Image).addClass(f+"Photo").error(function(){K.title=!1,e(Y("Error").text("This image could not be loaded"))}).load(function(){var a;R.onload=null,K.scalePhotos&&(d=function(){R.height-=R.height*a,R.width-=R.width*a},K.mw&&R.width>K.mw&&(a=(R.width-K.mw)/R.width,d()),K.mh&&R.height>K.mh&&(a=(R.height-K.mh)/R.height,d())),K.h&&(R.style.marginTop=Math.max(K.h-R.height,0)/2+"px"),y[1]&&(Q<y.length-1||K.loop)&&(R.style.cursor="pointer",R.onclick=function(){X.next()}),n&&(R.style.msInterpolationMode="bicubic"),setTimeout(function(){e(R)},1)}),setTimeout(function(){R.src=c},1)):c&&B.load(c,K.data,function(b,c,d){e(c==="error"?Y("Error").text("Request unsuccessful: "+d.statusText):a(this).contents())})},X.next=function(){!T&&y[1]&&(Q<y.length-1||K.loop)&&(Q=Q<y.length-1?Q+1:0,X.load())},X.prev=function(){!T&&y[1]&&(Q||K.loop)&&(Q=Q?Q-1:y.length-1,X.load())},X.close=function(){S&&!U&&(U=!0,S=!1,ba(k,K.onCleanup),z.unbind("."+f+" ."+p),q.fadeTo(200,0),r.stop().fadeTo(300,0,function(){r.add(q).css({opacity:1,cursor:"auto"}).hide(),ba(m),A.remove(),setTimeout(function(){U=!1,ba(l,K.onClosed)},1)}))},X.element=function(){return a(P)},X.settings=d,V=function(a){a.button!==0&&typeof a.button!="undefined"||a.ctrlKey||a.shiftKey||a.altKey||(a.preventDefault(),bc(this))},a.fn.delegate?a(b).delegate("."+g,"click",V):a("."+g).live("click",V),a(X.init)})(jQuery,document,this);
