/*!
 * jQuery JavaScript Library v1.4.2
 * http://jquery.com/
 *
 * Copyright 2010, John Resig
 * Dual licensed under the MIT or GPL Version 2 licenses.
 * http://jquery.org/license
 *
 * Includes Sizzle.js
 * http://sizzlejs.com/
 * Copyright 2010, The Dojo Foundation
 * Released under the MIT, BSD, and GPL Licenses.
 *
 * Date: Sat Feb 13 22:33:48 2010 -0500
 */
(function(A,w){function ma(){if(!c.isReady){try{s.documentElement.doScroll("left")}catch(a){setTimeout(ma,1);return}c.ready()}}function Qa(a,b){b.src?c.ajax({url:b.src,async:false,dataType:"script"}):c.globalEval(b.text||b.textContent||b.innerHTML||"");b.parentNode&&b.parentNode.removeChild(b)}function X(a,b,d,f,e,j){var i=a.length;if(typeof b==="object"){for(var o in b)X(a,o,b[o],f,e,d);return a}if(d!==w){f=!j&&f&&c.isFunction(d);for(o=0;o<i;o++)e(a[o],b,f?d.call(a[o],o,e(a[o],b)):d,j);return a}return i?
e(a[0],b):w}function J(){return(new Date).getTime()}function Y(){return false}function Z(){return true}function na(a,b,d){d[0].type=a;return c.event.handle.apply(b,d)}function oa(a){var b,d=[],f=[],e=arguments,j,i,o,k,n,r;i=c.data(this,"events");if(!(a.liveFired===this||!i||!i.live||a.button&&a.type==="click")){a.liveFired=this;var u=i.live.slice(0);for(k=0;k<u.length;k++){i=u[k];i.origType.replace(O,"")===a.type?f.push(i.selector):u.splice(k--,1)}j=c(a.target).closest(f,a.currentTarget);n=0;for(r=
j.length;n<r;n++)for(k=0;k<u.length;k++){i=u[k];if(j[n].selector===i.selector){o=j[n].elem;f=null;if(i.preType==="mouseenter"||i.preType==="mouseleave")f=c(a.relatedTarget).closest(i.selector)[0];if(!f||f!==o)d.push({elem:o,handleObj:i})}}n=0;for(r=d.length;n<r;n++){j=d[n];a.currentTarget=j.elem;a.data=j.handleObj.data;a.handleObj=j.handleObj;if(j.handleObj.origHandler.apply(j.elem,e)===false){b=false;break}}return b}}function pa(a,b){return"live."+(a&&a!=="*"?a+".":"")+b.replace(/\./g,"`").replace(/ /g,
"&")}function qa(a){return!a||!a.parentNode||a.parentNode.nodeType===11}function ra(a,b){var d=0;b.each(function(){if(this.nodeName===(a[d]&&a[d].nodeName)){var f=c.data(a[d++]),e=c.data(this,f);if(f=f&&f.events){delete e.handle;e.events={};for(var j in f)for(var i in f[j])c.event.add(this,j,f[j][i],f[j][i].data)}}})}function sa(a,b,d){var f,e,j;b=b&&b[0]?b[0].ownerDocument||b[0]:s;if(a.length===1&&typeof a[0]==="string"&&a[0].length<512&&b===s&&!ta.test(a[0])&&(c.support.checkClone||!ua.test(a[0]))){e=
true;if(j=c.fragments[a[0]])if(j!==1)f=j}if(!f){f=b.createDocumentFragment();c.clean(a,b,f,d)}if(e)c.fragments[a[0]]=j?f:1;return{fragment:f,cacheable:e}}function K(a,b){var d={};c.each(va.concat.apply([],va.slice(0,b)),function(){d[this]=a});return d}function wa(a){return"scrollTo"in a&&a.document?a:a.nodeType===9?a.defaultView||a.parentWindow:false}var c=function(a,b){return new c.fn.init(a,b)},Ra=A.jQuery,Sa=A.$,s=A.document,T,Ta=/^[^<]*(<[\w\W]+>)[^>]*$|^#([\w-]+)$/,Ua=/^.[^:#\[\.,]*$/,Va=/\S/,
Wa=/^(\s|\u00A0)+|(\s|\u00A0)+$/g,Xa=/^<(\w+)\s*\/?>(?:<\/\1>)?$/,P=navigator.userAgent,xa=false,Q=[],L,$=Object.prototype.toString,aa=Object.prototype.hasOwnProperty,ba=Array.prototype.push,R=Array.prototype.slice,ya=Array.prototype.indexOf;c.fn=c.prototype={init:function(a,b){var d,f;if(!a)return this;if(a.nodeType){this.context=this[0]=a;this.length=1;return this}if(a==="body"&&!b){this.context=s;this[0]=s.body;this.selector="body";this.length=1;return this}if(typeof a==="string")if((d=Ta.exec(a))&&
(d[1]||!b))if(d[1]){f=b?b.ownerDocument||b:s;if(a=Xa.exec(a))if(c.isPlainObject(b)){a=[s.createElement(a[1])];c.fn.attr.call(a,b,true)}else a=[f.createElement(a[1])];else{a=sa([d[1]],[f]);a=(a.cacheable?a.fragment.cloneNode(true):a.fragment).childNodes}return c.merge(this,a)}else{if(b=s.getElementById(d[2])){if(b.id!==d[2])return T.find(a);this.length=1;this[0]=b}this.context=s;this.selector=a;return this}else if(!b&&/^\w+$/.test(a)){this.selector=a;this.context=s;a=s.getElementsByTagName(a);return c.merge(this,
a)}else return!b||b.jquery?(b||T).find(a):c(b).find(a);else if(c.isFunction(a))return T.ready(a);if(a.selector!==w){this.selector=a.selector;this.context=a.context}return c.makeArray(a,this)},selector:"",jquery:"1.4.2",length:0,size:function(){return this.length},toArray:function(){return R.call(this,0)},get:function(a){return a==null?this.toArray():a<0?this.slice(a)[0]:this[a]},pushStack:function(a,b,d){var f=c();c.isArray(a)?ba.apply(f,a):c.merge(f,a);f.prevObject=this;f.context=this.context;if(b===
"find")f.selector=this.selector+(this.selector?" ":"")+d;else if(b)f.selector=this.selector+"."+b+"("+d+")";return f},each:function(a,b){return c.each(this,a,b)},ready:function(a){c.bindReady();if(c.isReady)a.call(s,c);else Q&&Q.push(a);return this},eq:function(a){return a===-1?this.slice(a):this.slice(a,+a+1)},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},slice:function(){return this.pushStack(R.apply(this,arguments),"slice",R.call(arguments).join(","))},map:function(a){return this.pushStack(c.map(this,
function(b,d){return a.call(b,d,b)}))},end:function(){return this.prevObject||c(null)},push:ba,sort:[].sort,splice:[].splice};c.fn.init.prototype=c.fn;c.extend=c.fn.extend=function(){var a=arguments[0]||{},b=1,d=arguments.length,f=false,e,j,i,o;if(typeof a==="boolean"){f=a;a=arguments[1]||{};b=2}if(typeof a!=="object"&&!c.isFunction(a))a={};if(d===b){a=this;--b}for(;b<d;b++)if((e=arguments[b])!=null)for(j in e){i=a[j];o=e[j];if(a!==o)if(f&&o&&(c.isPlainObject(o)||c.isArray(o))){i=i&&(c.isPlainObject(i)||
c.isArray(i))?i:c.isArray(o)?[]:{};a[j]=c.extend(f,i,o)}else if(o!==w)a[j]=o}return a};c.extend({noConflict:function(a){A.$=Sa;if(a)A.jQuery=Ra;return c},isReady:false,ready:function(){if(!c.isReady){if(!s.body)return setTimeout(c.ready,13);c.isReady=true;if(Q){for(var a,b=0;a=Q[b++];)a.call(s,c);Q=null}c.fn.triggerHandler&&c(s).triggerHandler("ready")}},bindReady:function(){if(!xa){xa=true;if(s.readyState==="complete")return c.ready();if(s.addEventListener){s.addEventListener("DOMContentLoaded",
L,false);A.addEventListener("load",c.ready,false)}else if(s.attachEvent){s.attachEvent("onreadystatechange",L);A.attachEvent("onload",c.ready);var a=false;try{a=A.frameElement==null}catch(b){}s.documentElement.doScroll&&a&&ma()}}},isFunction:function(a){return $.call(a)==="[object Function]"},isArray:function(a){return $.call(a)==="[object Array]"},isPlainObject:function(a){if(!a||$.call(a)!=="[object Object]"||a.nodeType||a.setInterval)return false;if(a.constructor&&!aa.call(a,"constructor")&&!aa.call(a.constructor.prototype,
"isPrototypeOf"))return false;var b;for(b in a);return b===w||aa.call(a,b)},isEmptyObject:function(a){for(var b in a)return false;return true},error:function(a){throw a;},parseJSON:function(a){if(typeof a!=="string"||!a)return null;a=c.trim(a);if(/^[\],:{}\s]*$/.test(a.replace(/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g,"@").replace(/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g,"]").replace(/(?:^|:|,)(?:\s*\[)+/g,"")))return A.JSON&&A.JSON.parse?A.JSON.parse(a):(new Function("return "+
a))();else c.error("Invalid JSON: "+a)},noop:function(){},globalEval:function(a){if(a&&Va.test(a)){var b=s.getElementsByTagName("head")[0]||s.documentElement,d=s.createElement("script");d.type="text/javascript";if(c.support.scriptEval)d.appendChild(s.createTextNode(a));else d.text=a;b.insertBefore(d,b.firstChild);b.removeChild(d)}},nodeName:function(a,b){return a.nodeName&&a.nodeName.toUpperCase()===b.toUpperCase()},each:function(a,b,d){var f,e=0,j=a.length,i=j===w||c.isFunction(a);if(d)if(i)for(f in a){if(b.apply(a[f],
d)===false)break}else for(;e<j;){if(b.apply(a[e++],d)===false)break}else if(i)for(f in a){if(b.call(a[f],f,a[f])===false)break}else for(d=a[0];e<j&&b.call(d,e,d)!==false;d=a[++e]);return a},trim:function(a){return(a||"").replace(Wa,"")},makeArray:function(a,b){b=b||[];if(a!=null)a.length==null||typeof a==="string"||c.isFunction(a)||typeof a!=="function"&&a.setInterval?ba.call(b,a):c.merge(b,a);return b},inArray:function(a,b){if(b.indexOf)return b.indexOf(a);for(var d=0,f=b.length;d<f;d++)if(b[d]===
a)return d;return-1},merge:function(a,b){var d=a.length,f=0;if(typeof b.length==="number")for(var e=b.length;f<e;f++)a[d++]=b[f];else for(;b[f]!==w;)a[d++]=b[f++];a.length=d;return a},grep:function(a,b,d){for(var f=[],e=0,j=a.length;e<j;e++)!d!==!b(a[e],e)&&f.push(a[e]);return f},map:function(a,b,d){for(var f=[],e,j=0,i=a.length;j<i;j++){e=b(a[j],j,d);if(e!=null)f[f.length]=e}return f.concat.apply([],f)},guid:1,proxy:function(a,b,d){if(arguments.length===2)if(typeof b==="string"){d=a;a=d[b];b=w}else if(b&&
!c.isFunction(b)){d=b;b=w}if(!b&&a)b=function(){return a.apply(d||this,arguments)};if(a)b.guid=a.guid=a.guid||b.guid||c.guid++;return b},uaMatch:function(a){a=a.toLowerCase();a=/(webkit)[ \/]([\w.]+)/.exec(a)||/(opera)(?:.*version)?[ \/]([\w.]+)/.exec(a)||/(msie) ([\w.]+)/.exec(a)||!/compatible/.test(a)&&/(mozilla)(?:.*? rv:([\w.]+))?/.exec(a)||[];return{browser:a[1]||"",version:a[2]||"0"}},browser:{}});P=c.uaMatch(P);if(P.browser){c.browser[P.browser]=true;c.browser.version=P.version}if(c.browser.webkit)c.browser.safari=
true;if(ya)c.inArray=function(a,b){return ya.call(b,a)};T=c(s);if(s.addEventListener)L=function(){s.removeEventListener("DOMContentLoaded",L,false);c.ready()};else if(s.attachEvent)L=function(){if(s.readyState==="complete"){s.detachEvent("onreadystatechange",L);c.ready()}};(function(){c.support={};var a=s.documentElement,b=s.createElement("script"),d=s.createElement("div"),f="script"+J();d.style.display="none";d.innerHTML="   <link/><table></table><a href='/a' style='color:red;float:left;opacity:.55;'>a</a><input type='checkbox'/>";
var e=d.getElementsByTagName("*"),j=d.getElementsByTagName("a")[0];if(!(!e||!e.length||!j)){c.support={leadingWhitespace:d.firstChild.nodeType===3,tbody:!d.getElementsByTagName("tbody").length,htmlSerialize:!!d.getElementsByTagName("link").length,style:/red/.test(j.getAttribute("style")),hrefNormalized:j.getAttribute("href")==="/a",opacity:/^0.55$/.test(j.style.opacity),cssFloat:!!j.style.cssFloat,checkOn:d.getElementsByTagName("input")[0].value==="on",optSelected:s.createElement("select").appendChild(s.createElement("option")).selected,
parentNode:d.removeChild(d.appendChild(s.createElement("div"))).parentNode===null,deleteExpando:true,checkClone:false,scriptEval:false,noCloneEvent:true,boxModel:null};b.type="text/javascript";try{b.appendChild(s.createTextNode("window."+f+"=1;"))}catch(i){}a.insertBefore(b,a.firstChild);if(A[f]){c.support.scriptEval=true;delete A[f]}try{delete b.test}catch(o){c.support.deleteExpando=false}a.removeChild(b);if(d.attachEvent&&d.fireEvent){d.attachEvent("onclick",function k(){c.support.noCloneEvent=
false;d.detachEvent("onclick",k)});d.cloneNode(true).fireEvent("onclick")}d=s.createElement("div");d.innerHTML="<input type='radio' name='radiotest' checked='checked'/>";a=s.createDocumentFragment();a.appendChild(d.firstChild);c.support.checkClone=a.cloneNode(true).cloneNode(true).lastChild.checked;c(function(){var k=s.createElement("div");k.style.width=k.style.paddingLeft="1px";s.body.appendChild(k);c.boxModel=c.support.boxModel=k.offsetWidth===2;s.body.removeChild(k).style.display="none"});a=function(k){var n=
s.createElement("div");k="on"+k;var r=k in n;if(!r){n.setAttribute(k,"return;");r=typeof n[k]==="function"}return r};c.support.submitBubbles=a("submit");c.support.changeBubbles=a("change");a=b=d=e=j=null}})();c.props={"for":"htmlFor","class":"className",readonly:"readOnly",maxlength:"maxLength",cellspacing:"cellSpacing",rowspan:"rowSpan",colspan:"colSpan",tabindex:"tabIndex",usemap:"useMap",frameborder:"frameBorder"};var G="jQuery"+J(),Ya=0,za={};c.extend({cache:{},expando:G,noData:{embed:true,object:true,
applet:true},data:function(a,b,d){if(!(a.nodeName&&c.noData[a.nodeName.toLowerCase()])){a=a==A?za:a;var f=a[G],e=c.cache;if(!f&&typeof b==="string"&&d===w)return null;f||(f=++Ya);if(typeof b==="object"){a[G]=f;e[f]=c.extend(true,{},b)}else if(!e[f]){a[G]=f;e[f]={}}a=e[f];if(d!==w)a[b]=d;return typeof b==="string"?a[b]:a}},removeData:function(a,b){if(!(a.nodeName&&c.noData[a.nodeName.toLowerCase()])){a=a==A?za:a;var d=a[G],f=c.cache,e=f[d];if(b){if(e){delete e[b];c.isEmptyObject(e)&&c.removeData(a)}}else{if(c.support.deleteExpando)delete a[c.expando];
else a.removeAttribute&&a.removeAttribute(c.expando);delete f[d]}}}});c.fn.extend({data:function(a,b){if(typeof a==="undefined"&&this.length)return c.data(this[0]);else if(typeof a==="object")return this.each(function(){c.data(this,a)});var d=a.split(".");d[1]=d[1]?"."+d[1]:"";if(b===w){var f=this.triggerHandler("getData"+d[1]+"!",[d[0]]);if(f===w&&this.length)f=c.data(this[0],a);return f===w&&d[1]?this.data(d[0]):f}else return this.trigger("setData"+d[1]+"!",[d[0],b]).each(function(){c.data(this,
a,b)})},removeData:function(a){return this.each(function(){c.removeData(this,a)})}});c.extend({queue:function(a,b,d){if(a){b=(b||"fx")+"queue";var f=c.data(a,b);if(!d)return f||[];if(!f||c.isArray(d))f=c.data(a,b,c.makeArray(d));else f.push(d);return f}},dequeue:function(a,b){b=b||"fx";var d=c.queue(a,b),f=d.shift();if(f==="inprogress")f=d.shift();if(f){b==="fx"&&d.unshift("inprogress");f.call(a,function(){c.dequeue(a,b)})}}});c.fn.extend({queue:function(a,b){if(typeof a!=="string"){b=a;a="fx"}if(b===
w)return c.queue(this[0],a);return this.each(function(){var d=c.queue(this,a,b);a==="fx"&&d[0]!=="inprogress"&&c.dequeue(this,a)})},dequeue:function(a){return this.each(function(){c.dequeue(this,a)})},delay:function(a,b){a=c.fx?c.fx.speeds[a]||a:a;b=b||"fx";return this.queue(b,function(){var d=this;setTimeout(function(){c.dequeue(d,b)},a)})},clearQueue:function(a){return this.queue(a||"fx",[])}});var Aa=/[\n\t]/g,ca=/\s+/,Za=/\r/g,$a=/href|src|style/,ab=/(button|input)/i,bb=/(button|input|object|select|textarea)/i,
cb=/^(a|area)$/i,Ba=/radio|checkbox/;c.fn.extend({attr:function(a,b){return X(this,a,b,true,c.attr)},removeAttr:function(a){return this.each(function(){c.attr(this,a,"");this.nodeType===1&&this.removeAttribute(a)})},addClass:function(a){if(c.isFunction(a))return this.each(function(n){var r=c(this);r.addClass(a.call(this,n,r.attr("class")))});if(a&&typeof a==="string")for(var b=(a||"").split(ca),d=0,f=this.length;d<f;d++){var e=this[d];if(e.nodeType===1)if(e.className){for(var j=" "+e.className+" ",
i=e.className,o=0,k=b.length;o<k;o++)if(j.indexOf(" "+b[o]+" ")<0)i+=" "+b[o];e.className=c.trim(i)}else e.className=a}return this},removeClass:function(a){if(c.isFunction(a))return this.each(function(k){var n=c(this);n.removeClass(a.call(this,k,n.attr("class")))});if(a&&typeof a==="string"||a===w)for(var b=(a||"").split(ca),d=0,f=this.length;d<f;d++){var e=this[d];if(e.nodeType===1&&e.className)if(a){for(var j=(" "+e.className+" ").replace(Aa," "),i=0,o=b.length;i<o;i++)j=j.replace(" "+b[i]+" ",
" ");e.className=c.trim(j)}else e.className=""}return this},toggleClass:function(a,b){var d=typeof a,f=typeof b==="boolean";if(c.isFunction(a))return this.each(function(e){var j=c(this);j.toggleClass(a.call(this,e,j.attr("class"),b),b)});return this.each(function(){if(d==="string")for(var e,j=0,i=c(this),o=b,k=a.split(ca);e=k[j++];){o=f?o:!i.hasClass(e);i[o?"addClass":"removeClass"](e)}else if(d==="undefined"||d==="boolean"){this.className&&c.data(this,"__className__",this.className);this.className=
this.className||a===false?"":c.data(this,"__className__")||""}})},hasClass:function(a){a=" "+a+" ";for(var b=0,d=this.length;b<d;b++)if((" "+this[b].className+" ").replace(Aa," ").indexOf(a)>-1)return true;return false},val:function(a){if(a===w){var b=this[0];if(b){if(c.nodeName(b,"option"))return(b.attributes.value||{}).specified?b.value:b.text;if(c.nodeName(b,"select")){var d=b.selectedIndex,f=[],e=b.options;b=b.type==="select-one";if(d<0)return null;var j=b?d:0;for(d=b?d+1:e.length;j<d;j++){var i=
e[j];if(i.selected){a=c(i).val();if(b)return a;f.push(a)}}return f}if(Ba.test(b.type)&&!c.support.checkOn)return b.getAttribute("value")===null?"on":b.value;return(b.value||"").replace(Za,"")}return w}var o=c.isFunction(a);return this.each(function(k){var n=c(this),r=a;if(this.nodeType===1){if(o)r=a.call(this,k,n.val());if(typeof r==="number")r+="";if(c.isArray(r)&&Ba.test(this.type))this.checked=c.inArray(n.val(),r)>=0;else if(c.nodeName(this,"select")){var u=c.makeArray(r);c("option",this).each(function(){this.selected=
c.inArray(c(this).val(),u)>=0});if(!u.length)this.selectedIndex=-1}else this.value=r}})}});c.extend({attrFn:{val:true,css:true,html:true,text:true,data:true,width:true,height:true,offset:true},attr:function(a,b,d,f){if(!a||a.nodeType===3||a.nodeType===8)return w;if(f&&b in c.attrFn)return c(a)[b](d);f=a.nodeType!==1||!c.isXMLDoc(a);var e=d!==w;b=f&&c.props[b]||b;if(a.nodeType===1){var j=$a.test(b);if(b in a&&f&&!j){if(e){b==="type"&&ab.test(a.nodeName)&&a.parentNode&&c.error("type property can't be changed");
a[b]=d}if(c.nodeName(a,"form")&&a.getAttributeNode(b))return a.getAttributeNode(b).nodeValue;if(b==="tabIndex")return(b=a.getAttributeNode("tabIndex"))&&b.specified?b.value:bb.test(a.nodeName)||cb.test(a.nodeName)&&a.href?0:w;return a[b]}if(!c.support.style&&f&&b==="style"){if(e)a.style.cssText=""+d;return a.style.cssText}e&&a.setAttribute(b,""+d);a=!c.support.hrefNormalized&&f&&j?a.getAttribute(b,2):a.getAttribute(b);return a===null?w:a}return c.style(a,b,d)}});var O=/\.(.*)$/,db=function(a){return a.replace(/[^\w\s\.\|`]/g,
function(b){return"\\"+b})};c.event={add:function(a,b,d,f){if(!(a.nodeType===3||a.nodeType===8)){if(a.setInterval&&a!==A&&!a.frameElement)a=A;var e,j;if(d.handler){e=d;d=e.handler}if(!d.guid)d.guid=c.guid++;if(j=c.data(a)){var i=j.events=j.events||{},o=j.handle;if(!o)j.handle=o=function(){return typeof c!=="undefined"&&!c.event.triggered?c.event.handle.apply(o.elem,arguments):w};o.elem=a;b=b.split(" ");for(var k,n=0,r;k=b[n++];){j=e?c.extend({},e):{handler:d,data:f};if(k.indexOf(".")>-1){r=k.split(".");
k=r.shift();j.namespace=r.slice(0).sort().join(".")}else{r=[];j.namespace=""}j.type=k;j.guid=d.guid;var u=i[k],z=c.event.special[k]||{};if(!u){u=i[k]=[];if(!z.setup||z.setup.call(a,f,r,o)===false)if(a.addEventListener)a.addEventListener(k,o,false);else a.attachEvent&&a.attachEvent("on"+k,o)}if(z.add){z.add.call(a,j);if(!j.handler.guid)j.handler.guid=d.guid}u.push(j);c.event.global[k]=true}a=null}}},global:{},remove:function(a,b,d,f){if(!(a.nodeType===3||a.nodeType===8)){var e,j=0,i,o,k,n,r,u,z=c.data(a),
C=z&&z.events;if(z&&C){if(b&&b.type){d=b.handler;b=b.type}if(!b||typeof b==="string"&&b.charAt(0)==="."){b=b||"";for(e in C)c.event.remove(a,e+b)}else{for(b=b.split(" ");e=b[j++];){n=e;i=e.indexOf(".")<0;o=[];if(!i){o=e.split(".");e=o.shift();k=new RegExp("(^|\\.)"+c.map(o.slice(0).sort(),db).join("\\.(?:.*\\.)?")+"(\\.|$)")}if(r=C[e])if(d){n=c.event.special[e]||{};for(B=f||0;B<r.length;B++){u=r[B];if(d.guid===u.guid){if(i||k.test(u.namespace)){f==null&&r.splice(B--,1);n.remove&&n.remove.call(a,u)}if(f!=
null)break}}if(r.length===0||f!=null&&r.length===1){if(!n.teardown||n.teardown.call(a,o)===false)Ca(a,e,z.handle);delete C[e]}}else for(var B=0;B<r.length;B++){u=r[B];if(i||k.test(u.namespace)){c.event.remove(a,n,u.handler,B);r.splice(B--,1)}}}if(c.isEmptyObject(C)){if(b=z.handle)b.elem=null;delete z.events;delete z.handle;c.isEmptyObject(z)&&c.removeData(a)}}}}},trigger:function(a,b,d,f){var e=a.type||a;if(!f){a=typeof a==="object"?a[G]?a:c.extend(c.Event(e),a):c.Event(e);if(e.indexOf("!")>=0){a.type=
e=e.slice(0,-1);a.exclusive=true}if(!d){a.stopPropagation();c.event.global[e]&&c.each(c.cache,function(){this.events&&this.events[e]&&c.event.trigger(a,b,this.handle.elem)})}if(!d||d.nodeType===3||d.nodeType===8)return w;a.result=w;a.target=d;b=c.makeArray(b);b.unshift(a)}a.currentTarget=d;(f=c.data(d,"handle"))&&f.apply(d,b);f=d.parentNode||d.ownerDocument;try{if(!(d&&d.nodeName&&c.noData[d.nodeName.toLowerCase()]))if(d["on"+e]&&d["on"+e].apply(d,b)===false)a.result=false}catch(j){}if(!a.isPropagationStopped()&&
f)c.event.trigger(a,b,f,true);else if(!a.isDefaultPrevented()){f=a.target;var i,o=c.nodeName(f,"a")&&e==="click",k=c.event.special[e]||{};if((!k._default||k._default.call(d,a)===false)&&!o&&!(f&&f.nodeName&&c.noData[f.nodeName.toLowerCase()])){try{if(f[e]){if(i=f["on"+e])f["on"+e]=null;c.event.triggered=true;f[e]()}}catch(n){}if(i)f["on"+e]=i;c.event.triggered=false}}},handle:function(a){var b,d,f,e;a=arguments[0]=c.event.fix(a||A.event);a.currentTarget=this;b=a.type.indexOf(".")<0&&!a.exclusive;
if(!b){d=a.type.split(".");a.type=d.shift();f=new RegExp("(^|\\.)"+d.slice(0).sort().join("\\.(?:.*\\.)?")+"(\\.|$)")}e=c.data(this,"events");d=e[a.type];if(e&&d){d=d.slice(0);e=0;for(var j=d.length;e<j;e++){var i=d[e];if(b||f.test(i.namespace)){a.handler=i.handler;a.data=i.data;a.handleObj=i;i=i.handler.apply(this,arguments);if(i!==w){a.result=i;if(i===false){a.preventDefault();a.stopPropagation()}}if(a.isImmediatePropagationStopped())break}}}return a.result},props:"altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode layerX layerY metaKey newValue offsetX offsetY originalTarget pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which".split(" "),
fix:function(a){if(a[G])return a;var b=a;a=c.Event(b);for(var d=this.props.length,f;d;){f=this.props[--d];a[f]=b[f]}if(!a.target)a.target=a.srcElement||s;if(a.target.nodeType===3)a.target=a.target.parentNode;if(!a.relatedTarget&&a.fromElement)a.relatedTarget=a.fromElement===a.target?a.toElement:a.fromElement;if(a.pageX==null&&a.clientX!=null){b=s.documentElement;d=s.body;a.pageX=a.clientX+(b&&b.scrollLeft||d&&d.scrollLeft||0)-(b&&b.clientLeft||d&&d.clientLeft||0);a.pageY=a.clientY+(b&&b.scrollTop||
d&&d.scrollTop||0)-(b&&b.clientTop||d&&d.clientTop||0)}if(!a.which&&(a.charCode||a.charCode===0?a.charCode:a.keyCode))a.which=a.charCode||a.keyCode;if(!a.metaKey&&a.ctrlKey)a.metaKey=a.ctrlKey;if(!a.which&&a.button!==w)a.which=a.button&1?1:a.button&2?3:a.button&4?2:0;return a},guid:1E8,proxy:c.proxy,special:{ready:{setup:c.bindReady,teardown:c.noop},live:{add:function(a){c.event.add(this,a.origType,c.extend({},a,{handler:oa}))},remove:function(a){var b=true,d=a.origType.replace(O,"");c.each(c.data(this,
"events").live||[],function(){if(d===this.origType.replace(O,""))return b=false});b&&c.event.remove(this,a.origType,oa)}},beforeunload:{setup:function(a,b,d){if(this.setInterval)this.onbeforeunload=d;return false},teardown:function(a,b){if(this.onbeforeunload===b)this.onbeforeunload=null}}}};var Ca=s.removeEventListener?function(a,b,d){a.removeEventListener(b,d,false)}:function(a,b,d){a.detachEvent("on"+b,d)};c.Event=function(a){if(!this.preventDefault)return new c.Event(a);if(a&&a.type){this.originalEvent=
a;this.type=a.type}else this.type=a;this.timeStamp=J();this[G]=true};c.Event.prototype={preventDefault:function(){this.isDefaultPrevented=Z;var a=this.originalEvent;if(a){a.preventDefault&&a.preventDefault();a.returnValue=false}},stopPropagation:function(){this.isPropagationStopped=Z;var a=this.originalEvent;if(a){a.stopPropagation&&a.stopPropagation();a.cancelBubble=true}},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=Z;this.stopPropagation()},isDefaultPrevented:Y,isPropagationStopped:Y,
isImmediatePropagationStopped:Y};var Da=function(a){var b=a.relatedTarget;try{for(;b&&b!==this;)b=b.parentNode;if(b!==this){a.type=a.data;c.event.handle.apply(this,arguments)}}catch(d){}},Ea=function(a){a.type=a.data;c.event.handle.apply(this,arguments)};c.each({mouseenter:"mouseover",mouseleave:"mouseout"},function(a,b){c.event.special[a]={setup:function(d){c.event.add(this,b,d&&d.selector?Ea:Da,a)},teardown:function(d){c.event.remove(this,b,d&&d.selector?Ea:Da)}}});if(!c.support.submitBubbles)c.event.special.submit=
{setup:function(){if(this.nodeName.toLowerCase()!=="form"){c.event.add(this,"click.specialSubmit",function(a){var b=a.target,d=b.type;if((d==="submit"||d==="image")&&c(b).closest("form").length)return na("submit",this,arguments)});c.event.add(this,"keypress.specialSubmit",function(a){var b=a.target,d=b.type;if((d==="text"||d==="password")&&c(b).closest("form").length&&a.keyCode===13)return na("submit",this,arguments)})}else return false},teardown:function(){c.event.remove(this,".specialSubmit")}};
if(!c.support.changeBubbles){var da=/textarea|input|select/i,ea,Fa=function(a){var b=a.type,d=a.value;if(b==="radio"||b==="checkbox")d=a.checked;else if(b==="select-multiple")d=a.selectedIndex>-1?c.map(a.options,function(f){return f.selected}).join("-"):"";else if(a.nodeName.toLowerCase()==="select")d=a.selectedIndex;return d},fa=function(a,b){var d=a.target,f,e;if(!(!da.test(d.nodeName)||d.readOnly)){f=c.data(d,"_change_data");e=Fa(d);if(a.type!=="focusout"||d.type!=="radio")c.data(d,"_change_data",
e);if(!(f===w||e===f))if(f!=null||e){a.type="change";return c.event.trigger(a,b,d)}}};c.event.special.change={filters:{focusout:fa,click:function(a){var b=a.target,d=b.type;if(d==="radio"||d==="checkbox"||b.nodeName.toLowerCase()==="select")return fa.call(this,a)},keydown:function(a){var b=a.target,d=b.type;if(a.keyCode===13&&b.nodeName.toLowerCase()!=="textarea"||a.keyCode===32&&(d==="checkbox"||d==="radio")||d==="select-multiple")return fa.call(this,a)},beforeactivate:function(a){a=a.target;c.data(a,
"_change_data",Fa(a))}},setup:function(){if(this.type==="file")return false;for(var a in ea)c.event.add(this,a+".specialChange",ea[a]);return da.test(this.nodeName)},teardown:function(){c.event.remove(this,".specialChange");return da.test(this.nodeName)}};ea=c.event.special.change.filters}s.addEventListener&&c.each({focus:"focusin",blur:"focusout"},function(a,b){function d(f){f=c.event.fix(f);f.type=b;return c.event.handle.call(this,f)}c.event.special[b]={setup:function(){this.addEventListener(a,
d,true)},teardown:function(){this.removeEventListener(a,d,true)}}});c.each(["bind","one"],function(a,b){c.fn[b]=function(d,f,e){if(typeof d==="object"){for(var j in d)this[b](j,f,d[j],e);return this}if(c.isFunction(f)){e=f;f=w}var i=b==="one"?c.proxy(e,function(k){c(this).unbind(k,i);return e.apply(this,arguments)}):e;if(d==="unload"&&b!=="one")this.one(d,f,e);else{j=0;for(var o=this.length;j<o;j++)c.event.add(this[j],d,i,f)}return this}});c.fn.extend({unbind:function(a,b){if(typeof a==="object"&&
!a.preventDefault)for(var d in a)this.unbind(d,a[d]);else{d=0;for(var f=this.length;d<f;d++)c.event.remove(this[d],a,b)}return this},delegate:function(a,b,d,f){return this.live(b,d,f,a)},undelegate:function(a,b,d){return arguments.length===0?this.unbind("live"):this.die(b,null,d,a)},trigger:function(a,b){return this.each(function(){c.event.trigger(a,b,this)})},triggerHandler:function(a,b){if(this[0]){a=c.Event(a);a.preventDefault();a.stopPropagation();c.event.trigger(a,b,this[0]);return a.result}},
toggle:function(a){for(var b=arguments,d=1;d<b.length;)c.proxy(a,b[d++]);return this.click(c.proxy(a,function(f){var e=(c.data(this,"lastToggle"+a.guid)||0)%d;c.data(this,"lastToggle"+a.guid,e+1);f.preventDefault();return b[e].apply(this,arguments)||false}))},hover:function(a,b){return this.mouseenter(a).mouseleave(b||a)}});var Ga={focus:"focusin",blur:"focusout",mouseenter:"mouseover",mouseleave:"mouseout"};c.each(["live","die"],function(a,b){c.fn[b]=function(d,f,e,j){var i,o=0,k,n,r=j||this.selector,
u=j?this:c(this.context);if(c.isFunction(f)){e=f;f=w}for(d=(d||"").split(" ");(i=d[o++])!=null;){j=O.exec(i);k="";if(j){k=j[0];i=i.replace(O,"")}if(i==="hover")d.push("mouseenter"+k,"mouseleave"+k);else{n=i;if(i==="focus"||i==="blur"){d.push(Ga[i]+k);i+=k}else i=(Ga[i]||i)+k;b==="live"?u.each(function(){c.event.add(this,pa(i,r),{data:f,selector:r,handler:e,origType:i,origHandler:e,preType:n})}):u.unbind(pa(i,r),e)}}return this}});c.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error".split(" "),
function(a,b){c.fn[b]=function(d){return d?this.bind(b,d):this.trigger(b)};if(c.attrFn)c.attrFn[b]=true});A.attachEvent&&!A.addEventListener&&A.attachEvent("onunload",function(){for(var a in c.cache)if(c.cache[a].handle)try{c.event.remove(c.cache[a].handle.elem)}catch(b){}});(function(){function a(g){for(var h="",l,m=0;g[m];m++){l=g[m];if(l.nodeType===3||l.nodeType===4)h+=l.nodeValue;else if(l.nodeType!==8)h+=a(l.childNodes)}return h}function b(g,h,l,m,q,p){q=0;for(var v=m.length;q<v;q++){var t=m[q];
if(t){t=t[g];for(var y=false;t;){if(t.sizcache===l){y=m[t.sizset];break}if(t.nodeType===1&&!p){t.sizcache=l;t.sizset=q}if(t.nodeName.toLowerCase()===h){y=t;break}t=t[g]}m[q]=y}}}function d(g,h,l,m,q,p){q=0;for(var v=m.length;q<v;q++){var t=m[q];if(t){t=t[g];for(var y=false;t;){if(t.sizcache===l){y=m[t.sizset];break}if(t.nodeType===1){if(!p){t.sizcache=l;t.sizset=q}if(typeof h!=="string"){if(t===h){y=true;break}}else if(k.filter(h,[t]).length>0){y=t;break}}t=t[g]}m[q]=y}}}var f=/((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^[\]]*\]|['"][^'"]*['"]|[^[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g,
e=0,j=Object.prototype.toString,i=false,o=true;[0,0].sort(function(){o=false;return 0});var k=function(g,h,l,m){l=l||[];var q=h=h||s;if(h.nodeType!==1&&h.nodeType!==9)return[];if(!g||typeof g!=="string")return l;for(var p=[],v,t,y,S,H=true,M=x(h),I=g;(f.exec(""),v=f.exec(I))!==null;){I=v[3];p.push(v[1]);if(v[2]){S=v[3];break}}if(p.length>1&&r.exec(g))if(p.length===2&&n.relative[p[0]])t=ga(p[0]+p[1],h);else for(t=n.relative[p[0]]?[h]:k(p.shift(),h);p.length;){g=p.shift();if(n.relative[g])g+=p.shift();
t=ga(g,t)}else{if(!m&&p.length>1&&h.nodeType===9&&!M&&n.match.ID.test(p[0])&&!n.match.ID.test(p[p.length-1])){v=k.find(p.shift(),h,M);h=v.expr?k.filter(v.expr,v.set)[0]:v.set[0]}if(h){v=m?{expr:p.pop(),set:z(m)}:k.find(p.pop(),p.length===1&&(p[0]==="~"||p[0]==="+")&&h.parentNode?h.parentNode:h,M);t=v.expr?k.filter(v.expr,v.set):v.set;if(p.length>0)y=z(t);else H=false;for(;p.length;){var D=p.pop();v=D;if(n.relative[D])v=p.pop();else D="";if(v==null)v=h;n.relative[D](y,v,M)}}else y=[]}y||(y=t);y||k.error(D||
g);if(j.call(y)==="[object Array]")if(H)if(h&&h.nodeType===1)for(g=0;y[g]!=null;g++){if(y[g]&&(y[g]===true||y[g].nodeType===1&&E(h,y[g])))l.push(t[g])}else for(g=0;y[g]!=null;g++)y[g]&&y[g].nodeType===1&&l.push(t[g]);else l.push.apply(l,y);else z(y,l);if(S){k(S,q,l,m);k.uniqueSort(l)}return l};k.uniqueSort=function(g){if(B){i=o;g.sort(B);if(i)for(var h=1;h<g.length;h++)g[h]===g[h-1]&&g.splice(h--,1)}return g};k.matches=function(g,h){return k(g,null,null,h)};k.find=function(g,h,l){var m,q;if(!g)return[];
for(var p=0,v=n.order.length;p<v;p++){var t=n.order[p];if(q=n.leftMatch[t].exec(g)){var y=q[1];q.splice(1,1);if(y.substr(y.length-1)!=="\\"){q[1]=(q[1]||"").replace(/\\/g,"");m=n.find[t](q,h,l);if(m!=null){g=g.replace(n.match[t],"");break}}}}m||(m=h.getElementsByTagName("*"));return{set:m,expr:g}};k.filter=function(g,h,l,m){for(var q=g,p=[],v=h,t,y,S=h&&h[0]&&x(h[0]);g&&h.length;){for(var H in n.filter)if((t=n.leftMatch[H].exec(g))!=null&&t[2]){var M=n.filter[H],I,D;D=t[1];y=false;t.splice(1,1);if(D.substr(D.length-
1)!=="\\"){if(v===p)p=[];if(n.preFilter[H])if(t=n.preFilter[H](t,v,l,p,m,S)){if(t===true)continue}else y=I=true;if(t)for(var U=0;(D=v[U])!=null;U++)if(D){I=M(D,t,U,v);var Ha=m^!!I;if(l&&I!=null)if(Ha)y=true;else v[U]=false;else if(Ha){p.push(D);y=true}}if(I!==w){l||(v=p);g=g.replace(n.match[H],"");if(!y)return[];break}}}if(g===q)if(y==null)k.error(g);else break;q=g}return v};k.error=function(g){throw"Syntax error, unrecognized expression: "+g;};var n=k.selectors={order:["ID","NAME","TAG"],match:{ID:/#((?:[\w\u00c0-\uFFFF-]|\\.)+)/,
CLASS:/\.((?:[\w\u00c0-\uFFFF-]|\\.)+)/,NAME:/\[name=['"]*((?:[\w\u00c0-\uFFFF-]|\\.)+)['"]*\]/,ATTR:/\[\s*((?:[\w\u00c0-\uFFFF-]|\\.)+)\s*(?:(\S?=)\s*(['"]*)(.*?)\3|)\s*\]/,TAG:/^((?:[\w\u00c0-\uFFFF\*-]|\\.)+)/,CHILD:/:(only|nth|last|first)-child(?:\((even|odd|[\dn+-]*)\))?/,POS:/:(nth|eq|gt|lt|first|last|even|odd)(?:\((\d*)\))?(?=[^-]|$)/,PSEUDO:/:((?:[\w\u00c0-\uFFFF-]|\\.)+)(?:\((['"]?)((?:\([^\)]+\)|[^\(\)]*)+)\2\))?/},leftMatch:{},attrMap:{"class":"className","for":"htmlFor"},attrHandle:{href:function(g){return g.getAttribute("href")}},
relative:{"+":function(g,h){var l=typeof h==="string",m=l&&!/\W/.test(h);l=l&&!m;if(m)h=h.toLowerCase();m=0;for(var q=g.length,p;m<q;m++)if(p=g[m]){for(;(p=p.previousSibling)&&p.nodeType!==1;);g[m]=l||p&&p.nodeName.toLowerCase()===h?p||false:p===h}l&&k.filter(h,g,true)},">":function(g,h){var l=typeof h==="string";if(l&&!/\W/.test(h)){h=h.toLowerCase();for(var m=0,q=g.length;m<q;m++){var p=g[m];if(p){l=p.parentNode;g[m]=l.nodeName.toLowerCase()===h?l:false}}}else{m=0;for(q=g.length;m<q;m++)if(p=g[m])g[m]=
l?p.parentNode:p.parentNode===h;l&&k.filter(h,g,true)}},"":function(g,h,l){var m=e++,q=d;if(typeof h==="string"&&!/\W/.test(h)){var p=h=h.toLowerCase();q=b}q("parentNode",h,m,g,p,l)},"~":function(g,h,l){var m=e++,q=d;if(typeof h==="string"&&!/\W/.test(h)){var p=h=h.toLowerCase();q=b}q("previousSibling",h,m,g,p,l)}},find:{ID:function(g,h,l){if(typeof h.getElementById!=="undefined"&&!l)return(g=h.getElementById(g[1]))?[g]:[]},NAME:function(g,h){if(typeof h.getElementsByName!=="undefined"){var l=[];
h=h.getElementsByName(g[1]);for(var m=0,q=h.length;m<q;m++)h[m].getAttribute("name")===g[1]&&l.push(h[m]);return l.length===0?null:l}},TAG:function(g,h){return h.getElementsByTagName(g[1])}},preFilter:{CLASS:function(g,h,l,m,q,p){g=" "+g[1].replace(/\\/g,"")+" ";if(p)return g;p=0;for(var v;(v=h[p])!=null;p++)if(v)if(q^(v.className&&(" "+v.className+" ").replace(/[\t\n]/g," ").indexOf(g)>=0))l||m.push(v);else if(l)h[p]=false;return false},ID:function(g){return g[1].replace(/\\/g,"")},TAG:function(g){return g[1].toLowerCase()},
CHILD:function(g){if(g[1]==="nth"){var h=/(-?)(\d*)n((?:\+|-)?\d*)/.exec(g[2]==="even"&&"2n"||g[2]==="odd"&&"2n+1"||!/\D/.test(g[2])&&"0n+"+g[2]||g[2]);g[2]=h[1]+(h[2]||1)-0;g[3]=h[3]-0}g[0]=e++;return g},ATTR:function(g,h,l,m,q,p){h=g[1].replace(/\\/g,"");if(!p&&n.attrMap[h])g[1]=n.attrMap[h];if(g[2]==="~=")g[4]=" "+g[4]+" ";return g},PSEUDO:function(g,h,l,m,q){if(g[1]==="not")if((f.exec(g[3])||"").length>1||/^\w/.test(g[3]))g[3]=k(g[3],null,null,h);else{g=k.filter(g[3],h,l,true^q);l||m.push.apply(m,
g);return false}else if(n.match.POS.test(g[0])||n.match.CHILD.test(g[0]))return true;return g},POS:function(g){g.unshift(true);return g}},filters:{enabled:function(g){return g.disabled===false&&g.type!=="hidden"},disabled:function(g){return g.disabled===true},checked:function(g){return g.checked===true},selected:function(g){return g.selected===true},parent:function(g){return!!g.firstChild},empty:function(g){return!g.firstChild},has:function(g,h,l){return!!k(l[3],g).length},header:function(g){return/h\d/i.test(g.nodeName)},
text:function(g){return"text"===g.type},radio:function(g){return"radio"===g.type},checkbox:function(g){return"checkbox"===g.type},file:function(g){return"file"===g.type},password:function(g){return"password"===g.type},submit:function(g){return"submit"===g.type},image:function(g){return"image"===g.type},reset:function(g){return"reset"===g.type},button:function(g){return"button"===g.type||g.nodeName.toLowerCase()==="button"},input:function(g){return/input|select|textarea|button/i.test(g.nodeName)}},
setFilters:{first:function(g,h){return h===0},last:function(g,h,l,m){return h===m.length-1},even:function(g,h){return h%2===0},odd:function(g,h){return h%2===1},lt:function(g,h,l){return h<l[3]-0},gt:function(g,h,l){return h>l[3]-0},nth:function(g,h,l){return l[3]-0===h},eq:function(g,h,l){return l[3]-0===h}},filter:{PSEUDO:function(g,h,l,m){var q=h[1],p=n.filters[q];if(p)return p(g,l,h,m);else if(q==="contains")return(g.textContent||g.innerText||a([g])||"").indexOf(h[3])>=0;else if(q==="not"){h=
h[3];l=0;for(m=h.length;l<m;l++)if(h[l]===g)return false;return true}else k.error("Syntax error, unrecognized expression: "+q)},CHILD:function(g,h){var l=h[1],m=g;switch(l){case "only":case "first":for(;m=m.previousSibling;)if(m.nodeType===1)return false;if(l==="first")return true;m=g;case "last":for(;m=m.nextSibling;)if(m.nodeType===1)return false;return true;case "nth":l=h[2];var q=h[3];if(l===1&&q===0)return true;h=h[0];var p=g.parentNode;if(p&&(p.sizcache!==h||!g.nodeIndex)){var v=0;for(m=p.firstChild;m;m=
m.nextSibling)if(m.nodeType===1)m.nodeIndex=++v;p.sizcache=h}g=g.nodeIndex-q;return l===0?g===0:g%l===0&&g/l>=0}},ID:function(g,h){return g.nodeType===1&&g.getAttribute("id")===h},TAG:function(g,h){return h==="*"&&g.nodeType===1||g.nodeName.toLowerCase()===h},CLASS:function(g,h){return(" "+(g.className||g.getAttribute("class"))+" ").indexOf(h)>-1},ATTR:function(g,h){var l=h[1];g=n.attrHandle[l]?n.attrHandle[l](g):g[l]!=null?g[l]:g.getAttribute(l);l=g+"";var m=h[2];h=h[4];return g==null?m==="!=":m===
"="?l===h:m==="*="?l.indexOf(h)>=0:m==="~="?(" "+l+" ").indexOf(h)>=0:!h?l&&g!==false:m==="!="?l!==h:m==="^="?l.indexOf(h)===0:m==="$="?l.substr(l.length-h.length)===h:m==="|="?l===h||l.substr(0,h.length+1)===h+"-":false},POS:function(g,h,l,m){var q=n.setFilters[h[2]];if(q)return q(g,l,h,m)}}},r=n.match.POS;for(var u in n.match){n.match[u]=new RegExp(n.match[u].source+/(?![^\[]*\])(?![^\(]*\))/.source);n.leftMatch[u]=new RegExp(/(^(?:.|\r|\n)*?)/.source+n.match[u].source.replace(/\\(\d+)/g,function(g,
h){return"\\"+(h-0+1)}))}var z=function(g,h){g=Array.prototype.slice.call(g,0);if(h){h.push.apply(h,g);return h}return g};try{Array.prototype.slice.call(s.documentElement.childNodes,0)}catch(C){z=function(g,h){h=h||[];if(j.call(g)==="[object Array]")Array.prototype.push.apply(h,g);else if(typeof g.length==="number")for(var l=0,m=g.length;l<m;l++)h.push(g[l]);else for(l=0;g[l];l++)h.push(g[l]);return h}}var B;if(s.documentElement.compareDocumentPosition)B=function(g,h){if(!g.compareDocumentPosition||
!h.compareDocumentPosition){if(g==h)i=true;return g.compareDocumentPosition?-1:1}g=g.compareDocumentPosition(h)&4?-1:g===h?0:1;if(g===0)i=true;return g};else if("sourceIndex"in s.documentElement)B=function(g,h){if(!g.sourceIndex||!h.sourceIndex){if(g==h)i=true;return g.sourceIndex?-1:1}g=g.sourceIndex-h.sourceIndex;if(g===0)i=true;return g};else if(s.createRange)B=function(g,h){if(!g.ownerDocument||!h.ownerDocument){if(g==h)i=true;return g.ownerDocument?-1:1}var l=g.ownerDocument.createRange(),m=
h.ownerDocument.createRange();l.setStart(g,0);l.setEnd(g,0);m.setStart(h,0);m.setEnd(h,0);g=l.compareBoundaryPoints(Range.START_TO_END,m);if(g===0)i=true;return g};(function(){var g=s.createElement("div"),h="script"+(new Date).getTime();g.innerHTML="<a name='"+h+"'/>";var l=s.documentElement;l.insertBefore(g,l.firstChild);if(s.getElementById(h)){n.find.ID=function(m,q,p){if(typeof q.getElementById!=="undefined"&&!p)return(q=q.getElementById(m[1]))?q.id===m[1]||typeof q.getAttributeNode!=="undefined"&&
q.getAttributeNode("id").nodeValue===m[1]?[q]:w:[]};n.filter.ID=function(m,q){var p=typeof m.getAttributeNode!=="undefined"&&m.getAttributeNode("id");return m.nodeType===1&&p&&p.nodeValue===q}}l.removeChild(g);l=g=null})();(function(){var g=s.createElement("div");g.appendChild(s.createComment(""));if(g.getElementsByTagName("*").length>0)n.find.TAG=function(h,l){l=l.getElementsByTagName(h[1]);if(h[1]==="*"){h=[];for(var m=0;l[m];m++)l[m].nodeType===1&&h.push(l[m]);l=h}return l};g.innerHTML="<a href='#'></a>";
if(g.firstChild&&typeof g.firstChild.getAttribute!=="undefined"&&g.firstChild.getAttribute("href")!=="#")n.attrHandle.href=function(h){return h.getAttribute("href",2)};g=null})();s.querySelectorAll&&function(){var g=k,h=s.createElement("div");h.innerHTML="<p class='TEST'></p>";if(!(h.querySelectorAll&&h.querySelectorAll(".TEST").length===0)){k=function(m,q,p,v){q=q||s;if(!v&&q.nodeType===9&&!x(q))try{return z(q.querySelectorAll(m),p)}catch(t){}return g(m,q,p,v)};for(var l in g)k[l]=g[l];h=null}}();
(function(){var g=s.createElement("div");g.innerHTML="<div class='test e'></div><div class='test'></div>";if(!(!g.getElementsByClassName||g.getElementsByClassName("e").length===0)){g.lastChild.className="e";if(g.getElementsByClassName("e").length!==1){n.order.splice(1,0,"CLASS");n.find.CLASS=function(h,l,m){if(typeof l.getElementsByClassName!=="undefined"&&!m)return l.getElementsByClassName(h[1])};g=null}}})();var E=s.compareDocumentPosition?function(g,h){return!!(g.compareDocumentPosition(h)&16)}:
function(g,h){return g!==h&&(g.contains?g.contains(h):true)},x=function(g){return(g=(g?g.ownerDocument||g:0).documentElement)?g.nodeName!=="HTML":false},ga=function(g,h){var l=[],m="",q;for(h=h.nodeType?[h]:h;q=n.match.PSEUDO.exec(g);){m+=q[0];g=g.replace(n.match.PSEUDO,"")}g=n.relative[g]?g+"*":g;q=0;for(var p=h.length;q<p;q++)k(g,h[q],l);return k.filter(m,l)};c.find=k;c.expr=k.selectors;c.expr[":"]=c.expr.filters;c.unique=k.uniqueSort;c.text=a;c.isXMLDoc=x;c.contains=E})();var eb=/Until$/,fb=/^(?:parents|prevUntil|prevAll)/,
gb=/,/;R=Array.prototype.slice;var Ia=function(a,b,d){if(c.isFunction(b))return c.grep(a,function(e,j){return!!b.call(e,j,e)===d});else if(b.nodeType)return c.grep(a,function(e){return e===b===d});else if(typeof b==="string"){var f=c.grep(a,function(e){return e.nodeType===1});if(Ua.test(b))return c.filter(b,f,!d);else b=c.filter(b,f)}return c.grep(a,function(e){return c.inArray(e,b)>=0===d})};c.fn.extend({find:function(a){for(var b=this.pushStack("","find",a),d=0,f=0,e=this.length;f<e;f++){d=b.length;
c.find(a,this[f],b);if(f>0)for(var j=d;j<b.length;j++)for(var i=0;i<d;i++)if(b[i]===b[j]){b.splice(j--,1);break}}return b},has:function(a){var b=c(a);return this.filter(function(){for(var d=0,f=b.length;d<f;d++)if(c.contains(this,b[d]))return true})},not:function(a){return this.pushStack(Ia(this,a,false),"not",a)},filter:function(a){return this.pushStack(Ia(this,a,true),"filter",a)},is:function(a){return!!a&&c.filter(a,this).length>0},closest:function(a,b){if(c.isArray(a)){var d=[],f=this[0],e,j=
{},i;if(f&&a.length){e=0;for(var o=a.length;e<o;e++){i=a[e];j[i]||(j[i]=c.expr.match.POS.test(i)?c(i,b||this.context):i)}for(;f&&f.ownerDocument&&f!==b;){for(i in j){e=j[i];if(e.jquery?e.index(f)>-1:c(f).is(e)){d.push({selector:i,elem:f});delete j[i]}}f=f.parentNode}}return d}var k=c.expr.match.POS.test(a)?c(a,b||this.context):null;return this.map(function(n,r){for(;r&&r.ownerDocument&&r!==b;){if(k?k.index(r)>-1:c(r).is(a))return r;r=r.parentNode}return null})},index:function(a){if(!a||typeof a===
"string")return c.inArray(this[0],a?c(a):this.parent().children());return c.inArray(a.jquery?a[0]:a,this)},add:function(a,b){a=typeof a==="string"?c(a,b||this.context):c.makeArray(a);b=c.merge(this.get(),a);return this.pushStack(qa(a[0])||qa(b[0])?b:c.unique(b))},andSelf:function(){return this.add(this.prevObject)}});c.each({parent:function(a){return(a=a.parentNode)&&a.nodeType!==11?a:null},parents:function(a){return c.dir(a,"parentNode")},parentsUntil:function(a,b,d){return c.dir(a,"parentNode",
d)},next:function(a){return c.nth(a,2,"nextSibling")},prev:function(a){return c.nth(a,2,"previousSibling")},nextAll:function(a){return c.dir(a,"nextSibling")},prevAll:function(a){return c.dir(a,"previousSibling")},nextUntil:function(a,b,d){return c.dir(a,"nextSibling",d)},prevUntil:function(a,b,d){return c.dir(a,"previousSibling",d)},siblings:function(a){return c.sibling(a.parentNode.firstChild,a)},children:function(a){return c.sibling(a.firstChild)},contents:function(a){return c.nodeName(a,"iframe")?
a.contentDocument||a.contentWindow.document:c.makeArray(a.childNodes)}},function(a,b){c.fn[a]=function(d,f){var e=c.map(this,b,d);eb.test(a)||(f=d);if(f&&typeof f==="string")e=c.filter(f,e);e=this.length>1?c.unique(e):e;if((this.length>1||gb.test(f))&&fb.test(a))e=e.reverse();return this.pushStack(e,a,R.call(arguments).join(","))}});c.extend({filter:function(a,b,d){if(d)a=":not("+a+")";return c.find.matches(a,b)},dir:function(a,b,d){var f=[];for(a=a[b];a&&a.nodeType!==9&&(d===w||a.nodeType!==1||!c(a).is(d));){a.nodeType===
1&&f.push(a);a=a[b]}return f},nth:function(a,b,d){b=b||1;for(var f=0;a;a=a[d])if(a.nodeType===1&&++f===b)break;return a},sibling:function(a,b){for(var d=[];a;a=a.nextSibling)a.nodeType===1&&a!==b&&d.push(a);return d}});var Ja=/ jQuery\d+="(?:\d+|null)"/g,V=/^\s+/,Ka=/(<([\w:]+)[^>]*?)\/>/g,hb=/^(?:area|br|col|embed|hr|img|input|link|meta|param)$/i,La=/<([\w:]+)/,ib=/<tbody/i,jb=/<|&#?\w+;/,ta=/<script|<object|<embed|<option|<style/i,ua=/checked\s*(?:[^=]|=\s*.checked.)/i,Ma=function(a,b,d){return hb.test(d)?
a:b+"></"+d+">"},F={option:[1,"<select multiple='multiple'>","</select>"],legend:[1,"<fieldset>","</fieldset>"],thead:[1,"<table>","</table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],col:[2,"<table><tbody></tbody><colgroup>","</colgroup></table>"],area:[1,"<map>","</map>"],_default:[0,"",""]};F.optgroup=F.option;F.tbody=F.tfoot=F.colgroup=F.caption=F.thead;F.th=F.td;if(!c.support.htmlSerialize)F._default=[1,"div<div>","</div>"];c.fn.extend({text:function(a){if(c.isFunction(a))return this.each(function(b){var d=
c(this);d.text(a.call(this,b,d.text()))});if(typeof a!=="object"&&a!==w)return this.empty().append((this[0]&&this[0].ownerDocument||s).createTextNode(a));return c.text(this)},wrapAll:function(a){if(c.isFunction(a))return this.each(function(d){c(this).wrapAll(a.call(this,d))});if(this[0]){var b=c(a,this[0].ownerDocument).eq(0).clone(true);this[0].parentNode&&b.insertBefore(this[0]);b.map(function(){for(var d=this;d.firstChild&&d.firstChild.nodeType===1;)d=d.firstChild;return d}).append(this)}return this},
wrapInner:function(a){if(c.isFunction(a))return this.each(function(b){c(this).wrapInner(a.call(this,b))});return this.each(function(){var b=c(this),d=b.contents();d.length?d.wrapAll(a):b.append(a)})},wrap:function(a){return this.each(function(){c(this).wrapAll(a)})},unwrap:function(){return this.parent().each(function(){c.nodeName(this,"body")||c(this).replaceWith(this.childNodes)}).end()},append:function(){return this.domManip(arguments,true,function(a){this.nodeType===1&&this.appendChild(a)})},
prepend:function(){return this.domManip(arguments,true,function(a){this.nodeType===1&&this.insertBefore(a,this.firstChild)})},before:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,false,function(b){this.parentNode.insertBefore(b,this)});else if(arguments.length){var a=c(arguments[0]);a.push.apply(a,this.toArray());return this.pushStack(a,"before",arguments)}},after:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,false,function(b){this.parentNode.insertBefore(b,
this.nextSibling)});else if(arguments.length){var a=this.pushStack(this,"after",arguments);a.push.apply(a,c(arguments[0]).toArray());return a}},remove:function(a,b){for(var d=0,f;(f=this[d])!=null;d++)if(!a||c.filter(a,[f]).length){if(!b&&f.nodeType===1){c.cleanData(f.getElementsByTagName("*"));c.cleanData([f])}f.parentNode&&f.parentNode.removeChild(f)}return this},empty:function(){for(var a=0,b;(b=this[a])!=null;a++)for(b.nodeType===1&&c.cleanData(b.getElementsByTagName("*"));b.firstChild;)b.removeChild(b.firstChild);
return this},clone:function(a){var b=this.map(function(){if(!c.support.noCloneEvent&&!c.isXMLDoc(this)){var d=this.outerHTML,f=this.ownerDocument;if(!d){d=f.createElement("div");d.appendChild(this.cloneNode(true));d=d.innerHTML}return c.clean([d.replace(Ja,"").replace(/=([^="'>\s]+\/)>/g,'="$1">').replace(V,"")],f)[0]}else return this.cloneNode(true)});if(a===true){ra(this,b);ra(this.find("*"),b.find("*"))}return b},html:function(a){if(a===w)return this[0]&&this[0].nodeType===1?this[0].innerHTML.replace(Ja,
""):null;else if(typeof a==="string"&&!ta.test(a)&&(c.support.leadingWhitespace||!V.test(a))&&!F[(La.exec(a)||["",""])[1].toLowerCase()]){a=a.replace(Ka,Ma);try{for(var b=0,d=this.length;b<d;b++)if(this[b].nodeType===1){c.cleanData(this[b].getElementsByTagName("*"));this[b].innerHTML=a}}catch(f){this.empty().append(a)}}else c.isFunction(a)?this.each(function(e){var j=c(this),i=j.html();j.empty().append(function(){return a.call(this,e,i)})}):this.empty().append(a);return this},replaceWith:function(a){if(this[0]&&
this[0].parentNode){if(c.isFunction(a))return this.each(function(b){var d=c(this),f=d.html();d.replaceWith(a.call(this,b,f))});if(typeof a!=="string")a=c(a).detach();return this.each(function(){var b=this.nextSibling,d=this.parentNode;c(this).remove();b?c(b).before(a):c(d).append(a)})}else return this.pushStack(c(c.isFunction(a)?a():a),"replaceWith",a)},detach:function(a){return this.remove(a,true)},domManip:function(a,b,d){function f(u){return c.nodeName(u,"table")?u.getElementsByTagName("tbody")[0]||
u.appendChild(u.ownerDocument.createElement("tbody")):u}var e,j,i=a[0],o=[],k;if(!c.support.checkClone&&arguments.length===3&&typeof i==="string"&&ua.test(i))return this.each(function(){c(this).domManip(a,b,d,true)});if(c.isFunction(i))return this.each(function(u){var z=c(this);a[0]=i.call(this,u,b?z.html():w);z.domManip(a,b,d)});if(this[0]){e=i&&i.parentNode;e=c.support.parentNode&&e&&e.nodeType===11&&e.childNodes.length===this.length?{fragment:e}:sa(a,this,o);k=e.fragment;if(j=k.childNodes.length===
1?(k=k.firstChild):k.firstChild){b=b&&c.nodeName(j,"tr");for(var n=0,r=this.length;n<r;n++)d.call(b?f(this[n],j):this[n],n>0||e.cacheable||this.length>1?k.cloneNode(true):k)}o.length&&c.each(o,Qa)}return this}});c.fragments={};c.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(a,b){c.fn[a]=function(d){var f=[];d=c(d);var e=this.length===1&&this[0].parentNode;if(e&&e.nodeType===11&&e.childNodes.length===1&&d.length===1){d[b](this[0]);
return this}else{e=0;for(var j=d.length;e<j;e++){var i=(e>0?this.clone(true):this).get();c.fn[b].apply(c(d[e]),i);f=f.concat(i)}return this.pushStack(f,a,d.selector)}}});c.extend({clean:function(a,b,d,f){b=b||s;if(typeof b.createElement==="undefined")b=b.ownerDocument||b[0]&&b[0].ownerDocument||s;for(var e=[],j=0,i;(i=a[j])!=null;j++){if(typeof i==="number")i+="";if(i){if(typeof i==="string"&&!jb.test(i))i=b.createTextNode(i);else if(typeof i==="string"){i=i.replace(Ka,Ma);var o=(La.exec(i)||["",
""])[1].toLowerCase(),k=F[o]||F._default,n=k[0],r=b.createElement("div");for(r.innerHTML=k[1]+i+k[2];n--;)r=r.lastChild;if(!c.support.tbody){n=ib.test(i);o=o==="table"&&!n?r.firstChild&&r.firstChild.childNodes:k[1]==="<table>"&&!n?r.childNodes:[];for(k=o.length-1;k>=0;--k)c.nodeName(o[k],"tbody")&&!o[k].childNodes.length&&o[k].parentNode.removeChild(o[k])}!c.support.leadingWhitespace&&V.test(i)&&r.insertBefore(b.createTextNode(V.exec(i)[0]),r.firstChild);i=r.childNodes}if(i.nodeType)e.push(i);else e=
c.merge(e,i)}}if(d)for(j=0;e[j];j++)if(f&&c.nodeName(e[j],"script")&&(!e[j].type||e[j].type.toLowerCase()==="text/javascript"))f.push(e[j].parentNode?e[j].parentNode.removeChild(e[j]):e[j]);else{e[j].nodeType===1&&e.splice.apply(e,[j+1,0].concat(c.makeArray(e[j].getElementsByTagName("script"))));d.appendChild(e[j])}return e},cleanData:function(a){for(var b,d,f=c.cache,e=c.event.special,j=c.support.deleteExpando,i=0,o;(o=a[i])!=null;i++)if(d=o[c.expando]){b=f[d];if(b.events)for(var k in b.events)e[k]?
c.event.remove(o,k):Ca(o,k,b.handle);if(j)delete o[c.expando];else o.removeAttribute&&o.removeAttribute(c.expando);delete f[d]}}});var kb=/z-?index|font-?weight|opacity|zoom|line-?height/i,Na=/alpha\([^)]*\)/,Oa=/opacity=([^)]*)/,ha=/float/i,ia=/-([a-z])/ig,lb=/([A-Z])/g,mb=/^-?\d+(?:px)?$/i,nb=/^-?\d/,ob={position:"absolute",visibility:"hidden",display:"block"},pb=["Left","Right"],qb=["Top","Bottom"],rb=s.defaultView&&s.defaultView.getComputedStyle,Pa=c.support.cssFloat?"cssFloat":"styleFloat",ja=
function(a,b){return b.toUpperCase()};c.fn.css=function(a,b){return X(this,a,b,true,function(d,f,e){if(e===w)return c.curCSS(d,f);if(typeof e==="number"&&!kb.test(f))e+="px";c.style(d,f,e)})};c.extend({style:function(a,b,d){if(!a||a.nodeType===3||a.nodeType===8)return w;if((b==="width"||b==="height")&&parseFloat(d)<0)d=w;var f=a.style||a,e=d!==w;if(!c.support.opacity&&b==="opacity"){if(e){f.zoom=1;b=parseInt(d,10)+""==="NaN"?"":"alpha(opacity="+d*100+")";a=f.filter||c.curCSS(a,"filter")||"";f.filter=
Na.test(a)?a.replace(Na,b):b}return f.filter&&f.filter.indexOf("opacity=")>=0?parseFloat(Oa.exec(f.filter)[1])/100+"":""}if(ha.test(b))b=Pa;b=b.replace(ia,ja);if(e)f[b]=d;return f[b]},css:function(a,b,d,f){if(b==="width"||b==="height"){var e,j=b==="width"?pb:qb;function i(){e=b==="width"?a.offsetWidth:a.offsetHeight;f!=="border"&&c.each(j,function(){f||(e-=parseFloat(c.curCSS(a,"padding"+this,true))||0);if(f==="margin")e+=parseFloat(c.curCSS(a,"margin"+this,true))||0;else e-=parseFloat(c.curCSS(a,
"border"+this+"Width",true))||0})}a.offsetWidth!==0?i():c.swap(a,ob,i);return Math.max(0,Math.round(e))}return c.curCSS(a,b,d)},curCSS:function(a,b,d){var f,e=a.style;if(!c.support.opacity&&b==="opacity"&&a.currentStyle){f=Oa.test(a.currentStyle.filter||"")?parseFloat(RegExp.$1)/100+"":"";return f===""?"1":f}if(ha.test(b))b=Pa;if(!d&&e&&e[b])f=e[b];else if(rb){if(ha.test(b))b="float";b=b.replace(lb,"-$1").toLowerCase();e=a.ownerDocument.defaultView;if(!e)return null;if(a=e.getComputedStyle(a,null))f=
a.getPropertyValue(b);if(b==="opacity"&&f==="")f="1"}else if(a.currentStyle){d=b.replace(ia,ja);f=a.currentStyle[b]||a.currentStyle[d];if(!mb.test(f)&&nb.test(f)){b=e.left;var j=a.runtimeStyle.left;a.runtimeStyle.left=a.currentStyle.left;e.left=d==="fontSize"?"1em":f||0;f=e.pixelLeft+"px";e.left=b;a.runtimeStyle.left=j}}return f},swap:function(a,b,d){var f={};for(var e in b){f[e]=a.style[e];a.style[e]=b[e]}d.call(a);for(e in b)a.style[e]=f[e]}});if(c.expr&&c.expr.filters){c.expr.filters.hidden=function(a){var b=
a.offsetWidth,d=a.offsetHeight,f=a.nodeName.toLowerCase()==="tr";return b===0&&d===0&&!f?true:b>0&&d>0&&!f?false:c.curCSS(a,"display")==="none"};c.expr.filters.visible=function(a){return!c.expr.filters.hidden(a)}}var sb=J(),tb=/<script(.|\s)*?\/script>/gi,ub=/select|textarea/i,vb=/color|date|datetime|email|hidden|month|number|password|range|search|tel|text|time|url|week/i,N=/=\?(&|$)/,ka=/\?/,wb=/(\?|&)_=.*?(&|$)/,xb=/^(\w+:)?\/\/([^\/?#]+)/,yb=/%20/g,zb=c.fn.load;c.fn.extend({load:function(a,b,d){if(typeof a!==
"string")return zb.call(this,a);else if(!this.length)return this;var f=a.indexOf(" ");if(f>=0){var e=a.slice(f,a.length);a=a.slice(0,f)}f="GET";if(b)if(c.isFunction(b)){d=b;b=null}else if(typeof b==="object"){b=c.param(b,c.ajaxSettings.traditional);f="POST"}var j=this;c.ajax({url:a,type:f,dataType:"html",data:b,complete:function(i,o){if(o==="success"||o==="notmodified")j.html(e?c("<div />").append(i.responseText.replace(tb,"")).find(e):i.responseText);d&&j.each(d,[i.responseText,o,i])}});return this},
serialize:function(){return c.param(this.serializeArray())},serializeArray:function(){return this.map(function(){return this.elements?c.makeArray(this.elements):this}).filter(function(){return this.name&&!this.disabled&&(this.checked||ub.test(this.nodeName)||vb.test(this.type))}).map(function(a,b){a=c(this).val();return a==null?null:c.isArray(a)?c.map(a,function(d){return{name:b.name,value:d}}):{name:b.name,value:a}}).get()}});c.each("ajaxStart ajaxStop ajaxComplete ajaxError ajaxSuccess ajaxSend".split(" "),
function(a,b){c.fn[b]=function(d){return this.bind(b,d)}});c.extend({get:function(a,b,d,f){if(c.isFunction(b)){f=f||d;d=b;b=null}return c.ajax({type:"GET",url:a,data:b,success:d,dataType:f})},getScript:function(a,b){return c.get(a,null,b,"script")},getJSON:function(a,b,d){return c.get(a,b,d,"json")},post:function(a,b,d,f){if(c.isFunction(b)){f=f||d;d=b;b={}}return c.ajax({type:"POST",url:a,data:b,success:d,dataType:f})},ajaxSetup:function(a){c.extend(c.ajaxSettings,a)},ajaxSettings:{url:location.href,
global:true,type:"GET",contentType:"application/x-www-form-urlencoded",processData:true,async:true,xhr:A.XMLHttpRequest&&(A.location.protocol!=="file:"||!A.ActiveXObject)?function(){return new A.XMLHttpRequest}:function(){try{return new A.ActiveXObject("Microsoft.XMLHTTP")}catch(a){}},accepts:{xml:"application/xml, text/xml",html:"text/html",script:"text/javascript, application/javascript",json:"application/json, text/javascript",text:"text/plain",_default:"*/*"}},lastModified:{},etag:{},ajax:function(a){function b(){e.success&&
e.success.call(k,o,i,x);e.global&&f("ajaxSuccess",[x,e])}function d(){e.complete&&e.complete.call(k,x,i);e.global&&f("ajaxComplete",[x,e]);e.global&&!--c.active&&c.event.trigger("ajaxStop")}function f(q,p){(e.context?c(e.context):c.event).trigger(q,p)}var e=c.extend(true,{},c.ajaxSettings,a),j,i,o,k=a&&a.context||e,n=e.type.toUpperCase();if(e.data&&e.processData&&typeof e.data!=="string")e.data=c.param(e.data,e.traditional);if(e.dataType==="jsonp"){if(n==="GET")N.test(e.url)||(e.url+=(ka.test(e.url)?
"&":"?")+(e.jsonp||"callback")+"=?");else if(!e.data||!N.test(e.data))e.data=(e.data?e.data+"&":"")+(e.jsonp||"callback")+"=?";e.dataType="json"}if(e.dataType==="json"&&(e.data&&N.test(e.data)||N.test(e.url))){j=e.jsonpCallback||"jsonp"+sb++;if(e.data)e.data=(e.data+"").replace(N,"="+j+"$1");e.url=e.url.replace(N,"="+j+"$1");e.dataType="script";A[j]=A[j]||function(q){o=q;b();d();A[j]=w;try{delete A[j]}catch(p){}z&&z.removeChild(C)}}if(e.dataType==="script"&&e.cache===null)e.cache=false;if(e.cache===
false&&n==="GET"){var r=J(),u=e.url.replace(wb,"$1_="+r+"$2");e.url=u+(u===e.url?(ka.test(e.url)?"&":"?")+"_="+r:"")}if(e.data&&n==="GET")e.url+=(ka.test(e.url)?"&":"?")+e.data;e.global&&!c.active++&&c.event.trigger("ajaxStart");r=(r=xb.exec(e.url))&&(r[1]&&r[1]!==location.protocol||r[2]!==location.host);if(e.dataType==="script"&&n==="GET"&&r){var z=s.getElementsByTagName("head")[0]||s.documentElement,C=s.createElement("script");C.src=e.url;if(e.scriptCharset)C.charset=e.scriptCharset;if(!j){var B=
false;C.onload=C.onreadystatechange=function(){if(!B&&(!this.readyState||this.readyState==="loaded"||this.readyState==="complete")){B=true;b();d();C.onload=C.onreadystatechange=null;z&&C.parentNode&&z.removeChild(C)}}}z.insertBefore(C,z.firstChild);return w}var E=false,x=e.xhr();if(x){e.username?x.open(n,e.url,e.async,e.username,e.password):x.open(n,e.url,e.async);try{if(e.data||a&&a.contentType)x.setRequestHeader("Content-Type",e.contentType);if(e.ifModified){c.lastModified[e.url]&&x.setRequestHeader("If-Modified-Since",
c.lastModified[e.url]);c.etag[e.url]&&x.setRequestHeader("If-None-Match",c.etag[e.url])}r||x.setRequestHeader("X-Requested-With","XMLHttpRequest");x.setRequestHeader("Accept",e.dataType&&e.accepts[e.dataType]?e.accepts[e.dataType]+", */*":e.accepts._default)}catch(ga){}if(e.beforeSend&&e.beforeSend.call(k,x,e)===false){e.global&&!--c.active&&c.event.trigger("ajaxStop");x.abort();return false}e.global&&f("ajaxSend",[x,e]);var g=x.onreadystatechange=function(q){if(!x||x.readyState===0||q==="abort"){E||
d();E=true;if(x)x.onreadystatechange=c.noop}else if(!E&&x&&(x.readyState===4||q==="timeout")){E=true;x.onreadystatechange=c.noop;i=q==="timeout"?"timeout":!c.httpSuccess(x)?"error":e.ifModified&&c.httpNotModified(x,e.url)?"notmodified":"success";var p;if(i==="success")try{o=c.httpData(x,e.dataType,e)}catch(v){i="parsererror";p=v}if(i==="success"||i==="notmodified")j||b();else c.handleError(e,x,i,p);d();q==="timeout"&&x.abort();if(e.async)x=null}};try{var h=x.abort;x.abort=function(){x&&h.call(x);
g("abort")}}catch(l){}e.async&&e.timeout>0&&setTimeout(function(){x&&!E&&g("timeout")},e.timeout);try{x.send(n==="POST"||n==="PUT"||n==="DELETE"?e.data:null)}catch(m){c.handleError(e,x,null,m);d()}e.async||g();return x}},handleError:function(a,b,d,f){if(a.error)a.error.call(a.context||a,b,d,f);if(a.global)(a.context?c(a.context):c.event).trigger("ajaxError",[b,a,f])},active:0,httpSuccess:function(a){try{return!a.status&&location.protocol==="file:"||a.status>=200&&a.status<300||a.status===304||a.status===
1223||a.status===0}catch(b){}return false},httpNotModified:function(a,b){var d=a.getResponseHeader("Last-Modified"),f=a.getResponseHeader("Etag");if(d)c.lastModified[b]=d;if(f)c.etag[b]=f;return a.status===304||a.status===0},httpData:function(a,b,d){var f=a.getResponseHeader("content-type")||"",e=b==="xml"||!b&&f.indexOf("xml")>=0;a=e?a.responseXML:a.responseText;e&&a.documentElement.nodeName==="parsererror"&&c.error("parsererror");if(d&&d.dataFilter)a=d.dataFilter(a,b);if(typeof a==="string")if(b===
"json"||!b&&f.indexOf("json")>=0)a=c.parseJSON(a);else if(b==="script"||!b&&f.indexOf("javascript")>=0)c.globalEval(a);return a},param:function(a,b){function d(i,o){if(c.isArray(o))c.each(o,function(k,n){b||/\[\]$/.test(i)?f(i,n):d(i+"["+(typeof n==="object"||c.isArray(n)?k:"")+"]",n)});else!b&&o!=null&&typeof o==="object"?c.each(o,function(k,n){d(i+"["+k+"]",n)}):f(i,o)}function f(i,o){o=c.isFunction(o)?o():o;e[e.length]=encodeURIComponent(i)+"="+encodeURIComponent(o)}var e=[];if(b===w)b=c.ajaxSettings.traditional;
if(c.isArray(a)||a.jquery)c.each(a,function(){f(this.name,this.value)});else for(var j in a)d(j,a[j]);return e.join("&").replace(yb,"+")}});var la={},Ab=/toggle|show|hide/,Bb=/^([+-]=)?([\d+-.]+)(.*)$/,W,va=[["height","marginTop","marginBottom","paddingTop","paddingBottom"],["width","marginLeft","marginRight","paddingLeft","paddingRight"],["opacity"]];c.fn.extend({show:function(a,b){if(a||a===0)return this.animate(K("show",3),a,b);else{a=0;for(b=this.length;a<b;a++){var d=c.data(this[a],"olddisplay");
this[a].style.display=d||"";if(c.css(this[a],"display")==="none"){d=this[a].nodeName;var f;if(la[d])f=la[d];else{var e=c("<"+d+" />").appendTo("body");f=e.css("display");if(f==="none")f="block";e.remove();la[d]=f}c.data(this[a],"olddisplay",f)}}a=0;for(b=this.length;a<b;a++)this[a].style.display=c.data(this[a],"olddisplay")||"";return this}},hide:function(a,b){if(a||a===0)return this.animate(K("hide",3),a,b);else{a=0;for(b=this.length;a<b;a++){var d=c.data(this[a],"olddisplay");!d&&d!=="none"&&c.data(this[a],
"olddisplay",c.css(this[a],"display"))}a=0;for(b=this.length;a<b;a++)this[a].style.display="none";return this}},_toggle:c.fn.toggle,toggle:function(a,b){var d=typeof a==="boolean";if(c.isFunction(a)&&c.isFunction(b))this._toggle.apply(this,arguments);else a==null||d?this.each(function(){var f=d?a:c(this).is(":hidden");c(this)[f?"show":"hide"]()}):this.animate(K("toggle",3),a,b);return this},fadeTo:function(a,b,d){return this.filter(":hidden").css("opacity",0).show().end().animate({opacity:b},a,d)},
animate:function(a,b,d,f){var e=c.speed(b,d,f);if(c.isEmptyObject(a))return this.each(e.complete);return this[e.queue===false?"each":"queue"](function(){var j=c.extend({},e),i,o=this.nodeType===1&&c(this).is(":hidden"),k=this;for(i in a){var n=i.replace(ia,ja);if(i!==n){a[n]=a[i];delete a[i];i=n}if(a[i]==="hide"&&o||a[i]==="show"&&!o)return j.complete.call(this);if((i==="height"||i==="width")&&this.style){j.display=c.css(this,"display");j.overflow=this.style.overflow}if(c.isArray(a[i])){(j.specialEasing=
j.specialEasing||{})[i]=a[i][1];a[i]=a[i][0]}}if(j.overflow!=null)this.style.overflow="hidden";j.curAnim=c.extend({},a);c.each(a,function(r,u){var z=new c.fx(k,j,r);if(Ab.test(u))z[u==="toggle"?o?"show":"hide":u](a);else{var C=Bb.exec(u),B=z.cur(true)||0;if(C){u=parseFloat(C[2]);var E=C[3]||"px";if(E!=="px"){k.style[r]=(u||1)+E;B=(u||1)/z.cur(true)*B;k.style[r]=B+E}if(C[1])u=(C[1]==="-="?-1:1)*u+B;z.custom(B,u,E)}else z.custom(B,u,"")}});return true})},stop:function(a,b){var d=c.timers;a&&this.queue([]);
this.each(function(){for(var f=d.length-1;f>=0;f--)if(d[f].elem===this){b&&d[f](true);d.splice(f,1)}});b||this.dequeue();return this}});c.each({slideDown:K("show",1),slideUp:K("hide",1),slideToggle:K("toggle",1),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"}},function(a,b){c.fn[a]=function(d,f){return this.animate(b,d,f)}});c.extend({speed:function(a,b,d){var f=a&&typeof a==="object"?a:{complete:d||!d&&b||c.isFunction(a)&&a,duration:a,easing:d&&b||b&&!c.isFunction(b)&&b};f.duration=c.fx.off?0:typeof f.duration===
"number"?f.duration:c.fx.speeds[f.duration]||c.fx.speeds._default;f.old=f.complete;f.complete=function(){f.queue!==false&&c(this).dequeue();c.isFunction(f.old)&&f.old.call(this)};return f},easing:{linear:function(a,b,d,f){return d+f*a},swing:function(a,b,d,f){return(-Math.cos(a*Math.PI)/2+0.5)*f+d}},timers:[],fx:function(a,b,d){this.options=b;this.elem=a;this.prop=d;if(!b.orig)b.orig={}}});c.fx.prototype={update:function(){this.options.step&&this.options.step.call(this.elem,this.now,this);(c.fx.step[this.prop]||
c.fx.step._default)(this);if((this.prop==="height"||this.prop==="width")&&this.elem.style)this.elem.style.display="block"},cur:function(a){if(this.elem[this.prop]!=null&&(!this.elem.style||this.elem.style[this.prop]==null))return this.elem[this.prop];return(a=parseFloat(c.css(this.elem,this.prop,a)))&&a>-10000?a:parseFloat(c.curCSS(this.elem,this.prop))||0},custom:function(a,b,d){function f(j){return e.step(j)}this.startTime=J();this.start=a;this.end=b;this.unit=d||this.unit||"px";this.now=this.start;
this.pos=this.state=0;var e=this;f.elem=this.elem;if(f()&&c.timers.push(f)&&!W)W=setInterval(c.fx.tick,13)},show:function(){this.options.orig[this.prop]=c.style(this.elem,this.prop);this.options.show=true;this.custom(this.prop==="width"||this.prop==="height"?1:0,this.cur());c(this.elem).show()},hide:function(){this.options.orig[this.prop]=c.style(this.elem,this.prop);this.options.hide=true;this.custom(this.cur(),0)},step:function(a){var b=J(),d=true;if(a||b>=this.options.duration+this.startTime){this.now=
this.end;this.pos=this.state=1;this.update();this.options.curAnim[this.prop]=true;for(var f in this.options.curAnim)if(this.options.curAnim[f]!==true)d=false;if(d){if(this.options.display!=null){this.elem.style.overflow=this.options.overflow;a=c.data(this.elem,"olddisplay");this.elem.style.display=a?a:this.options.display;if(c.css(this.elem,"display")==="none")this.elem.style.display="block"}this.options.hide&&c(this.elem).hide();if(this.options.hide||this.options.show)for(var e in this.options.curAnim)c.style(this.elem,
e,this.options.orig[e]);this.options.complete.call(this.elem)}return false}else{e=b-this.startTime;this.state=e/this.options.duration;a=this.options.easing||(c.easing.swing?"swing":"linear");this.pos=c.easing[this.options.specialEasing&&this.options.specialEasing[this.prop]||a](this.state,e,0,1,this.options.duration);this.now=this.start+(this.end-this.start)*this.pos;this.update()}return true}};c.extend(c.fx,{tick:function(){for(var a=c.timers,b=0;b<a.length;b++)a[b]()||a.splice(b--,1);a.length||
c.fx.stop()},stop:function(){clearInterval(W);W=null},speeds:{slow:600,fast:200,_default:400},step:{opacity:function(a){c.style(a.elem,"opacity",a.now)},_default:function(a){if(a.elem.style&&a.elem.style[a.prop]!=null)a.elem.style[a.prop]=(a.prop==="width"||a.prop==="height"?Math.max(0,a.now):a.now)+a.unit;else a.elem[a.prop]=a.now}}});if(c.expr&&c.expr.filters)c.expr.filters.animated=function(a){return c.grep(c.timers,function(b){return a===b.elem}).length};c.fn.offset="getBoundingClientRect"in s.documentElement?
function(a){var b=this[0];if(a)return this.each(function(e){c.offset.setOffset(this,a,e)});if(!b||!b.ownerDocument)return null;if(b===b.ownerDocument.body)return c.offset.bodyOffset(b);var d=b.getBoundingClientRect(),f=b.ownerDocument;b=f.body;f=f.documentElement;return{top:d.top+(self.pageYOffset||c.support.boxModel&&f.scrollTop||b.scrollTop)-(f.clientTop||b.clientTop||0),left:d.left+(self.pageXOffset||c.support.boxModel&&f.scrollLeft||b.scrollLeft)-(f.clientLeft||b.clientLeft||0)}}:function(a){var b=
this[0];if(a)return this.each(function(r){c.offset.setOffset(this,a,r)});if(!b||!b.ownerDocument)return null;if(b===b.ownerDocument.body)return c.offset.bodyOffset(b);c.offset.initialize();var d=b.offsetParent,f=b,e=b.ownerDocument,j,i=e.documentElement,o=e.body;f=(e=e.defaultView)?e.getComputedStyle(b,null):b.currentStyle;for(var k=b.offsetTop,n=b.offsetLeft;(b=b.parentNode)&&b!==o&&b!==i;){if(c.offset.supportsFixedPosition&&f.position==="fixed")break;j=e?e.getComputedStyle(b,null):b.currentStyle;
k-=b.scrollTop;n-=b.scrollLeft;if(b===d){k+=b.offsetTop;n+=b.offsetLeft;if(c.offset.doesNotAddBorder&&!(c.offset.doesAddBorderForTableAndCells&&/^t(able|d|h)$/i.test(b.nodeName))){k+=parseFloat(j.borderTopWidth)||0;n+=parseFloat(j.borderLeftWidth)||0}f=d;d=b.offsetParent}if(c.offset.subtractsBorderForOverflowNotVisible&&j.overflow!=="visible"){k+=parseFloat(j.borderTopWidth)||0;n+=parseFloat(j.borderLeftWidth)||0}f=j}if(f.position==="relative"||f.position==="static"){k+=o.offsetTop;n+=o.offsetLeft}if(c.offset.supportsFixedPosition&&
f.position==="fixed"){k+=Math.max(i.scrollTop,o.scrollTop);n+=Math.max(i.scrollLeft,o.scrollLeft)}return{top:k,left:n}};c.offset={initialize:function(){var a=s.body,b=s.createElement("div"),d,f,e,j=parseFloat(c.curCSS(a,"marginTop",true))||0;c.extend(b.style,{position:"absolute",top:0,left:0,margin:0,border:0,width:"1px",height:"1px",visibility:"hidden"});b.innerHTML="<div style='position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;'><div></div></div><table style='position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;' cellpadding='0' cellspacing='0'><tr><td></td></tr></table>";
a.insertBefore(b,a.firstChild);d=b.firstChild;f=d.firstChild;e=d.nextSibling.firstChild.firstChild;this.doesNotAddBorder=f.offsetTop!==5;this.doesAddBorderForTableAndCells=e.offsetTop===5;f.style.position="fixed";f.style.top="20px";this.supportsFixedPosition=f.offsetTop===20||f.offsetTop===15;f.style.position=f.style.top="";d.style.overflow="hidden";d.style.position="relative";this.subtractsBorderForOverflowNotVisible=f.offsetTop===-5;this.doesNotIncludeMarginInBodyOffset=a.offsetTop!==j;a.removeChild(b);
c.offset.initialize=c.noop},bodyOffset:function(a){var b=a.offsetTop,d=a.offsetLeft;c.offset.initialize();if(c.offset.doesNotIncludeMarginInBodyOffset){b+=parseFloat(c.curCSS(a,"marginTop",true))||0;d+=parseFloat(c.curCSS(a,"marginLeft",true))||0}return{top:b,left:d}},setOffset:function(a,b,d){if(/static/.test(c.curCSS(a,"position")))a.style.position="relative";var f=c(a),e=f.offset(),j=parseInt(c.curCSS(a,"top",true),10)||0,i=parseInt(c.curCSS(a,"left",true),10)||0;if(c.isFunction(b))b=b.call(a,
d,e);d={top:b.top-e.top+j,left:b.left-e.left+i};"using"in b?b.using.call(a,d):f.css(d)}};c.fn.extend({position:function(){if(!this[0])return null;var a=this[0],b=this.offsetParent(),d=this.offset(),f=/^body|html$/i.test(b[0].nodeName)?{top:0,left:0}:b.offset();d.top-=parseFloat(c.curCSS(a,"marginTop",true))||0;d.left-=parseFloat(c.curCSS(a,"marginLeft",true))||0;f.top+=parseFloat(c.curCSS(b[0],"borderTopWidth",true))||0;f.left+=parseFloat(c.curCSS(b[0],"borderLeftWidth",true))||0;return{top:d.top-
f.top,left:d.left-f.left}},offsetParent:function(){return this.map(function(){for(var a=this.offsetParent||s.body;a&&!/^body|html$/i.test(a.nodeName)&&c.css(a,"position")==="static";)a=a.offsetParent;return a})}});c.each(["Left","Top"],function(a,b){var d="scroll"+b;c.fn[d]=function(f){var e=this[0],j;if(!e)return null;if(f!==w)return this.each(function(){if(j=wa(this))j.scrollTo(!a?f:c(j).scrollLeft(),a?f:c(j).scrollTop());else this[d]=f});else return(j=wa(e))?"pageXOffset"in j?j[a?"pageYOffset":
"pageXOffset"]:c.support.boxModel&&j.document.documentElement[d]||j.document.body[d]:e[d]}});c.each(["Height","Width"],function(a,b){var d=b.toLowerCase();c.fn["inner"+b]=function(){return this[0]?c.css(this[0],d,false,"padding"):null};c.fn["outer"+b]=function(f){return this[0]?c.css(this[0],d,false,f?"margin":"border"):null};c.fn[d]=function(f){var e=this[0];if(!e)return f==null?null:this;if(c.isFunction(f))return this.each(function(j){var i=c(this);i[d](f.call(this,j,i[d]()))});return"scrollTo"in
e&&e.document?e.document.compatMode==="CSS1Compat"&&e.document.documentElement["client"+b]||e.document.body["client"+b]:e.nodeType===9?Math.max(e.documentElement["client"+b],e.body["scroll"+b],e.documentElement["scroll"+b],e.body["offset"+b],e.documentElement["offset"+b]):f===w?c.css(e,d):this.css(d,typeof f==="string"?f:f+"px")}});A.jQuery=A.$=c})(window);

 /*! Copyright (c) 2010 Brandon Aaron (http://brandonaaron.net)
  * Licensed under the MIT License (LICENSE.txt).
  *
  * Thanks to: http://adomas.org/javascript-mouse-wheel/ for some pointers.
  * Thanks to: Mathias Bank(http://www.mathias-bank.de) for a scope bug fix.
  * Thanks to: Seamus Leahy for adding deltaX and deltaY
  * 
  * Version: 3.0.4
  * 
  * Requires: 1.2.2+
  */

 (function($) {

 var types = ['DOMMouseScroll', 'mousewheel'];

 $.event.special.mousewheel = {
     setup: function() {
         if ( this.addEventListener ) {
             for ( var i=types.length; i; ) {
                 this.addEventListener( types[--i], handler, false );
             }
         } else {
             this.onmousewheel = handler;
         }
     },

     teardown: function() {
         if ( this.removeEventListener ) {
             for ( var i=types.length; i; ) {
                 this.removeEventListener( types[--i], handler, false );
             }
         } else {
             this.onmousewheel = null;
         }
     }
 };

 $.fn.extend({
     mousewheel: function(fn) {
         return fn ? this.bind("mousewheel", fn) : this.trigger("mousewheel");
     },

     unmousewheel: function(fn) {
         return this.unbind("mousewheel", fn);
     }
 });


 function handler(event) {
     var orgEvent = event || window.event, args = [].slice.call( arguments, 1 ), delta = 0, returnValue = true, deltaX = 0, deltaY = 0;
     event = $.event.fix(orgEvent);
     event.type = "mousewheel";

     // Old school scrollwheel delta
     if ( event.wheelDelta ) { delta = event.wheelDelta/120; }
     if ( event.detail     ) { delta = -event.detail/3; }

     // New school multidimensional scroll (touchpads) deltas
     deltaY = delta;

     // Gecko
     if ( orgEvent.axis !== undefined && orgEvent.axis === orgEvent.HORIZONTAL_AXIS ) {
         deltaY = 0;
         deltaX = -1*delta;
     }

     // Webkit
     if ( orgEvent.wheelDeltaY !== undefined ) { deltaY = orgEvent.wheelDeltaY/120; }
     if ( orgEvent.wheelDeltaX !== undefined ) { deltaX = -1*orgEvent.wheelDeltaX/120; }

     // Add event and delta to the front of the arguments
     args.unshift(event, delta, deltaX, deltaY);

     return $.event.handle.apply(this, args);
 }

 })(jQuery);
 
 /* Copyright (c) 2009 Kelvin Luck (kelvin AT kelvinluck DOT com || http://www.kelvinluck.com)
  * Dual licensed under the MIT (http://www.opensource.org/licenses/mit-license.php) 
  * and GPL (http://www.opensource.org/licenses/gpl-license.php) licenses.
  * 
  * See http://kelvinluck.com/assets/jquery/jScrollPane/
  * $Id: jScrollPane.js 93 2010-06-01 08:17:28Z kelvin.luck $
  */


 (function($) {

 $.jScrollPane = {
 	active : []
 };
 $.fn.jScrollPane = function(settings)
 {
 	settings = $.extend({}, $.fn.jScrollPane.defaults, settings);

 	var rf = function() { return false; };

 	return this.each(
 		function()
 		{
 			var $this = $(this);
 			var paneEle = this;
 			var currentScrollPosition = 0;
 			var paneWidth;
 			var paneHeight;
 			var trackHeight;
 			var trackOffset = settings.topCapHeight;
 			var $container;

 			if ($(this).parent().is('.jScrollPaneContainer')) {
 				$container = $(this).parent();
 				currentScrollPosition = settings.maintainPosition ? $this.position().top : 0;
 				var $c = $(this).parent();
 				paneWidth = $c.innerWidth();
 				paneHeight = $c.outerHeight();
 				$('>.jScrollPaneTrack, >.jScrollArrowUp, >.jScrollArrowDown, >.jScrollCap', $c).remove();
 				$this.css({'top':0});
 			} else {
 				$this.data('originalStyleTag', $this.attr('style'));
 				// Switch the element's overflow to hidden to ensure we get the size of the element without the scrollbars [http://plugins.jquery.com/node/1208]
 				$this.css('overflow', 'hidden');
 				this.originalPadding = $this.css('paddingTop') + ' ' + $this.css('paddingRight') + ' ' + $this.css('paddingBottom') + ' ' + $this.css('paddingLeft');
 				this.originalSidePaddingTotal = (parseInt($this.css('paddingLeft')) || 0) + (parseInt($this.css('paddingRight')) || 0);
 				paneWidth = $this.innerWidth();
 				paneHeight = $this.innerHeight();
 				$container = $('<div></div>')
 					.attr({'className':'jScrollPaneContainer'})
 					.css(
 						{
 							'height':paneHeight+'px', 
 							'width':paneWidth+'px'
 						}
 					);
 				if (settings.enableKeyboardNavigation) {
 					$container.attr(
 						'tabindex', 
 						settings.tabIndex
 					);
 				}
 				$this.wrap($container);
 				$container = $this.parent();
 				// deal with text size changes (if the jquery.em plugin is included)
 				// and re-initialise the scrollPane so the track maintains the
 				// correct size
 				$(document).bind(
 					'emchange', 
 					function(e, cur, prev)
 					{
 						$this.jScrollPane(settings);
 					}
 				);

 			}
 			trackHeight = paneHeight;

 			if (settings.reinitialiseOnImageLoad) {
 				// code inspired by jquery.onImagesLoad: http://plugins.jquery.com/project/onImagesLoad
 				// except we re-initialise the scroll pane when each image loads so that the scroll pane is always up to size...
 				// TODO: Do I even need to store it in $.data? Is a local variable here the same since I don't pass the reinitialiseOnImageLoad when I re-initialise?
 				var $imagesToLoad = $.data(paneEle, 'jScrollPaneImagesToLoad') || $('img', $this);
 				var loadedImages = [];











 				if ($imagesToLoad.length) {
 					$imagesToLoad.each(function(i, val)	{
 						$(this).bind('load readystatechange', function() {
 							if($.inArray(i, loadedImages) == -1){ //don't double count images
 								loadedImages.push(val); //keep a record of images we've seen
 								$imagesToLoad = $.grep($imagesToLoad, function(n, i) {
 									return n != val;
 								});
 								$.data(paneEle, 'jScrollPaneImagesToLoad', $imagesToLoad);
 								var s2 = $.extend(settings, {reinitialiseOnImageLoad:false});
 								$this.jScrollPane(s2); // re-initialise
 							}
 						}).each(function(i, val) {
 							if(this.complete || this.complete===undefined) { 
 								//needed for potential cached images
 								this.src = this.src; 
 							} 
 						});
 					});
 				};
 			}

 			var p = this.originalSidePaddingTotal;
 			var realPaneWidth = paneWidth - settings.scrollbarWidth - settings.scrollbarMargin - p;

 			var cssToApply = {
 				'height':'auto',
 				'width': realPaneWidth + 'px'
 			}

 			if(settings.scrollbarOnLeft) {
 				cssToApply.paddingLeft = settings.scrollbarMargin + settings.scrollbarWidth + 'px';
 			} else {
 				cssToApply.paddingRight = settings.scrollbarMargin + 'px';
 			}

 			$this.css(cssToApply);

 			var contentHeight = $this.outerHeight();
 			var percentInView = paneHeight / contentHeight;

 			var isScrollable = percentInView < .99;
 			$container[isScrollable ? 'addClass' : 'removeClass']('jScrollPaneScrollable');

 			if (isScrollable) {
 			  // Ipad, Iphone, Ipod and Android support
        				if((navigator.userAgent.match(/iPhone/i)) || (navigator.userAgent.match(/iPod/i)) || (navigator.userAgent.match(/iPad/i)) || (navigator.userAgent.match(/Android/i))) {
        				 		var isTouchScreen = 1;
        				 	}else{
        				 		var isTouchScreen = 0;
        				 	}


        				$container.bind('touchstart', function(e){
        					var cpos = dragPosition;
        					if(isTouchScreen){
        									e = e.originalEvent.touches[0];
        								}
        					var sY = e.pageY;
        					var sX = e.pageX;


        					$container.bind('touchmove',function(ev){
        						if(isTouchScreen){
        							ev.preventDefault();
        							ev = ev.originalEvent.touches[0];
        						}

        						var top = cpos-(ev.pageY-sY);
        						positionDrag(top);

        					});
        					$container.bind('touchend',function(ev){
        						$container.unbind('touchmove touchend');
        					});
        				});
 				$container.append(
 					$('<div></div>').addClass('jScrollCap jScrollCapTop').css({height:settings.topCapHeight}),
 					$('<div></div>').attr({'className':'jScrollPaneTrack'}).css({'width':settings.scrollbarWidth+'px'}).append(
 						$('<div></div>').attr({'className':'jScrollPaneDrag'}).css({'width':settings.scrollbarWidth+'px'}).append(
 							$('<div></div>').attr({'className':'jScrollPaneDragTop'}).css({'width':settings.scrollbarWidth+'px'}),
 							$('<div></div>').attr({'className':'jScrollPaneDragBottom'}).css({'width':settings.scrollbarWidth+'px'})
 						)
 					),
 					$('<div></div>').addClass('jScrollCap jScrollCapBottom').css({height:settings.bottomCapHeight})
 				);

 				var $track = $('>.jScrollPaneTrack', $container);
 				var $drag = $('>.jScrollPaneTrack .jScrollPaneDrag', $container);


 				var currentArrowDirection;
 				var currentArrowTimerArr = [];// Array is used to store timers since they can stack up when dealing with keyboard events. This ensures all timers are cleaned up in the end, preventing an acceleration bug.
 				var currentArrowInc;
 				var whileArrowButtonDown = function() 
 				{
 					if (currentArrowInc > 4 || currentArrowInc % 4 == 0) {
 						positionDrag(dragPosition + currentArrowDirection * mouseWheelMultiplier);
 					}
 					currentArrowInc++;
 				};

 				if (settings.enableKeyboardNavigation) {
 					$container.bind(
 						'keydown.jscrollpane',
 						function(e) 
 						{
 							switch (e.keyCode) {
 								case 38: //up
 									currentArrowDirection = -1;
 									currentArrowInc = 0;
 									whileArrowButtonDown();
 									currentArrowTimerArr[currentArrowTimerArr.length] = setInterval(whileArrowButtonDown, 100);
 									return false;
 								case 40: //down
 									currentArrowDirection = 1;
 									currentArrowInc = 0;
 									whileArrowButtonDown();
 									currentArrowTimerArr[currentArrowTimerArr.length] = setInterval(whileArrowButtonDown, 100);
 									return false;
 								case 33: // page up
 								case 34: // page down
 									// TODO
 									return false;
 								default:
 							}
 						}
 					).bind(
 						'keyup.jscrollpane',
 						function(e) 
 						{
 							if (e.keyCode == 38 || e.keyCode == 40) {
 								for (var i = 0; i < currentArrowTimerArr.length; i++) {
 									clearInterval(currentArrowTimerArr[i]);
 								}
 								return false;
 							}
 						}
 					);
 				}

 				if (settings.showArrows) {

 					var currentArrowButton;
 					var currentArrowInterval;

 					var onArrowMouseUp = function(event)
 					{
 						$('html').unbind('mouseup', onArrowMouseUp);
 						currentArrowButton.removeClass('jScrollActiveArrowButton');
 						clearInterval(currentArrowInterval);
 					};
 					var onArrowMouseDown = function() {
 						$('html').bind('mouseup', onArrowMouseUp);
 						currentArrowButton.addClass('jScrollActiveArrowButton');
 						currentArrowInc = 0;
 						whileArrowButtonDown();
 						currentArrowInterval = setInterval(whileArrowButtonDown, 100);
 					};
 					$container
 						.append(
 							$('<a></a>')
 								.attr(
 									{
 										'href':'javascript:;', 
 										'className':'jScrollArrowUp', 
 										'tabindex':-1
 									}
 								)
 								.css(
 									{
 										'width':settings.scrollbarWidth+'px',
 										'top':settings.topCapHeight + 'px'
 									}
 								)
 								.html('Scroll up')
 								.bind('mousedown', function()
 								{
 									currentArrowButton = $(this);
 									currentArrowDirection = -1;
 									onArrowMouseDown();
 									this.blur();
 									return false;
 								})
 								.bind('click', rf),
 							$('<a></a>')
 								.attr(
 									{
 										'href':'javascript:;', 
 										'className':'jScrollArrowDown', 
 										'tabindex':-1
 									}
 								)
 								.css(
 									{
 										'width':settings.scrollbarWidth+'px',
 										'bottom':settings.bottomCapHeight + 'px'
 									}
 								)
 								.html('Scroll down')
 								.bind('mousedown', function()
 								{
 									currentArrowButton = $(this);
 									currentArrowDirection = 1;
 									onArrowMouseDown();
 									this.blur();
 									return false;
 								})
 								.bind('click', rf)
 						);
 					var $upArrow = $('>.jScrollArrowUp', $container);
 					var $downArrow = $('>.jScrollArrowDown', $container);
 				}

 				if (settings.arrowSize) {
 					trackHeight = paneHeight - settings.arrowSize - settings.arrowSize;
 					trackOffset += settings.arrowSize;
 				} else if ($upArrow) {
 					var topArrowHeight = $upArrow.height();
 					settings.arrowSize = topArrowHeight;
 					trackHeight = paneHeight - topArrowHeight - $downArrow.height();
 					trackOffset += topArrowHeight;
 				}
 				trackHeight -= settings.topCapHeight + settings.bottomCapHeight;
 				$track.css({'height': trackHeight+'px', top:trackOffset+'px'})

 				var $pane = $(this).css({'position':'absolute', 'overflow':'visible'});

 				var currentOffset;
 				var maxY;
 				var mouseWheelMultiplier;
 				// store this in a seperate variable so we can keep track more accurately than just updating the css property..
 				var dragPosition = 0;
 				var dragMiddle = percentInView*paneHeight/2;

 				// pos function borrowed from tooltip plugin and adapted...
 				var getPos = function (event, c) {
 					var p = c == 'X' ? 'Left' : 'Top';
 					return event['page' + c] || (event['client' + c] + (document.documentElement['scroll' + p] || document.body['scroll' + p])) || 0;
 				};

 				var ignoreNativeDrag = function() {	return false; };

 				var initDrag = function()
 				{
 					ceaseAnimation();
 					currentOffset = $drag.offset(false);
 					currentOffset.top -= dragPosition;
 					maxY = trackHeight - $drag[0].offsetHeight;
 					mouseWheelMultiplier = 2 * settings.wheelSpeed * maxY / contentHeight;
 				};

 				var onStartDrag = function(event)
 				{
 					initDrag();
 					dragMiddle = getPos(event, 'Y') - dragPosition - currentOffset.top;
 					$('html').bind('mouseup', onStopDrag).bind('mousemove', updateScroll).bind('mouseleave', onStopDrag)
 					if ($.browser.msie) {
 						$('html').bind('dragstart', ignoreNativeDrag).bind('selectstart', ignoreNativeDrag);
 					}
 					return false;
 				};
 				var onStopDrag = function()
 				{
 					$('html').unbind('mouseup', onStopDrag).unbind('mousemove', updateScroll);
 					dragMiddle = percentInView*paneHeight/2;
 					if ($.browser.msie) {
 						$('html').unbind('dragstart', ignoreNativeDrag).unbind('selectstart', ignoreNativeDrag);
 					}
 				};
 				var positionDrag = function(destY)
 				{
 					$container.scrollTop(0);
 					destY = destY < 0 ? 0 : (destY > maxY ? maxY : destY);
 					dragPosition = destY;
 					$drag.css({'top':destY+'px'});
 					var p = destY / maxY;
 					$this.data('jScrollPanePosition', (paneHeight-contentHeight)*-p);
 					$pane.css({'top':((paneHeight-contentHeight)*p) + 'px'});
 					$this.trigger('scroll');
 					if (settings.showArrows) {
 						$upArrow[destY == 0 ? 'addClass' : 'removeClass']('disabled');
 						$downArrow[destY == maxY ? 'addClass' : 'removeClass']('disabled');
 					}
 				};
 				var updateScroll = function(e)
 				{
 					positionDrag(getPos(e, 'Y') - currentOffset.top - dragMiddle);
 				};

 				var dragH = Math.max(Math.min(percentInView*(paneHeight-settings.arrowSize*2), settings.dragMaxHeight), settings.dragMinHeight);

 				$drag.css(
 					{'height':dragH+'px'}
 				).bind('mousedown', onStartDrag);

 				var trackScrollInterval;
 				var trackScrollInc;
 				var trackScrollMousePos;
 				var doTrackScroll = function()
 				{
 					if (trackScrollInc > 8 || trackScrollInc%4==0) {
 						positionDrag((dragPosition - ((dragPosition - trackScrollMousePos) / 2)));
 					}
 					trackScrollInc ++;
 				};
 				var onStopTrackClick = function()
 				{
 					clearInterval(trackScrollInterval);
 					$('html').unbind('mouseup', onStopTrackClick).unbind('mousemove', onTrackMouseMove);
 				};
 				var onTrackMouseMove = function(event)
 				{
 					trackScrollMousePos = getPos(event, 'Y') - currentOffset.top - dragMiddle;
 				};
 				var onTrackClick = function(event)
 				{
 					initDrag();
 					onTrackMouseMove(event);
 					trackScrollInc = 0;
 					$('html').bind('mouseup', onStopTrackClick).bind('mousemove', onTrackMouseMove);
 					trackScrollInterval = setInterval(doTrackScroll, 100);
 					doTrackScroll();
 					return false;
 				};

 				$track.bind('mousedown', onTrackClick);

 				$container.bind(
 					'mousewheel',
 					function (event, delta) {
 						delta = delta || (event.wheelDelta ? event.wheelDelta / 120 : (event.detail) ?
 -event.detail/3 : 0);
 						initDrag();
 						ceaseAnimation();
 						var d = dragPosition;
 						positionDrag(dragPosition - delta * mouseWheelMultiplier);
 						var dragOccured = d != dragPosition;
 						return !dragOccured;
 					}
 				);

 				var _animateToPosition;
 				var _animateToInterval;
 				function animateToPosition()
 				{
 					var diff = (_animateToPosition - dragPosition) / settings.animateStep;
 					if (diff > 1 || diff < -1) {
 						positionDrag(dragPosition + diff);
 					} else {
 						positionDrag(_animateToPosition);
 						ceaseAnimation();
 					}
 				}
 				var ceaseAnimation = function()
 				{
 					if (_animateToInterval) {
 						clearInterval(_animateToInterval);
 						delete _animateToPosition;
 					}
 				};
 				var scrollTo = function(pos, preventAni)
 				{
 					if (typeof pos == "string") {
 						// Legal hash values aren't necessarily legal jQuery selectors so we need to catch any
 						// errors from the lookup...
 						try {
 							$e = $(pos, $this);
 						} catch (err) {
 							return;
 						}
 						if (!$e.length) return;
 						pos = $e.offset().top - $this.offset().top;
 					}
 					ceaseAnimation();
 					var maxScroll = contentHeight - paneHeight;
 					pos = pos > maxScroll ? maxScroll : pos;
 					$this.data('jScrollPaneMaxScroll', maxScroll);
 					var destDragPosition = pos/maxScroll * maxY;
 					if (preventAni || !settings.animateTo) {
 						positionDrag(destDragPosition);
 					} else {
 						$container.scrollTop(0);
 						_animateToPosition = destDragPosition;
 						_animateToInterval = setInterval(animateToPosition, settings.animateInterval);
 					}
 				};
 				$this[0].scrollTo = scrollTo;

 				$this[0].scrollBy = function(delta)
 				{
 					var currentPos = -parseInt($pane.css('top')) || 0;
 					scrollTo(currentPos + delta);
 				};

 				initDrag();

 				scrollTo(-currentScrollPosition, true);

 				// Deal with it when the user tabs to a link or form element within this scrollpane
 				$('*', this).bind(
 					'focus',
 					function(event)
 					{
 						var $e = $(this);

 						// loop through parents adding the offset top of any elements that are relatively positioned between
 						// the focused element and the jScrollPaneContainer so we can get the true distance from the top
 						// of the focused element to the top of the scrollpane...
 						var eleTop = 0;

 						var preventInfiniteLoop = 100;

 						while ($e[0] != $this[0]) {
 							eleTop += $e.position().top;
 							$e = $e.offsetParent();
 							if (!preventInfiniteLoop--) {
 								return;
 							}
 						}

 						var viewportTop = -parseInt($pane.css('top')) || 0;
 						var maxVisibleEleTop = viewportTop + paneHeight;
 						var eleInView = eleTop > viewportTop && eleTop < maxVisibleEleTop;
 						if (!eleInView) {
 							var destPos = eleTop - settings.scrollbarMargin;
 							if (eleTop > viewportTop) { // element is below viewport - scroll so it is at bottom.
 								destPos += $(this).height() + 15 + settings.scrollbarMargin - paneHeight;
 							}
 							scrollTo(destPos);
 						}
 					}
 				)


 				if (settings.observeHash) {
 					if (location.hash && location.hash.length > 1) {
 						setTimeout(function(){
 							scrollTo(location.hash);
 						}, $.browser.safari ? 100 : 0);
 					}

 					// use event delegation to listen for all clicks on links and hijack them if they are links to
 					// anchors within our content...
 					$(document).bind('click', function(e){
 						$target = $(e.target);
 						if ($target.is('a')) {
 							var h = $target.attr('href');
 							if (h && h.substr(0, 1) == '#' && h.length > 1) {
 								setTimeout(function(){
 									scrollTo(h, !settings.animateToInternalLinks);
 								}, $.browser.safari ? 100 : 0);
 							}
 						}
 					});
 				}

 				// Deal with dragging and selecting text to make the scrollpane scroll...
 				function onSelectScrollMouseDown(e)
 				{
 				   $(document).bind('mousemove.jScrollPaneDragging', onTextSelectionScrollMouseMove);
 				   $(document).bind('mouseup.jScrollPaneDragging',   onSelectScrollMouseUp);

 				}

 				var textDragDistanceAway;
 				var textSelectionInterval;

 				function onTextSelectionInterval()
 				{
 					direction = textDragDistanceAway < 0 ? -1 : 1;
 					$this[0].scrollBy(textDragDistanceAway / 2);
 				}

 				function clearTextSelectionInterval()
 				{
 					if (textSelectionInterval) {
 						clearInterval(textSelectionInterval);
 						textSelectionInterval = undefined;
 					}
 				}

 				function onTextSelectionScrollMouseMove(e)
 				{
 					var offset = $this.parent().offset().top;
 					var maxOffset = offset + paneHeight;
 					var mouseOffset = getPos(e, 'Y');
 					textDragDistanceAway = mouseOffset < offset ? mouseOffset - offset : (mouseOffset > maxOffset ? mouseOffset - maxOffset : 0);
 					if (textDragDistanceAway == 0) {
 						clearTextSelectionInterval();
 					} else {
 						if (!textSelectionInterval) {
 							textSelectionInterval  = setInterval(onTextSelectionInterval, 100);
 						}
 					}
 				}

 				function onSelectScrollMouseUp(e)
 				{
 				   $(document)
 					  .unbind('mousemove.jScrollPaneDragging')
 					  .unbind('mouseup.jScrollPaneDragging');
 				   clearTextSelectionInterval();
 				}

 				$container.bind('mousedown.jScrollPane', onSelectScrollMouseDown);


 				$.jScrollPane.active.push($this[0]);

 			} else {
 				$this.css(
 					{
 						'height':paneHeight+'px',
 						'width':paneWidth-this.originalSidePaddingTotal+'px',
 						'padding':this.originalPadding
 					}
 				);
 				$this[0].scrollTo = $this[0].scrollBy = function() {};
 				// clean up listeners
 				$this.parent().unbind('mousewheel').unbind('mousedown.jScrollPane').unbind('keydown.jscrollpane').unbind('keyup.jscrollpane');
 			}

 		}
 	)
 };

 $.fn.jScrollPaneRemove = function()
 {
 	$(this).each(function()
 	{
 		$this = $(this);
 		var $c = $this.parent();
 		if ($c.is('.jScrollPaneContainer')) {
 			$this.css(
 				{
 					'top':'',
 					'height':'',
 					'width':'',
 					'padding':'',
 					'overflow':'',
 					'position':''
 				}
 			);
 			$this.attr('style', $this.data('originalStyleTag'));
 			$c.after($this).remove();
 		}
 	});
 }

 $.fn.jScrollPane.defaults = {
 	scrollbarWidth : 10,
 	scrollbarMargin : 5,
 	wheelSpeed : 18,
 	showArrows : false,
 	arrowSize : 0,
 	animateTo : false,
 	dragMinHeight : 1,
 	dragMaxHeight : 99999,
 	animateInterval : 100,
 	animateStep: 3,
 	maintainPosition: true,
 	scrollbarOnLeft: false,
 	reinitialiseOnImageLoad: false,
 	tabIndex : 0,
 	enableKeyboardNavigation: true,
 	animateToInternalLinks: false,
 	topCapHeight: 0,
 	bottomCapHeight: 0,
 	observeHash: true
 };

 // clean up the scrollTo expandos
 $(window)
 	.bind('unload', function() {
 		var els = $.jScrollPane.active; 
 		for (var i=0; i<els.length; i++) {
 			els[i].scrollTo = els[i].scrollBy = null;
 		}
 	}
 );

 })(jQuery);
 
 /*!
  * Galleria v 1.1.95 2010-08-06
  * http://galleria.aino.se
  *
  * Copyright (c) 2010, Aino
  * Licensed under the MIT license.
  */

 (function() {

 var initializing = false,
     fnTest = /xyz/.test(function(){xyz;}) ? /\b__super\b/ : /.*/,
     Class = function(){},
     window = this;

 Class.extend = function(prop) {
     var __super = this.prototype;
     initializing = true;
     var proto = new this();
     initializing = false;
     for (var name in prop) {
         if (name) {
             proto[name] = typeof prop[name] == "function" && 
                 typeof __super[name] == "function" && fnTest.test(prop[name]) ? 
                 (function(name, fn) { 
                     return function() { 
                         var tmp = this.__super; 
                         this.__super = __super[name]; 
                         var ret = fn.apply(this, arguments);       
                         this.__super = tmp; 
                         return ret; 
                     }; 
                 })(name, prop[name]) : prop[name]; 
         } 
     }

     function Class() {
         if ( !initializing && this.__constructor ) {
             this.__constructor.apply(this, arguments);
         }
     }
     Class.prototype = proto;
     Class.constructor = Class;
     Class.extend = arguments.callee;
     return Class;
 };

 var Base = Class.extend({
     loop : function( elem, fn) {
         var scope = this;
         if (typeof elem == 'number') {
             elem = new Array(elem);
         }
         jQuery.each(elem, function() {
             fn.call(scope, arguments[1], arguments[0]);
         });
         return elem;
     },
     create : function( elem, className ) {
         elem = elem || 'div';
         var el = document.createElement(elem);
         if (className) {
             el.className = className;
         }
         return el;
     },
     getElements : function( selector ) {
         var elems = {};
         this.loop( jQuery(selector), this.proxy(function( elem ) {
             this.push(elem, elems);
         }));
         return elems;
     },
     setStyle : function( elem, css ) {
         jQuery(elem).css(css);
         return this;
     },
     getStyle : function( elem, styleProp, parse ) {
         var val = jQuery(elem).css(styleProp);
         return parse ? this.parseValue( val ) : val;
     },
     cssText : function( string ) {
         var style = document.createElement('style');
         this.getElements('head')[0].appendChild(style);
         if (style.styleSheet) { // IE
             style.styleSheet.cssText = string;
         } else {
             var cssText = document.createTextNode(string);
             style.appendChild(cssText);
         }
         return this;
     },
     touch : function(el) {
         var sibling = el.nextSibling;
         var parent = el.parentNode;
         parent.removeChild(el);
         if ( sibling ) {
             parent.insertBefore(el, sibling);
         } else {
             parent.appendChild(el);
         }
         if (el.styleSheet && el.styleSheet.imports.length) {
             this.loop(el.styleSheet.imports, function(i) {
                 el.styleSheet.addImport(i.href);
             });
         }
     },
     loadCSS : function(href, callback) {
         var exists = this.getElements('link[href="'+href+'"]').length;
         if (exists) {
             callback.call(null);
             return exists[0];
         }
         var link = this.create('link');
         link.rel = 'stylesheet';
         link.href = href;

         if (typeof callback == 'function') {
             // a new css check method, still experimental...
             this.wait(function() {
                 return !!document.body;
             }, function() {
                 var testElem = this.create('div', 'galleria-container galleria-stage');
                 this.moveOut(testElem);
                 document.body.appendChild(testElem);
                 var getStyles = this.proxy(function() {
                     var str = '';
                     var props;
                     if (document.defaultView && document.defaultView.getComputedStyle) {
                         props = document.defaultView.getComputedStyle(testElem, "");
                         this.loop(props, function(prop) {
                             str += prop + props.getPropertyValue(prop);
                         });
                     } else if (testElem.currentStyle) { // IE
                         props = testElem.currentStyle;
                         this.loop(props, function(val, prop) {
                             str += prop + val;
                         });
                     }
                     return str;
                 });
                 var current = getStyles();
                 this.wait(function() {
                     return getStyles() !== current;
                 }, function() {
                     document.body.removeChild(testElem);
                     callback.call(link);
                 }, function() {
                     G.raise('Could not confirm theme CSS');
                 }, 10000);
             });
         }
         window.setTimeout(this.proxy(function() {
             var styles = this.getElements('link[rel="stylesheet"],style');
             if (styles.length) {
                 styles[0].parentNode.insertBefore(link, styles[0]);
             } else {
                 this.getElements('head')[0].appendChild(link);
             }
             // IE needs a manual touch to re-order the cascade
             if (G.IE) {
                 this.loop(styles, function(el) {
                     this.touch(el);
                 })
             }
         }), 2);
         return link;
     },
     moveOut : function( elem ) {
         return this.setStyle(elem, {
             position: 'absolute',
             left: '-10000px',
             display: 'block'
         });
     },
     moveIn : function( elem ) {
         return this.setStyle(elem, {
             left: '0'
         }); 
     },
     reveal : function( elem ) {
         return jQuery( elem ).show();
     },
     hide : function( elem ) {
         return jQuery( elem ).hide();
     },
     mix : function() {
         return jQuery.extend.apply(jQuery, arguments);
     },
     proxy : function( fn, scope ) {
         if ( typeof fn !== 'function' ) {
             return function() {};
         }
         scope = scope || this;
         return function() {
             return fn.apply( scope, Array.prototype.slice.call(arguments) );
         };
     },
     listen : function( elem, type, fn ) {
         jQuery(elem).bind( type, fn );
     },
     forget : function( elem, type, fn ) {
         jQuery(elem).unbind(type, fn);
     },
     dispatch : function( elem, type ) {
         jQuery(elem).trigger(type);
     },
     clone : function( elem, keepEvents ) {
         keepEvents = keepEvents || false;
         return jQuery(elem).clone(keepEvents)[0];
     },
     removeAttr : function( elem, attributes ) {
         this.loop( attributes.split(' '), function(attr) {
             jQuery(elem).removeAttr(attr);
         });
     },
     push : function( elem, obj ) {
         if (typeof obj.length == 'undefined') {
             obj.length = 0;
         }
         Array.prototype.push.call( obj, elem );
         return elem;
     },
     width : function( elem, outer ) {
         return this.meassure(elem, outer, 'Width');
     },
     height : function( elem, outer ) {
         return this.meassure(elem, outer, 'Height');
     },
     meassure : function(el, outer, meassure) {
         var elem = jQuery( el );
         var ret = outer ? elem['outer'+meassure](true) : elem[meassure.toLowerCase()]();
         // fix quirks mode
         if (G.QUIRK) {
             var which = meassure == "Width" ? [ "left", "right" ] : [ "top", "bottom" ];
             this.loop(which, function(s) {
                 ret += elem.css('border-' + s + '-width').replace(/[^\d]/g,'') * 1;
                 ret += elem.css('padding-' + s).replace(/[^\d]/g,'') * 1;
             });
         }
         return ret;
     },
     toggleClass : function( elem, className, arg ) {
         if (typeof arg !== 'undefined') {
             var fn = arg ? 'addClass' : 'removeClass';
             jQuery(elem)[fn](className);
             return this;
         }
         jQuery(elem).toggleClass(className);
         return this;
     },
     hideAll : function( el ) {
         jQuery(el).find('*').hide();
     },
     animate : function( el, options ) {
         options.complete = this.proxy(options.complete);
         var elem = jQuery(el);
         if (!elem.length) {
             return;
         }
         if (options.from) {
             elem.css(from);
         }
         elem.animate(options.to, {
             duration: options.duration || 400,
             complete: options.complete,
             easing: options.easing || 'swing'
         });
     },
     wait : function(fn, callback, err, max) {
         fn = this.proxy(fn);
         callback = this.proxy(callback);
         err = this.proxy(err);
         var ts = new Date().getTime() + (max || 3000);
         window.setTimeout(function() {
             if (fn()) {
                 callback();
                 return false;
             }
             if (new Date().getTime() >= ts) {
                 err();
                 callback();
                 return false;
             }
             window.setTimeout(arguments.callee, 2);
         }, 2);
         return this;
     },
     loadScript: function(url, callback) {
        var script = document.createElement('script');
        script.src = url;
        script.async = true; // HTML5

        var done = false;
        var scope = this;

        // Attach handlers for all browsers
        script.onload = script.onreadystatechange = function() {
            if ( !done && (!this.readyState ||
                this.readyState == "loaded" || this.readyState == "complete") ) {
                done = true;

                if (typeof callback == 'function') {
                    callback.call(scope, this);
                }

                // Handle memory leak in IE
                script.onload = script.onreadystatechange = null;
            }
        };
        var s = document.getElementsByTagName('script')[0];
        s.parentNode.insertBefore(script, s);

        return this;
     },
     parseValue: function(val) {
         if (typeof val == 'number') {
             return val;
         } else if (typeof val == 'string') {
             var arr = val.match(/\-?\d/g);
             return arr && arr.constructor == Array ? arr.join('')*1 : 0;
         } else {
             return 0;
         }
     }
 });

 var Picture = Base.extend({
     __constructor : function(order) {
         this.image = null;
         this.elem = this.create('div', 'galleria-image');
         this.setStyle( this.elem, {
             overflow: 'hidden',
             position: 'relative' // for IE Standards mode
         } );
         this.order = order;
         this.orig = { w:0, h:0, r:1 };
     },

     cache: {},
     ready: false,

     add: function(src) {
         if (this.cache[src]) {
             return this.cache[src];
         }
         var image = new Image();
         image.src = src;
         this.setStyle(image, {display: 'block'});
         if (image.complete && image.width) {
             this.cache[src] = image;
             return image;
         }
         image.onload = (function(scope) {
             return function() {
                 scope.cache[src] = image;
             };
         })(this);
         return image;
     },

     isCached: function(src) {
         return this.cache[src] ? this.cache[src].complete : false;
     },

     make: function(src) {
         var i = this.cache[src] || this.add(src);
         return this.clone(i);
     },

     load: function(src, callback) {
         callback = this.proxy( callback );
         this.elem.innerHTML = '';
         this.image = this.make( src );
         this.moveOut( this.image );
         this.elem.appendChild( this.image );
         this.wait(function() {
             return (this.image.complete && this.image.width);
         }, function() {
             this.orig = {
                 h: this.h || this.image.height,
                 w: this.w || this.image.width
             };
             callback( {target: this.image, scope: this} );
         }, function() {
             G.raise('image not loaded in 20 seconds: '+ src);
         }, 100000);
         return this;
     },

     scale: function(options) {
         var o = this.mix({
             width: 0,
             height: 0,
             min: undefined,
             max: undefined,
             margin: 0,
             complete: function(){},
             position: 'center',
             crop: false
         }, options);
         if (!this.image) {
             return this;
         }
         var width,height;
         this.wait(function() {
             width  = o.width || this.width(this.elem);
             height = o.height || this.height(this.elem);
             return width && height;
         }, function() {
             var nw = (width - o.margin*2) / this.orig.w;
             var nh = (height- o.margin*2) / this.orig.h;
             var rmap = {
                 'true': Math.max(nw,nh),
                 'width': nw,
                 'height': nh,
                 'false': Math.min(nw,nh)
             }
             var ratio = rmap[o.crop.toString()];
             if (o.max) {
                 ratio = Math.min(o.max, ratio);
             }
             if (o.min) {
                 ratio = Math.max(o.min, ratio);
             }
             this.setStyle(this.elem, {
                 width: width,
                 height: height
             });
             this.image.width = Math.ceil(this.orig.w * ratio);
             this.image.height = Math.ceil(this.orig.h * ratio);

             var getPosition = this.proxy(function(value, img, m) {
                 var result = 0;
                 if (/\%/.test(value)) {
                     var pos = parseInt(value) / 100;
                     result = Math.ceil(this.image[img] * -1 * pos + m * pos);
                 } else {
                     result = parseInt(value);
                 }
                 return result;
             });

             var map = {
                 'top': { top: 0 },
                 'left': { left: 0 },
                 'right': { left: '100%' },
                 'bottom': { top: '100%' }
             }

             var pos = {};
             var mix = {};

             this.loop(o.position.toLowerCase().split(' '), function(p, i) {
                 if (p == 'center') {
                     p = '50%';
                 }
                 pos[i ? 'top' : 'left'] = p;
             });

             this.loop(pos, function(val, key) {
                 if (map.hasOwnProperty(val)) {
                     mix = this.mix(mix, map[val]);
                 }
             });

             pos = pos.top ? this.mix(pos, mix) : mix;

             pos = this.mix({
                 top: '50%',
                 left: '50%'
             }, pos);

             this.setStyle(this.image, {
                 position : 'relative',
                 top :  getPosition(pos.top, 'height', height),
                 left : getPosition(pos.left, 'width', width)
             });
             this.ready = true;
             o.complete.call(this);
         });
         return this;
     }
 });

 var G = window.Galleria = Base.extend({

     __constructor : function(options) {
         this.theme = undefined;
         this.options = options;
         this.playing = false;
         this.playtime = 5000;
         this.active = null;
         this.queue = {};
         this.data = {};
         this.dom = {};

         var kb = this.keyboard = {
             keys : {
                 UP: 38,
                 DOWN: 40,
                 LEFT: 37,
                 RIGHT: 39,
                 RETURN: 13,
                 ESCAPE: 27,
                 BACKSPACE: 8
             },
             map : {},
             bound: false,
             press: this.proxy(function(e) {
                 var key = e.keyCode || e.which;
                 if (kb.map[key] && typeof kb.map[key] == 'function') {
                     kb.map[key].call(this, e);
                 }
             }),
             attach: this.proxy(function(map) {
                 for( var i in map ) {
                     var k = i.toUpperCase();
                     if ( kb.keys[k] ) {
                         kb.map[kb.keys[k]] = map[i];
                     }
                 }
                 if (!kb.bound) {
                     kb.bound = true;
                     this.listen(document, 'keydown', kb.press);
                 }
             }),
             detach: this.proxy(function() {
                 kb.bound = false;
                 this.forget(document, 'keydown', kb.press);
             })
         };

         this.timeouts = {
             trunk: {},
             add: function(id, fn, delay, loop) {
                 loop = loop || false;
                 this.clear(id);
                 if (loop) {
                     var self = this;
                     var old = fn;
                     fn = function() {
                         old();
                         self.add(id,fn,delay);
                     }
                 }
                 this.trunk[id] = window.setTimeout(fn,delay);
             },
             clear: function(id) {
                 if (id && this.trunk[id]) {
                     window.clearTimeout(this.trunk[id]);
                     delete this.trunk[id];
                 } else if (typeof id == 'undefined') {
                     for (var i in this.trunk) {
                         window.clearTimeout(this.trunk[i]);
                         delete this.trunk[i];
                     }
                 }
             }
         };

         this.controls = {
             0 : null,
             1 : null,
             active : 0,
             swap : function() {
                 this.active = this.active ? 0 : 1;
             },
             getActive : function() {
                 return this[this.active];
             },
             getNext : function() {
                 return this[Math.abs(this.active - 1)];
             }
         };

         var fs = this.fullscreen = {
             scrolled: 0,
             enter: this.proxy(function() {
                 this.toggleClass( this.get('container'), 'fullscreen');
                 fs.scrolled = jQuery(window).scrollTop();
                 this.loop(fs.getElements(), function(el, i) {
                     fs.styles[i] = el.getAttribute('style');
                     el.removeAttribute('style');
                 });
                 this.setStyle(fs.getElements(0), {
                     position: 'fixed',
                     top: 0,
                     left: 0,
                     width: '100%',
                     height: '100%',
                     zIndex: 10000
                 });
                 var bh = {
                     height: '100%',
                     overflow: 'hidden',
                     margin:0,
                     padding:0
                 };
                 this.setStyle( fs.getElements(1), bh );
                 this.setStyle( fs.getElements(2), bh );
                 this.attachKeyboard({
                     escape: this.exitFullscreen,
                     right: this.next,
                     left: this.prev
                 });
                 this.rescale(this.proxy(function() {
                     this.trigger(G.FULLSCREEN_ENTER);
                 }));
                 this.listen(window, 'resize', fs.scale);
             }),
             scale: this.proxy(function() {
                 this.rescale();
             }),
             exit: this.proxy(function() {
                 this.toggleClass( this.get('container'), 'fullscreen', false);
                 if (!fs.styles.length) {
                     return;
                 }
                 this.loop(fs.getElements(), function(el, i) {
                     el.removeAttribute('style');
                     el.setAttribute('style', fs.styles[i]);
                 });
                 window.scrollTo(0, fs.scrolled);
                 this.detachKeyboard();
                 this.rescale(this.proxy(function() {
                     this.trigger(G.FULLSCREEN_EXIT);
                 }));
                 this.forget(window, 'resize', fs.scale);
             }),
             styles: [],
             getElements: this.proxy(function(i) {
                 var elems = [ this.get('container'), document.body, this.getElements('html')[0] ];
                 return i ? elems[i] : elems;
             })
         };

         var idle = this.idle = {
             trunk: [],
             bound: false,
             add: this.proxy(function(elem, styles, fn) {
                 if (!elem) {
                     return;
                 }
                 if (!idle.bound) {
                     idle.addEvent();
                 }
                 elem = jQuery(elem);
                 var orig = {};
                 for (var style in styles) {
                     orig[style] = elem.css(style);
                 }
                 elem.data('idle', {
                     from: orig,
                     to: styles,
                     complete: true,
                     busy: false,
                     fn: this.proxy(fn)
                 });
                 idle.addTimer();
                 idle.trunk.push(elem);
             }),
             remove: this.proxy(function(elem) {
                 elem = jQuery(elem);
                 this.loop(idle.trunk, function(el, i) {
                     if ( el && !el.not(elem).length ) {
                         idle.show(elem);
                         idle.trunk.splice(i,1);
                     }
                 });
                 if (!idle.trunk.length) {
                     idle.removeEvent();
                     this.clearTimer('idle');
                 }
             }),
             addEvent: this.proxy(function() {
                 idle.bound = true;
                 this.listen( this.get('container'), 'mousemove click', idle.showAll );
             }),
             removeEvent: this.proxy(function() {
                 idle.bound = false;
                 this.forget( this.get('container'), 'mousemove click', idle.showAll );
             }),
             addTimer: this.proxy(function() {
                 this.addTimer('idle', this.proxy(function() {
                     idle.hide();
                 }),this.options.idle_time);
             }),
             hide: this.proxy(function() {
                 this.trigger(G.IDLE_ENTER);
                 this.loop(idle.trunk, function(elem) {
                     var data = elem.data('idle');
                     data.complete = false;
                     data.fn();
                     elem.animate(data.to, {
                         duration: 600,
                         queue: false,
                         easing: 'swing'
                     });
                 });
             }),
             showAll: this.proxy(function() {
                 this.clearTimer('idle');
                 this.loop(idle.trunk, function(elem) {
                     idle.show(elem);
                 });
             }),
             show: this.proxy(function(elem) {
                 var data = elem.data('idle');
                 if (!data.busy && !data.complete) {
                     data.busy = true;
                     this.trigger(G.IDLE_EXIT);
                     elem.animate(data.from, {
                         duration: 300,
                         queue: false,
                         easing: 'swing',
                         complete: function() {
                             $(this).data('idle').busy = false;
                             $(this).data('idle').complete = true;
                         }
                     });
                 }
                 idle.addTimer();
             })
         };

    
         this.thumbnails = { width: 0 };
         this.stageWidth = 0;
         this.stageHeight = 0;

         var elems = 'container stage images image-nav image-nav-left image-nav-right ' + 
                     'info info-text info-title info-description info-author ' +
                     'thumbnails thumbnails-list thumbnails-container thumb-nav-left thumb-nav-right logo thumbnails-categories thumbnails-categories ' +
                     'loader counter';
         elems = elems.split(' ');

         this.loop(elems, function(blueprint) {
             this.dom[ blueprint ] = this.create('div', 'galleria-' + blueprint);
         });

         this.target = this.dom.target = options.target.nodeName ? 
             options.target : this.getElements(options.target)[0];

         if (!this.target) {
              G.raise('Target not found.');
         }
     },

     init: function() {

         this.options = this.mix(G.theme.defaults, this.options);
         this.options = this.mix({
             autoplay: false,
             carousel: true,
             carousel_follow: true,
             carousel_speed: 400,
             carousel_steps: 'auto',
             clicknext: false,
             data_config : function( elem ) { return {}; },
             data_image_selector: 'img',
             data_source: this.target,
             data_type: 'auto',
             debug: false,
             extend: function(options) {},
             height: 'auto',
             idle_time: 3000,
             image_crop: false,
             image_margin: 0,
             image_pan: false,
             image_pan_smoothness: 12,
             image_position: '50%',
             keep_source: false,
             lightbox_clicknext: true,
             lightbox_fade_speed: 200,
             lightbox_transition_speed: 300,
             link_source_images: true,
             max_scale_ratio: undefined,
             min_scale_ratio: undefined,
             on_image: function(img,thumb) {},
             overlay_opacity: .85,
             overlay_background: '#0b0b0b',
             popup_links: false,
             preload: 2,
             queue: true,
             show: 0,
             show_info: true,
             show_counter: true,
             show_imagenav: true,
             thumb_crop: true,
             thumb_fit: true,
             thumb_margin: 0,
             thumb_quality: 'auto',
             thumbnails: true,
             transition: G.transitions.fade,
             transition_speed: 400
         }, this.options);

         var o = this.options;

         this.bind(G.DATA, function() {
             this.run();
         });

         if (o.clicknext) {
             this.loop(this.data, function(data) {
                 delete data.link;
             });
             this.setStyle(this.get('stage'), { cursor: 'pointer'} );
             this.listen(this.get('stage'), 'click', this.proxy(function() {
                 this.next();
             }));
         }

         this.bind(G.IMAGE, function(e) {
             o.on_image.call(this, e.imageTarget, e.thumbTarget);
         });

         this.bind(G.READY, function() {
             if (G.History) {
                 G.History.change(this.proxy(function(e) {
                     var val = parseInt(e.value.replace(/\//,''));
                     if (isNaN(val)) {
                         window.history.go(-1);
                     } else {
                         this.show(val, undefined, true);
                     }
                 }));
             }

             G.theme.init.call(this, o);
             o.extend.call(this, o);

             if (/^[0-9]{1,4}$/.test(hash) && G.History) {
                 this.show(hash, undefined, true);
             } else if (typeof o.show == 'number') {
                 this.show(o.show);
             }

             if (o.autoplay) {
                 if (typeof o.autoplay == 'number') {
                     this.playtime = o.autoplay;
                 }
                 this.trigger( G.PLAY );
                 this.playing = true;
             }
         });
         this.load();
         return this;
     },

     bind : function(type, fn) {
         this.listen( this.get('container'), type, this.proxy(fn) );
         return this;
     },

     unbind : function(type) {
         this.forget( this.get('container'), type );
     },

     trigger : function( type ) {
         type = typeof type == 'object' ? 
             this.mix( type, { scope: this } ) : 
             { type: type, scope: this };
         this.dispatch( this.get('container'), type );
         return this;
     },

     addIdleState: function() {
         this.idle.add.apply(this, arguments);
         return this;
     },

     removeIdleState: function() {
         this.idle.remove.apply(this, arguments);
         return this;
     },

     enterIdleMode: function() {
         this.idle.hide();
         return this;
     },

     exitIdleMode: function() {
         this.idle.show();
         return this;
     },

     addTimer: function() {
         this.timeouts.add.apply(this.timeouts, arguments);
         return this;
     },

     clearTimer: function() {
         this.timeouts.clear.apply(this.timeouts, arguments);
         return this;
     },

     enterFullscreen: function() {
         this.fullscreen.enter.apply(this, arguments);
         return this;
     },

     exitFullscreen: function() {
         this.fullscreen.exit.apply(this, arguments);
         return this;
     },

     openLightbox: function() {
         this.lightbox.show.apply(this, arguments);
     },

     closeLightbox: function() {
         this.lightbox.hide.apply(this, arguments);
     },

     getActive: function() {
         return this.controls.getActive();
     },

     getActiveImage: function() {
         return this.getActive().image || null;
     },

     run : function() {
         var o = this.options;
         if (!this.data.length) {
             G.raise('Data is empty.');
         }
         if (!o.keep_source && !Galleria.IE) {
             this.target.innerHTML = '';
         }
         this.loop(2, function() {
             var image = new Picture();
             this.setStyle( image.elem, {
                 position: 'absolute',
                 top: 0,
                 left: 0
             });
             this.setStyle(this.get( 'images' ), {
                 position: 'relative',
                 top: 0,
                 left: 0,
                 width: '100%',
                 height: '100%'
             });
             this.get( 'images' ).appendChild( image.elem );
             this.push(image, this.controls);
         }, this);

         if (o.carousel) {
             // try the carousel on each thumb load
             this.bind(G.THUMBNAIL, this.parseCarousel);
         }

         this.build();
         this.target.appendChild(this.get('container'));

         this.loop(['info','counter','image-nav'], function(el) {
             if ( o[ 'show_'+el.replace(/-/,'') ] === false ) {
                 this.moveOut( this.get(el) );
             }
         });

         var w = 0;
         var h = 0;

         for( var i=0; this.data[i]; i++ ) {
             var thumb;
             if (o.thumbnails === true) {
                 thumb = new Picture(i);
                 var src = this.data[i].thumb || this.data[i].image;

                 
                 image=this.data[i].image;
                  image = image.split('/');
                  var mx_image = image[image.length-1];
                  var mx_description = this.data[i].description;
                  if(mx_image != "black.png" && mx_description) {
                  mx_container = document.createElement("div");
                  mx_container.setAttribute("class", "overlay");
                  mx_image = document.createElement("img");
                  if(!checked) {
                  var path = $('#app').attr('src').split("/");
                  path[path.length-1] = ""; 
                  path = path.join("/");
                  var checked = true;
                  }
                  mx_image.setAttribute("src", path + "overlay.png");
                  mx_container.appendChild(mx_image);
                }

                 this.get( 'thumbnails' ).appendChild( thumb.elem );
                if(mx_image != "black.png" && mx_description) {
                 this.get( 'thumbnails' ).appendChild(mx_container);
               }
                 
                 w = this.getStyle(thumb.elem, 'width', true);
                 h = this.getStyle(thumb.elem, 'height', true);

                 // grab & reset size for smoother thumbnail loads
                 if (o.thumb_fit && o.thum_crop !== true) {
                     this.setStyle(thumb.elem, { width:0, height: 0});
                 }
         
                 thumb.load(src, this.proxy(function(e) {
                     var orig = e.target.width;
                     e.scope.scale({
                         width: w,
                         height: h,
                         crop: o.thumb_crop,
                         margin: o.thumb_margin,
                         complete: this.proxy(function() {
                             // shrink thumbnails to fit
                             var top = ['left', 'top'];
                             var arr = ['Height', 'Width'];
                             this.loop(arr, function(m,i) {
                                 if ((!o.thumb_crop || o.thumb_crop == m.toLowerCase()) && o.thumb_fit) {
                                     var css = {};
                                     var opp = arr[Math.abs(i-1)].toLowerCase();
                                     css[opp] = e.target[opp];
                                     this.setStyle(e.target.parentNode, css);
                                     var css = {};
                                     css[top[i]] = 0;
                                     this.setStyle(e.target, css);
                                 }
                                 e.scope['outer'+m] = this[m.toLowerCase()](e.target.parentNode, true);
                             });
                             // set high quality if downscale is moderate
                             this.toggleQuality(e.target, o.thumb_quality === true || ( o.thumb_quality == 'auto' && orig < e.target.width * 3 ));
                             this.trigger({
                                 type: G.THUMBNAIL,
                                 thumbTarget: e.target,
                                 thumbOrder: e.scope.order
                             });
                         })
                     });
                 }));
                 if (o.preload == 'all') {
                     thumb.add(this.data[i].image);    
                 }
             } else if (o.thumbnails == 'empty') {
                 thumb = {
                     elem:  this.create('div','galleria-image'),
                     image: this.create('span','img')
                 };
                 thumb.elem.appendChild(thumb.image);
                 this.get( 'thumbnails' ).appendChild( thumb.elem );
             } else {
                 thumb = {
                     elem: false,
                     image: false
                 }
             }
             var activate = this.proxy(function(e) {
                 this.pause();
                 e.preventDefault();
                 var ind = e.currentTarget.rel;
                 if (this.active !== ind) {
                     this.show( ind );
                 }
             });
             if (o.thumbnails !== false) {
                 thumb.elem.rel = i;
                 this.listen(thumb.elem, 'click', activate);
             }
             if (o.link_source_images && o.keep_source && this.data[i].elem) {
                 this.data[i].elem.rel = i;
                 this.listen(this.data[i].elem, 'click', activate);
             }
             this.push(thumb, this.thumbnails );
         }
         this.setStyle( this.get('thumbnails'), { opacity: 0 } );

         if (o.height && o.height != 'auto') {
             this.setStyle( this.get('container'), { height: o.height })
         }

         this.wait(function() {
             // the most sensitive piece of code in Galleria, we need to have all the meassurements right to continue
             var cssHeight = this.getStyle( this.get( 'container' ), 'height', true );
             this.stageWidth = this.width(this.get( 'stage' ));
             this.stageHeight = this.height( this.get( 'stage' ));
             if (this.stageHeight < 50 && o.height == 'auto') {
                 // no height detected for sure, set reasonable ratio (16/9)
                 this.setStyle( this.get( 'container' ),  { 
                     height: Math.round( this.stageWidth*9/16 ) 
                 } );
                 this.stageHeight = this.height( this.get( 'stage' ));
             }
             return this.stageHeight && this.stageWidth;
         }, function() {
             this.listen(this.get('image-nav-right'), 'click', this.proxy(function(e) {
                 if (o.clicknext) {
                     e.stopPropagation();
                 }
                 this.pause();
                 this.next();
             }));
             this.listen(this.get('image-nav-left'), 'click', this.proxy(function(e) {
                 if (o.clicknext) {
                     e.stopPropagation();
                 }
                 this.pause();
                 this.prev();
             }));
             this.setStyle( this.get('thumbnails'), { opacity: 1 } );
             this.trigger( G.READY );
         }, function() {
             G.raise('Galleria could not load properly. Make sure stage has a height and width.');
         }, 5000);
     },

     mousePosition : function(e) {
         return {
             x: e.pageX - this.$('stage').offset().left + jQuery(document).scrollLeft(),
             y: e.pageY - this.$('stage').offset().top + jQuery(document).scrollTop()
         };
     },

     addPan : function(img) {
         var c = this.options.image_crop;
         if ( c === false ) {
             return;
         }
         if (this.options.image_crop === false) {
             return;
         }
         img = img || this.controls.getActive().image;
         if (img.tagName.toUpperCase() != 'IMG') {
             G.raise('Could not add pan');
         }

         var x = img.width/2;
         var y = img.height/2;
         var curX = destX = this.getStyle(img, 'left', true) || 0;
         var curY = destY = this.getStyle(img, 'top', true) || 0;
         var distX = 0;
         var distY = 0;
         var active = false;
         var ts = new Date().getTime();
         var calc = this.proxy(function(e) {
             if (new Date().getTime() - ts < 50) {
                 return;
             }
             active = true;
             x = this.mousePosition(e).x;
             y = this.mousePosition(e).y;
         });
         var loop = this.proxy(function(e) {
             if (!active) {
                 return;
             }
             distX = img.width - this.stageWidth;
             distY = img.height - this.stageHeight;
             destX = x / this.stageWidth * distX * -1;
             destY = y / this.stageHeight * distY * -1;
             curX += (destX - curX) / this.options.image_pan_smoothness;
             curY += (destY - curY) / this.options.image_pan_smoothness;
             if (distY > 0) {
                 this.setStyle(img, { top: Math.max(distY*-1, Math.min(0, curY)) });
             }
             if (distX > 0) {
                 this.setStyle(img, { left: Math.max(distX*-1, Math.min(0, curX)) });
             }
         });
         this.forget(this.get('stage'), 'mousemove');
         this.listen(this.get('stage'), 'mousemove', calc);
         this.addTimer('pan', loop, 30, true);
     },

     removePan: function() {
         this.forget(this.get('stage'), 'mousemove');
         this.clearTimer('pan');
     },

     parseCarousel : function(e) {
         var w = 0;
         var h = 0;
         var hooks = [0];
         this.loop(this.thumbnails, function(thumb,i) {
             if (thumb.ready) {
                 w += thumb.outerWidth || this.width(thumb.elem, true);
                 hooks[i+1] = w;
                 h = Math.max(h, this.height(thumb.elem));
             }
         });
         this.toggleClass(this.get('thumbnails-container'), 'galleria-carousel', w > this.stageWidth);
         this.setStyle(this.get('thumbnails-list'), {
             overflow:'hidden',
             position: 'relative' // for IE Standards mode
         });
         this.setStyle(this.get('thumbnails'), {
             width: w,
             height: h,
             position: 'relative',
             overflow: 'hidden'
         });
         if (!this.carousel) {
             this.initCarousel();
         }
         this.carousel.max = w;
         this.carousel.hooks = hooks;
         this.carousel.width = this.width(this.get('thumbnails-list'));
         this.carousel.setClasses();
     },

     initCarousel : function() {
         var c = this.carousel = {
             right: this.get('thumb-nav-right'),
             left: this.get('thumb-nav-left'),
             update: this.proxy(function() {
                 this.parseCarousel();
                 // todo: fix so the carousel moves to the left
             }),
             width: 0,
             current: 0,
             set: function(i) {
                 i = Math.max(i,0);
                 while (c.hooks[i-1] + c.width > c.max && i >= 0) {
                     i--;
                 }
                 c.current = i;
                 c.animate();
             },
             hooks: [],
             getLast: function(i) {
                 i = i || c.current

                 return i-1;
             },
             follow: function(i) {
                 if (i == 0 || i == c.hooks.length-2) {
                     c.set(i);
                     return;
                 }
                 var last = c.current;
                 while(c.hooks[last] - c.hooks[c.current] < c.width && last<= c.hooks.length) {
                     last++;
                 }
                 if (i-1 < c.current) {
                     c.set(i-1)
                 } else if (i+2 > last) {
                     c.set(i - last + c.current + 2)
                 }
             },
             max: 0,
             setClasses: this.proxy(function() {
                 this.toggleClass( c.left, 'disabled', !c.current );
                 this.toggleClass( c.right, 'disabled', c.hooks[c.current] + c.width > c.max );
             }),
             animate: this.proxy(function(to) {
                 c.setClasses();
                 this.animate( this.get('thumbnails'), {
                     to: { left: c.hooks[c.current] * -1 },
                     duration: this.options.carousel_speed,
                     easing: 'galleria',
                     queue: false
                 });
             })
         };
         this.listen(c.right, 'click', this.proxy(function(e) {
             if (this.options.carousel_steps == 'auto') {
                 for (var i = c.current; i<c.hooks.length; i++) {
                     if (c.hooks[i] - c.hooks[c.current] > c.width) {
                         c.set(i-2);
                         break;
                     }
                 }
             } else {
                 c.set(c.current + this.options.carousel_steps);
             }
         }));
         this.listen(c.left, 'click', this.proxy(function(e) {
             if (this.options.carousel_steps == 'auto') {
                 for (var i = c.current; i>=0; i--) {
                     if (c.hooks[c.current] - c.hooks[i] > c.width) {
                         c.set(i+2);
                         break;
                     } else if (i == 0) {
                         c.set(0);
                         break;
                     }
                 }
             } else {
                 c.set(c.current - this.options.carousel_steps);
             }
         }));
     },
     addElement : function() {
         this.loop(arguments, function(b) {
             this.dom[b] = this.create('div', 'galleria-' + b );
         });
         return this;
     },
     getDimensions: function(i) {
         return {
             w: i.width,
             h: i.height,
             cw: this.stageWidth,
             ch: this.stageHeight,
             top: (this.stageHeight - i.height) / 2,
             left: (this.stageWidth - i.width) / 2
         };
     },
     attachKeyboard : function(map) {
         this.keyboard.attach(map);
         return this;
     },
     detachKeyboard : function() {
         this.keyboard.detach();
         return this;
     },
     build : function() {

         this.append({
             'info-text' :
                 ['info-title', 'info-description', 'info-author'],
             'info' : 
                 ['info-text'],
             'image-nav' : 
                 ['image-nav-right', 'image-nav-left'],
             'stage' : 
                 ['images', 'loader'],
             'thumbnails-list' :
                 ['thumbnails', 'thumbnails-categories'],
             'thumbnails-container' : 
                 ['thumb-nav-left', 'thumbnails-list', 'thumb-nav-right'],
             'container' : 
                 ['stage', 'thumbnails-container', 'info', 'logo', 'counter', 'image-nav']
         });

         this.current = this.create('span', 'current');
         this.current.innerHTML = '-';
         this.get('counter').innerHTML = ' / <span class="total">' + this.data.length + '</span>';
         this.prependChild('counter', this.current);
     },

     appendChild : function(parent, child) {
         try {
             this.get(parent).appendChild(this.get(child));
         } catch(e) {}
     },

     prependChild : function(parent, child) {
         var child = this.get(child) || child;
         try {
             this.get(parent).insertBefore(child, this.get(parent).firstChild);
         } catch(e) {}
     },

     remove : function() {
         var a = Array.prototype.slice.call(arguments);
         this.jQuery(a.join(',')).remove();
     },

     append : function(data) {
         for( var i in data) {
             if (data[i].constructor == Array) {
                 for(var j=0; data[i][j]; j++) {
                     this.appendChild(i, data[i][j]);
                 }
             } else {
                 this.appendChild(i, data[i]);
             }
         }
         return this;
     },

     rescale : function(width, height, callback) {

         var o = this.options;
         callback = this.proxy(callback);

         if (typeof width == 'function') {
             callback = this.proxy(width);
             width = undefined;
         }

         var scale = this.proxy(function() {
             this.stageWidth = width || this.width(this.get('stage'));
             this.stageHeight = height || this.height(this.get('stage'));
             this.controls.getActive().scale({
                 width: this.stageWidth, 
                 height: this.stageHeight, 
                 crop: o.image_crop, 
                 max: o.max_scale_ratio,
                 min: o.min_scale_ratio,
                 margin: o.image_margin,
                 position: o.image_position
             });
             if (this.carousel) {
                 this.carousel.update();
             }
             this.trigger(G.RESCALE)
             callback();
         });
         if ( G.WEBKIT && !width && !height ) {
             this.addTimer('scale', scale, 5);// webkit is too fast
         } else {
             scale.call(this); 
         }
     },

     show : function(index, rewind, history) {
         if (!this.options.queue && this.queue.stalled) {
             return;
         }
         rewind = typeof rewind != 'undefined' ? !!rewind : index < this.active;
         history = history || false;
         index = Math.max(0, Math.min(parseInt(index), this.data.length - 1));
         if (!history && G.History) {
             G.History.value(index.toString());
             return;
         }
         this.active = index;
         this.push([index,rewind], this.queue);
         if (!this.queue.stalled) {
             this.showImage();
         }
         return this;
     },

     showImage : function() {
         var o = this.options;
         var args = this.queue[0];
         var index = args[0];
         var rewind = !!args[1];
         if (o.carousel && this.carousel && o.carousel_follow) {
             this.carousel.follow(index);
         }

         var src = this.getData(index).image;
         var active = this.controls.getActive();
         var next = this.controls.getNext();
         var cached = next.isCached(src);
         var complete = this.proxy(function() {
             this.queue.stalled = false;
             this.toggleQuality(next.image, o.image_quality);
             this.setStyle( active.elem, { zIndex : 0 } );
             this.setStyle( next.elem, { zIndex : 1 } );
             this.trigger({
                 type: G.IMAGE,
                 index: index,
                 imageTarget: next.image,
                 thumbTarget: this.thumbnails[index].image
              });
             if (o.image_pan) {
                 this.addPan(next.image);
             }
             this.controls.swap();
             this.moveOut( active.image );
             if (this.getData( index ).link) {
                 this.setStyle( next.image, { cursor: 'pointer' } );
                 this.listen( next.image, 'click', this.proxy(function() {
                     if (o.popup_links) {
                         var win = window.open(this.getData( index ).link, '_blank');
                     } else {
                         window.location.href = this.getData( index ).link;
                     }
                 }));
             }
             Array.prototype.shift.call( this.queue );
             if (this.queue.length) {
                 this.showImage();
             }
             this.playCheck();
         });
         if (typeof o.preload == 'number' && o.preload > 0) {
             var p,n = this.getNext();
             try {
                 for (var i = o.preload; i>0; i--) {
                     p = new Picture();
                     p.add(this.getData(n).image);
                     n = this.getNext(n);
                 }
             } catch(e) {}
         }
         this.trigger( {
             type: G.LOADSTART,
             cached: cached,
             index: index,
             imageTarget: next.image,
             thumbTarget: this.thumbnails[index].image
         } );

         jQuery(this.thumbnails[index].elem).addClass('active').siblings('.active').removeClass('active');

         next.load( src, this.proxy(function(e) {
             next.scale({
                 width: this.stageWidth, 
                 height: this.stageHeight, 
                 crop: o.image_crop, 
                 max: o.max_scale_ratio, 
                 min: o.min_scale_ratio,
                 margin: o.image_margin,
                 position: o.image_position,
                 complete: this.proxy(function() {
                     if (active.image) {
                         this.toggleQuality(active.image, false);
                     }
                     this.toggleQuality(next.image, false);
                     this.trigger({
                         type: G.LOADFINISH,
                         cached: cached,
                         index: index,
                         imageTarget: next.image,
                         thumbTarget: this.thumbnails[index].image
                     });
                     this.queue.stalled = true;
                     var transition = G.transitions[o.transition] || o.transition;
                     this.removePan();
                     this.setInfo(index);
                     this.setCounter(index);
                     var content = $('.galleria-info-description').html();
                     var regex = /(<embed|<video|<iframe|<param)/mi;
                     var isvideo = regex.test(content);
                     if (isvideo)
                       $('.galleria-info-description').css('max-width', '100%');
                     else
                       $('.galleria-info-description').css('max-width', '800px');
                     if (content.charAt(0) == "√"){
                       $('.galleria-info').hide();
                       $('.galleria-info').addClass('slide');

                                                
                       $('.galleria-info-description').html(content.substr(1));
                       $('.galleria-info').css({'display' : 'block', 'visibility' : 'hidden' });
                       $('.galleria-info-description').css({
                         margin: function(){
                           elementWidth = $(".galleria-info-description").width();
                           elementHeight = $(".galleria-info-description").height();                         
                           output =  "-" + (elementHeight/2) + "px 0 0 " + "-" + (elementWidth/2)  + "px";
                           return output;
                           
                         }
                       });
                      
                      $('.galleria-info').css({'display' : 'none', 'visibility' : 'visible' });
                     
                       $('.galleria-info').fadeIn(1000);
                       if(!isvideo) {
                       //secondtime, stupid IE
                       $('.galleria-info-description').css({
                         margin: function(){
                           elementWidth = $(".galleria-info-description").width();
                           elementHeight = $(".galleria-info-description").height();                         
                           output =  "-" + (elementHeight/2) + "px 0 0 " + "-" + (elementWidth/2)  + "px";
                           return output;
                           
                         }
                       });
                       }
                     }
                     else {

                       $('.galleria-info').removeClass('slide');
                       $('.galleria-info-description').css('margin', '0');
                     }
                     if (typeof transition == 'function') {
                         transition.call(this, {
                             prev: active.image,
                             next: next.image,
                             rewind: rewind,
                             speed: o.transition_speed || 400
                         }, complete );
                     } else {
                         complete();
                     }
                 })
             });
         }));
     },

     getNext : function(base) {
         base = typeof base == 'number' ? base : this.active;
         return base == this.data.length - 1 ? 0 : base + 1;
     },

     getPrev : function(base) {
         base = typeof base == 'number' ? base : this.active;
         return base === 0 ? this.data.length - 1 : base - 1;
     },

     next : function() {
         if (this.data.length > 1) {
             this.show(this.getNext(), false);
         }
         return this;
         
     },

     prev : function() {
         if (this.data.length > 1) {
             this.show(this.getPrev(), true);
         }
         return this;
     },

     get : function( elem ) {
         return elem in this.dom ? this.dom[ elem ] : null;
     },

     getData : function( index ) {
         return this.data[index] || this.data[this.active];
     },

     getIndex : function() {
         return typeof this.active === 'number' ? this.active : 0;
     },

     play : function(delay) {
         this.trigger( G.PLAY );
         this.playing = true;
         this.playtime = delay || this.playtime;
         this.playCheck();
         return this;
     },

     pause : function() {
         this.trigger( G.PAUSE );
         this.playing = false;
         return this;
     },

     playCheck : function() {
         var p = 0;
         var i = 20; // the interval
         var ts = function() {
             return new Date().getTime();
         }
         var now = ts();
         if (this.playing) {
             this.clearTimer('play');
             var fn = this.proxy(function() {
                 p = ts() - now;
                 if ( p >= this.playtime && this.playing ) {
                     this.clearTimer('play');
                     this.next();
                     return;
                 }
                 if ( this.playing ) {
                     this.trigger({
                         type: G.PROGRESS,
                         percent: Math.ceil(p / this.playtime * 100),
                         seconds: Math.floor(p/1000),
                         milliseconds: p
                     });
                     this.addTimer('play', fn, i);
                 }
             });
             this.addTimer('play', fn, i);
         }
     },

     setActive: function(val) {
         this.active = val;
         return this;
     },

     setCounter: function(index) {
         index = index || this.active;
         this.current.innerHTML = index+1;
         return this;
     },

     setInfo : function(index) {
         var data = this.getData(index || this.active);
         this.loop(['title','description','author'], function(type) {
             var elem = this.get('info-'+type);
             var fn = data[type] && data[type].length ? 'reveal' : 'hide';
             this[fn](elem);
             if (data[type]) {
                 elem.innerHTML = data[type];
             }
         });
         return this;
     },

     hasInfo : function(index) {
         var d = this.getData(index);
         var check = 'title description author'.split(' ');
         for ( var i=0; check[i]; i++ ) {
             if ( d[ check[i] ] && d[ check[i] ].length ) {
                 return true;
             }
         }
         return false;
     },

     getDataObject : function(o) {
         var obj = {
             image: '',
             thumb: '',
             title: '',
             description: '',
             author: '',
             link: ''
         };
         return o ? this.mix(obj,o) : obj;
     },

     jQuery : function( str ) {
         var ret = [];
         this.loop(str.split(','), this.proxy(function(elem) {
             elem = elem.replace(/^\s\s*/, "").replace(/\s\s*$/, "");
             if (this.get(elem)) {
                 ret.push(elem);
             }
         }));
         var jQ = jQuery(this.get(ret.shift()));
         this.loop(ret, this.proxy(function(elem) {
             jQ = jQ.add(this.get(elem));
         }));
         return jQ;
     },

     $ : function( str ) {
         return this.jQuery( str );
     },

     toggleQuality : function(img, force) {
         if (!G.IE7 || typeof img == 'undefined' || !img) {
             return this;
         }
         if (typeof force === 'undefined') {
             force = img.style.msInterpolationMode == 'nearest-neighbor';
         }
         img.style.msInterpolationMode = force ? 'bicubic' : 'nearest-neighbor';

         return this;
     },

     unload : function() {
         //TODO
     },

     load : function() {
         var loaded = 0;
         var o = this.options;
         if (
             (o.data_type == 'auto' && 
                 typeof o.data_source == 'object' && 
                 !(o.data_source instanceof jQuery) && 
                 !o.data_source.tagName
             ) || o.data_type == 'json' || o.data_source.constructor == Array ) {
             this.data = o.data_source;
             this.trigger( G.DATA );

         } else { // assume selector
             var images = jQuery(o.data_source).find(o.data_image_selector);
             var getData = this.proxy(function( elem ) {
                 var i,j,anchor = elem.parentNode;
                 if (anchor && anchor.nodeName == 'A') {
                     if (anchor.href.match(/\.(png|gif|jpg|jpeg)/i)) {
                         i = anchor.href;
                     } else {
                         j = anchor.href;
                     }
                 }
                 var obj = this.getDataObject({
                     title: elem.title,
                     thumb: elem.src,
                     image: i || elem.src,
                     description: elem.alt,
                     link: j || elem.getAttribute('longdesc'),
                     elem: elem
                 });
                 return this.mix(obj, o.data_config( elem ) );
             });
             this.loop(images, function( elem ) {
                 loaded++;
                 this.push( getData( elem ), this.data );
                 if (!o.keep_source && !Galleria.IE) {
                     elem.parentNode.removeChild(elem);
                 }
                 if ( loaded == images.length ) {
                     this.trigger( G.DATA );
                 }
             });
         }
     }
 });

 G.log = function() {
     try { 
         console.log.apply( console, Array.prototype.slice.call(arguments) ); 
     } catch(e) {
         try {
             opera.postError.apply( opera, arguments ); 
         } catch(er) { 
               alert( Array.prototype.join.call( arguments, " " ) ); 
         } 
     }
 };

 var nav = navigator.userAgent.toLowerCase();
 var hash = window.location.hash.replace(/#\//,'');

 G.DATA = 'data';
 G.READY = 'ready';
 G.THUMBNAIL = 'thumbnail';
 G.LOADSTART = 'loadstart';
 G.LOADFINISH = 'loadfinish';
 G.IMAGE = 'image';
 G.THEMELOAD = 'themeload';
 G.PLAY = 'play';
 G.PAUSE = 'pause';
 G.PROGRESS = 'progress';
 G.FULLSCREEN_ENTER = 'fullscreen_enter';
 G.FULLSCREEN_EXIT = 'fullscreen_exit';
 G.IDLE_ENTER = 'idle_enter';
 G.IDLE_EXIT = 'idle_exit';
 G.RESCALE = 'rescale';
 G.LIGHTBOX_OPEN = 'lightbox_open';
 G.LIGHTBOX_CLOSE = 'lightbox_cloe';
 G.LIGHTBOX_IMAGE = 'lightbox_image';

 G.IE8 = (typeof(XDomainRequest) !== 'undefined')
 G.IE7 = !!(window.XMLHttpRequest && document.expando);
 G.IE6 = (!window.XMLHttpRequest);
 G.IE = !!(G.IE6 || G.IE7);
 G.WEBKIT = /webkit/.test( nav );
 G.SAFARI = /safari/.test( nav );
 G.CHROME = /chrome/.test( nav );
 G.QUIRK = (G.IE && document.compatMode && document.compatMode == "BackCompat");
 G.MAC = /mac/.test(navigator.platform.toLowerCase());
 G.OPERA = !!window.opera

 G.Picture = Picture;

 G.addTheme = function(obj) {
     var theme = {};
     var orig = ['name','author','version','defaults','init'];
     var proto = G.prototype;
     proto.loop(orig, function(val) {
         if (!obj[ val ]) {
             G.raise(val+' not specified in theme.');
         }
         if (val != 'name' && val != 'init') {
             theme[val] = obj[val];
         }
     });
     theme.init = obj.init;

     if (obj.css) {
         var css;
         proto.loop(proto.getElements('script'), function(el) {
             var reg = new RegExp('galleria.' + obj.name.toLowerCase() + '.js');
             if(reg.test(el.src)) {
                 css = el.src.replace(/[^\/]*$/, "") + obj.css;
                 proto.loadCSS(css, function() {
                     G.theme = theme;
                     jQuery(document).trigger( G.THEMELOAD );
                 });
             }
         });
         if (!css) {
             G.raise('No theme CSS loaded');
         }
     }
     return theme;
 };

 G.raise = function(msg) {
     if ( G.debug ) {
         throw new Error( msg );
     }
 };

 G.loadTheme = function(src) {
     G.prototype.loadScript(src);
 };

 G.galleries = [];
 G.get = function(index) {
     if (G.galleries[index]) {
         return G.galleries[index];
     } else if (typeof index !== 'number') {
         return G.galleries;
     } else {
         G.raise('Gallery index not found');
     }
 }

 jQuery.easing.galleria = function (x, t, b, c, d) {
     if ((t/=d/2) < 1) { 
         return c/2*t*t*t*t + b;
     }
     return -c/2 * ((t-=2)*t*t*t - 2) + b;
 };

 G.transitions = {
     add: function(name, fn) {
         if (name != arguments.callee.name ) {
             this[name] = fn;
         }
     },
     fade: function(params, complete) {
         jQuery(params.next).show().css('opacity',0).animate({
             opacity: 1
         }, params.speed, complete);
         if (params.prev) {
             jQuery(params.prev).css('opacity',1).animate({
                 opacity: 0
             }, params.speed);
         }
     },
     flash: function(params, complete) {
         jQuery(params.next).css('opacity',0);
         if (params.prev) {
             jQuery(params.prev).animate({
                 opacity: 0
             }, (params.speed/2), function() {
                 jQuery(params.next).animate({
                     opacity: 1
                 }, params.speed, complete);
             });
         } else {
             jQuery(params.next).animate({
                 opacity: 1
             }, params.speed, complete);
         }
     },
     pulse: function(params, complete) {
         if (params.prev) {
             jQuery(params.prev).css('opacity',0);
         }
         jQuery(params.next).css('opacity',0).animate({
             opacity:1
         }, params.speed, complete);
     },
     slide: function(params, complete) {
         var image = jQuery(params.next).parent();
         var images =  this.$('images');
         var width = this.stageWidth;
         image.css({
             left: width * ( params.rewind ? -1 : 1 )
         });
        images.animate({
            left: width * ( params.rewind ? 1 : -1 )
        }, {
           duration: params.speed,
            queue: false,
            easing: 'galleria',
            complete: function() {
                images.css('left',0);
                image.css('left',0);
                complete();
            }
        });
     },
     webkitslide: function(params, complete) {
          var image = jQuery(params.next).parent();
           var images =  this.$('images');
           var width = this.stageWidth;
           image.css({
                left: width * ( params.rewind ? -1 : 1 )
            });
            images.CSS3Animate({ 
               "property": ["-moz-transform", "webkit-transform"], 
               "transition-duration": 500, 
               "css": { 
                  "-moz-transform" : "translateX("+ width * ( params.rewind ? 1 : -1 ) +"px)", 
                  "webkit-transform" : "translateX("+ width * ( params.rewind ? 1 : -1 ) +"px)" 
               }, 
               "oncomplete" :function(){ 
                 images.css({'-webkit-transform' : 'translateX(0)', '-webkit-transition-property' : 'none'});
                 image.css('left',0);
                  complete();
               } 
            });
      },
     fadeslide: function(params, complete) {
         if (params.prev) {
             jQuery(params.prev).css({
                 opacity: 1,
                 left: 0
             }).animate({
                 opacity: 0,
                 left: 50 * ( params.rewind ? 1 : -1 )
             },{
                 duration: params.speed,
                 queue: false,
                 easing: 'swing'
             });
         }
         jQuery(params.next).css({
             left: 50 * ( params.rewind ? -1 : 1 ), 
             opacity: 0
         }).animate({
             opacity: 1,
             left:0
         }, {
             duration: params.speed,
             complete: complete,
             queue: false,
             easing: 'swing'
         });
     }
 };

 G.addTransition = function() {
     G.transitions.add.apply(this, arguments);
 }

 jQuery.fn.galleria = function(options) {

     options = options || {};
     var selector = this.selector;

     return this.each(function() {
         if ( !options.keep_source ) {
             jQuery(this).children().hide();
         }

         options = G.prototype.mix(options, {target: this} );
         var height = G.prototype.height(this) || G.prototype.getStyle(this, 'height', true);
         if (!options.height && height) {
             options = G.prototype.mix( { height: height }, options );
         }

         G.debug = !!options.debug;

         var gallery = new G(options);

         Galleria.galleries.push(gallery);

         if (G.theme) {
             gallery.init();
         } else {
             jQuery(document).bind(G.THEMELOAD, function() {
                 gallery.init();
             });
         }
     })
 };


 })();
 
 /*!
  * Galleria History Plugin v 1.0
  * http://galleria.aino.se
  *
  * Original Copyright (c) 2009-2010 Rostislav Hristov
  * Modified by Aino (c) 2010
  *
  * Dual licensed under the MIT or GPL Version 2 licenses.
  * http://jquery.org/license
  *
  */
 (function($) {

     var G = window.Galleria; 
     if (typeof G == 'undefined') {
         return;
     }

     G.History = (function () {

         var _trigger = function(name) {
                 $(G.History).trigger(
                     $.extend($.Event(name), 
                         (function() {
                             var parameters = {},
                                 parameterNames = G.History.parameterNames();
                             for (var i = 0, l = parameterNames.length; i < l; i++) {
                                 parameters[parameterNames[i]] = G.History.parameter(parameterNames[i]);
                             }
                             return {
                                 value: G.History.value(),
                                 path: G.History.path(),
                                 pathNames: G.History.pathNames(),
                                 parameterNames: parameterNames,
                                 parameters: parameters,
                                 queryString: G.History.queryString()
                             };
                         }).call(G.History)
                     )
                 );
             },
             _bind = function(value, data, fn) {
                 fn = fn || function(){};
                 $(G.History).bind(value, data, fn);
                 return G.History;
             },
             _hash = function() {
                 var index = _l.href.indexOf('#');
                 return index != -1 ? _ec(_dc(_crawl(_l.href.substr(index + 1), FALSE))) : '';
             },
             _window = function() {
                 try {
                     return top.document !== undefined ? top : window;
                 } catch (e) { 
                     return window;
                 }
             },
             _js = function() {
                 return 'javascript';
             },
             _strict = function(value, force) {
                 if (_opts.strict) {
                     value = force ? (value.substr(0, 1) != '/' ? '/' + value : value) : (value == '' ? '/' : value);
                 }
                 return value;
             },
             _local = function(value, direction) {
                 return (_msie && _l.protocol == 'file:') ? 
                     (direction ? _value.replace(/\?/, '%3F') : _value.replace(/%253F/, '?')) : value;
             },
             _crawl = function(value, direction) {
                 if (_opts.crawlable && direction) {
                     return (value != '' ? '!' : '') + value;
                 }
                 return value.replace(/^\!/, '');
             },
             _cssint = function(el, value) {
                 return parseInt(el.css(value), 10);
             },
             _search = function(el) {
                 var url, s;
                 for (var i = 0, l = el.childNodes.length; i < l; i++) {
                     if (el.childNodes[i].src) {
                         url = String(el.childNodes[i].src);
                     }
                     s = _search(el.childNodes[i]);
                     if (s) {
                         url = s;
                     }
                 }
                 return url;
             },
             _listen = function() {
                 if (!_silent) {
                     var hash = _hash(),
                         diff = _value != hash;
                     if (_safari && _version < 523) {
                         if (_length != _h.length) {
                             _length = _h.length;
                             if (typeof _stack[_length - 1] != UNDEFINED) {
                                 _value = _stack[_length - 1];
                             }
                             _update(FALSE);
                         }
                     } else if (_msie && _version < 7 && diff) {
                         _l.reload();
                     } else if (diff) {
                         _value = hash;
                         _update(FALSE);
                     }
                 }
             },
             _update = function(internal) {
                 _trigger(CHANGE);
                 _trigger(internal ? INTERNAL_CHANGE : EXTERNAL_CHANGE);
                 _st(_track, 10);
             },
             _track = function() {
                 var value = (_l.pathname + (/\/$/.test(_l.pathname) ? '' : '/') + 
                     (G.History ? G.History.value() : '')).replace(/\/\//, '/').replace(/^\/$/, ''),
                     fn = _t[_opts.tracker];
                 if (typeof fn == FUNCTION) {
                     fn(value);
                 } else if (typeof urchinTracker == FUNCTION) {
                     urchinTracker(value);
                 } else if (typeof pageTracker != UNDEFINED && typeof pageTracker._trackPageview == FUNCTION) {
                     pageTracker._trackPageview(value);
                 } else if (typeof _gaq != UNDEFINED && typeof _gaq.push == FUNCTION) {
                     _gaq.push(['_trackPageview', value]);
                 }
             },
             _html = function() {
                 var doc = _frame.contentWindow.document;
                 doc.open();
                 doc.write('<html><head><title>' + _d.title + '</title><script>var ' + ID + ' = "' + _hash() + '";</' + 'script></head></html>');
                 doc.close();
             },
             _load = function() {
                 if (!_loaded) {
                     _loaded = TRUE;
                     var body = $('body').ajaxComplete(function() {
                         _unescape.call(this);
                     }).trigger('ajaxComplete');
                     if (_opts.wrap) {
                         var wrap = $('body > *')
                             .wrapAll('<div style="padding:' + 
                                 (_cssint(body, 'marginTop') + _cssint(body, 'paddingTop')) + 'px ' + 
                                 (_cssint(body, 'marginRight') + _cssint(body, 'paddingRight')) + 'px ' + 
                                 (_cssint(body, 'marginBottom') + _cssint(body, 'paddingBottom')) + 'px ' + 
                                 (_cssint(body, 'marginLeft') + _cssint(body, 'paddingLeft')) + 'px;" />')
                             .parent()
                             .wrap('<div id="' + ID + '" style="height:100%; overflow:auto;' + 
                                 (_safari ? (window.statusbar.visible && !/chrome/i.test(_agent) ? '' : ' resize:both;') : '') + '" />');
                         $('html, body')
                             .css({
                                 height: '100%',
                                 margin: 0,
                                 padding: 0,
                                 overflow: 'hidden'
                             });
                         if (_safari) {
                             $('<style type="text/css" />')
                                 .appendTo('head')
                                 .text('#' + ID + '::-webkit-resizer { background-color: #fff; }');
                         }
                     }
                     if (_msie && _version < 8) {
                         var frameset = _d.getElementsByTagName('frameset')[0];
                         _frame = _d.createElement((frameset ? '' : 'i') + 'frame');
                         if (frameset) {
                             frameset.insertAdjacentElement('beforeEnd', _frame);
                             frameset[frameset.cols ? 'cols' : 'rows'] += ',0';
                             _frame.src = _js() + ':' + FALSE;
                             _frame.noResize = TRUE;
                             _frame.frameBorder = _frame.frameSpacing = 0;
                         } else {
                             _frame.src = _js() + ':' + FALSE;
                             _frame.style.display = 'none';
                             _d.body.insertAdjacentElement('afterBegin', _frame);
                         }
                         _st(function() {
                             $(_frame).bind('load', function() {
                                 var win = _frame.contentWindow;
                                 var src = win.location.href;
                                 _value = (typeof win[ID] != UNDEFINED ? win[ID] : '');
                                 if (_value != _hash()) {
                                     _update(FALSE);
                                     _l.hash = _local(_crawl(_value, TRUE), TRUE);
                                 }
                             });
                             if (typeof _frame.contentWindow[ID] == UNDEFINED) {
                                 _html();
                             }
                         }, 50);
                     } else if (_safari) {
                         if (_version < 418) {
                             $(_d.body).append('<form id="' + ID + '" style="position:absolute;top:-9999px;" method="get"></form>');
                             _form = _d.getElementById(ID);
                         }
                         if (typeof _l[ID] == UNDEFINED) {
                             _l[ID] = {};
                         }
                         if (typeof _l[ID][_l.pathname] != UNDEFINED) {
                             _stack = _l[ID][_l.pathname].split(',');
                         }
                     }

                     _st(function() {
                         _trigger('init');
                         _update(FALSE);
                     }, 1);

                     if ((_msie && _version > 7) || (!_msie && ('on' + HASH_CHANGE) in _t)) {
                         if (_t.addEventListener) {
                             _t.addEventListener(HASH_CHANGE, _listen, false);
                         } else if (_t.attachEvent) {
                             _t.attachEvent('on' + HASH_CHANGE, _listen);
                         }
                     } else {
                         _si(_listen, 50);
                     }

                     //$('a').filter('[rel*=address:]').address();
                 }
             },
             _unload = function() {
                 if (_t.removeEventListener) {
                     _t.removeEventListener(HASH_CHANGE, _listen, false);
                 } else if (_t.detachEvent) {
                     _t.detachEvent('on' + HASH_CHANGE, _listen);
                 }
             },
             _unescape = function() {
                 var base = _l.pathname.replace(/\/$/, ''),
                     fragment = '_escaped_fragment_';
                 if ($('body').html().indexOf(fragment) != -1) {
                     $('a[href]:not([href^=http])', this).each(function() {
                         var href = $(this).attr('href').replace(new RegExp(base + '/?$'), '');
                         if (href == '' || href.indexOf(fragment) != -1) {
                             $(this).attr('href', '#' + decodeURIComponent(href.replace(new RegExp('/(.*)\\?' + fragment + '=(.*)$'), '!$2')));
                         }
                     });
                 }
             },
             ID = 'jQueryAddress',
             FUNCTION = 'function',
             UNDEFINED = 'undefined',
             HASH_CHANGE = 'hashchange',
             INIT = 'init',
             CHANGE = 'change',
             INTERNAL_CHANGE = 'internalChange',
             EXTERNAL_CHANGE = 'externalChange',
             TRUE = true,
             FALSE = false,
             _opts = {
                 autoUpdate: TRUE, 
                 crawlable: FALSE,
                 history: TRUE, 
                 strict: TRUE,
                 wrap: FALSE
             },
             _browser = $.browser, 
             _version = parseFloat($.browser.version),
             _mozilla = _browser.mozilla,
             _msie = _browser.msie,
             _opera = _browser.opera,
             _safari = _browser.safari,
             _supported = FALSE,
             _t = _window(),
             _d = _t.document,
             _h = _t.history, 
             _l = _t.location,
             _si = setInterval,
             _st = setTimeout, 
             _dc = decodeURI,
             _ec = encodeURI,
             _agent = navigator.userAgent,            
             _frame,
             _form,
             _url = _search(document),
             _qi = _url ? _url.indexOf('?') : -1,
             _title = _d.title, 
             _length = _h.length, 
             _silent = FALSE,
             _loaded = FALSE,
             _justset = TRUE,
             _juststart = TRUE,
             _updating = FALSE,
             _stack = [], 
             _listeners = {}, 
             _value = _hash();

         if (_msie) {
             _version = parseFloat(_agent.substr(_agent.indexOf('MSIE') + 4));
             if (_d.documentMode && _d.documentMode != _version) {
                 _version = _d.documentMode != 8 ? 7 : 8;
             }
             $(document).bind('propertychange', function() {
                 if (_d.title != _title && _d.title.indexOf('#' + _hash()) != -1) {
                     _d.title = _title;
                 }
             });
         }

         _supported = 
             (_mozilla && _version >= 1) || 
             (_msie && _version >= 6) ||
             (_opera && _version >= 9.5) ||
             (_safari && _version >= 312);

         if (_supported) {

             for (var i = 1; i < _length; i++) {
                 _stack.push('');
             }

             _stack.push(_value);

             if (_msie && _l.hash != _value) {
                 _l.hash = '#' + _local(_crawl(_value, TRUE), TRUE);
             }

             if (_opera) {
                 history.navigationMode = 'compatible'; 
             }

             if (_url && _qi != -1) {
                 var param, params = _url.substr(_qi + 1).split('&');
                 for (i = 0; i < params.length; i++) {
                     param = params[i].split('=');
                     if (/^(autoUpdate|crawlable|history|strict|wrap)$/.test(param[0])) {
                         _opts[param[0]] = (isNaN(param[1]) ? /^(true|yes)$/i.test(param[1]) : (parseInt(param[1], 10) !== 0));
                     }
                     if (/^tracker$/.test(param[0])) {
                         _opts[param[0]] = param[1];
                     }
                 }
             }

             if (document.readyState == 'complete') {
                 _load();
             }
             $(_load);
             $(window).bind('unload', _unload);

         } else if ((!_supported && _hash() != '') || 
             (_safari && _version < 418 && _hash() != '' && _l.search != '')) {
             _d.open();
             _d.write('<html><head><meta http-equiv="refresh" content="0;url=' + 
                 encodeURI(_l.href.substr(0, _l.href.indexOf('#'))) + '" /></head></html>');
             _d.close();
         } else {
             _track();
         }

         return {
             bind: function(type, data, fn) {
                 return _bind(type, data, fn);
             },
             init: function(fn) {
                 return _bind(INIT, fn);
             },
             change: function(fn) {
                 return _bind(CHANGE, fn);
             },
             internalChange: function(fn) {
                 return _bind(INTERNAL_CHANGE, fn);
             },
             externalChange: function(fn) {
                 return _bind(EXTERNAL_CHANGE, fn);
             },
             baseURL: function() {
                 var url = _l.href;
                 if (url.indexOf('#') != -1) {
                     url = url.substr(0, url.indexOf('#'));
                 }
                 if (/\/$/.test(url)) {
                     url = url.substr(0, url.length - 1);
                 }
                 return url;
             },
             autoUpdate: function(value) {
                 if (value !== undefined) {
                     _opts.autoUpdate = value;
                     return this;
                 }
                 return _opts.autoUpdate;
             },
             crawlable: function(value) {
                 if (value !== undefined) {
                     _opts.crawlable = value;
                     return this;
                 }
                 return _opts.crawlable;
             },
             history: function(value) {
                 if (value !== undefined) {
                     _opts.history = value;
                     return this;
                 }
                 return _opts.history;
             },
             strict: function(value) {
                 if (value !== undefined) {
                     _opts.strict = value;
                     return this;
                 }
                 return _opts.strict;
             },
             tracker: function(value) {
                 if (value !== undefined) {
                     _opts.tracker = value;
                     return this;
                 }
                 return _opts.tracker;
             },
             wrap: function(value) {
                 if (value !== undefined) {
                     _opts.wrap = value;
                     return this;
                 }
                 return _opts.wrap;
             },
             update: function() {
                 _updating = TRUE;
                 this.value(_value);
                 _updating = FALSE;
                 return this;
             },
             title: function(value) {
                 if (value !== undefined) {
                     value = _dc(value);
                     _st(function() {
                         _title = _d.title = value;
                         if (_juststart && _frame && _frame.contentWindow && _frame.contentWindow.document) {
                             _frame.contentWindow.document.title = value;
                             _juststart = FALSE;
                         }
                         if (!_justset && _mozilla) {
                             _l.replace(_l.href.indexOf('#') != -1 ? _l.href : _l.href + '#');
                         }
                         _justset = FALSE;
                     }, 50);
                     return this;
                 }
                 return _d.title;
             },
             value: function(value) {
                 if (value !== undefined) {
                     value = _ec(_dc(_strict(value, TRUE)));
                     if (value == '/') {
                         value = '';
                     }
                     if (_value == value && !_updating) {
                         return;
                     }
                     _justset = TRUE;
                     _value = value;
                     if (_opts.autoUpdate || _updating) {
                         _silent = TRUE;
                         _update(TRUE);
                         _stack[_h.length] = _value;
                         if (_safari) {
                             if (_opts.history) {
                                 _l[ID][_l.pathname] = _stack.toString();
                                 _length = _h.length + 1;
                                 if (_version < 418) {
                                     if (_l.search == '') {
                                         _form.action = '#' + _crawl(_value, TRUE);
                                         _form.submit();
                                     }
                                 } else if (_version < 523 || _value == '') {
                                     var evt = _d.createEvent('MouseEvents');
                                     evt.initEvent('click', TRUE, TRUE);
                                     var anchor = _d.createElement('a');
                                     anchor.href = '#' + _crawl(_value, TRUE);
                                     anchor.dispatchEvent(evt);                
                                 } else {
                                     _l.hash = '#' + _crawl(_value, TRUE);
                                 }
                             } else {
                                 _l.replace('#' + _crawl(_value, TRUE));
                             }
                         } else if (_value != _hash()) {
                             if (_opts.history) {
                                 _l.hash = '#' + _local(_crawl(_value, TRUE), TRUE);
                             } else {
                                 _l.replace('#' + _crawl(_value, TRUE));
                             }
                         }
                         if ((_msie && _version < 8) && _opts.history) {
                             _st(_html, 50);
                         }
                         if (_safari) {
                             _st(function(){ _silent = FALSE; }, 1);
                         } else {
                             _silent = FALSE;
                         }
                     }
                     return this;
                 }
                 if (!_supported) {
                     return null;
                 }
                 return _dc(_strict(_local(_value, FALSE), FALSE));
             },
             path: function(value) {
                 if (value !== undefined) {
                     var qs = this.queryString(),
                         hash = this.hash();
                     this.value(value + (qs ? '?' + qs : '') + (hash ? '#' + hash : ''));
                     return this;
                 }
                 return this.value().split('#')[0].split('?')[0];
             },
             queryString: function(value) {
                 if (value !== undefined) {
                     var hash = this.hash();
                     this.value(this.path() + (value ? '?' + value : '') + (hash ? '#' + hash : ''));
                     return this;
                 }
                 var arr = this.value().split('?');
                 return arr.slice(1, arr.length).join('?').split('#')[0];
             },
             parameter: function(name, value, append) {
                 var i, params;
                 if (value !== undefined) {
                     var names = this.parameterNames();
                     params = [];
                     for (i = 0; i < names.length; i++) {
                         var n = names[i],
                             v = this.parameter(n);
                         if (typeof v == 'string') {
                             v = [v];
                         }
                         if (n == name) {
                             v = (value === null || value === '') ? [] : 
                                 (append ? v.concat([value]) : [value]);
                         }
                         for (var j = 0; j < v.length; j++) {
                             params.push(n + '=' + v[j]);
                         }
                     }
                     if ($.inArray(name, names) == -1 && value !== null && value !== '') {
                         params.push(name + '=' + value);
                     }
                     this.queryString(params.join('&'));
                     return this;
                 }
                 value = this.queryString();
                 if (value) {
                     params = value.split('&');
                     var r = [];
                     for (i = 0; i < params.length; i++) {
                         var p = params[i].split('=');
                         if (p[0] == name) {
                             r.push(p[1]);
                         }
                     }
                     if (r.length !== 0) {
                         return r.length != 1 ? r : r[0];
                     }
                 }
             },
             pathNames: function() {
                 var path = this.path(),
                     names = path.replace(/\/{2,9}/g, '/').split('/');
                 if (path.substr(0, 1) == '/' || path.length === 0) {
                     names.splice(0, 1);
                 }
                 if (path.substr(path.length - 1, 1) == '/') {
                     names.splice(names.length - 1, 1);
                 }
                 return names;
             },
             parameterNames: function() {
                 var qs = this.queryString(),
                     names = [];
                 if (qs && qs.indexOf('=') != -1) {
                     var params = qs.split('&');
                     for (var i = 0; i < params.length; i++) {
                         var name = params[i].split('=')[0];
                         if ($.inArray(name, names) == -1) {
                             names.push(name);
                         }
                     }
                 }
                 return names;
             },
             hash: function(value) {
                 if (value !== undefined) {
                     this.value(this.value().split('#')[0] + (value ? '#' + value : ''));
                     return this;
                 }
                 var arr = this.value().split('#');
                 return arr.slice(1, arr.length).join('#');
             }            
         };

     })();

 }(jQuery));
 

 
 /**  
  * @author bipsa  
  * @class CSS3 Jquery Plugin and Mobile handlers.  
  */  
 ;(function($){  

    $.fn.isCSSAnimable = function (){  
       return true;  
    }  

    /**  
     * @author Sebastian Romero  
     * @param {Object} options  
     */  
    $.fn.CSS3Animate = function(options){  
       var defaults = {  
          "class" : "in",  
          "oncomplete": null,  
          "time": 500,  
          "property": "opacity",  
          "css" : {},  
          "transition": "ease-out",  
          "delay" : 0  
       };  
       var settings = $.extend({}, defaults, options);  
       this.each(function(index, current){  
          var element = $(this);
          if ($("body").isCSSAnimable()) {  
             if (typeof settings.property === "object")   
                settings.property = settings.property.join(",");
             var cssApply = $.extend({}, {  
                "-webkit-animation-timing-function": settings.transition,  
                "-webkit-transition-duration": (settings.time / 1000) + "s",  
                "-webkit-transition-property": "-webkit-transform",  
                "-webkit-transition-delay": (settings.delay / 1000) + "s",  
                "-moz-transition-duration": (settings.time / 1000) + "s",  
                "-moz-transition-property" : settings.property  
             }, settings.css);  
             element.css(cssApply).addClass(settings["class"]);  
             if (settings.oncomplete)   
                element.transitionEnded(settings.oncomplete);  
          } else {  
             if(settings.oncomplete)  
                element.animate(settings.css, settings.oncomplete);  
             else   
                element.animate(settings.css);  
          }  
       });  
       return this;  
    };  

    /**
     * jQuery Plugin to obtain touch gestures from iPhone, iPod Touch and iPad, should also work with Android mobile phones (not tested yet!)
     * Common usage: wipe images (left and right to show the previous or next image)
     * 
     * @author Andreas Waltl, netCU Internetagentur (http://www.netcu.de)
     * @version 1.0 (15th July 2010)
     */
    ;(function($){$.fn.touchwipe=function(settings){var config={min_move_x:20,wipeLeft:function(){alert("left");},wipeRight:function(){alert("right");},preventDefaultEvents:true};if(settings)$.extend(config,settings);this.each(function(){var startX;var isMoving=false;function cancelTouch(){this.removeEventListener('touchmove',onTouchMove);startX=null;isMoving=false;}function onTouchMove(e){if(config.preventDefaultEvents){e.preventDefault();}if(isMoving){var x=e.touches[0].pageX;var dx=startX-x;if(Math.abs(dx)>=config.min_move_x){cancelTouch();if(dx>0){config.wipeLeft();}else{config.wipeRight();}}}}function onTouchStart(e){if(e.touches.length==1){startX=e.touches[0].pageX;isMoving=true;this.addEventListener('touchmove',onTouchMove,false);}}
    if (!Galleria.IE) {
    this.addEventListener('touchstart',onTouchStart,false);
    }
    });return this;};})(jQuery);

    /**  
     * @author bipsa  
     * @param {Function} onComplete  
     */  
    $.fn.transitionEnded = function(onComplete){  
       this.each(function(index, current){  
          var element = $(this);  
          var action = function (event) {  
             if (onComplete) {  
                onComplete(event, element);  
                if((jQuery.browser.webkit != true))  
                   element.get(0).removeEventListener('transitionend', action, false);  
                else   
                   element.get(0).removeEventListener('webkitTransitionEnd', action, false);  
             }  
          };  
          if((jQuery.browser.webkit == true))  
             element.get(0).addEventListener('webkitTransitionEnd', action, false);  
          else if (jQuery.browser.mozilla && (parseFloat(jQuery.browser.version.substr(0, 3)) > 1.9)) {  
             element.get(0).addEventListener('transitionend', action, false);  
          } else   
             onComplete(null, element);  
       });  
       return this;  
    };     
 })(jQuery);
