$(document).ready(
		function(){
			$('#gallery').innerfade({
				animationtype: 'fade',
				speed: 600,
				timeout: 4000,
				type: 'sequence',
				containerheight: '270px'
			});
 		}
	);


$(document).ready(function() {
	function megaHoverOver(){
		$(this).find(".sub").stop().fadeTo('fast', 1).show();
		//Calculate width of all ul's
		(function($) {
			jQuery.fn.calcSubWidth = function() {
				rowWidth = 0;
				//Calculate row
				$(this).find("ul").each(function() {
					rowWidth += $(this).width();
				});
			};
		})(jQuery);

		if ( $(this).find(".row").length > 0 ) { //If row exists...
			var biggestRow = 0;
			//Calculate each row
			$(this).find(".row").each(function() {
				$(this).calcSubWidth();
				//Find biggest row
				if(rowWidth > biggestRow) {
					biggestRow = rowWidth;
				}
			});
			//Set width
			$(this).find(".sub").css({'width' :biggestRow});
			$(this).find(".row:last").css({'margin':'0'});

		} else { //If row does not exist...

			$(this).calcSubWidth();
			//Set Width
			$(this).find(".sub").css({'width' : rowWidth});
			// Clear navigation edge
			var topNavOffset = $('#nav').offset();
			var topNavRightEdge = topNavOffset.left + $('#nav').width();
			var thisOffset = $(this).offset();
			var thisRightEdge = thisOffset.left + $(this).width();
			var rightEdgeOffset = $(this).find('.sub').offset();
			if (rightEdgeOffset == null) rightEdgeOffset = 0;
			var rightEdge = rightEdgeOffset.left + rowWidth;
			if (rightEdge > topNavRightEdge) {
				var calc = rowWidth - (topNavRightEdge - thisRightEdge) - 47;
				//alert(calc);
				//$('#search_q').val('rW: ' + rowWidth + '; tNRE: ' + topNavRightEdge + '; tRE: ' + thisRightEdge + '; os: -' + calc);
				$(this).find('.sub').css({'left': (0 - calc)});
			}
		}
	}

	function megaHoverOut(){
	  $(this).find(".sub").stop().fadeTo('fast', 0, function() {
		  $(this).hide();
	  });
	}

	var config = {
		 sensitivity: 2, // number = sensitivity threshold (must be 1 or higher)
		 interval: 100, // number = milliseconds for onMouseOver polling interval
		 over: megaHoverOver, // function = onMouseOver callback (REQUIRED)
		 timeout: 500, // number = milliseconds delay before onMouseOut
		 out: megaHoverOut // function = onMouseOut callback (REQUIRED)
	};
	$("ul#nav li .sub").css({'opacity':'0'});
	$("ul#nav li").hoverIntent(config);
});

