(function($) {
	$(function() {

		// Get browser
    	$.each($.browser, function(i) {
    	    $('body').addClass(i);

    	    return false;
    	});

    	// Get OS
    	var os = [
    		'iphone',
    		'ipad',
    		'windows',
    		'mac',
    		'linux'
    	];

    	var match = navigator.appVersion.toLowerCase().match(new RegExp(os.join('|')));
    	if (match) {
    	    $('body').addClass(match[0]);
    	};

    	// Some js is being attached here, and I don't want it

    	$('.advertising_block a').click(function(event) {
    		event.preventDefault();
    		event.stopPropagation();
    		window.open(this.href);

    	});

	});


	var homeInfoPanels = (function() {

		var init = function() {

			if ($('#products-featured').length === 0) {
				return;
			};

			$('#products-featured ul li').each(function() {

				var pane = $(this).find('.extra-info'),
				    link = $(this).find('h3 a')[0].href,
				    lastP = pane.find('p:last');

				lastP.append(' ');


				$('<a />', {
					'href': link,
					'html': 'More Information'
				}).appendTo(lastP);



				$(this).hoverIntent(function() {

				    pane.fadeIn(250);

				}, function() {
					pane.fadeOut(500);
				});

				$('<a />', { 'class': 'big-link', 'href': link }).appendTo(this);

				//$('<div />', { 'class': 'more-link', 'html': 'More +'}).appendTo(this);


			});

		};

		$(init);
	})();


	var menu = (function() {

		var init = function() {

			$('.sf-contener > ul > li:gt(0)').each(function() {

				var hoverIcon = $('<div class="hover" style="display: none;" />');

				hoverIcon.appendTo(this);

				$(this).find('a, strong').hoverIntent(function() {
					hoverIcon.show().fadeIn(500);
				}, function() {
					hoverIcon.fadeOut(500);
				});

			});

		};

		$(init);
	})();

	var fader = (function () {
		var fader, faderContainer, fadeTo;

		var init = function() {
			faderContainer = $('#gallery-container');
			fader = $('#gallery');

			fadeTo = $('<ol />', { id: 'gallery-jump-to' }).appendTo(faderContainer);

			var current = window.location.hash || '#panel-1';

			fader.find('ul li').first().addClass('active');
			fader.find('ul li').each(function(i) {

				var href = '#panel-' + (i + 1);
				var button = $('<li><a href="' + href + '">&bull;</a></li>').appendTo(fadeTo);

				if (href === current) {
					button.addClass('active');
				}

				button.find('a').click(function(event) {
					event.preventDefault();

					var link = $(this);
					var id = link[0].hash;

					// change the buttons
					link.parents('li').siblings().removeClass('active');
					link.parent().addClass('active');

					$(id).siblings('li').each(function(i) {
						var elem = $(this);

						if (elem.hasClass('active')) {
							var active = elem;
							var next = active.next();

							if (active.is(':last-child')) {
								next = $(id).parent().find('li').first();
							}

							active.addClass('last-active').removeClass('active');

							// make the current image fade over the next one
							next.addClass('active').css({opacity: 0.0}).animate({opacity: 1.0}, 800, function() {
								active.removeClass('active last-active');
							});
						}

					});

				});
			});

			setInterval(nextSlide, 5000);
		};

		var nextSlide = function() {
			var active = fadeTo.find('li.active');

			if (active.is(':last-child')) {
				fadeTo.find('li:first-child a').click();
			} else {
				active.next().find('a').click();
			}
		};

		$(init);
	})();

	var form = (function() {


		var init = function() {

			var link = $('#modal-form');

			if (link.length == 0) {
				return;
			}

			link.fancybox({
				width: 900,
				height: 500,
				type: 'iframe'
			});


		};

		$(init);
	})();


})(jQuery);



/**
 * jQuery.ScrollTo - Easy element scrolling using jQuery.
 * Copyright (c) 2007-2009 Ariel Flesler - aflesler(at)gmail(dot)com | http://flesler.blogspot.com
 * Dual licensed under MIT and GPL.
 * Date: 5/25/2009
 * @author Ariel Flesler
 * @version 1.4.2
 *
 * http://flesler.blogspot.com/2007/10/jqueryscrollto.html
 */


;(function(d){var k=d.scrollTo=function(a,i,e){d(window).scrollTo(a,i,e)};k.defaults={axis:'xy',duration:parseFloat(d.fn.jquery)>=1.3?0:1};k.window=function(a){return d(window)._scrollable()};d.fn._scrollable=function(){return this.map(function(){var a=this,i=!a.nodeName||d.inArray(a.nodeName.toLowerCase(),['iframe','#document','html','body'])!=-1;if(!i)return a;var e=(a.contentWindow||a).document||a.ownerDocument||a;return d.browser.safari||e.compatMode=='BackCompat'?e.body:e.documentElement})};d.fn.scrollTo=function(n,j,b){if(typeof j=='object'){b=j;j=0}if(typeof b=='function')b={onAfter:b};if(n=='max')n=9e9;b=d.extend({},k.defaults,b);j=j||b.speed||b.duration;b.queue=b.queue&&b.axis.length>1;if(b.queue)j/=2;b.offset=p(b.offset);b.over=p(b.over);return this._scrollable().each(function(){var q=this,r=d(q),f=n,s,g={},u=r.is('html,body');switch(typeof f){case'number':case'string':if(/^([+-]=)?\d+(\.\d+)?(px|%)?$/.test(f)){f=p(f);break}f=d(f,this);case'object':if(f.is||f.style)s=(f=d(f)).offset()}d.each(b.axis.split(''),function(a,i){var e=i=='x'?'Left':'Top',h=e.toLowerCase(),c='scroll'+e,l=q[c],m=k.max(q,i);if(s){g[c]=s[h]+(u?0:l-r.offset()[h]);if(b.margin){g[c]-=parseInt(f.css('margin'+e))||0;g[c]-=parseInt(f.css('border'+e+'Width'))||0}g[c]+=b.offset[h]||0;if(b.over[h])g[c]+=f[i=='x'?'width':'height']()*b.over[h]}else{var o=f[h];g[c]=o.slice&&o.slice(-1)=='%'?parseFloat(o)/100*m:o}if(/^\d+$/.test(g[c]))g[c]=g[c]<=0?0:Math.min(g[c],m);if(!a&&b.queue){if(l!=g[c])t(b.onAfterFirst);delete g[c]}});t(b.onAfter);function t(a){r.animate(g,j,b.easing,a&&function(){a.call(this,n,b)})}}).end()};k.max=function(a,i){var e=i=='x'?'Width':'Height',h='scroll'+e;if(!d(a).is('html,body'))return a[h]-d(a)[e.toLowerCase()]();var c='client'+e,l=a.ownerDocument.documentElement,m=a.ownerDocument.body;return Math.max(l[h],m[h])-Math.min(l[c],m[c])};function p(a){return typeof a=='object'?a:{top:a,left:a}}})(jQuery);



/**
* hoverIntent r5 // 2007.03.27 // jQuery 1.1.2+
* <http://cherne.net/brian/resources/jquery.hoverIntent.html>
*
* @param  f  onMouseOver function || An object with configuration options
* @param  g  onMouseOut function  || Nothing (use configuration options object)
* @author    Brian Cherne <brian@cherne.net>
*/
(function($){$.fn.hoverIntent=function(f,g){var cfg={sensitivity:7,interval:100,timeout:0};cfg=$.extend(cfg,g?{over:f,out:g}:f);var cX,cY,pX,pY;var track=function(ev){cX=ev.pageX;cY=ev.pageY;};var compare=function(ev,ob){ob.hoverIntent_t=clearTimeout(ob.hoverIntent_t);if((Math.abs(pX-cX)+Math.abs(pY-cY))<cfg.sensitivity){$(ob).unbind("mousemove",track);ob.hoverIntent_s=1;return cfg.over.apply(ob,[ev]);}else{pX=cX;pY=cY;ob.hoverIntent_t=setTimeout(function(){compare(ev,ob);},cfg.interval);}};var delay=function(ev,ob){ob.hoverIntent_t=clearTimeout(ob.hoverIntent_t);ob.hoverIntent_s=0;return cfg.out.apply(ob,[ev]);};var handleHover=function(e){var p=(e.type=="mouseover"?e.fromElement:e.toElement)||e.relatedTarget;while(p&&p!=this){try{p=p.parentNode;}catch(e){p=this;}}if(p==this){return false;}var ev=jQuery.extend({},e);var ob=this;if(ob.hoverIntent_t){ob.hoverIntent_t=clearTimeout(ob.hoverIntent_t);}if(e.type=="mouseover"){pX=ev.pageX;pY=ev.pageY;$(ob).bind("mousemove",track);if(ob.hoverIntent_s!=1){ob.hoverIntent_t=setTimeout(function(){compare(ev,ob);},cfg.interval);}}else{$(ob).unbind("mousemove",track);if(ob.hoverIntent_s==1){ob.hoverIntent_t=setTimeout(function(){delay(ev,ob);},cfg.timeout);}}};return this.mouseover(handleHover).mouseout(handleHover);};})(jQuery);

