(function(z,v){
    function la() {
        if (!c.isReady) {
            try {
                r.documentElement.doScroll("left")
            } catch(a) {
                setTimeout(la, 1);
                return
            }
            c.ready()
        }
    }
    function Ma(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, i) {
        var j = a.length;
        if (typeof b === "object") {
            for (var n in b) X(a, n, b[n], f, e, d);
            return a
        }
        if (d !== v) {
            f = !i && f && c.isFunction(d);
            for (n = 0; n < j; n++) e(a[n], b, f ? d.call(a[n], n, e(a[n], b)) : d, i);
            return a
        }
        return j ? e(a[0], b) : null
    }
    function J() {
        return (new Date).getTime()
    }
    function Y() {
        return false
    }
    function Z() {
        return true
    }
    function ma(a, b, d) {
        d[0].type = a;
        return c.event.handle.apply(b, d)
    }
    function na(a) {
        var b, d = [],
        f = [],
        e = arguments,
        i,
        j,
        n,
        o,
        m,
        s,
        x = c.extend({},
        c.data(this, "events").live);
        if (! (a.button && a.type === "click")) {
            for (o in x) {
                j = x[o];
                if (j.live === a.type || j.altLive && c.inArray(a.type, j.altLive) > -1) {
                    i = j.data;
                    i.beforeFilter && i.beforeFilter[a.type] && !i.beforeFilter[a.type](a) || f.push(j.selector)
                } else delete x[o]
            }
            i = c(a.target).closest(f, a.currentTarget);
            m = 0;
            for (s = i.length; m < s; m++) for (o in x) {
                j = x[o];
                n = i[m].elem;
                f = null;
                if (i[m].selector === j.selector) {
                    if (j.live === "mouseenter" || j.live === "mouseleave") f = c(a.relatedTarget).closest(j.selector)[0];
                    if (!f || f !== n) d.push({
                        elem: n,
                        fn: j
                    })
                }
            }
            m = 0;
            for (s = d.length; m < s; m++) {
                i = d[m];
                a.currentTarget = i.elem;
                a.data = i.fn.data;
                if (i.fn.apply(i.elem, e) === false) {
                    b = false;
                    break
                }
            }
            return b
        }
    }
    function oa(a, b) {
        return "live." + (a ? a + ".": "") + b.replace(/\./g, "`").replace(/ /g, "&")
    }
    function pa(a) {
        return ! a || !a.parentNode || a.parentNode.nodeType === 11
    }
    function qa(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 i in f) for (var j in f[i]) c.event.add(this, i, f[i][j], f[i][j].data)
                }
            }
        })
    }
    function ra(a, b, d) {
        var f, e, i;
        if (a.length === 1 && typeof a[0] === "string" && a[0].length < 512 && a[0].indexOf("<option") < 0 && (c.support.checkClone || !sa.test(a[0]))) {
            e = true;
            if (i = c.fragments[a[0]]) if (i !== 1) f = i
        }
        if (!f) {
            b = b && b[0] ? b[0].ownerDocument || b[0] : r;
            f = b.createDocumentFragment();
            c.clean(a, b, f, d)
        }
        if (e) c.fragments[a[0]] = i ? f: 1;
        return {
            fragment: f,
            cacheable: e
        }
    }
    function K(a, b) {
        var d = {};
        c.each(ta.concat.apply([], ta.slice(0, b)),
        function() {
            d[this] = a
        });
        return d
    }
    function ua(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)
    },
    Na = z.jQuery,
    Oa = z.$,
    r = z.document,
    S,
    Pa = /^[^<]*(<[\w\W]+>)[^>]*$|^#([\w-]+)$/,
    Qa = /^.[^:#\[\.,]*$/,
    Ra = /\S/,
    Sa = /^(\s|\u00A0)+|(\s|\u00A0)+$/g,
    Ta = /^<(\w+)\s*\/?>(?:<\/\1>)?$/,
    O = navigator.userAgent,
    va = false,
    P = [],
    L,
    $ = Object.prototype.toString,
    aa = Object.prototype.hasOwnProperty,
    ba = Array.prototype.push,
    Q = Array.prototype.slice,
    wa = 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 (typeof a === "string") if ((d = Pa.exec(a)) && (d[1] || !b)) if (d[1]) {
                f = b ? b.ownerDocument || b: r;
                if (a = Ta.exec(a)) if (c.isPlainObject(b)) {
                    a = [r.createElement(a[1])];
                    c.fn.attr.call(a, b, true)
                } else a = [f.createElement(a[1])];
                else {
                    a = ra([d[1]], [f]);
                    a = (a.cacheable ? a.fragment.cloneNode(true) : a.fragment).childNodes
                }
            } else {
                if (b = r.getElementById(d[2])) {
                    if (b.id !== d[2]) return S.find(a);
                    this.length = 1;
                    this[0] = b
                }
                this.context = r;
                this.selector = a;
                return this
            } else if (!b && /^\w+$/.test(a)) {
                this.selector = a;
                this.context = r;
                a = r.getElementsByTagName(a)
            } else return ! b || b.jquery ? (b || S).find(a) : c(b).find(a);
            else if (c.isFunction(a)) return S.ready(a);
            if (a.selector !== v) {
                this.selector = a.selector;
                this.context = a.context
            }
            return c.isArray(a) ? this.setArray(a) : c.makeArray(a, this)
        },
        selector: "",
        jquery: "1.4.1",
        length: 0,
        size: function() {
            return this.length
        },
        toArray: function() {
            return Q.call(this, 0)
        },
        get: function(a) {
            return a == null ? this.toArray() : a < 0 ? this.slice(a)[0] : this[a]
        },
        pushStack: function(a, b, d) {
            a = c(a || null);
            a.prevObject = this;
            a.context = this.context;
            if (b === "find") a.selector = this.selector + (this.selector ? " ": "") + d;
            else if (b) a.selector = this.selector + "." + b + "(" + d + ")";
            return a
        },
        setArray: function(a) {
            this.length = 0;
            ba.apply(this, a);
            return this
        },
        each: function(a, b) {
            return c.each(this, a, b)
        },
        ready: function(a) {
            c.bindReady();
            if (c.isReady) a.call(r, c);
            else P && P.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(Q.apply(this, arguments), "slice", Q.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,
        i,
        j,
        n;
        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 (i in e) {
            j = a[i];
            n = e[i];
            if (a !== n) if (f && n && (c.isPlainObject(n) || c.isArray(n))) {
                j = j && (c.isPlainObject(j) || c.isArray(j)) ? j: c.isArray(n) ? [] : {};
                a[i] = c.extend(f, j, n)
            } else if (n !== v) a[i] = n
        }
        return a
    };
    c.extend({
        noConflict: function(a) {
            z.$ = Oa;
            if (a) z.jQuery = Na;
            return c
        },
        isReady: false,
        ready: function() {
            if (!c.isReady) {
                if (!r.body) return setTimeout(c.ready, 13);
                c.isReady = true;
                if (P) {
                    for (var a, b = 0; a = P[b++];) a.call(r, c);
                    P = null
                }
                c.fn.triggerHandler && c(r).triggerHandler("ready")
            }
        },
        bindReady: function() {
            if (!va) {
                va = true;
                if (r.readyState === "complete") return c.ready();
                if (r.addEventListener) {
                    r.addEventListener("DOMContentLoaded", L, false);
                    z.addEventListener("load", c.ready, false)
                } else if (r.attachEvent) {
                    r.attachEvent("onreadystatechange", L);
                    z.attachEvent("onload", c.ready);
                    var a = false;
                    try {
                        a = z.frameElement == null
                    } catch(b) {}
                    r.documentElement.doScroll && a && la()
                }
            }
        },
        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 === v || 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;
            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 z.JSON && z.JSON.parse ? z.JSON.parse(a) : (new Function("return " + a))();
            else c.error("Invalid JSON: " + a)
        },
        noop: function() {},
        globalEval: function(a) {
            if (a && Ra.test(a)) {
                var b = r.getElementsByTagName("head")[0] || r.documentElement,
                d = r.createElement("script");
                d.type = "text/javascript";
                if (c.support.scriptEval) d.appendChild(r.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,
            i = a.length,
            j = i === v || c.isFunction(a);
            if (d) if (j) for (f in a) {
                if (b.apply(a[f], d) === false) break
            } else for (; e < i;) {
                if (b.apply(a[e++], d) === false) break
            } else if (j) for (f in a) {
                if (b.call(a[f], f, a[f]) === false) break
            } else for (d = a[0]; e < i && b.call(d, e, d) !== false; d = a[++e]);
            return a
        },
        trim: function(a) {
            return (a || "").replace(Sa, "")
        },
        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] !== v;) a[d++] = b[f++];
            a.length = d;
            return a
        },
        grep: function(a, b, d) {
            for (var f = [], e = 0, i = a.length; e < i; e++) ! d !== !b(a[e], e) && f.push(a[e]);
            return f
        },
        map: function(a, b, d) {
            for (var f = [], e, i = 0, j = a.length; i < j; i++) {
                e = b(a[i], i, 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 = v
            } else if (b && !c.isFunction(b)) {
                d = b;
                b = v
            }
            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: {}
    });
    O = c.uaMatch(O);
    if (O.browser) {
        c.browser[O.browser] = true;
        c.browser.version = O.version
    }
    if (c.browser.webkit) c.browser.safari = true;
    if (wa) c.inArray = function(a, b) {
        return wa.call(b, a)
    };
    S = c(r);
    if (r.addEventListener) L = function() {
        r.removeEventListener("DOMContentLoaded", L, false);
        c.ready()
    };
    else if (r.attachEvent) L = function() {
        if (r.readyState === "complete") {
            r.detachEvent("onreadystatechange", L);
            c.ready()
        }
    }; (function() {
        c.support = {};
        var a = r.documentElement,
        b = r.createElement("script"),
        d = r.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("*"),
        i = d.getElementsByTagName("a")[0];
        if (! (!e || !e.length || !i)) {
            c.support = {
                leadingWhitespace: d.firstChild.nodeType === 3,
                tbody: !d.getElementsByTagName("tbody").length,
                htmlSerialize: !!d.getElementsByTagName("link").length,
                style: /red/.test(i.getAttribute("style")),
                hrefNormalized: i.getAttribute("href") === "/a",
                opacity: /^0.55$/.test(i.style.opacity),
                cssFloat: !!i.style.cssFloat,
                checkOn: d.getElementsByTagName("input")[0].value === "on",
                optSelected: r.createElement("select").appendChild(r.createElement("option")).selected,
                checkClone: false,
                scriptEval: false,
                noCloneEvent: true,
                boxModel: null
            };
            b.type = "text/javascript";
            try {
                b.appendChild(r.createTextNode("window." + f + "=1;"))
            } catch(j) {}
            a.insertBefore(b, a.firstChild);
            if (z[f]) {
                c.support.scriptEval = true;
                delete z[f]
            }
            a.removeChild(b);
            if (d.attachEvent && d.fireEvent) {
                d.attachEvent("onclick",
                function n() {
                    c.support.noCloneEvent = false;
                    d.detachEvent("onclick", n)
                });
                d.cloneNode(true).fireEvent("onclick")
            }
            d = r.createElement("div");
            d.innerHTML = "<input type='radio' name='radiotest' checked='checked'/>";
            a = r.createDocumentFragment();
            a.appendChild(d.firstChild);
            c.support.checkClone = a.cloneNode(true).cloneNode(true).lastChild.checked;
            c(function() {
                var n = r.createElement("div");
                n.style.width = n.style.paddingLeft = "1px";
                r.body.appendChild(n);
                c.boxModel = c.support.boxModel = n.offsetWidth === 2;
                r.body.removeChild(n).style.display = "none"
            });
            a = function(n) {
                var o = r.createElement("div");
                n = "on" + n;
                var m = n in o;
                if (!m) {
                    o.setAttribute(n, "return;");
                    m = typeof o[n] === "function"
                }
                return m
            };
            c.support.submitBubbles = a("submit");
            c.support.changeBubbles = a("change");
            a = b = d = e = i = 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(),
    Ua = 0,
    xa = {},
    Va = {};
    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 == z ? xa: a;
                var f = a[G],
                e = c.cache;
                if (!b && !f) return null;
                f || (f = ++Ua);
                if (typeof b === "object") {
                    a[G] = f;
                    e = e[f] = c.extend(true, {},
                    b)
                } else e = e[f] ? e[f] : typeof d === "undefined" ? Va: (e[f] = {});
                if (d !== v) {
                    a[G] = f;
                    e[b] = d
                }
                return typeof b === "string" ? e[b] : e
            }
        },
        removeData: function(a, b) {
            if (! (a.nodeName && c.noData[a.nodeName.toLowerCase()])) {
                a = a == z ? xa: 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 {
                    try {
                        delete a[G]
                    } catch(i) {
                        a.removeAttribute && a.removeAttribute(G)
                    }
                    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 === v) {
                var f = this.triggerHandler("getData" + d[1] + "!", [d[0]]);
                if (f === v && this.length) f = c.data(this[0], a);
                return f === v && 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 === v) 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 ya = /[\n\t]/g,
    ca = /\s+/,
    Wa = /\r/g,
    Xa = /href|src|style/,
    Ya = /(button|input)/i,
    Za = /(button|input|object|select|textarea)/i,
    $a = /^(a|area)$/i,
    za = /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(o) {
                var m = c(this);
                m.addClass(a.call(this, o, m.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 i = " " + e.className + " ",
                j = 0,
                n = b.length; j < n; j++) {
                    if (i.indexOf(" " + b[j] + " ") < 0) e.className += " " + b[j]
                } else e.className = a
            }
            return this
        },
        removeClass: function(a) {
            if (c.isFunction(a)) return this.each(function(o) {
                var m = c(this);
                m.removeClass(a.call(this, o, m.attr("class")))
            });
            if (a && typeof a === "string" || a === v) 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 i = (" " + e.className + " ").replace(ya, " "), j = 0, n = b.length; j < n; j++) i = i.replace(" " + b[j] + " ", " ");
                    e.className = i.substring(1, i.length - 1)
                } 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 i = c(this);
                i.toggleClass(a.call(this, e, i.attr("class"), b), b)
            });
            return this.each(function() {
                if (d === "string") for (var e, i = 0,
                j = c(this), n = b, o = a.split(ca); e = o[i++];) {
                    n = f ? n: !j.hasClass(e);
                    j[n ? "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(ya, " ").indexOf(a) > -1) return true;
            return false
        },
        val: function(a) {
            if (a === v) {
                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 i = b ? d: 0;
                        for (d = b ? d + 1 : e.length; i < d; i++) {
                            var j = e[i];
                            if (j.selected) {
                                a = c(j).val();
                                if (b) return a;
                                f.push(a)
                            }
                        }
                        return f
                    }
                    if (za.test(b.type) && !c.support.checkOn) return b.getAttribute("value") === null ? "on": b.value;
                    return (b.value || "").replace(Wa, "")
                }
                return v
            }
            var n = c.isFunction(a);
            return this.each(function(o) {
                var m = c(this),
                s = a;
                if (this.nodeType === 1) {
                    if (n) s = a.call(this, o, m.val());
                    if (typeof s === "number") s += "";
                    if (c.isArray(s) && za.test(this.type)) this.checked = c.inArray(m.val(), s) >= 0;
                    else if (c.nodeName(this, "select")) {
                        var x = c.makeArray(s);
                        c("option", this).each(function() {
                            this.selected = c.inArray(c(this).val(), x) >= 0
                        });
                        if (!x.length) this.selectedIndex = -1
                    } else this.value = s
                }
            })
        }
    });
    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 v;
            if (f && b in c.attrFn) return c(a)[b](d);
            f = a.nodeType !== 1 || !c.isXMLDoc(a);
            var e = d !== v;
            b = f && c.props[b] || b;
            if (a.nodeType === 1) {
                var i = Xa.test(b);
                if (b in a && f && !i) {
                    if (e) {
                        b === "type" && Ya.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: Za.test(a.nodeName) || $a.test(a.nodeName) && a.href ? 0 : v;
                    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 && i ? a.getAttribute(b, 2) : a.getAttribute(b);
                return a === null ? v: a
            }
            return c.style(a, b, d)
        }
    });
    var ab = 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 !== z && !a.frameElement) a = z;
                if (!d.guid) d.guid = c.guid++;
                if (f !== v) {
                    d = c.proxy(d);
                    d.data = f
                }
                var e = c.data(a, "events") || c.data(a, "events", {}),
                i = c.data(a, "handle"),
                j;
                if (!i) {
                    j = function() {
                        return typeof c !== "undefined" && !c.event.triggered ? c.event.handle.apply(j.elem, arguments) : v
                    };
                    i = c.data(a, "handle", j)
                }
                if (i) {
                    i.elem = a;
                    b = b.split(/\s+/);
                    for (var n, o = 0; n = b[o++];) {
                        var m = n.split(".");
                        n = m.shift();
                        if (o > 1) {
                            d = c.proxy(d);
                            if (f !== v) d.data = f
                        }
                        d.type = m.slice(0).sort().join(".");
                        var s = e[n],
                        x = this.special[n] || {};
                        if (!s) {
                            s = e[n] = {};
                            if (!x.setup || x.setup.call(a, f, m, d) === false) if (a.addEventListener) a.addEventListener(n, i, false);
                            else a.attachEvent && a.attachEvent("on" + n, i)
                        }
                        if (x.add) if ((m = x.add.call(a, d, f, m, s)) && c.isFunction(m)) {
                            m.guid = m.guid || d.guid;
                            m.data = m.data || d.data;
                            m.type = m.type || d.type;
                            d = m
                        }
                        s[d.guid] = d;
                        this.global[n] = true
                    }
                    a = null
                }
            }
        },
        global: {},
        remove: function(a, b, d) {
            if (! (a.nodeType === 3 || a.nodeType === 8)) {
                var f = c.data(a, "events"),
                e,
                i,
                j;
                if (f) {
                    if (b === v || typeof b === "string" && b.charAt(0) === ".") for (i in f) this.remove(a, i + (b || ""));
                    else {
                        if (b.type) {
                            d = b.handler;
                            b = b.type
                        }
                        b = b.split(/\s+/);
                        for (var n = 0; i = b[n++];) {
                            var o = i.split(".");
                            i = o.shift();
                            var m = !o.length,
                            s = c.map(o.slice(0).sort(), ab);
                            s = new RegExp("(^|\\.)" + s.join("\\.(?:.*\\.)?") + "(\\.|$)");
                            var x = this.special[i] || {};
                            if (f[i]) {
                                if (d) {
                                    j = f[i][d.guid];
                                    delete f[i][d.guid]
                                } else for (var A in f[i]) if (m || s.test(f[i][A].type)) delete f[i][A];
                                x.remove && x.remove.call(a, o, j);
                                for (e in f[i]) break;
                                if (!e) {
                                    if (!x.teardown || x.teardown.call(a, o) === false) if (a.removeEventListener) a.removeEventListener(i, c.data(a, "handle"), false);
                                    else a.detachEvent && a.detachEvent("on" + i, c.data(a, "handle"));
                                    e = null;
                                    delete f[i]
                                }
                            }
                        }
                    }
                    for (e in f) break;
                    if (!e) {
                        if (A = c.data(a, "handle")) A.elem = null;
                        c.removeData(a, "events");
                        c.removeData(a, "handle")
                    }
                }
            }
        },
        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();
                    this.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 v;
                a.result = v;
                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(i) {}
            if (!a.isPropagationStopped() && f) c.event.trigger(a, b, f, true);
            else if (!a.isDefaultPrevented()) {
                d = a.target;
                var j;
                if (! (c.nodeName(d, "a") && e === "click") && !(d && d.nodeName && c.noData[d.nodeName.toLowerCase()])) {
                    try {
                        if (d[e]) {
                            if (j = d["on" + e]) d["on" + e] = null;
                            this.triggered = true;
                            d[e]()
                        }
                    } catch(n) {}
                    if (j) d["on" + e] = j;
                    this.triggered = false
                }
            }
        },
        handle: function(a) {
            var b, d;
            a = arguments[0] = c.event.fix(a || z.event);
            a.currentTarget = this;
            d = a.type.split(".");
            a.type = d.shift();
            b = !d.length && !a.exclusive;
            var f = new RegExp("(^|\\.)" + d.slice(0).sort().join("\\.(?:.*\\.)?") + "(\\.|$)");
            d = (c.data(this, "events") || {})[a.type];
            for (var e in d) {
                var i = d[e];
                if (b || f.test(i.type)) {
                    a.handler = i;
                    a.data = i.data;
                    i = i.apply(this, arguments);
                    if (i !== v) {
                        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 || r;
            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 = r.documentElement;
                d = r.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 !== v) 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, b) {
                    c.extend(a, b || {});
                    a.guid += b.selector + b.live;
                    b.liveProxy = a;
                    c.event.add(this, b.live, na, b)
                },
                remove: function(a) {
                    if (a.length) {
                        var b = 0,
                        d = new RegExp("(^|\\.)" + a[0] + "(\\.|$)");
                        c.each(c.data(this, "events").live || {},
                        function() {
                            d.test(this.type) && b++
                        });
                        b < 1 && c.event.remove(this, a[0], na)
                    }
                },
                special: {}
            },
            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
                }
            }
        }
    };
    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 Aa = function(a) {
        for (var b = a.relatedTarget; b && b !== this;) try {
            b = b.parentNode
        } catch(d) {
            break
        }
        if (b !== this) {
            a.type = a.data;
            c.event.handle.apply(this, arguments)
        }
    },
    Ba = 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 ? Ba: Aa, a)
            },
            teardown: function(d) {
                c.event.remove(this, b, d && d.selector ? Ba: Aa)
            }
        }
    });
    if (!c.support.submitBubbles) c.event.special.submit = {
        setup: function(a, b, d) {
            if (this.nodeName.toLowerCase() !== "form") {
                c.event.add(this, "click.specialSubmit." + d.guid,
                function(f) {
                    var e = f.target,
                    i = e.type;
                    if ((i === "submit" || i === "image") && c(e).closest("form").length) return ma("submit", this, arguments)
                });
                c.event.add(this, "keypress.specialSubmit." + d.guid,
                function(f) {
                    var e = f.target,
                    i = e.type;
                    if ((i === "text" || i === "password") && c(e).closest("form").length && f.keyCode === 13) return ma("submit", this, arguments)
                })
            } else return false
        },
        remove: function(a, b) {
            c.event.remove(this, "click.specialSubmit" + (b ? "." + b.guid: ""));
            c.event.remove(this, "keypress.specialSubmit" + (b ? "." + b.guid: ""))
        }
    };
    if (!c.support.changeBubbles) {
        var da = /textarea|input|select/i;
        function Ca(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
        }
        function ea(a, b) {
            var d = a.target,
            f, e;
            if (! (!da.test(d.nodeName) || d.readOnly)) {
                f = c.data(d, "_change_data");
                e = Ca(d);
                if (a.type !== "focusout" || d.type !== "radio") c.data(d, "_change_data", e);
                if (! (f === v || e === f)) if (f != null || e) {
                    a.type = "change";
                    return c.event.trigger(a, b, d)
                }
            }
        }
        c.event.special.change = {
            filters: {
                focusout: ea,
                click: function(a) {
                    var b = a.target,
                    d = b.type;
                    if (d === "radio" || d === "checkbox" || b.nodeName.toLowerCase() === "select") return ea.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 ea.call(this, a)
                },
                beforeactivate: function(a) {
                    a = a.target;
                    a.nodeName.toLowerCase() === "input" && a.type === "radio" && c.data(a, "_change_data", Ca(a))
                }
            },
            setup: function(a, b, d) {
                for (var f in T) c.event.add(this, f + ".specialChange." + d.guid, T[f]);
                return da.test(this.nodeName)
            },
            remove: function(a, b) {
                for (var d in T) c.event.remove(this, d + ".specialChange" + (b ? "." + b.guid: ""), T[d]);
                return da.test(this.nodeName)
            }
        };
        var T = c.event.special.change.filters
    }
    r.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 i in d) this[b](i, f, d[i], e);
                return this
            }
            if (c.isFunction(f)) {
                e = f;
                f = v
            }
            var j = b === "one" ? c.proxy(e,
            function(n) {
                c(this).unbind(n, j);
                return e.apply(this, arguments)
            }) : e;
            return d === "unload" && b !== "one" ? this.one(d, f, e) : this.each(function() {
                c.event.add(this, d, j, f)
            })
        }
    });
    c.fn.extend({
        unbind: function(a, b) {
            if (typeof a === "object" && !a.preventDefault) {
                for (var d in a) this.unbind(d, a[d]);
                return this
            }
            return this.each(function() {
                c.event.remove(this, a, b)
            })
        },
        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)
        }
    });
    c.each(["live", "die"],
    function(a, b) {
        c.fn[b] = function(d, f, e) {
            var i, j = 0;
            if (c.isFunction(f)) {
                e = f;
                f = v
            }
            for (d = (d || "").split(/\s+/); (i = d[j++]) != null;) {
                i = i === "focus" ? "focusin": i === "blur" ? "focusout": i === "hover" ? d.push("mouseleave") && "mouseenter": i;
                b === "live" ? c(this.context).bind(oa(i, this.selector), {
                    data: f,
                    selector: this.selector,
                    live: i
                },
                e) : c(this.context).unbind(oa(i, this.selector), e ? {
                    guid: e.guid + this.selector + i
                }: null)
            }
            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
    });
    z.attachEvent && !z.addEventListener && z.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 = "",
            k, l = 0; g[l]; l++) {
                k = g[l];
                if (k.nodeType === 3 || k.nodeType === 4) h += k.nodeValue;
                else if (k.nodeType !== 8) h += a(k.childNodes)
            }
            return h
        }
        function b(g, h, k, l, q, p) {
            q = 0;
            for (var u = l.length; q < u; q++) {
                var t = l[q];
                if (t) {
                    t = t[g];
                    for (var y = false; t;) {
                        if (t.sizcache === k) {
                            y = l[t.sizset];
                            break
                        }
                        if (t.nodeType === 1 && !p) {
                            t.sizcache = k;
                            t.sizset = q
                        }
                        if (t.nodeName.toLowerCase() === h) {
                            y = t;
                            break
                        }
                        t = t[g]
                    }
                    l[q] = y
                }
            }
        }
        function d(g, h, k, l, q, p) {
            q = 0;
            for (var u = l.length; q < u; q++) {
                var t = l[q];
                if (t) {
                    t = t[g];
                    for (var y = false; t;) {
                        if (t.sizcache === k) {
                            y = l[t.sizset];
                            break
                        }
                        if (t.nodeType === 1) {
                            if (!p) {
                                t.sizcache = k;
                                t.sizset = q
                            }
                            if (typeof h !== "string") {
                                if (t === h) {
                                    y = true;
                                    break
                                }
                            } else if (o.filter(h, [t]).length > 0) {
                                y = t;
                                break
                            }
                        }
                        t = t[g]
                    }
                    l[q] = y
                }
            }
        }
        var f = /((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^[\]]*\]|['"][^'"]*['"]|[^[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g,
        e = 0,
        i = Object.prototype.toString,
        j = false,
        n = true; [0, 0].sort(function() {
            n = false;
            return 0
        });
        var o = function(g, h, k, l) {
            k = k || [];
            var q = h = h || r;
            if (h.nodeType !== 1 && h.nodeType !== 9) return [];
            if (!g || typeof g !== "string") return k;
            for (var p = [], u, t, y, R, H = true, M = w(h), I = g; (f.exec(""), u = f.exec(I)) !== null;) {
                I = u[3];
                p.push(u[1]);
                if (u[2]) {
                    R = u[3];
                    break
                }
            }
            if (p.length > 1 && s.exec(g)) if (p.length === 2 && m.relative[p[0]]) t = fa(p[0] + p[1], h);
            else for (t = m.relative[p[0]] ? [h] : o(p.shift(), h); p.length;) {
                g = p.shift();
                if (m.relative[g]) g += p.shift();
                t = fa(g, t)
            } else {
                if (!l && p.length > 1 && h.nodeType === 9 && !M && m.match.ID.test(p[0]) && !m.match.ID.test(p[p.length - 1])) {
                    u = o.find(p.shift(), h, M);
                    h = u.expr ? o.filter(u.expr, u.set)[0] : u.set[0]
                }
                if (h) {
                    u = l ? {
                        expr: p.pop(),
                        set: A(l)
                    }: o.find(p.pop(), p.length === 1 && (p[0] === "~" || p[0] === "+") && h.parentNode ? h.parentNode: h, M);
                    t = u.expr ? o.filter(u.expr, u.set) : u.set;
                    if (p.length > 0) y = A(t);
                    else H = false;
                    for (; p.length;) {
                        var D = p.pop();
                        u = D;
                        if (m.relative[D]) u = p.pop();
                        else D = "";
                        if (u == null) u = h;
                        m.relative[D](y, u, M)
                    }
                } else y = []
            }
            y || (y = t);
            y || o.error(D || g);
            if (i.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]))) k.push(t[g])
            } else for (g = 0; y[g] != null; g++) y[g] && y[g].nodeType === 1 && k.push(t[g]);
            else k.push.apply(k, y);
            else A(y, k);
            if (R) {
                o(R, q, k, l);
                o.uniqueSort(k)
            }
            return k
        };
        o.uniqueSort = function(g) {
            if (C) {
                j = n;
                g.sort(C);
                if (j) for (var h = 1; h < g.length; h++) g[h] === g[h - 1] && g.splice(h--, 1)
            }
            return g
        };
        o.matches = function(g, h) {
            return o(g, null, null, h)
        };
        o.find = function(g, h, k) {
            var l, q;
            if (!g) return [];
            for (var p = 0,
            u = m.order.length; p < u; p++) {
                var t = m.order[p];
                if (q = m.leftMatch[t].exec(g)) {
                    var y = q[1];
                    q.splice(1, 1);
                    if (y.substr(y.length - 1) !== "\\") {
                        q[1] = (q[1] || "").replace(/\\/g, "");
                        l = m.find[t](q, h, k);
                        if (l != null) {
                            g = g.replace(m.match[t], "");
                            break
                        }
                    }
                }
            }
            l || (l = h.getElementsByTagName("*"));
            return {
                set: l,
                expr: g
            }
        };
        o.filter = function(g, h, k, l) {
            for (var q = g,
            p = [], u = h, t, y, R = h && h[0] && w(h[0]); g && h.length;) {
                for (var H in m.filter) if ((t = m.leftMatch[H].exec(g)) != null && t[2]) {
                    var M = m.filter[H],
                    I,
                    D;
                    D = t[1];
                    y = false;
                    t.splice(1, 1);
                    if (D.substr(D.length - 1) !== "\\") {
                        if (u === p) p = [];
                        if (m.preFilter[H]) if (t = m.preFilter[H](t, u, k, p, l, R)) {
                            if (t === true) continue
                        } else y = I = true;
                        if (t) for (var U = 0; (D = u[U]) != null; U++) if (D) {
                            I = M(D, t, U, u);
                            var Da = l ^ !!I;
                            if (k && I != null) if (Da) y = true;
                            else u[U] = false;
                            else if (Da) {
                                p.push(D);
                                y = true
                            }
                        }
                        if (I !== v) {
                            k || (u = p);
                            g = g.replace(m.match[H], "");
                            if (!y) return [];
                            break
                        }
                    }
                }
                if (g === q) if (y == null) o.error(g);
                else break;
                q = g
            }
            return u
        };
        o.error = function(g) {
            throw "Syntax error, unrecognized expression: " + g;
        };
        var m = o.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 k = typeof h === "string",
                    l = k && !/\W/.test(h);
                    k = k && !l;
                    if (l) h = h.toLowerCase();
                    l = 0;
                    for (var q = g.length,
                    p; l < q; l++) if (p = g[l]) {
                        for (; (p = p.previousSibling) && p.nodeType !== 1;);
                        g[l] = k || p && p.nodeName.toLowerCase() === h ? p || false: p === h
                    }
                    k && o.filter(h, g, true)
                },
                ">": function(g, h) {
                    var k = typeof h === "string";
                    if (k && !/\W/.test(h)) {
                        h = h.toLowerCase();
                        for (var l = 0,
                        q = g.length; l < q; l++) {
                            var p = g[l];
                            if (p) {
                                k = p.parentNode;
                                g[l] = k.nodeName.toLowerCase() === h ? k: false
                            }
                        }
                    } else {
                        l = 0;
                        for (q = g.length; l < q; l++) if (p = g[l]) g[l] = k ? p.parentNode: p.parentNode === h;
                        k && o.filter(h, g, true)
                    }
                },
                "": function(g, h, k) {
                    var l = e++,
                    q = d;
                    if (typeof h === "string" && !/\W/.test(h)) {
                        var p = h = h.toLowerCase();
                        q = b
                    }
                    q("parentNode", h, l, g, p, k)
                },
                "~": function(g, h, k) {
                    var l = e++,
                    q = d;
                    if (typeof h === "string" && !/\W/.test(h)) {
                        var p = h = h.toLowerCase();
                        q = b
                    }
                    q("previousSibling", h, l, g, p, k)
                }
            },
            find: {
                ID: function(g, h, k) {
                    if (typeof h.getElementById !== "undefined" && !k) return (g = h.getElementById(g[1])) ? [g] : []
                },
                NAME: function(g, h) {
                    if (typeof h.getElementsByName !== "undefined") {
                        var k = [];
                        h = h.getElementsByName(g[1]);
                        for (var l = 0,
                        q = h.length; l < q; l++) h[l].getAttribute("name") === g[1] && k.push(h[l]);
                        return k.length === 0 ? null: k
                    }
                },
                TAG: function(g, h) {
                    return h.getElementsByTagName(g[1])
                }
            },
            preFilter: {
                CLASS: function(g, h, k, l, q, p) {
                    g = " " + g[1].replace(/\\/g, "") + " ";
                    if (p) return g;
                    p = 0;
                    for (var u; (u = h[p]) != null; p++) if (u) if (q ^ (u.className && (" " + u.className + " ").replace(/[\t\n]/g, " ").indexOf(g) >= 0)) k || l.push(u);
                    else if (k) 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, k, l, q, p) {
                    h = g[1].replace(/\\/g, "");
                    if (!p && m.attrMap[h]) g[1] = m.attrMap[h];
                    if (g[2] === "~=") g[4] = " " + g[4] + " ";
                    return g
                },
                PSEUDO: function(g, h, k, l, q) {
                    if (g[1] === "not") if ((f.exec(g[3]) || "").length > 1 || /^\w/.test(g[3])) g[3] = o(g[3], null, null, h);
                    else {
                        g = o.filter(g[3], h, k, true ^ q);
                        k || l.push.apply(l, g);
                        return false
                    } else if (m.match.POS.test(g[0]) || m.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, k) {
                    return !! o(k[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, k, l) {
                    return h === l.length - 1
                },
                even: function(g, h) {
                    return h % 2 === 0
                },
                odd: function(g, h) {
                    return h % 2 === 1
                },
                lt: function(g, h, k) {
                    return h < k[3] - 0
                },
                gt: function(g, h, k) {
                    return h > k[3] - 0
                },
                nth: function(g, h, k) {
                    return k[3] - 0 === h
                },
                eq: function(g, h, k) {
                    return k[3] - 0 === h
                }
            },
            filter: {
                PSEUDO: function(g, h, k, l) {
                    var q = h[1],
                    p = m.filters[q];
                    if (p) return p(g, k, h, l);
                    else if (q === "contains") return (g.textContent || g.innerText || a([g]) || "").indexOf(h[3]) >= 0;
                    else if (q === "not") {
                        h = h[3];
                        k = 0;
                        for (l = h.length; k < l; k++) if (h[k] === g) return false;
                        return true
                    } else o.error("Syntax error, unrecognized expression: " + q)
                },
                CHILD: function(g, h) {
                    var k = h[1],
                    l = g;
                    switch (k) {
                    case "only":
                    case "first":
                        for (; l = l.previousSibling;) if (l.nodeType === 1) return false;
                        if (k === "first") return true;
                        l = g;
                    case "last":
                        for (; l = l.nextSibling;) if (l.nodeType === 1) return false;
                        return true;
                    case "nth":
                        k = h[2];
                        var q = h[3];
                        if (k === 1 && q === 0) return true;
                        h = h[0];
                        var p = g.parentNode;
                        if (p && (p.sizcache !== h || !g.nodeIndex)) {
                            var u = 0;
                            for (l = p.firstChild; l; l = l.nextSibling) if (l.nodeType === 1) l.nodeIndex = ++u;
                            p.sizcache = h
                        }
                        g = g.nodeIndex - q;
                        return k === 0 ? g === 0 : g % k === 0 && g / k >= 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 k = h[1];
                    g = m.attrHandle[k] ? m.attrHandle[k](g) : g[k] != null ? g[k] : g.getAttribute(k);
                    k = g + "";
                    var l = h[2];
                    h = h[4];
                    return g == null ? l === "!=": l === "=" ? k === h: l === "*=" ? k.indexOf(h) >= 0 : l === "~=" ? (" " + k + " ").indexOf(h) >= 0 : !h ? k && g !== false: l === "!=" ? k !== h: l === "^=" ? k.indexOf(h) === 0 : l === "$=" ? k.substr(k.length - h.length) === h: l === "|=" ? k === h || k.substr(0, h.length + 1) === h + "-": false
                },
                POS: function(g, h, k, l) {
                    var q = m.setFilters[h[2]];
                    if (q) return q(g, k, h, l)
                }
            }
        },
        s = m.match.POS;
        for (var x in m.match) {
            m.match[x] = new RegExp(m.match[x].source + /(?![^\[]*\])(?![^\(]*\))/.source);
            m.leftMatch[x] = new RegExp(/(^(?:.|\r|\n)*?)/.source + m.match[x].source.replace(/\\(\d+)/g,
            function(g, h) {
                return "\\" + (h - 0 + 1)
            }))
        }
        var A = 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(r.documentElement.childNodes, 0)
        } catch(B) {
            A = function(g, h) {
                h = h || [];
                if (i.call(g) === "[object Array]") Array.prototype.push.apply(h, g);
                else if (typeof g.length === "number") for (var k = 0,
                l = g.length; k < l; k++) h.push(g[k]);
                else for (k = 0; g[k]; k++) h.push(g[k]);
                return h
            }
        }
        var C;
        if (r.documentElement.compareDocumentPosition) C = function(g, h) {
            if (!g.compareDocumentPosition || !h.compareDocumentPosition) {
                if (g == h) j = true;
                return g.compareDocumentPosition ? -1 : 1
            }
            g = g.compareDocumentPosition(h) & 4 ? -1 : g === h ? 0 : 1;
            if (g === 0) j = true;
            return g
        };
        else if ("sourceIndex" in r.documentElement) C = function(g, h) {
            if (!g.sourceIndex || !h.sourceIndex) {
                if (g == h) j = true;
                return g.sourceIndex ? -1 : 1
            }
            g = g.sourceIndex - h.sourceIndex;
            if (g === 0) j = true;
            return g
        };
        else if (r.createRange) C = function(g, h) {
            if (!g.ownerDocument || !h.ownerDocument) {
                if (g == h) j = true;
                return g.ownerDocument ? -1 : 1
            }
            var k = g.ownerDocument.createRange(),
            l = h.ownerDocument.createRange();
            k.setStart(g, 0);
            k.setEnd(g, 0);
            l.setStart(h, 0);
            l.setEnd(h, 0);
            g = k.compareBoundaryPoints(Range.START_TO_END, l);
            if (g === 0) j = true;
            return g
        }; (function() {
            var g = r.createElement("div"),
            h = "script" + (new Date).getTime();
            g.innerHTML = "<a name='" + h + "'/>";
            var k = r.documentElement;
            k.insertBefore(g, k.firstChild);
            if (r.getElementById(h)) {
                m.find.ID = function(l, q, p) {
                    if (typeof q.getElementById !== "undefined" && !p) return (q = q.getElementById(l[1])) ? q.id === l[1] || typeof q.getAttributeNode !== "undefined" && q.getAttributeNode("id").nodeValue === l[1] ? [q] : v: []
                };
                m.filter.ID = function(l, q) {
                    var p = typeof l.getAttributeNode !== "undefined" && l.getAttributeNode("id");
                    return l.nodeType === 1 && p && p.nodeValue === q
                }
            }
            k.removeChild(g);
            k = g = null
        })(); (function() {
            var g = r.createElement("div");
            g.appendChild(r.createComment(""));
            if (g.getElementsByTagName("*").length > 0) m.find.TAG = function(h, k) {
                k = k.getElementsByTagName(h[1]);
                if (h[1] === "*") {
                    h = [];
                    for (var l = 0; k[l]; l++) k[l].nodeType === 1 && h.push(k[l]);
                    k = h
                }
                return k
            };
            g.innerHTML = "<a href='#'></a>";
            if (g.firstChild && typeof g.firstChild.getAttribute !== "undefined" && g.firstChild.getAttribute("href") !== "#") m.attrHandle.href = function(h) {
                return h.getAttribute("href", 2)
            };
            g = null
        })();
        r.querySelectorAll &&
        function() {
            var g = o,
            h = r.createElement("div");
            h.innerHTML = "<p class='TEST'></p>";
            if (! (h.querySelectorAll && h.querySelectorAll(".TEST").length === 0)) {
                o = function(l, q, p, u) {
                    q = q || r;
                    if (!u && q.nodeType === 9 && !w(q)) try {
                        return A(q.querySelectorAll(l), p)
                    } catch(t) {}
                    return g(l, q, p, u)
                };
                for (var k in g) o[k] = g[k];
                h = null
            }
        } (); (function() {
            var g = r.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) {
                    m.order.splice(1, 0, "CLASS");
                    m.find.CLASS = function(h, k, l) {
                        if (typeof k.getElementsByClassName !== "undefined" && !l) return k.getElementsByClassName(h[1])
                    };
                    g = null
                }
            }
        })();
        var E = r.compareDocumentPosition ?
        function(g, h) {
            return g.compareDocumentPosition(h) & 16
        }: function(g, h) {
            return g !== h && (g.contains ? g.contains(h) : true)
        },
        w = function(g) {
            return (g = (g ? g.ownerDocument || g: 0).documentElement) ? g.nodeName !== "HTML": false
        },
        fa = function(g, h) {
            var k = [],
            l = "",
            q;
            for (h = h.nodeType ? [h] : h; q = m.match.PSEUDO.exec(g);) {
                l += q[0];
                g = g.replace(m.match.PSEUDO, "")
            }
            g = m.relative[g] ? g + "*": g;
            q = 0;
            for (var p = h.length; q < p; q++) o(g, h[q], k);
            return o.filter(l, k)
        };
        c.find = o;
        c.expr = o.selectors;
        c.expr[":"] = c.expr.filters;
        c.unique = o.uniqueSort;
        c.getText = a;
        c.isXMLDoc = w;
        c.contains = E
    })();
    var bb = /Until$/,
    cb = /^(?:parents|prevUntil|prevAll)/,
    db = /,/;
    Q = Array.prototype.slice;
    var Ea = function(a, b, d) {
        if (c.isFunction(b)) return c.grep(a,
        function(e, i) {
            return !! b.call(e, i, 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 (Qa.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 i = d; i < b.length; i++) for (var j = 0; j < d; j++) if (b[j] === b[i]) {
                    b.splice(i--, 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(Ea(this, a, false), "not", a)
        },
        filter: function(a) {
            return this.pushStack(Ea(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,
                i = {},
                j;
                if (f && a.length) {
                    e = 0;
                    for (var n = a.length; e < n; e++) {
                        j = a[e];
                        i[j] || (i[j] = c.expr.match.POS.test(j) ? c(j, b || this.context) : j)
                    }
                    for (; f && f.ownerDocument && f !== b;) {
                        for (j in i) {
                            e = i[j];
                            if (e.jquery ? e.index(f) > -1 : c(f).is(e)) {
                                d.push({
                                    selector: j,
                                    elem: f
                                });
                                delete i[j]
                            }
                        }
                        f = f.parentNode
                    }
                }
                return d
            }
            var o = c.expr.match.POS.test(a) ? c(a, b || this.context) : null;
            return this.map(function(m, s) {
                for (; s && s.ownerDocument && s !== b;) {
                    if (o ? o.index(s) > -1 : c(s).is(a)) return s;
                    s = s.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(pa(a[0]) || pa(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);
            bb.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 || db.test(f)) && cb.test(a)) e = e.reverse();
            return this.pushStack(e, a, Q.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 === v || 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 Fa = / jQuery\d+="(?:\d+|null)"/g,
    V = /^\s+/,
    Ga = /(<([\w:]+)[^>]*?)\/>/g,
    eb = /^(?:area|br|col|embed|hr|img|input|link|meta|param)$/i,
    Ha = /<([\w:]+)/,
    fb = /<tbody/i,
    gb = /<|&\w+;/,
    sa = /checked\s*(?:[^=]|=\s*.checked.)/i,
    Ia = function(a, b, d) {
        return eb.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 !== v) return this.empty().append((this[0] && this[0].ownerDocument || r).createTextNode(a));
            return c.getText(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
            }
        },
        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(Fa, "").replace(V, "")], f)[0]
                } else return this.cloneNode(true)
            });
            if (a === true) {
                qa(this, b);
                qa(this.find("*"), b.find("*"))
            }
            return b
        },
        html: function(a) {
            if (a === v) return this[0] && this[0].nodeType === 1 ? this[0].innerHTML.replace(Fa, "") : null;
            else if (typeof a === "string" && !/<script/i.test(a) && (c.support.leadingWhitespace || !V.test(a)) && !F[(Ha.exec(a) || ["", ""])[1].toLowerCase()]) {
                a = a.replace(Ga, Ia);
                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 i = c(this),
                j = i.html();
                i.empty().append(function() {
                    return a.call(this, e, j)
                })
            }) : 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))
                });
                else 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(s) {
                return c.nodeName(s, "table") ? s.getElementsByTagName("tbody")[0] || s.appendChild(s.ownerDocument.createElement("tbody")) : s
            }
            var e, i, j = a[0],
            n = [];
            if (!c.support.checkClone && arguments.length === 3 && typeof j === "string" && sa.test(j)) return this.each(function() {
                c(this).domManip(a, b, d, true)
            });
            if (c.isFunction(j)) return this.each(function(s) {
                var x = c(this);
                a[0] = j.call(this, s, b ? x.html() : v);
                x.domManip(a, b, d)
            });
            if (this[0]) {
                e = a[0] && a[0].parentNode && a[0].parentNode.nodeType === 11 ? {
                    fragment: a[0].parentNode
                }: ra(a, this, n);
                if (i = e.fragment.firstChild) {
                    b = b && c.nodeName(i, "tr");
                    for (var o = 0,
                    m = this.length; o < m; o++) d.call(b ? f(this[o], i) : this[o], e.cacheable || this.length > 1 || o > 0 ? e.fragment.cloneNode(true) : e.fragment)
                }
                n && c.each(n, Ma)
            }
            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);
            for (var e = 0,
            i = d.length; e < i; e++) {
                var j = (e > 0 ? this.clone(true) : this).get();
                c.fn[b].apply(c(d[e]), j);
                f = f.concat(j)
            }
            return this.pushStack(f, a, d.selector)
        }
    });
    c.each({
        remove: function(a, b) {
            if (!a || c.filter(a, [this]).length) {
                if (!b && this.nodeType === 1) {
                    c.cleanData(this.getElementsByTagName("*"));
                    c.cleanData([this])
                }
                this.parentNode && this.parentNode.removeChild(this)
            }
        },
        empty: function() {
            for (this.nodeType === 1 && c.cleanData(this.getElementsByTagName("*")); this.firstChild;) this.removeChild(this.firstChild)
        }
    },
    function(a, b) {
        c.fn[a] = function() {
            return this.each(b, arguments)
        }
    });
    c.extend({
        clean: function(a, b, d, f) {
            b = b || r;
            if (typeof b.createElement === "undefined") b = b.ownerDocument || b[0] && b[0].ownerDocument || r;
            var e = [];
            c.each(a,
            function(i, j) {
                if (typeof j === "number") j += "";
                if (j) {
                    if (typeof j === "string" && !gb.test(j)) j = b.createTextNode(j);
                    else if (typeof j === "string") {
                        j = j.replace(Ga, Ia);
                        var n = (Ha.exec(j) || ["", ""])[1].toLowerCase(),
                        o = F[n] || F._default,
                        m = o[0];
                        i = b.createElement("div");
                        for (i.innerHTML = o[1] + j + o[2]; m--;) i = i.lastChild;
                        if (!c.support.tbody) {
                            m = fb.test(j);
                            n = n === "table" && !m ? i.firstChild && i.firstChild.childNodes: o[1] === "<table>" && !m ? i.childNodes: [];
                            for (o = n.length - 1; o >= 0; --o) c.nodeName(n[o], "tbody") && !n[o].childNodes.length && n[o].parentNode.removeChild(n[o])
                        } ! c.support.leadingWhitespace && V.test(j) && i.insertBefore(b.createTextNode(V.exec(j)[0]), i.firstChild);
                        j = c.makeArray(i.childNodes)
                    }
                    if (j.nodeType) e.push(j);
                    else e = c.merge(e, j)
                }
            });
            if (d) for (a = 0; e[a]; a++) if (f && c.nodeName(e[a], "script") && (!e[a].type || e[a].type.toLowerCase() === "text/javascript")) f.push(e[a].parentNode ? e[a].parentNode.removeChild(e[a]) : e[a]);
            else {
                e[a].nodeType === 1 && e.splice.apply(e, [a + 1, 0].concat(c.makeArray(e[a].getElementsByTagName("script"))));
                d.appendChild(e[a])
            }
            return e
        },
        cleanData: function(a) {
            for (var b = 0,
            d; (d = a[b]) != null; b++) {
                c.event.remove(d);
                c.removeData(d)
            }
        }
    });
    var hb = /z-?index|font-?weight|opacity|zoom|line-?height/i,
    Ja = /alpha\([^)]*\)/,
    Ka = /opacity=([^)]*)/,
    ga = /float/i,
    ha = /-([a-z])/ig,
    ib = /([A-Z])/g,
    jb = /^-?\d+(?:px)?$/i,
    kb = /^-?\d/,
    lb = {
        position: "absolute",
        visibility: "hidden",
        display: "block"
    },
    mb = ["Left", "Right"],
    nb = ["Top", "Bottom"],
    ob = r.defaultView && r.defaultView.getComputedStyle,
    La = c.support.cssFloat ? "cssFloat": "styleFloat",
    ia = function(a, b) {
        return b.toUpperCase()
    };
    c.fn.css = function(a, b) {
        return X(this, a, b, true,
        function(d, f, e) {
            if (e === v) return c.curCSS(d, f);
            if (typeof e === "number" && !hb.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 v;
            if ((b === "width" || b === "height") && parseFloat(d) < 0) d = v;
            var f = a.style || a,
            e = d !== v;
            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 = Ja.test(a) ? a.replace(Ja, b) : b
                }
                return f.filter && f.filter.indexOf("opacity=") >= 0 ? parseFloat(Ka.exec(f.filter)[1]) / 100 + "": ""
            }
            if (ga.test(b)) b = La;
            b = b.replace(ha, ia);
            if (e) f[b] = d;
            return f[b]
        },
        css: function(a, b, d, f) {
            if (b === "width" || b === "height") {
                var e, i = b === "width" ? mb: nb;
                function j() {
                    e = b === "width" ? a.offsetWidth: a.offsetHeight;
                    f !== "border" && c.each(i,
                    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 ? j() : c.swap(a, lb, j);
                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 = Ka.test(a.currentStyle.filter || "") ? parseFloat(RegExp.$1) / 100 + "": "";
                return f === "" ? "1": f
            }
            if (ga.test(b)) b = La;
            if (!d && e && e[b]) f = e[b];
            else if (ob) {
                if (ga.test(b)) b = "float";
                b = b.replace(ib, "-$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(ha, ia);
                f = a.currentStyle[b] || a.currentStyle[d];
                if (!jb.test(f) && kb.test(f)) {
                    b = e.left;
                    var i = 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 = i
                }
            }
            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 pb = J(),
    qb = /<script(.|\s)*?\/script>/gi,
    rb = /select|textarea/i,
    sb = /color|date|datetime|email|hidden|month|number|password|range|search|tel|text|time|url|week/i,
    N = /=\?(&|$)/,
    ja = /\?/,
    tb = /(\?|&)_=.*?(&|$)/,
    ub = /^(\w+:)?\/\/([^\/?#]+)/,
    vb = /%20/g;
    c.fn.extend({
        _load: c.fn.load,
        load: function(a, b, d) {
            if (typeof a !== "string") return this._load(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 i = this;
            c.ajax({
                url: a,
                type: f,
                dataType: "html",
                data: b,
                complete: function(j, n) {
                    if (n === "success" || n === "notmodified") i.html(e ? c("<div />").append(j.responseText.replace(qb, "")).find(e) : j.responseText);
                    d && i.each(d, [j.responseText, n, j])
                }
            });
            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 || rb.test(this.nodeName) || sb.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: z.XMLHttpRequest && (z.location.protocol !== "file:" || !z.ActiveXObject) ?
            function() {
                return new z.XMLHttpRequest
            }: function() {
                try {
                    return new z.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(o, n, j, w);
                e.global && f("ajaxSuccess", [w, e])
            }
            function d() {
                e.complete && e.complete.call(o, w, j);
                e.global && f("ajaxComplete", [w, 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),
            i,
            j,
            n,
            o = a && a.context || e,
            m = 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 (m === "GET") N.test(e.url) || (e.url += (ja.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))) {
                i = e.jsonpCallback || "jsonp" + pb++;
                if (e.data) e.data = (e.data + "").replace(N, "=" + i + "$1");
                e.url = e.url.replace(N, "=" + i + "$1");
                e.dataType = "script";
                z[i] = z[i] ||
                function(q) {
                    n = q;
                    b();
                    d();
                    z[i] = v;
                    try {
                        delete z[i]
                    } catch(p) {}
                    A && A.removeChild(B)
                }
            }
            if (e.dataType === "script" && e.cache === null) e.cache = false;
            if (e.cache === false && m === "GET") {
                var s = J(),
                x = e.url.replace(tb, "$1_=" + s + "$2");
                e.url = x + (x === e.url ? (ja.test(e.url) ? "&": "?") + "_=" + s: "")
            }
            if (e.data && m === "GET") e.url += (ja.test(e.url) ? "&": "?") + e.data;
            e.global && !c.active++&&c.event.trigger("ajaxStart");
            s = (s = ub.exec(e.url)) && (s[1] && s[1] !== location.protocol || s[2] !== location.host);
            if (e.dataType === "script" && m === "GET" && s) {
                var A = r.getElementsByTagName("head")[0] || r.documentElement,
                B = r.createElement("script");
                B.src = e.url;
                if (e.scriptCharset) B.charset = e.scriptCharset;
                if (!i) {
                    var C = false;
                    B.onload = B.onreadystatechange = function() {
                        if (!C && (!this.readyState || this.readyState === "loaded" || this.readyState === "complete")) {
                            C = true;
                            b();
                            d();
                            B.onload = B.onreadystatechange = null;
                            A && B.parentNode && A.removeChild(B)
                        }
                    }
                }
                A.insertBefore(B, A.firstChild);
                return v
            }
            var E = false,
            w = e.xhr();
            if (w) {
                e.username ? w.open(m, e.url, e.async, e.username, e.password) : w.open(m, e.url, e.async);
                try {
                    if (e.data || a && a.contentType) w.setRequestHeader("Content-Type", e.contentType);
                    if (e.ifModified) {
                        c.lastModified[e.url] && w.setRequestHeader("If-Modified-Since", c.lastModified[e.url]);
                        c.etag[e.url] && w.setRequestHeader("If-None-Match", c.etag[e.url])
                    }
                    s || w.setRequestHeader("X-Requested-With", "XMLHttpRequest");
                    w.setRequestHeader("Accept", e.dataType && e.accepts[e.dataType] ? e.accepts[e.dataType] + ", */*": e.accepts._default)
                } catch(fa) {}
                if (e.beforeSend && e.beforeSend.call(o, w, e) === false) {
                    e.global && !--c.active && c.event.trigger("ajaxStop");
                    w.abort();
                    return false
                }
                e.global && f("ajaxSend", [w, e]);
                var g = w.onreadystatechange = function(q) {
                    if (!w || w.readyState === 0 || q === "abort") {
                        E || d();
                        E = true;
                        if (w) w.onreadystatechange = c.noop
                    } else if (!E && w && (w.readyState === 4 || q === "timeout")) {
                        E = true;
                        w.onreadystatechange = c.noop;
                        j = q === "timeout" ? "timeout": !c.httpSuccess(w) ? "error": e.ifModified && c.httpNotModified(w, e.url) ? "notmodified": "success";
                        var p;
                        if (j === "success") try {
                            n = c.httpData(w, e.dataType, e)
                        } catch(u) {
                            j = "parsererror";
                            p = u
                        }
                        if (j === "success" || j === "notmodified") i || b();
                        else c.handleError(e, w, j, p);
                        d();
                        q === "timeout" && w.abort();
                        if (e.async) w = null
                    }
                };
                try {
                    var h = w.abort;
                    w.abort = function() {
                        w && h.call(w);
                        g("abort")
                    }
                } catch(k) {}
                e.async && e.timeout > 0 && setTimeout(function() {
                    w && !E && g("timeout")
                },
                e.timeout);
                try {
                    w.send(m === "POST" || m === "PUT" || m === "DELETE" ? e.data: null)
                } catch(l) {
                    c.handleError(e, w, null, l);
                    d()
                }
                e.async || g();
                return w
            }
        },
        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(j, n) {
                if (c.isArray(n)) c.each(n,
                function(o, m) {
                    b ? f(j, m) : d(j + "[" + (typeof m === "object" || c.isArray(m) ? o: "") + "]", m)
                });
                else ! b && n != null && typeof n === "object" ? c.each(n,
                function(o, m) {
                    d(j + "[" + o + "]", m)
                }) : f(j, n)
            }
            function f(j, n) {
                n = c.isFunction(n) ? n() : n;
                e[e.length] = encodeURIComponent(j) + "=" + encodeURIComponent(n)
            }
            var e = [];
            if (b === v) b = c.ajaxSettings.traditional;
            if (c.isArray(a) || a.jquery) c.each(a,
            function() {
                f(this.name, this.value)
            });
            else for (var i in a) d(i, a[i]);
            return e.join("&").replace(vb, "+")
        }
    });
    var ka = {},
    wb = /toggle|show|hide/,
    xb = /^([+-]=)?([\d+-.]+)(.*)$/,
    W, ta = [["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 (ka[d]) f = ka[d];
                        else {
                            var e = c("<" + d + " />").appendTo("body");
                            f = e.css("display");
                            if (f === "none") f = "block";
                            e.remove();
                            ka[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 i = c.extend({},
                e),
                j,
                n = this.nodeType === 1 && c(this).is(":hidden"),
                o = this;
                for (j in a) {
                    var m = j.replace(ha, ia);
                    if (j !== m) {
                        a[m] = a[j];
                        delete a[j];
                        j = m
                    }
                    if (a[j] === "hide" && n || a[j] === "show" && !n) return i.complete.call(this);
                    if ((j === "height" || j === "width") && this.style) {
                        i.display = c.css(this, "display");
                        i.overflow = this.style.overflow
                    }
                    if (c.isArray(a[j])) { (i.specialEasing = i.specialEasing || {})[j] = a[j][1];
                        a[j] = a[j][0]
                    }
                }
                if (i.overflow != null) this.style.overflow = "hidden";
                i.curAnim = c.extend({},
                a);
                c.each(a,
                function(s, x) {
                    var A = new c.fx(o, i, s);
                    if (wb.test(x)) A[x === "toggle" ? n ? "show": "hide": x](a);
                    else {
                        var B = xb.exec(x),
                        C = A.cur(true) || 0;
                        if (B) {
                            x = parseFloat(B[2]);
                            var E = B[3] || "px";
                            if (E !== "px") {
                                o.style[s] = (x || 1) + E;
                                C = (x || 1) / A.cur(true) * C;
                                o.style[s] = C + E
                            }
                            if (B[1]) x = (B[1] === "-=" ? -1 : 1) * x + C;
                            A.custom(C, x, E)
                        } else A.custom(C, x, "")
                    }
                });
                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(i) {
                return e.step(i)
            }
            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 r.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(s) {
            c.offset.setOffset(this, a, s)
        });
        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,
        i, j = e.documentElement,
        n = e.body;
        f = (e = e.defaultView) ? e.getComputedStyle(b, null) : b.currentStyle;
        for (var o = b.offsetTop,
        m = b.offsetLeft; (b = b.parentNode) && b !== n && b !== j;) {
            if (c.offset.supportsFixedPosition && f.position === "fixed") break;
            i = e ? e.getComputedStyle(b, null) : b.currentStyle;
            o -= b.scrollTop;
            m -= b.scrollLeft;
            if (b === d) {
                o += b.offsetTop;
                m += b.offsetLeft;
                if (c.offset.doesNotAddBorder && !(c.offset.doesAddBorderForTableAndCells && /^t(able|d|h)$/i.test(b.nodeName))) {
                    o += parseFloat(i.borderTopWidth) || 0;
                    m += parseFloat(i.borderLeftWidth) || 0
                }
                f = d;
                d = b.offsetParent
            }
            if (c.offset.subtractsBorderForOverflowNotVisible && i.overflow !== "visible") {
                o += parseFloat(i.borderTopWidth) || 0;
                m += parseFloat(i.borderLeftWidth) || 0
            }
            f = i
        }
        if (f.position === "relative" || f.position === "static") {
            o += n.offsetTop;
            m += n.offsetLeft
        }
        if (c.offset.supportsFixedPosition && f.position === "fixed") {
            o += Math.max(j.scrollTop, n.scrollTop);
            m += Math.max(j.scrollLeft, n.scrollLeft)
        }
        return {
            top: o,
            left: m
        }
    };
    c.offset = {
        initialize: function() {
            var a = r.body,
            b = r.createElement("div"),
            d,
            f,
            e,
            i = 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 !== i;
            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(),
            i = parseInt(c.curCSS(a, "top", true), 10) || 0,
            j = parseInt(c.curCSS(a, "left", true), 10) || 0;
            if (c.isFunction(b)) b = b.call(a, d, e);
            d = {
                top: b.top - e.top + i,
                left: b.left - e.left + j
            };
            "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 || r.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],
            i;
            if (!e) return null;
            if (f !== v) return this.each(function() {
                if (i = ua(this)) i.scrollTo(!a ? f: c(i).scrollLeft(), a ? f: c(i).scrollTop());
                else this[d] = f
            });
            else return (i = ua(e)) ? "pageXOffset" in i ? i[a ? "pageYOffset": "pageXOffset"] : c.support.boxModel && i.document.documentElement[d] || i.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(i) {
                var j = c(this);
                j[d](f.call(this, i, j[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 === v ? c.css(e, d) : this.css(d, typeof f === "string" ? f: f + "px")
        }
    });
    z.jQuery = z.$ = c
})(window);



var hs = {
    lang: {
        cssDirection: 'ltr',
        loadingText: 'Loading...',
        loadingTitle: 'Click to cancel',
        focusTitle: 'Click to bring to front',
        fullExpandTitle: 'Expand to actual size (f)',
        creditsText: 'Powered by <i>Highslide JS</i>',
        creditsTitle: 'Go to the Highslide JS homepage',
        restoreTitle: 'Click to close image, click and drag to move. Use arrow keys for next and previous.'
    },
    graphicsDir: 'highslide/graphics/',
    expandCursor: 'zoomin.cur',
    restoreCursor: 'zoomout.cur',
    expandDuration: 250,
    restoreDuration: 250,
    marginLeft: 15,
    marginRight: 15,
    marginTop: 15,
    marginBottom: 15,
    zIndexCounter: 1001,
    loadingOpacity: 0.75,
    allowMultipleInstances: true,
    numberOfImagesToPreload: 5,
    outlineWhileAnimating: 2,
    outlineStartOffset: 3,
    padToMinWidth: false,
    fullExpandPosition: 'bottom right',
    fullExpandOpacity: 1,
    showCredits: true,
    creditsHref: 'http://highslide.com/',
    enableKeyListener: true,
    openerTagNames: ['a'],
    dragByHeading: true,
    minWidth: 200,
    minHeight: 200,
    allowSizeReduction: true,
    outlineType: 'drop-shadow',
    wrapperClassName: 'highslide-wrapper',
    preloadTheseImages: [],
    continuePreloading: true,
    expanders: [],
    overrides: ['allowSizeReduction', 'useBox', 'outlineType', 'outlineWhileAnimating', 'captionId', 'captionText', 'captionEval', 'captionOverlay', 'headingId', 'headingText', 'headingEval', 'headingOverlay', 'dragByHeading', 'width', 'height', 'wrapperClassName', 'minWidth', 'minHeight', 'maxWidth', 'maxHeight', 'slideshowGroup', 'easing', 'easingClose', 'fadeInOut', 'src'],
    overlays: [],
    idCounter: 0,
    oPos: {
        x: ['leftpanel', 'left', 'center', 'right', 'rightpanel'],
        y: ['above', 'top', 'middle', 'bottom', 'below']
    },
    mouse: {},
    headingOverlay: {},
    captionOverlay: {},
    faders: [],
    pendingOutlines: {},
    clones: {},
    ie: (document.all && !window.opera),
    safari: /Safari/.test(navigator.userAgent),
    geckoMac: /Macintosh.+rv:1\.[0-8].+Gecko/.test(navigator.userAgent),
    $: function(id) {
        return document.getElementById(id)
    },
    push: function(arr, val) {
        arr[arr.length] = val
    },
    createElement: function(tag, attribs, styles, parent, nopad) {
        var el = document.createElement(tag);
        if (attribs) hs.setAttribs(el, attribs);
        if (nopad) hs.setStyles(el, {
            padding: 0,
            border: 'none',
            margin: 0
        });
        if (styles) hs.setStyles(el, styles);
        if (parent) parent.appendChild(el);
        return el
    },
    setAttribs: function(el, attribs) {
        for (var x in attribs) el[x] = attribs[x]
    },
    setStyles: function(el, styles) {
        for (var x in styles) {
            if (hs.ie && x == 'opacity') {
                if (styles[x] > 0.99) el.style.removeAttribute('filter');
                else el.style.filter = 'alpha(opacity=' + (styles[x] * 100) + ')'
            } else el.style[x] = styles[x]
        }
    },
    ieVersion: function() {
        var arr = navigator.appVersion.split("MSIE");
        return arr[1] ? parseFloat(arr[1]) : null
    },
    getPageSize: function() {
        var d = document,
        w = window,
        iebody = d.compatMode && d.compatMode != 'BackCompat' ? d.documentElement: d.body;
        var width = hs.ie ? iebody.clientWidth: (d.documentElement.clientWidth || self.innerWidth),
        height = hs.ie ? iebody.clientHeight: self.innerHeight;
        return {
            width: width,
            height: height,
            scrollLeft: hs.ie ? iebody.scrollLeft: pageXOffset,
            scrollTop: hs.ie ? iebody.scrollTop: pageYOffset
        }
    },
    getPosition: function(el) {
        var p = {
            x: el.offsetLeft,
            y: el.offsetTop
        };
        while (el.offsetParent) {
            el = el.offsetParent;
            p.x += el.offsetLeft;
            p.y += el.offsetTop;
            if (el != document.body && el != document.documentElement) {
                p.x -= el.scrollLeft;
                p.y -= el.scrollTop
            }
        }
        return p
    },
    expand: function(a, params, custom, type) {
        if (!a) a = hs.createElement('a', null, {
            display: 'none'
        },
        hs.container);
        if (typeof a.getParams == 'function') return params;
        try {
            new hs.Expander(a, params, custom);
            return false
        } catch(e) {
            return true
        }
    },
    focusTopmost: function() {
        var topZ = 0,
        topmostKey = -1;
        for (var i = 0; i < hs.expanders.length; i++) {
            if (hs.expanders[i]) {
                if (hs.expanders[i].wrapper.style.zIndex && hs.expanders[i].wrapper.style.zIndex > topZ) {
                    topZ = hs.expanders[i].wrapper.style.zIndex;
                    topmostKey = i
                }
            }
        }
        if (topmostKey == -1) hs.focusKey = -1;
        else hs.expanders[topmostKey].focus()
    },
    getParam: function(a, param) {
        a.getParams = a.onclick;
        var p = a.getParams ? a.getParams() : null;
        a.getParams = null;
        return (p && typeof p[param] != 'undefined') ? p[param] : (typeof hs[param] != 'undefined' ? hs[param] : null)
    },
    getSrc: function(a) {
        var src = hs.getParam(a, 'src');
        if (src) return src;
        return a.href
    },
    getNode: function(id) {
        var node = hs.$(id),
        clone = hs.clones[id],
        a = {};
        if (!node && !clone) return null;
        if (!clone) {
            clone = node.cloneNode(true);
            clone.id = '';
            hs.clones[id] = clone;
            return node
        } else {
            return clone.cloneNode(true)
        }
    },
    discardElement: function(d) {
        hs.garbageBin.appendChild(d);
        hs.garbageBin.innerHTML = ''
    },
    transit: function(adj, exp) {
        hs.last = exp = exp || hs.getExpander();
        try {
            hs.upcoming = adj;
            adj.onclick()
        } catch(e) {
            hs.last = hs.upcoming = null
        }
        try {
            exp.close()
        } catch(e) {}
        return false
    },
    previousOrNext: function(el, op) {
        var exp = hs.getExpander(el),
        adj = exp.getAdjacentAnchor(op);
        return hs.transit(adj, exp)
    },
    previous: function(el) {
        return hs.previousOrNext(el, -1)
    },
    next: function(el) {
        return hs.previousOrNext(el, 1)
    },
    keyHandler: function(e) {
        if (!e) e = window.event;
        if (!e.target) e.target = e.srcElement;
        if (typeof e.target.form != 'undefined') return true;
        var exp = hs.getExpander();
        var op = null;
        switch (e.keyCode) {
        case 70:
            if (exp) exp.doFullExpand();
            return true;
        case 32:
        case 34:
        case 39:
        case 40:
            op = 1;
            break;
        case 8:
        case 33:
        case 37:
        case 38:
            op = -1;
            break;
        case 27:
        case 13:
            op = 0
        }
        if (op !== null) {
            hs.removeEventListener(document, window.opera ? 'keypress': 'keydown', hs.keyHandler);
            if (!hs.enableKeyListener) return true;
            if (e.preventDefault) e.preventDefault();
            else e.returnValue = false;
            if (exp) {
                if (op == 0) {
                    exp.close()
                } else {
                    hs.previousOrNext(exp.key, op)
                }
                return false
            }
        }
        return true
    },
    registerOverlay: function(overlay) {
        hs.push(hs.overlays, overlay)
    },
    getWrapperKey: function(element, expOnly) {
        var el, re = /^highslide-wrapper-([0-9]+)$/;
        el = element;
        while (el.parentNode) {
            if (el.id && re.test(el.id)) return el.id.replace(re, "$1");
            el = el.parentNode
        }
        if (!expOnly) {
            el = element;
            while (el.parentNode) {
                if (el.tagName && hs.isHsAnchor(el)) {
                    for (var key = 0; key < hs.expanders.length; key++) {
                        var exp = hs.expanders[key];
                        if (exp && exp.a == el) return key
                    }
                }
                el = el.parentNode
            }
        }
        return null
    },
    getExpander: function(el, expOnly) {
        if (typeof el == 'undefined') return hs.expanders[hs.focusKey] || null;
        if (typeof el == 'number') return hs.expanders[el] || null;
        if (typeof el == 'string') el = hs.$(el);
        return hs.expanders[hs.getWrapperKey(el, expOnly)] || null
    },
    isHsAnchor: function(a) {
        return (a.onclick && a.onclick.toString().replace(/\s/g, ' ').match(/hs.(htmlE|e)xpand/))
    },
    reOrder: function() {
        for (var i = 0; i < hs.expanders.length; i++) if (hs.expanders[i] && hs.expanders[i].isExpanded) hs.focusTopmost()
    },
    mouseClickHandler: function(e) {
        if (!e) e = window.event;
        if (e.button > 1) return true;
        if (!e.target) e.target = e.srcElement;
        var el = e.target;
        while (el.parentNode && !(/highslide-(image|move|html|resize)/.test(el.className))) {
            el = el.parentNode
        }
        var exp = hs.getExpander(el);
        if (exp && (exp.isClosing || !exp.isExpanded)) return true;
        if (exp && e.type == 'mousedown') {
            if (e.target.form) return true;
            var match = el.className.match(/highslide-(image|move|resize)/);
            if (match) {
                hs.dragArgs = {
                    exp: exp,
                    type: match[1],
                    left: exp.x.pos,
                    width: exp.x.size,
                    top: exp.y.pos,
                    height: exp.y.size,
                    clickX: e.clientX,
                    clickY: e.clientY
                };
                hs.addEventListener(document, 'mousemove', hs.dragHandler);
                if (e.preventDefault) e.preventDefault();
                if (/highslide-(image|html)-blur/.test(exp.content.className)) {
                    exp.focus();
                    hs.hasFocused = true
                }
                return false
            }
        } else if (e.type == 'mouseup') {
            hs.removeEventListener(document, 'mousemove', hs.dragHandler);
            if (hs.dragArgs) {
                if (hs.styleRestoreCursor && hs.dragArgs.type == 'image') hs.dragArgs.exp.content.style.cursor = hs.styleRestoreCursor;
                var hasDragged = hs.dragArgs.hasDragged;
                if (!hasDragged && !hs.hasFocused && !/(move|resize)/.test(hs.dragArgs.type)) {
                    exp.close()
                } else if (hasDragged || (!hasDragged && hs.hasHtmlExpanders)) {
                    hs.dragArgs.exp.doShowHide('hidden')
                }
                hs.hasFocused = false;
                hs.dragArgs = null
            } else if (/highslide-image-blur/.test(el.className)) {
                el.style.cursor = hs.styleRestoreCursor
            }
        }
        return false
    },
    dragHandler: function(e) {
        if (!hs.dragArgs) return true;
        if (!e) e = window.event;
        var a = hs.dragArgs,
        exp = a.exp;
        a.dX = e.clientX - a.clickX;
        a.dY = e.clientY - a.clickY;
        var distance = Math.sqrt(Math.pow(a.dX, 2) + Math.pow(a.dY, 2));
        if (!a.hasDragged) a.hasDragged = (a.type != 'image' && distance > 0) || (distance > (hs.dragSensitivity || 5));
        if (a.hasDragged && e.clientX > 5 && e.clientY > 5) {
            if (a.type == 'resize') exp.resize(a);
            else {
                exp.moveTo(a.left + a.dX, a.top + a.dY);
                if (a.type == 'image') exp.content.style.cursor = 'move'
            }
        }
        return false
    },
    wrapperMouseHandler: function(e) {
        try {
            if (!e) e = window.event;
            var over = /mouseover/i.test(e.type);
            if (!e.target) e.target = e.srcElement;
            if (hs.ie) e.relatedTarget = over ? e.fromElement: e.toElement;
            var exp = hs.getExpander(e.target);
            if (!exp.isExpanded) return;
            if (!exp || !e.relatedTarget || hs.getExpander(e.relatedTarget, true) == exp || hs.dragArgs) return;
            for (var i = 0; i < exp.overlays.length; i++) {
                var o = hs.$('hsId' + exp.overlays[i]);
                if (o && o.hideOnMouseOut) {
                    var from = over ? 0 : o.opacity,
                    to = over ? o.opacity: 0;
                    hs.fade(o, from, to)
                }
            }
        } catch(e) {}
    },
    addEventListener: function(el, event, func) {
        try {
            el.addEventListener(event, func, false)
        } catch(e) {
            try {
                el.detachEvent('on' + event, func);
                el.attachEvent('on' + event, func)
            } catch(e) {
                el['on' + event] = func
            }
        }
    },
    removeEventListener: function(el, event, func) {
        try {
            el.removeEventListener(event, func, false)
        } catch(e) {
            try {
                el.detachEvent('on' + event, func)
            } catch(e) {
                el['on' + event] = null
            }
        }
    },
    preloadFullImage: function(i) {
        if (hs.continuePreloading && hs.preloadTheseImages[i] && hs.preloadTheseImages[i] != 'undefined') {
            var img = document.createElement('img');
            img.onload = function() {
                img = null;
                hs.preloadFullImage(i + 1)
            };
            img.src = hs.preloadTheseImages[i]
        }
    },
    preloadImages: function(number) {
        if (number && typeof number != 'object') hs.numberOfImagesToPreload = number;
        var arr = hs.getAnchors();
        for (var i = 0; i < arr.images.length && i < hs.numberOfImagesToPreload; i++) {
            hs.push(hs.preloadTheseImages, hs.getSrc(arr.images[i]))
        }
        if (hs.outlineType) new hs.Outline(hs.outlineType,
        function() {
            hs.preloadFullImage(0)
        });
        else hs.preloadFullImage(0);
        if (hs.restoreCursor) var cur = hs.createElement('img', {
            src: hs.graphicsDir + hs.restoreCursor
        })
    },
    init: function() {
        if (!hs.container) {
            hs.container = hs.createElement('div', {
                className: 'highslide-container'
            },
            {
                position: 'absolute',
                left: 0,
                top: 0,
                width: '100%',
                zIndex: hs.zIndexCounter,
                direction: 'ltr'
            },
            document.body, true);
            hs.loading = hs.createElement('a', {
                className: 'highslide-loading',
                title: hs.lang.loadingTitle,
                innerHTML: hs.lang.loadingText,
                href: 'javascript:;'
            },
            {
                position: 'absolute',
                top: '-9999px',
                opacity: hs.loadingOpacity,
                zIndex: 1
            },
            hs.container);
            hs.garbageBin = hs.createElement('div', null, {
                display: 'none'
            },
            hs.container);
            Math.linearTween = function(t, b, c, d) {
                return c * t / d + b
            };
            Math.easeInQuad = function(t, b, c, d) {
                return c * (t /= d) * t + b
            };
            for (var x in hs.langDefaults) {
                if (typeof hs[x] != 'undefined') hs.lang[x] = hs[x];
                else if (typeof hs.lang[x] == 'undefined' && typeof hs.langDefaults[x] != 'undefined') hs.lang[x] = hs.langDefaults[x]
            }
            hs.hideSelects = (hs.ie && hs.ieVersion() < 7);
            hs.hideIframes = ((window.opera && navigator.appVersion < 9) || navigator.vendor == 'KDE' || (hs.ie && hs.ieVersion() < 5.5))
        }
    },
    domReady: function() {
        hs.isDomReady = true;
        if (hs.onDomReady) hs.onDomReady()
    },
    updateAnchors: function() {
        var el, els, all = [],
        images = [],
        groups = {},
        re;
        for (var i = 0; i < hs.openerTagNames.length; i++) {
            els = document.getElementsByTagName(hs.openerTagNames[i]);
            for (var j = 0; j < els.length; j++) {
                el = els[j];
                re = hs.isHsAnchor(el);
                if (re) {
                    hs.push(all, el);
                    if (re[0] == 'hs.expand') hs.push(images, el);
                    var g = hs.getParam(el, 'slideshowGroup') || 'none';
                    if (!groups[g]) groups[g] = [];
                    hs.push(groups[g], el)
                }
            }
        }
        hs.anchors = {
            all: all,
            groups: groups,
            images: images
        };
        return hs.anchors
    },
    getAnchors: function() {
        return hs.anchors || hs.updateAnchors()
    },
    fade: function(el, o, oFinal, dur, fn, i, dir) {
        if (typeof i == 'undefined') {
            if (typeof dur != 'number') dur = 250;
            if (dur < 25) {
                hs.setStyles(el, {
                    opacity: oFinal
                });
                if (fn) fn();
                return
            }
            i = hs.faders.length;
            dir = oFinal > o ? 1 : -1;
            var step = (25 / (dur - dur % 25)) * Math.abs(o - oFinal)
        }
        o = parseFloat(o);
        var skip = (el.fade === 0 || el.fade === false || (el.fade == 2 && hs.ie));
        el.style.visibility = ((skip ? oFinal: o) <= 0) ? 'hidden': 'visible';
        if (skip || o < 0 || (dir == 1 && o > oFinal)) {
            if (fn) fn();
            return
        }
        if (el.fading && el.fading.i != i) {
            clearTimeout(hs.faders[el.fading.i]);
            o = el.fading.o
        }
        el.fading = {
            i: i,
            o: o,
            step: (step || el.fading.step)
        };
        el.style.visibility = (o <= 0) ? 'hidden': 'visible';
        hs.setStyles(el, {
            opacity: o
        });
        hs.faders[i] = setTimeout(function() {
            hs.fade(el, o + el.fading.step * dir, oFinal, null, fn, i, dir)
        },
        25)
    },
    close: function(el) {
        var exp = hs.getExpander(el);
        if (exp) exp.close();
        return false
    }
};
hs.Outline = function(outlineType, onLoad) {
    this.onLoad = onLoad;
    this.outlineType = outlineType;
    var v = hs.ieVersion(),
    tr;
    this.hasAlphaImageLoader = hs.ie && v >= 5.5 && v < 7;
    if (!outlineType) {
        if (onLoad) onLoad();
        return
    }
    hs.init();
    this.table = hs.createElement('table', {
        cellSpacing: 0
    },
    {
        visibility: 'hidden',
        position: 'absolute',
        borderCollapse: 'collapse',
        width: 0
    },
    hs.container, true);
    var tbody = hs.createElement('tbody', null, null, this.table, 1);
    this.td = [];
    for (var i = 0; i <= 8; i++) {
        if (i % 3 == 0) tr = hs.createElement('tr', null, {
            height: 'auto'
        },
        tbody, true);
        this.td[i] = hs.createElement('td', null, null, tr, true);
        var style = i != 4 ? {
            lineHeight: 0,
            fontSize: 0
        }: {
            position: 'relative'
        };
        hs.setStyles(this.td[i], style)
    }
    this.td[4].className = outlineType + ' highslide-outline';
    this.preloadGraphic()
};
hs.Outline.prototype = {
    preloadGraphic: function() {
        var src = hs.graphicsDir + (hs.outlinesDir || "outlines/") + this.outlineType + ".png";
        var appendTo = hs.safari ? hs.container: null;
        this.graphic = hs.createElement('img', null, {
            position: 'absolute',
            top: '-9999px'
        },
        appendTo, true);
        var pThis = this;
        this.graphic.onload = function() {
            pThis.onGraphicLoad()
        };
        this.graphic.src = src
    },
    onGraphicLoad: function() {
        var o = this.offset = this.graphic.width / 4,
        pos = [[0, 0], [0, -4], [ - 2, 0], [0, -8], 0, [ - 2, -8], [0, -2], [0, -6], [ - 2, -2]],
        dim = {
            height: (2 * o) + 'px',
            width: (2 * o) + 'px'
        };
        for (var i = 0; i <= 8; i++) {
            if (pos[i]) {
                if (this.hasAlphaImageLoader) {
                    var w = (i == 1 || i == 7) ? '100%': this.graphic.width + 'px';
                    var div = hs.createElement('div', null, {
                        width: '100%',
                        height: '100%',
                        position: 'relative',
                        overflow: 'hidden'
                    },
                    this.td[i], true);
                    hs.createElement('div', null, {
                        filter: "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale, src='" + this.graphic.src + "')",
                        position: 'absolute',
                        width: w,
                        height: this.graphic.height + 'px',
                        left: (pos[i][0] * o) + 'px',
                        top: (pos[i][1] * o) + 'px'
                    },
                    div, true)
                } else {
                    hs.setStyles(this.td[i], {
                        background: 'url(' + this.graphic.src + ') ' + (pos[i][0] * o) + 'px ' + (pos[i][1] * o) + 'px'
                    })
                }
                if (window.opera && (i == 3 || i == 5)) hs.createElement('div', null, dim, this.td[i], true);
                hs.setStyles(this.td[i], dim)
            }
        }
        this.graphic = null;
        if (hs.pendingOutlines[this.outlineType]) hs.pendingOutlines[this.outlineType].destroy();
        hs.pendingOutlines[this.outlineType] = this;
        if (this.onLoad) this.onLoad()
    },
    setPosition: function(exp, pos, vis) {
        pos = pos || {
            x: exp.x.pos,
            y: exp.y.pos,
            w: exp.x.size + exp.x.p1 + exp.x.p2,
            h: exp.y.size + exp.y.p1 + exp.y.p2
        };
        if (vis) this.table.style.visibility = (pos.h >= 4 * this.offset) ? 'visible': 'hidden';
        hs.setStyles(this.table, {
            left: (pos.x - this.offset) + 'px',
            top: (pos.y - this.offset) + 'px',
            width: (pos.w + 2 * (exp.x.cb + this.offset)) + 'px'
        });
        pos.w += 2 * (exp.x.cb - this.offset);
        pos.h += +2 * (exp.y.cb - this.offset);
        hs.setStyles(this.td[4], {
            width: pos.w >= 0 ? pos.w + 'px': 0,
            height: pos.h >= 0 ? pos.h + 'px': 0
        });
        if (this.hasAlphaImageLoader) this.td[3].style.height = this.td[5].style.height = this.td[4].style.height
    },
    destroy: function(hide) {
        if (hide) this.table.style.visibility = 'hidden';
        else hs.discardElement(this.table)
    }
};
hs.Dimension = function(exp, dim) {
    this.exp = exp;
    this.dim = dim;
    this.ucwh = dim == 'x' ? 'Width': 'Height';
    this.wh = this.ucwh.toLowerCase();
    this.uclt = dim == 'x' ? 'Left': 'Top';
    this.lt = this.uclt.toLowerCase();
    this.ucrb = dim == 'x' ? 'Right': 'Bottom';
    this.rb = this.ucrb.toLowerCase();
    this.p1 = this.p2 = 0
};
hs.Dimension.prototype = {
    get: function(key) {
        switch (key) {
        case 'loadingPos':
            return this.tpos + this.tb + (this.t - hs.loading['offset' + this.ucwh]) / 2;
        case 'wsize':
            return this.size + 2 * this.cb + this.p1 + this.p2;
        case 'fitsize':
            return this.clientSize - this.marginMin - this.marginMax;
        case 'opos':
            return this.pos - (this.exp.outline ? this.exp.outline.offset: 0);
        case 'osize':
            return this.get('wsize') + (this.exp.outline ? 2 * this.exp.outline.offset: 0);
        case 'imgPad':
            return this.imgSize ? Math.round((this.size - this.imgSize) / 2) : 0
        }
    },
    calcBorders: function() {
        this.cb = (this.exp.content['offset' + this.ucwh] - this.t) / 2;
        this.marginMax = hs['margin' + this.ucrb] + 2 * this.cb
    },
    calcThumb: function() {
        this.t = this.exp.el[this.wh] ? parseInt(this.exp.el[this.wh]) : this.exp.el['offset' + this.ucwh];
        this.tpos = this.exp.tpos[this.dim];
        this.tb = (this.exp.el['offset' + this.ucwh] - this.t) / 2;
        if (this.tpos == 0) {
            this.tpos = (hs.page[this.wh] / 2) + hs.page['scroll' + this.uclt]
        }
    },
    calcExpanded: function() {
        var exp = this.exp;
        this.justify = 'auto';
        this.pos = this.tpos - this.cb + this.tb;
        this.size = Math.min(this.full, exp['max' + this.ucwh] || this.full);
        this.minSize = exp.allowSizeReduction ? Math.min(exp['min' + this.ucwh], this.full) : this.full;
        if (exp.useBox) {
            this.size = exp[this.wh];
            this.imgSize = this.full
        }
        if (this.dim == 'x' && hs.padToMinWidth) this.minSize = exp.minWidth;
        this.marginMin = hs['margin' + this.uclt];
        this.scroll = hs.page['scroll' + this.uclt];
        this.clientSize = hs.page[this.wh]
    },
    setSize: function(i) {
        var exp = this.exp;
        if (exp.isImage && (exp.useBox || hs.padToMinWidth)) {
            this.imgSize = i;
            this.size = Math.max(this.size, this.imgSize);
            exp.content.style[this.lt] = this.get('imgPad') + 'px'
        } else this.size = i;
        exp.content.style[this.wh] = i + 'px';
        exp.wrapper.style[this.wh] = this.get('wsize') + 'px';
        if (exp.outline) exp.outline.setPosition(exp);
        if (this.dim == 'x' && exp.overlayBox) exp.sizeOverlayBox(true)
    },
    setPos: function(i) {
        this.pos = i;
        this.exp.wrapper.style[this.lt] = i + 'px';
        if (this.exp.outline) this.exp.outline.setPosition(this.exp)
    }
};
hs.Expander = function(a, params, custom, contentType) {
    if (document.readyState && hs.ie && !hs.isDomReady) {
        hs.onDomReady = function() {
            new hs.Expander(a, params, custom, contentType)
        };
        return
    }
    this.a = a;
    this.custom = custom;
    this.contentType = contentType || 'image';
    this.isImage = !this.isHtml;
    hs.continuePreloading = false;
    this.overlays = [];
    hs.init();
    var key = this.key = hs.expanders.length;
    for (var i = 0; i < hs.overrides.length; i++) {
        var name = hs.overrides[i];
        this[name] = params && typeof params[name] != 'undefined' ? params[name] : hs[name]
    }
    if (!this.src) this.src = a.href;
    var el = (params && params.thumbnailId) ? hs.$(params.thumbnailId) : a;
    el = this.thumb = el.getElementsByTagName('img')[0] || el;
    this.thumbsUserSetId = el.id || a.id;
    for (var i = 0; i < hs.expanders.length; i++) {
        if (hs.expanders[i] && hs.expanders[i].a == a) {
            hs.expanders[i].focus();
            return false
        }
    }
    for (var i = 0; i < hs.expanders.length; i++) {
        if (hs.expanders[i] && hs.expanders[i].thumb != el && !hs.expanders[i].onLoadStarted) {
            hs.expanders[i].cancelLoading()
        }
    }
    hs.expanders[this.key] = this;
    if (!hs.allowMultipleInstances && !hs.upcoming) {
        if (hs.expanders[key - 1]) hs.expanders[key - 1].close();
        if (typeof hs.focusKey != 'undefined' && hs.expanders[hs.focusKey]) hs.expanders[hs.focusKey].close()
    }
    this.el = el;
    this.tpos = hs.getPosition(el);
    hs.page = hs.getPageSize();
    var x = this.x = new hs.Dimension(this, 'x');
    x.calcThumb();
    var y = this.y = new hs.Dimension(this, 'y');
    y.calcThumb();
    this.wrapper = hs.createElement('div', {
        id: 'highslide-wrapper-' + this.key,
        className: this.wrapperClassName
    },
    {
        visibility: 'hidden',
        position: 'absolute',
        zIndex: hs.zIndexCounter++
    },
    null, true);
    this.wrapper.onmouseover = this.wrapper.onmouseout = hs.wrapperMouseHandler;
    if (this.contentType == 'image' && this.outlineWhileAnimating == 2) this.outlineWhileAnimating = 0;
    if (!this.outlineType) {
        this[this.contentType + 'Create']()
    } else if (hs.pendingOutlines[this.outlineType]) {
        this.connectOutline();
        this[this.contentType + 'Create']()
    } else {
        this.showLoading();
        var exp = this;
        new hs.Outline(this.outlineType,
        function() {
            exp.connectOutline();
            exp[exp.contentType + 'Create']()
        })
    }
    return true
};
hs.Expander.prototype = {
    connectOutline: function() {
        var o = this.outline = hs.pendingOutlines[this.outlineType];
        o.table.style.zIndex = this.wrapper.style.zIndex;
        hs.pendingOutlines[this.outlineType] = null
    },
    showLoading: function() {
        if (this.onLoadStarted || this.loading) return;
        this.loading = hs.loading;
        var exp = this;
        this.loading.onclick = function() {
            exp.cancelLoading()
        };
        var exp = this,
        l = this.x.get('loadingPos') + 'px',
        t = this.y.get('loadingPos') + 'px';
        setTimeout(function() {
            if (exp.loading) hs.setStyles(exp.loading, {
                left: l,
                top: t,
                zIndex: hs.zIndexCounter++
            })
        },
        100)
    },
    imageCreate: function() {
        var exp = this;
        var img = document.createElement('img');
        this.content = img;
        img.onload = function() {
            if (hs.expanders[exp.key]) exp.contentLoaded()
        };
        if (hs.blockRightClick) img.oncontextmenu = function() {
            return false
        };
        img.className = 'highslide-image';
        hs.setStyles(img, {
            visibility: 'hidden',
            display: 'block',
            position: 'absolute',
            maxWidth: '9999px',
            zIndex: 3
        });
        img.title = hs.lang.restoreTitle;
        if (hs.safari) hs.container.appendChild(img);
        if (hs.ie && hs.flushImgSize) img.src = null;
        img.src = this.src;
        this.showLoading()
    },
    contentLoaded: function() {
        try {
            if (!this.content) return;
            this.content.onload = null;
            if (this.onLoadStarted) return;
            else this.onLoadStarted = true;
            var x = this.x,
            y = this.y;
            if (this.loading) {
                hs.setStyles(this.loading, {
                    top: '-9999px'
                });
                this.loading = null
            }
            hs.setStyles(this.wrapper, {
                left: x.tpos + 'px',
                top: y.tpos + 'px'
            });
            x.full = this.content.width;
            y.full = this.content.height;
            hs.setStyles(this.content, {
                width: this.x.t + 'px',
                height: this.y.t + 'px'
            });
            this.wrapper.appendChild(this.content);
            hs.container.appendChild(this.wrapper);
            x.calcBorders();
            y.calcBorders();
            this.getOverlays();
            var ratio = x.full / y.full;
            x.calcExpanded();
            this.justify(x);
            y.calcExpanded();
            this.justify(y);
            if (this.overlayBox) this.sizeOverlayBox(0, 1);
            if (this.allowSizeReduction) {
                this.correctRatio(ratio);
                if (this.isImage && this.x.full > (this.x.imgSize || this.x.size)) {
                    this.createFullExpand();
                    if (this.overlays.length == 1) this.sizeOverlayBox()
                }
            }
            this.show()
        } catch(e) {
            window.location.href = this.src
        }
    },
    justify: function(p, moveOnly) {
        var tgtArr, tgt = p.target,
        dim = p == this.x ? 'x': 'y';
        var hasMovedMin = false;
        var allowReduce = p.exp.allowSizeReduction;
        p.pos = Math.round(p.pos - ((p.get('wsize') - p.t) / 2));
        if (p.pos < p.scroll + p.marginMin) {
            p.pos = p.scroll + p.marginMin;
            hasMovedMin = true
        }
        if (!moveOnly && p.size < p.minSize) {
            p.size = p.minSize;
            allowReduce = false
        }
        if (p.pos + p.get('wsize') > p.scroll + p.clientSize - p.marginMax) {
            if (!moveOnly && hasMovedMin && allowReduce) {
                p.size = p.get('fitsize') - 2 * p.cb - p.p1 - p.p2
            } else if (p.get('wsize') < p.get('fitsize')) {
                p.pos = p.scroll + p.clientSize - p.marginMax - p.get('wsize')
            } else {
                p.pos = p.scroll + p.marginMin;
                if (!moveOnly && allowReduce) p.size = p.get('fitsize') - 2 * p.cb - p.p1 - p.p2
            }
        }
        if (!moveOnly && p.size < p.minSize) {
            p.size = p.minSize;
            allowReduce = false
        }
        if (p.pos < p.marginMin) {
            var tmpMin = p.pos;
            p.pos = p.marginMin;
            if (allowReduce && !moveOnly) p.size = p.size - (p.pos - tmpMin)
        }
    },
    correctRatio: function(ratio) {
        var x = this.x,
        y = this.y,
        changed = false,
        xSize = Math.min(x.full, x.size),
        ySize = Math.min(y.full, y.size),
        useBox = (this.useBox || hs.padToMinWidth);
        if (xSize / ySize > ratio) {
            xSize = ySize * ratio;
            if (xSize < x.minSize) {
                xSize = x.minSize;
                ySize = xSize / ratio
            }
            changed = true
        } else if (xSize / ySize < ratio) {
            ySize = xSize / ratio;
            changed = true
        }
        if (hs.padToMinWidth && x.full < x.minSize) {
            x.imgSize = x.full;
            y.size = y.imgSize = y.full
        } else if (this.useBox) {
            x.imgSize = xSize;
            y.imgSize = ySize
        } else {
            x.size = xSize;
            y.size = ySize
        }
        this.fitOverlayBox(useBox ? null: ratio);
        if (useBox && y.size < y.imgSize) {
            y.imgSize = y.size;
            x.imgSize = y.size * ratio
        }
        if (changed || useBox) {
            x.pos = x.tpos - x.cb + x.tb;
            x.minSize = x.size;
            this.justify(x, true);
            y.pos = y.tpos - y.cb + y.tb;
            y.minSize = y.size;
            this.justify(y, true);
            if (this.overlayBox) this.sizeOverlayBox()
        }
    },
    fitOverlayBox: function(ratio) {
        var x = this.x,
        y = this.y;
        if (this.overlayBox) {
            while (y.size > this.minHeight && x.size > this.minWidth && y.get('wsize') > y.get('fitsize')) {
                y.size -= 10;
                if (ratio) x.size = y.size * ratio;
                this.sizeOverlayBox(0, 1)
            }
        }
    },
    show: function() {
        this.doShowHide('hidden');
        this.changeSize(1, {
            xpos: this.x.tpos + this.x.tb - this.x.cb,
            ypos: this.y.tpos + this.y.tb - this.y.cb,
            xsize: this.x.t,
            ysize: this.y.t,
            xp1: 0,
            xp2: 0,
            yp1: 0,
            yp2: 0,
            ximgSize: this.x.t,
            ximgPad: 0,
            yimgSize: this.y.t,
            yimgPad: 0,
            o: hs.outlineStartOffset
        },
        {
            xpos: this.x.pos,
            ypos: this.y.pos,
            xsize: this.x.size,
            ysize: this.y.size,
            xp1: this.x.p1,
            yp1: this.y.p1,
            xp2: this.x.p2,
            yp2: this.y.p2,
            ximgSize: this.x.imgSize,
            ximgPad: this.x.get('imgPad'),
            yimgSize: this.y.imgSize,
            yimgPad: this.y.get('imgPad'),
            o: this.outline ? this.outline.offset: 0
        },
        hs.expandDuration)
    },
    changeSize: function(up, from, to, dur) {
        if (this.outline && !this.outlineWhileAnimating) {
            if (up) this.outline.setPosition(this);
            else this.outline.destroy()
        }
        if (!up && this.overlayBox) {
            hs.discardElement(this.overlayBox)
        }
        if (this.fadeInOut) {
            from.op = up ? 0 : 1;
            to.op = up
        }
        var t, exp = this,
        easing = Math[this.easing] || Math.easeInQuad,
        steps = (up ? hs.expandSteps: hs.restoreSteps) || parseInt(dur / 25) || 1;
        if (!up) easing = Math[this.easingClose] || easing;
        for (var i = 1; i <= steps; i++) {
            t = Math.round(i * (dur / steps)); (function() {
                var pI = i,
                size = {};
                for (var x in from) {
                    size[x] = easing(t, from[x], to[x] - from[x], dur);
                    if (isNaN(size[x])) size[x] = to[x];
                    if (!/^op$/.test(x)) size[x] = Math.round(size[x])
                }
                setTimeout(function() {
                    if (up && pI == 1) {
                        exp.content.style.visibility = 'visible';
                        exp.a.className += ' highslide-active-anchor'
                    }
                    exp.setSize(size)
                },
                t)
            })()
        }
        if (up) {
            setTimeout(function() {
                if (exp.outline) exp.outline.table.style.visibility = "visible"
            },
            t);
            setTimeout(function() {
                exp.afterExpand()
            },
            t + 50)
        } else setTimeout(function() {
            exp.afterClose()
        },
        t)
    },
    setSize: function(to) {
        try {
            if (to.op) hs.setStyles(this.wrapper, {
                opacity: to.op
            });
            hs.setStyles(this.wrapper, {
                width: (to.xsize + to.xp1 + to.xp2 + 2 * this.x.cb) + 'px',
                height: (to.ysize + to.yp1 + to.yp2 + 2 * this.y.cb) + 'px',
                left: to.xpos + 'px',
                top: to.ypos + 'px'
            });
            hs.setStyles(this.content, {
                left: (to.xp1 + to.ximgPad) + 'px',
                top: (to.yp1 + to.yimgPad) + 'px',
                width: (to.ximgSize || to.xsize) + 'px',
                height: (to.yimgSize || to.ysize) + 'px'
            });
            if (this.outline && this.outlineWhileAnimating) {
                var o = this.outline.offset - to.o;
                this.outline.setPosition(this, {
                    x: to.xpos + o,
                    y: to.ypos + o,
                    w: to.xsize + to.xp1 + to.xp2 + -2 * o,
                    h: to.ysize + to.yp1 + to.yp2 + -2 * o
                },
                1)
            }
            this.wrapper.style.visibility = 'visible'
        } catch(e) {
            window.location.href = this.src
        }
    },
    afterExpand: function() {
        this.isExpanded = true;
        this.focus();
        this.prepareNextOutline();
        var p = hs.page,
        mX = hs.mouse.x + p.scrollLeft,
        mY = hs.mouse.y + p.scrollTop;
        this.mouseIsOver = this.x.pos < mX && mX < this.x.pos + this.x.get('wsize') && this.y.pos < mY && mY < this.y.pos + this.y.get('wsize');
        if (this.overlayBox) this.showOverlays()
    },
    prepareNextOutline: function() {
        var key = this.key;
        var outlineType = this.outlineType;
        new hs.Outline(outlineType,
        function() {
            try {
                hs.expanders[key].preloadNext()
            } catch(e) {}
        })
    },
    preloadNext: function() {
        var next = this.getAdjacentAnchor(1);
        if (next && next.onclick.toString().match(/hs\.expand/)) var img = hs.createElement('img', {
            src: hs.getSrc(next)
        })
    },
    getAdjacentAnchor: function(op) {
        var current = this.getAnchorIndex(),
        as = hs.anchors.groups[this.slideshowGroup || 'none'];
        if (!as[current + op] && this.slideshow && this.slideshow.repeat) {
            if (op == 1) return as[0];
            else if (op == -1) return as[as.length - 1]
        }
        return as[current + op] || null
    },
    getAnchorIndex: function() {
        var arr = hs.anchors.groups[this.slideshowGroup || 'none'];
        for (var i = 0; i < arr.length; i++) {
            if (arr[i] == this.a) return i
        }
        return null
    },
    cancelLoading: function() {
        hs.expanders[this.key] = null;
        if (this.loading) hs.loading.style.left = '-9999px'
    },
    writeCredits: function() {
        this.credits = hs.createElement('a', {
            href: hs.creditsHref,
            className: 'highslide-credits',
            innerHTML: hs.lang.creditsText,
            title: hs.lang.creditsTitle
        });
        this.createOverlay({
            overlayId: this.credits,
            position: 'top left'
        })
    },
    getInline: function(types, addOverlay) {
        for (var i = 0; i < types.length; i++) {
            var type = types[i],
            s = null;
            if (!this[type + 'Id'] && this.thumbsUserSetId) this[type + 'Id'] = type + '-for-' + this.thumbsUserSetId;
            if (this[type + 'Id']) this[type] = hs.getNode(this[type + 'Id']);
            if (!this[type] && !this[type + 'Text'] && this[type + 'Eval']) try {
                s = eval(this[type + 'Eval'])
            } catch(e) {}
            if (!this[type] && this[type + 'Text']) {
                s = this[type + 'Text']
            }
            if (!this[type] && !s) {
                var next = this.a.nextSibling;
                while (next && !hs.isHsAnchor(next)) {
                    if ((new RegExp('highslide-' + type)).test(next.className || null)) {
                        this[type] = next.cloneNode(1);
                        break
                    }
                    next = next.nextSibling
                }
            }
            if (!this[type] && s) this[type] = hs.createElement('div', {
                className: 'highslide-' + type,
                innerHTML: s
            });
            if (addOverlay && this[type]) {
                var o = {
                    position: (type == 'heading') ? 'above': 'below'
                };
                for (var x in this[type + 'Overlay']) o[x] = this[type + 'Overlay'][x];
                o.overlayId = this[type];
                this.createOverlay(o)
            }
        }
    },
    doShowHide: function(visibility) {
        if (hs.hideSelects) this.showHideElements('SELECT', visibility);
        if (hs.hideIframes) this.showHideElements('IFRAME', visibility);
        if (hs.geckoMac) this.showHideElements('*', visibility)
    },
    showHideElements: function(tagName, visibility) {
        var els = document.getElementsByTagName(tagName);
        var prop = tagName == '*' ? 'overflow': 'visibility';
        for (var i = 0; i < els.length; i++) {
            if (prop == 'visibility' || (document.defaultView.getComputedStyle(els[i], "").getPropertyValue('overflow') == 'auto' || els[i].getAttribute('hidden-by') != null)) {
                var hiddenBy = els[i].getAttribute('hidden-by');
                if (visibility == 'visible' && hiddenBy) {
                    hiddenBy = hiddenBy.replace('[' + this.key + ']', '');
                    els[i].setAttribute('hidden-by', hiddenBy);
                    if (!hiddenBy) els[i].style[prop] = els[i].origProp
                } else if (visibility == 'hidden') {
                    var elPos = hs.getPosition(els[i]);
                    elPos.w = els[i].offsetWidth;
                    elPos.h = els[i].offsetHeight;
                    var clearsX = (elPos.x + elPos.w < this.x.get('opos') || elPos.x > this.x.get('opos') + this.x.get('osize'));
                    var clearsY = (elPos.y + elPos.h < this.y.get('opos') || elPos.y > this.y.get('opos') + this.y.get('osize'));
                    var wrapperKey = hs.getWrapperKey(els[i]);
                    if (!clearsX && !clearsY && wrapperKey != this.key) {
                        if (!hiddenBy) {
                            els[i].setAttribute('hidden-by', '[' + this.key + ']');
                            els[i].origProp = els[i].style[prop];
                            els[i].style[prop] = 'hidden'
                        } else if (hiddenBy.indexOf('[' + this.key + ']') == -1) {
                            els[i].setAttribute('hidden-by', hiddenBy + '[' + this.key + ']')
                        }
                    } else if ((hiddenBy == '[' + this.key + ']' || hs.focusKey == wrapperKey) && wrapperKey != this.key) {
                        els[i].setAttribute('hidden-by', '');
                        els[i].style[prop] = els[i].origProp || ''
                    } else if (hiddenBy && hiddenBy.indexOf('[' + this.key + ']') > -1) {
                        els[i].setAttribute('hidden-by', hiddenBy.replace('[' + this.key + ']', ''))
                    }
                }
            }
        }
    },
    focus: function() {
        this.wrapper.style.zIndex = hs.zIndexCounter++;
        for (var i = 0; i < hs.expanders.length; i++) {
            if (hs.expanders[i] && i == hs.focusKey) {
                var blurExp = hs.expanders[i];
                blurExp.content.className += ' highslide-' + blurExp.contentType + '-blur';
                blurExp.content.style.cursor = hs.ie ? 'hand': 'pointer';
                blurExp.content.title = hs.lang.focusTitle
            }
        }
        if (this.outline) this.outline.table.style.zIndex = this.wrapper.style.zIndex;
        this.content.className = 'highslide-' + this.contentType;
        this.content.title = hs.lang.restoreTitle;
        if (hs.restoreCursor) {
            hs.styleRestoreCursor = window.opera ? 'pointer': 'url(' + hs.graphicsDir + hs.restoreCursor + '), pointer';
            if (hs.ie && hs.ieVersion() < 6) hs.styleRestoreCursor = 'hand';
            this.content.style.cursor = hs.styleRestoreCursor
        }
        hs.focusKey = this.key;
        hs.addEventListener(document, window.opera ? 'keypress': 'keydown', hs.keyHandler)
    },
    moveTo: function(x, y) {
        this.x.setPos(x);
        this.y.setPos(y)
    },
    resize: function(e) {
        var w, h, r = e.width / e.height;
        w = Math.max(e.width + e.dX, Math.min(this.minWidth, this.x.full));
        if (this.isImage && Math.abs(w - this.x.full) < 12) w = this.x.full;
        h = w / r;
        if (h < Math.min(this.minHeight, this.y.full)) {
            h = Math.min(this.minHeight, this.y.full);
            if (this.isImage) w = h * r
        }
        this.resizeTo(w, h)
    },
    resizeTo: function(w, h) {
        this.y.setSize(h);
        this.x.setSize(w)
    },
    close: function() {
        if (this.isClosing || !this.isExpanded) return;
        this.isClosing = true;
        hs.removeEventListener(document, window.opera ? 'keypress': 'keydown', hs.keyHandler);
        try {
            this.content.style.cursor = 'default';
            this.changeSize(0, {
                xpos: this.x.pos,
                ypos: this.y.pos,
                xsize: this.x.size,
                ysize: this.y.size,
                xp1: this.x.p1,
                yp1: this.y.p1,
                xp2: this.x.p2,
                yp2: this.y.p2,
                ximgSize: this.x.imgSize,
                ximgPad: this.x.get('imgPad'),
                yimgSize: this.y.imgSize,
                yimgPad: this.y.get('imgPad'),
                o: this.outline ? this.outline.offset: 0
            },
            {
                xpos: this.x.tpos - this.x.cb + this.x.tb,
                ypos: this.y.tpos - this.y.cb + this.y.tb,
                xsize: this.x.t,
                ysize: this.y.t,
                xp1: 0,
                yp1: 0,
                xp2: 0,
                yp2: 0,
                ximgSize: this.x.imgSize ? this.x.t: null,
                ximgPad: 0,
                yimgSize: this.y.imgSize ? this.y.t: null,
                yimgPad: 0,
                o: hs.outlineStartOffset
            },
            hs.restoreDuration)
        } catch(e) {
            this.afterClose()
        }
    },
    createOverlay: function(o) {
        var el = o.overlayId;
        if (typeof el == 'string') el = hs.getNode(el);
        if (!el || typeof el == 'string') return;
        el.style.display = 'block';
        this.genOverlayBox();
        var width = o.width && /^[0-9]+(px|%)$/.test(o.width) ? o.width: 'auto';
        if (/^(left|right)panel$/.test(o.position) && !/^[0-9]+px$/.test(o.width)) width = '200px';
        var overlay = hs.createElement('div', {
            id: 'hsId' + hs.idCounter++,
            hsId: o.hsId
        },
        {
            position: 'absolute',
            visibility: 'hidden',
            width: width,
            direction: hs.lang.cssDirection || ''
        },
        this.overlayBox, true);
        overlay.appendChild(el);
        hs.setAttribs(overlay, {
            hideOnMouseOut: o.hideOnMouseOut,
            opacity: o.opacity || 1,
            hsPos: o.position,
            fade: o.fade
        });
        if (this.gotOverlays) {
            this.positionOverlay(overlay);
            if (!overlay.hideOnMouseOut || this.mouseIsOver) hs.fade(overlay, 0, overlay.opacity)
        }
        hs.push(this.overlays, hs.idCounter - 1)
    },
    positionOverlay: function(overlay) {
        var p = overlay.hsPos || 'middle center';
        if (/left$/.test(p)) overlay.style.left = 0;
        if (/center$/.test(p)) hs.setStyles(overlay, {
            left: '50%',
            marginLeft: '-' + Math.round(overlay.offsetWidth / 2) + 'px'
        });
        if (/right$/.test(p)) overlay.style.right = 0;
        if (/^leftpanel$/.test(p)) {
            hs.setStyles(overlay, {
                right: '100%',
                marginRight: this.x.cb + 'px',
                top: -this.y.cb + 'px',
                bottom: -this.y.cb + 'px',
                overflow: 'auto'
            });
            this.x.p1 = overlay.offsetWidth
        } else if (/^rightpanel$/.test(p)) {
            hs.setStyles(overlay, {
                left: '100%',
                marginLeft: this.x.cb + 'px',
                top: -this.y.cb + 'px',
                bottom: -this.y.cb + 'px',
                overflow: 'auto'
            });
            this.x.p2 = overlay.offsetWidth
        }
        if (/^top/.test(p)) overlay.style.top = 0;
        if (/^middle/.test(p)) hs.setStyles(overlay, {
            top: '50%',
            marginTop: '-' + Math.round(overlay.offsetHeight / 2) + 'px'
        });
        if (/^bottom/.test(p)) overlay.style.bottom = 0;
        if (/^above$/.test(p)) {
            hs.setStyles(overlay, {
                left: ( - this.x.p1 - this.x.cb) + 'px',
                right: ( - this.x.p2 - this.x.cb) + 'px',
                bottom: '100%',
                marginBottom: this.y.cb + 'px',
                width: 'auto'
            });
            this.y.p1 = overlay.offsetHeight
        } else if (/^below$/.test(p)) {
            hs.setStyles(overlay, {
                position: 'relative',
                left: ( - this.x.p1 - this.x.cb) + 'px',
                right: ( - this.x.p2 - this.x.cb) + 'px',
                top: '100%',

                marginTop: this.y.cb + 'px',
                width: 'auto'
            });
            this.y.p2 = overlay.offsetHeight;
            overlay.style.position = 'absolute'
        }
    },
    getOverlays: function() {
        this.getInline(['heading', 'caption'], true);
        if (this.heading && this.dragByHeading) this.heading.className += ' highslide-move';
        if (hs.showCredits) this.writeCredits();
        for (var i = 0; i < hs.overlays.length; i++) {
            var o = hs.overlays[i],
            tId = o.thumbnailId,
            sg = o.slideshowGroup;
            if ((!tId && !sg) || (tId && tId == this.thumbsUserSetId) || (sg && sg === this.slideshowGroup)) {
                this.createOverlay(o)
            }
        }
        var os = [];
        for (var i = 0; i < this.overlays.length; i++) {
            var o = hs.$('hsId' + this.overlays[i]);
            if (/panel$/.test(o.hsPos)) this.positionOverlay(o);
            else hs.push(os, o)
        }
        for (var i = 0; i < os.length; i++) this.positionOverlay(os[i]);
        this.gotOverlays = true
    },
    genOverlayBox: function() {
        if (!this.overlayBox) this.overlayBox = hs.createElement('div', {
            className: this.wrapperClassName
        },
        {
            position: 'absolute',
            width: this.x.size ? this.x.size + 'px': this.x.full + 'px',
            height: 0,
            visibility: 'hidden',
            overflow: 'hidden',
            zIndex: hs.ie ? 4 : null
        },
        hs.container, true)
    },
    sizeOverlayBox: function(doWrapper, doPanels) {
        hs.setStyles(this.overlayBox, {
            width: this.x.size + 'px',
            height: this.y.size + 'px'
        });
        if (doWrapper || doPanels) {
            for (var i = 0; i < this.overlays.length; i++) {
                var o = hs.$('hsId' + this.overlays[i]);
                var ie6 = (hs.ie && (hs.ieVersion() <= 6 || document.compatMode == 'BackCompat'));
                if (o && /^(above|below)$/.test(o.hsPos)) {
                    if (ie6) {
                        o.style.width = (this.overlayBox.offsetWidth + 2 * this.x.cb + this.x.p1 + this.x.p2) + 'px'
                    }
                    this.y[o.hsPos == 'above' ? 'p1': 'p2'] = o.offsetHeight
                }
                if (o && ie6 && /^(left|right)panel$/.test(o.hsPos)) {
                    o.style.height = (this.overlayBox.offsetHeight + 2 * this.y.cb + this.y.p1 + this.y.p2) + 'px'
                }
            }
        }
        if (doWrapper) {
            hs.setStyles(this.content, {
                top: this.y.p1 + 'px'
            });
            hs.setStyles(this.overlayBox, {
                top: (this.y.p1 + this.y.cb) + 'px'
            })
        }
    },
    showOverlays: function() {
        var b = this.overlayBox;
        b.className = '';
        hs.setStyles(b, {
            top: (this.y.p1 + this.y.cb) + 'px',
            left: (this.x.p1 + this.x.cb) + 'px',
            overflow: 'visible'
        });
        if (hs.safari) b.style.visibility = 'visible';
        this.wrapper.appendChild(b);
        for (var i = 0; i < this.overlays.length; i++) {
            var o = hs.$('hsId' + this.overlays[i]);
            o.style.zIndex = 4;
            if (!o.hideOnMouseOut || this.mouseIsOver) hs.fade(o, 0, o.opacity)
        }
    },
    createFullExpand: function() {
        this.fullExpandLabel = hs.createElement('a', {
            href: 'javascript:hs.expanders[' + this.key + '].doFullExpand();',
            title: hs.lang.fullExpandTitle,
            className: 'highslide-full-expand'
        });
        this.createOverlay({
            overlayId: this.fullExpandLabel,
            position: hs.fullExpandPosition,
            hideOnMouseOut: true,
            opacity: hs.fullExpandOpacity
        })
    },
    doFullExpand: function() {
        try {
            if (this.fullExpandLabel) hs.discardElement(this.fullExpandLabel);
            this.focus();
            var xSize = this.x.size;
            this.resizeTo(this.x.full, this.y.full);
            var xpos = this.x.pos - (this.x.size - xSize) / 2;
            if (xpos < hs.marginLeft) xpos = hs.marginLeft;
            this.moveTo(xpos, this.y.pos);
            this.doShowHide('hidden')
        } catch(e) {
            window.location.href = this.content.src
        }
    },
    afterClose: function() {
        this.a.className = this.a.className.replace('highslide-active-anchor', '');
        this.doShowHide('visible');
        if (this.outline && this.outlineWhileAnimating) this.outline.destroy();
        hs.discardElement(this.wrapper);
        hs.expanders[this.key] = null;
        hs.reOrder()
    }
};
if (document.readyState && hs.ie) { (function() {
        try {
            document.documentElement.doScroll('left')
        } catch(e) {
            setTimeout(arguments.callee, 50);
            return
        }
        hs.domReady()
    })()
}
hs.langDefaults = hs.lang;
var HsExpander = hs.Expander;
hs.addEventListener(window, 'load',
function() {
    if (hs.expandCursor) {
        var sel = '.highslide img',
        dec = 'cursor: url(' + hs.graphicsDir + hs.expandCursor + '), pointer !important;';
        var style = hs.createElement('style', {
            type: 'text/css'
        },
        null, document.getElementsByTagName('HEAD')[0]);
        if (!hs.ie) {
            style.appendChild(document.createTextNode(sel + " {" + dec + "}"))
        } else {
            var last = document.styleSheets[document.styleSheets.length - 1];
            if (typeof(last.addRule) == "object") last.addRule(sel, dec)
        }
    }
});
hs.addEventListener(document, 'mousemove',
function(e) {
    hs.mouse = {
        x: e.clientX,
        y: e.clientY
    }
});
hs.addEventListener(document, 'mousedown', hs.mouseClickHandler);
hs.addEventListener(document, 'mouseup', hs.mouseClickHandler);
hs.addEventListener(window, 'load', hs.preloadImages);



/* 
 * flowplayer.js 3.1.4. The Flowplayer API
 * 
 * Copyright 2009 Flowplayer Oy
 * 
 * This file is part of Flowplayer.
 * 
 * Flowplayer is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 * 
 * Flowplayer is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 * 
 * You should have received a copy of the GNU General Public License
 * along with Flowplayer.  If not, see <http://www.gnu.org/licenses/>.
 * 
 * Date: 2009-02-25 21:24:29 +0000 (Wed, 25 Feb 2009)
 * Revision: 166 
 */
(function() {
    function g(o) {
        console.log("$f.fireEvent", [].slice.call(o))
    }
    function k(q) {
        if (!q || typeof q != "object") {
            return q
        }
        var o = new q.constructor();
        for (var p in q) {
            if (q.hasOwnProperty(p)) {
                o[p] = k(q[p])
            }
        }
        return o
    }
    function m(t, q) {
        if (!t) {
            return
        }
        var o, p = 0,
        r = t.length;
        if (r === undefined) {
            for (o in t) {
                if (q.call(t[o], o, t[o]) === false) {
                    break
                }
            }
        } else {
            for (var s = t[0]; p < r && q.call(s, p, s) !== false; s = t[++p]) {}
        }
        return t
    }
    function c(o) {
        return document.getElementById(o)
    }
    function i(q, p, o) {
        if (typeof p != "object") {
            return q
        }
        if (q && p) {
            m(p,
            function(r, s) {
                if (!o || typeof s != "function") {
                    q[r] = s
                }
            })
        }
        return q
    }
    function n(s) {
        var q = s.indexOf(".");
        if (q != -1) {
            var p = s.substring(0, q) || "*";
            var o = s.substring(q + 1, s.length);
            var r = [];
            m(document.getElementsByTagName(p),
            function() {
                if (this.className && this.className.indexOf(o) != -1) {
                    r.push(this)
                }
            });
            return r
        }
    }
    function f(o) {
        o = o || window.event;
        if (o.preventDefault) {
            o.stopPropagation();
            o.preventDefault()
        } else {
            o.returnValue = false;
            o.cancelBubble = true
        }
        return false
    }
    function j(q, o, p) {
        q[o] = q[o] || [];
        q[o].push(p)
    }
    function e() {
        return "_" + ("" + Math.random()).substring(2, 10)
    }
    var h = function(t, r, s) {
        var q = this;
        var p = {};
        var u = {};
        q.index = r;
        if (typeof t == "string") {
            t = {
                url: t
            }
        }
        i(this, t, true);
        m(("Begin*,Start,Pause*,Resume*,Seek*,Stop*,Finish*,LastSecond,Update,BufferFull,BufferEmpty,BufferStop").split(","),
        function() {
            var v = "on" + this;
            if (v.indexOf("*") != -1) {
                v = v.substring(0, v.length - 1);
                var w = "onBefore" + v.substring(2);
                q[w] = function(x) {
                    j(u, w, x);
                    return q
                }
            }
            q[v] = function(x) {
                j(u, v, x);
                return q
            };
            if (r == -1) {
                if (q[w]) {
                    s[w] = q[w]
                }
                if (q[v]) {
                    s[v] = q[v]
                }
            }
        });
        i(this, {
            onCuepoint: function(x, w) {
                if (arguments.length == 1) {
                    p.embedded = [null, x];
                    return q
                }
                if (typeof x == "number") {
                    x = [x]
                }
                var v = e();
                p[v] = [x, w];
                if (s.isLoaded()) {
                    s._api().fp_addCuepoints(x, r, v)
                }
                return q
            },
            update: function(w) {
                i(q, w);
                if (s.isLoaded()) {
                    s._api().fp_updateClip(w, r)
                }
                var v = s.getConfig();
                var x = (r == -1) ? v.clip: v.playlist[r];
                i(x, w, true)
            },
            _fireEvent: function(v, y, w, A) {
                if (v == "onLoad") {
                    m(p,
                    function(B, C) {
                        if (C[0]) {
                            s._api().fp_addCuepoints(C[0], r, B)
                        }
                    });
                    return false
                }
                A = A || q;
                if (v == "onCuepoint") {
                    var z = p[y];
                    if (z) {
                        return z[1].call(s, A, w)
                    }
                }
                if (y && "onBeforeBegin,onMetaData,onStart,onUpdate,onResume".indexOf(v) != -1) {
                    i(A, y);
                    if (y.metaData) {
                        if (!A.duration) {
                            A.duration = y.metaData.duration
                        } else {
                            A.fullDuration = y.metaData.duration
                        }
                    }
                }
                var x = true;
                m(u[v],
                function() {
                    x = this.call(s, A, y, w)
                });
                return x
            }
        });
        if (t.onCuepoint) {
            var o = t.onCuepoint;
            q.onCuepoint.apply(q, typeof o == "function" ? [o] : o);
            delete t.onCuepoint
        }
        m(t,
        function(v, w) {
            if (typeof w == "function") {
                j(u, v, w);
                delete t[v]
            }
        });
        if (r == -1) {
            s.onCuepoint = this.onCuepoint
        }
    };
    var l = function(p, r, q, t) {
        var s = {};
        var o = this;
        var u = false;
        if (t) {
            i(s, t)
        }
        m(r,
        function(v, w) {
            if (typeof w == "function") {
                s[v] = w;
                delete r[v]
            }
        });
        i(this, {
            animate: function(y, z, x) {
                if (!y) {
                    return o
                }
                if (typeof z == "function") {
                    x = z;
                    z = 500
                }
                if (typeof y == "string") {
                    var w = y;
                    y = {};
                    y[w] = z;
                    z = 500
                }
                if (x) {
                    var v = e();
                    s[v] = x
                }
                if (z === undefined) {
                    z = 500
                }
                r = q._api().fp_animate(p, y, z, v);
                return o
            },
            css: function(w, x) {
                if (x !== undefined) {
                    var v = {};
                    v[w] = x;
                    w = v
                }
                r = q._api().fp_css(p, w);
                i(o, r);
                return o
            },
            show: function() {
                this.display = "block";
                q._api().fp_showPlugin(p);
                return o
            },
            hide: function() {
                this.display = "none";
                q._api().fp_hidePlugin(p);
                return o
            },
            toggle: function() {
                this.display = q._api().fp_togglePlugin(p);
                return o
            },
            fadeTo: function(y, x, w) {
                if (typeof x == "function") {
                    w = x;
                    x = 500
                }
                if (w) {
                    var v = e();
                    s[v] = w
                }
                this.display = q._api().fp_fadeTo(p, y, x, v);
                this.opacity = y;
                return o
            },
            fadeIn: function(w, v) {
                return o.fadeTo(1, w, v)
            },
            fadeOut: function(w, v) {
                return o.fadeTo(0, w, v)
            },
            getName: function() {
                return p
            },
            getPlayer: function() {
                return q
            },
            _fireEvent: function(w, v, x) {
                if (w == "onUpdate") {
                    var y = q._api().fp_getPlugin(p);
                    if (!y) {
                        return
                    }
                    i(o, y);
                    delete o.methods;
                    if (!u) {
                        m(y.methods,
                        function() {
                            var A = "" + this;
                            o[A] = function() {
                                var B = [].slice.call(arguments);
                                var C = q._api().fp_invoke(p, A, B);
                                return C === "undefined" || C === undefined ? o: C
                            }
                        });
                        u = true
                    }
                }
                var z = s[w];
                if (z) {
                    z.apply(o, v);
                    if (w.substring(0, 1) == "_") {
                        delete s[w]
                    }
                }
            }
        })
    };
    function b(o, t, z) {
        var E = this,
        y = null,
        x, u, p = [],
        s = {},
        B = {},
        r,
        v,
        w,
        D,
        A,
        q;
        i(E, {
            id: function() {
                return r
            },
            isLoaded: function() {
                return (y !== null)
            },
            getParent: function() {
                return o
            },
            hide: function(F) {
                if (F) {
                    o.style.height = "0px"
                }
                if (y) {
                    y.style.height = "0px"
                }
                return E
            },
            show: function() {
                o.style.height = q + "px";
                if (y) {
                    y.style.height = A + "px"
                }
                return E
            },
            isHidden: function() {
                return y && parseInt(y.style.height, 10) === 0
            },
            load: function(F) {
                if (!y && E._fireEvent("onBeforeLoad") !== false) {
                    m(a,
                    function() {
                        this.unload()
                    });
                    x = o.innerHTML;
                    if (x && !flashembed.isSupported(t.version)) {
                        o.innerHTML = ""
                    }
                    flashembed(o, t, {
                        config: z
                    });
                    if (F) {
                        F.cached = true;
                        j(B, "onLoad", F)
                    }
                }
                return E
            },
            unload: function() {
                if (x.replace(/\s/g, "") !== "") {
                    if (E._fireEvent("onBeforeUnload") === false) {
                        return E
                    }
                    try {
                        if (y) {
                            y.fp_close();
                            E._fireEvent("onUnload")
                        }
                    } catch(F) {}
                    y = null;
                    o.innerHTML = x
                }
                return E
            },
            getClip: function(F) {
                if (F === undefined) {
                    F = D
                }
                return p[F]
            },
            getCommonClip: function() {
                return u
            },
            getPlaylist: function() {
                return p
            },
            getPlugin: function(F) {
                var H = s[F];
                if (!H && E.isLoaded()) {
                    var G = E._api().fp_getPlugin(F);
                    if (G) {
                        H = new l(F, G, E);
                        s[F] = H
                    }
                }
                return H
            },
            getScreen: function() {
                return E.getPlugin("screen")
            },
            getControls: function() {
                return E.getPlugin("controls")
            },
            getConfig: function(F) {
                return F ? k(z) : z
            },
            getFlashParams: function() {
                return t
            },
            loadPlugin: function(I, H, K, J) {
                if (typeof K == "function") {
                    J = K;
                    K = {}
                }
                var G = J ? e() : "_";
                E._api().fp_loadPlugin(I, H, K, G);
                var F = {};
                F[G] = J;
                var L = new l(I, null, E, F);
                s[I] = L;
                return L
            },
            getState: function() {
                return y ? y.fp_getState() : -1
            },
            play: function(G, F) {
                function H() {
                    if (G !== undefined) {
                        E._api().fp_play(G, F)
                    } else {
                        E._api().fp_play()
                    }
                }
                if (y) {
                    H()
                } else {
                    E.load(function() {
                        H()
                    })
                }
                return E
            },
            getVersion: function() {
                var G = "flowplayer.js 3.1.4";
                if (y) {
                    var F = y.fp_getVersion();
                    F.push(G);
                    return F
                }
                return G
            },
            _api: function() {
                if (!y) {
                    throw "Flowplayer " + E.id() + " not loaded when calling an API method"
                }
                return y
            },
            setClip: function(F) {
                E.setPlaylist([F]);
                return E
            },
            getIndex: function() {
                return w
            }
        });
        m(("Click*,Load*,Unload*,Keypress*,Volume*,Mute*,Unmute*,PlaylistReplace,ClipAdd,Fullscreen*,FullscreenExit,Error,MouseOver,MouseOut").split(","),
        function() {
            var F = "on" + this;
            if (F.indexOf("*") != -1) {
                F = F.substring(0, F.length - 1);
                var G = "onBefore" + F.substring(2);
                E[G] = function(H) {
                    j(B, G, H);
                    return E
                }
            }
            E[F] = function(H) {
                j(B, F, H);
                return E
            }
        });
        m(("pause,resume,mute,unmute,stop,toggle,seek,getStatus,getVolume,setVolume,getTime,isPaused,isPlaying,startBuffering,stopBuffering,isFullscreen,toggleFullscreen,reset,close,setPlaylist,addClip,playFeed").split(","),
        function() {
            var F = this;
            E[F] = function(H, G) {
                if (!y) {
                    return E
                }
                var I = null;
                if (H !== undefined && G !== undefined) {
                    I = y["fp_" + F](H, G)
                } else {
                    I = (H === undefined) ? y["fp_" + F]() : y["fp_" + F](H)
                }
                return I === "undefined" || I === undefined ? E: I
            }
        });
        E._fireEvent = function(O) {
            if (typeof O == "string") {
                O = [O]
            }
            var P = O[0],
            M = O[1],
            K = O[2],
            J = O[3],
            I = 0;
            if (z.debug) {
                g(O)
            }
            if (!y && P == "onLoad" && M == "player") {
                y = y || c(v);
                A = y.clientHeight;
                m(p,
                function() {
                    this._fireEvent("onLoad")
                });
                m(s,
                function(Q, R) {
                    R._fireEvent("onUpdate")
                });
                u._fireEvent("onLoad")
            }
            if (P == "onLoad" && M != "player") {
                return
            }
            if (P == "onError") {
                if (typeof M == "string" || (typeof M == "number" && typeof K == "number")) {
                    M = K;
                    K = J
                }
            }
            if (P == "onContextMenu") {
                m(z.contextMenu[M],
                function(Q, R) {
                    R.call(E)
                });
                return
            }
            if (P == "onPluginEvent") {
                var F = M.name || M;
                var G = s[F];
                if (G) {
                    G._fireEvent("onUpdate", M);
                    G._fireEvent(K, O.slice(3))
                }
                return
            }
            if (P == "onPlaylistReplace") {
                p = [];
                var L = 0;
                m(M,
                function() {
                    p.push(new h(this, L++, E))
                })
            }
            if (P == "onClipAdd") {
                if (M.isInStream) {
                    return
                }
                M = new h(M, K, E);
                p.splice(K, 0, M);
                for (I = K + 1; I < p.length; I++) {
                    p[I].index++
                }
            }
            var N = true;
            if (typeof M == "number" && M < p.length) {
                D = M;
                var H = p[M];
                if (H) {
                    N = H._fireEvent(P, K, J)
                }
                if (!H || N !== false) {
                    N = u._fireEvent(P, K, J, H)
                }
            }
            m(B[P],
            function() {
                N = this.call(E, M, K);
                if (this.cached) {
                    B[P].splice(I, 1)
                }
                if (N === false) {
                    return false
                }
                I++
            });
            return N
        };
        function C() {
            if ($f(o)) {
                $f(o).getParent().innerHTML = "";
                w = $f(o).getIndex();
                a[w] = E
            } else {
                a.push(E);
                w = a.length - 1
            }
            q = parseInt(o.style.height, 10) || o.clientHeight;
            if (typeof t == "string") {
                t = {
                    src: t
                }
            }
            r = o.id || "fp" + e();
            v = t.id || r + "_api";
            t.id = v;
            z.playerId = r;
            if (typeof z == "string") {
                z = {
                    clip: {
                        url: z
                    }
                }
            }
            if (typeof z.clip == "string") {
                z.clip = {
                    url: z.clip
                }
            }
            z.clip = z.clip || {};
            if (o.getAttribute("href", 2) && !z.clip.url) {
                z.clip.url = o.getAttribute("href", 2)
            }
            u = new h(z.clip, -1, E);
            z.playlist = z.playlist || [z.clip];
            var F = 0;
            m(z.playlist,
            function() {
                var H = this;
                if (typeof H == "object" && H.length) {
                    H = {
                        url: "" + H
                    }
                }
                m(z.clip,
                function(I, J) {
                    if (J !== undefined && H[I] === undefined && typeof J != "function") {
                        H[I] = J
                    }
                });
                z.playlist[F] = H;
                H = new h(H, F, E);
                p.push(H);
                F++
            });
            m(z,
            function(H, I) {
                if (typeof I == "function") {
                    if (u[H]) {
                        u[H](I)
                    } else {
                        j(B, H, I)
                    }
                    delete z[H]
                }
            });
            m(z.plugins,
            function(H, I) {
                if (I) {
                    s[H] = new l(H, I, E)
                }
            });
            if (!z.plugins || z.plugins.controls === undefined) {
                s.controls = new l("controls", null, E)
            }
            s.canvas = new l("canvas", null, E);
            t.bgcolor = t.bgcolor || "#000000";
            t.version = t.version || [9, 0];
            t.expressInstall = "http://www.flowplayer.org/swf/expressinstall.swf";
            function G(H) {
                if (!E.isLoaded() && E._fireEvent("onBeforeClick") !== false) {
                    E.load()
                }
                return f(H)
            }
            x = o.innerHTML;
            if (x.replace(/\s/g, "") !== "") {
                if (o.addEventListener) {
                    o.addEventListener("click", G, false)
                } else {
                    if (o.attachEvent) {
                        o.attachEvent("onclick", G)
                    }
                }
            } else {
                if (o.addEventListener) {
                    o.addEventListener("click", f, false)
                }
                E.load()
            }
        }
        if (typeof o == "string") {
            flashembed.domReady(function() {
                var F = c(o);
                if (!F) {
                    throw "Flowplayer cannot access element: " + o
                } else {
                    o = F;
                    C()
                }
            })
        } else {
            C()
        }
    }
    var a = [];
    function d(o) {
        this.length = o.length;
        this.each = function(p) {
            m(o, p)
        };
        this.size = function() {
            return o.length
        }
    }
    window.flowplayer = window.$f = function() {
        var p = null;
        var o = arguments[0];
        if (!arguments.length) {
            m(a,
            function() {
                if (this.isLoaded()) {
                    p = this;
                    return false
                }
            });
            return p || a[0]
        }
        if (arguments.length == 1) {
            if (typeof o == "number") {
                return a[o]
            } else {
                if (o == "*") {
                    return new d(a)
                }
                m(a,
                function() {
                    if (this.id() == o.id || this.id() == o || this.getParent() == o) {
                        p = this;
                        return false
                    }
                });
                return p
            }
        }
        if (arguments.length > 1) {
            var r = arguments[1];
            var q = (arguments.length == 3) ? arguments[2] : {};
            if (typeof o == "string") {
                if (o.indexOf(".") != -1) {
                    var t = [];
                    m(n(o),
                    function() {
                        t.push(new b(this, k(r), k(q)))
                    });
                    return new d(t)
                } else {
                    var s = c(o);
                    return new b(s !== null ? s: o, r, q)
                }
            } else {
                if (o) {
                    return new b(o, r, q)
                }
            }
        }
        return null
    };
    i(window.$f, {
        fireEvent: function() {
            var o = [].slice.call(arguments);
            var q = $f(o[0]);
            return q ? q._fireEvent(o.slice(1)) : null
        },
        addPlugin: function(o, p) {
            b.prototype[o] = p;
            return $f
        },
        each: m,
        extend: i
    });
    if (typeof jQuery == "function") {
        jQuery.prototype.flowplayer = function(q, p) {
            if (!arguments.length || typeof arguments[0] == "number") {
                var o = [];
                this.each(function() {
                    var r = $f(this);
                    if (r) {
                        o.push(r)
                    }
                });
                return arguments.length ? o[arguments[0]] : new d(o)
            }
            return this.each(function() {
                $f(this, k(q), p ? k(p) : {})
            })
        }
    }
})(); (function() {
    var e = typeof jQuery == "function";
    var i = {
        width: "100%",
        height: "100%",
        allowfullscreen: true,
        allowscriptaccess: "always",
        quality: "high",
        version: null,
        onFail: null,
        expressInstall: null,
        w3c: false,
        cachebusting: false
    };
    if (e) {
        jQuery.tools = jQuery.tools || {};
        jQuery.tools.flashembed = {
            version: "1.0.4",
            conf: i
        }
    }
    function j() {
        if (c.done) {
            return false
        }
        var l = document;
        if (l && l.getElementsByTagName && l.getElementById && l.body) {
            clearInterval(c.timer);
            c.timer = null;
            for (var k = 0; k < c.ready.length; k++) {
                c.ready[k].call()
            }
            c.ready = null;
            c.done = true
        }
    }
    var c = e ? jQuery: function(k) {
        if (c.done) {
            return k()
        }
        if (c.timer) {
            c.ready.push(k)
        } else {
            c.ready = [k];
            c.timer = setInterval(j, 13)
        }
    };
    function f(l, k) {
        if (k) {
            for (key in k) {
                if (k.hasOwnProperty(key)) {
                    l[key] = k[key]
                }
            }
        }
        return l
    }
    function g(k) {
        switch (h(k)) {
        case "string":
            k = k.replace(new RegExp('(["\\\\])', "g"), "\\$1");
            k = k.replace(/^\s?(\d+)%/, "$1pct");
            return '"' + k + '"';
        case "array":
            return "[" + b(k,
            function(n) {
                return g(n)
            }).join(",") + "]";
        case "function":
            return '"function()"';
        case "object":
            var l = [];
            for (var m in k) {
                if (k.hasOwnProperty(m)) {
                    l.push('"' + m + '":' + g(k[m]))
                }
            }
            return "{" + l.join(",") + "}"
        }
        return String(k).replace(/\s/g, " ").replace(/\'/g, '"')
    }
    function h(l) {
        if (l === null || l === undefined) {
            return false
        }
        var k = typeof l;
        return (k == "object" && l.push) ? "array": k
    }
    if (window.attachEvent) {
        window.attachEvent("onbeforeunload",
        function() {
            __flash_unloadHandler = function() {};
            __flash_savedUnloadHandler = function() {}
        })
    }
    function b(k, n) {
        var m = [];
        for (var l in k) {
            if (k.hasOwnProperty(l)) {
                m[l] = n(k[l])
            }
        }
        return m
    }
    function a(r, t) {
        var q = f({},
        r);
        var s = document.all;
        var n = '<object width="' + q.width + '" height="' + q.height + '"';
        if (s && !q.id) {
            q.id = "_" + ("" + Math.random()).substring(9)
        }
        if (q.id) {
            n += ' id="' + q.id + '"'
        }
        if (q.cachebusting) {
            q.src += ((q.src.indexOf("?") != -1 ? "&": "?") + Math.random())
        }
        if (q.w3c || !s) {
            n += ' data="' + q.src + '" type="application/x-shockwave-flash"'
        } else {
            n += ' classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"'
        }
        n += ">";
        if (q.w3c || s) {
            n += '<param name="movie" value="' + q.src + '" />'
        }
        q.width = q.height = q.id = q.w3c = q.src = null;
        for (var l in q) {
            if (q[l] !== null) {
                n += '<param name="' + l + '" value="' + q[l] + '" />'
            }
        }
        var o = "";
        if (t) {
            for (var m in t) {
                if (t[m] !== null) {
                    o += m + "=" + (typeof t[m] == "object" ? g(t[m]) : t[m]) + "&"
                }
            }
            o = o.substring(0, o.length - 1);
            n += '<param name="flashvars" value=\'' + o + "' />"
        }
        n += "</object>";
        return n
    }
    function d(m, p, l) {
        var k = flashembed.getVersion();
        f(this, {
            getContainer: function() {
                return m
            },
            getConf: function() {
                return p
            },
            getVersion: function() {
                return k
            },
            getFlashvars: function() {
                return l
            },
            getApi: function() {
                return m.firstChild
            },
            getHTML: function() {
                return a(p, l)
            }
        });
        var q = p.version;
        var r = p.expressInstall;
        var o = !q || flashembed.isSupported(q);
        if (o) {
            p.onFail = p.version = p.expressInstall = null;
            m.innerHTML = a(p, l)
        } else {
            if (q && r && flashembed.isSupported([6, 65])) {
                f(p, {
                    src: r
                });
                l = {
                    MMredirectURL: location.href,
                    MMplayerType: "PlugIn",
                    MMdoctitle: document.title
                };
                m.innerHTML = a(p, l)
            } else {
                if (m.innerHTML.replace(/\s/g, "") !== "") {} else {
                    m.innerHTML = "<h2>Flash version " + q + " or greater is required</h2><h3>" + (k[0] > 0 ? "Your version is " + k: "You have no flash plugin installed") + "</h3>" + (m.tagName == "A" ? "<p>Click here to download latest version</p>": "<p>Download latest version from <a href='http://www.adobe.com/go/getflashplayer'>here</a></p>");
                    if (m.tagName == "A") {
                        m.onclick = function() {
                            location.href = "http://www.adobe.com/go/getflashplayer"
                        }
                    }
                }
            }
        }
        if (!o && p.onFail) {
            var n = p.onFail.call(this);
            if (typeof n == "string") {
                m.innerHTML = n
            }
        }
        if (document.all) {
            window[p.id] = document.getElementById(p.id)
        }
    }
    window.flashembed = function(l, m, k) {
        if (typeof l == "string") {
            var n = document.getElementById(l);
            if (n) {
                l = n
            } else {
                c(function() {
                    flashembed(l, m, k)
                });
                return
            }
        }
        if (!l) {
            return
        }
        if (typeof m == "string") {
            m = {
                src: m
            }
        }
        var o = f({},
        i);
        f(o, m);
        return new d(l, o, k)
    };
    f(window.flashembed, {
        getVersion: function() {
            var m = [0, 0];
            if (navigator.plugins && typeof navigator.plugins["Shockwave Flash"] == "object") {
                var l = navigator.plugins["Shockwave Flash"].description;
                if (typeof l != "undefined") {
                    l = l.replace(/^.*\s+(\S+\s+\S+$)/, "$1");
                    var n = parseInt(l.replace(/^(.*)\..*$/, "$1"), 10);
                    var r = /r/.test(l) ? parseInt(l.replace(/^.*r(.*)$/, "$1"), 10) : 0;
                    m = [n, r]
                }
            } else {
                if (window.ActiveXObject) {
                    try {
                        var p = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.7")
                    } catch(q) {
                        try {
                            p = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.6");
                            m = [6, 0];
                            p.AllowScriptAccess = "always"
                        } catch(k) {
                            if (m[0] == 6) {
                                return m
                            }
                        }
                        try {
                            p = new ActiveXObject("ShockwaveFlash.ShockwaveFlash")
                        } catch(o) {}
                    }
                    if (typeof p == "object") {
                        l = p.GetVariable("$version");
                        if (typeof l != "undefined") {
                            l = l.replace(/^\S+\s+(.*)$/, "$1").split(",");
                            m = [parseInt(l[0], 10), parseInt(l[2], 10)]
                        }
                    }
                }
            }
            return m
        },
        isSupported: function(k) {
            var m = flashembed.getVersion();
            var l = (m[0] > k[0]) || (m[0] == k[0] && m[1] >= k[1]);
            return l
        },
        domReady: c,
        asString: g,
        getHTML: a
    });
    if (e) {
        jQuery.fn.flashembed = function(l, k) {
            var m = null;
            this.each(function() {
                m = flashembed(this, l, k)
            });
            return l.api === false ? this: m
        }
    }
})();


function createCookie(name,value,days)
{        
	if (days)
	{
		var date = new Date();
		date.setTime(date.getTime()+(days*24*60*60*1000));
		var expires = "; expires="+date.toGMTString();
	}
	else var expires = "";
	document.cookie = name+"="+encodeURIComponent(value)+expires+"; path=/";
}

function readCookie(name)
{
	var nameEQ = name + "=";
	var ca = document.cookie.split(';');
	for(var i=0;i < ca.length;i++)
	{
		var c = ca[i];
		while (c.charAt(0)==' ') c = c.substring(1,c.length);
		if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length,c.length);
	}
	return null;
}

function eraseCookie(name)
{
	createCookie(name,"",-1);
}



var widgets = {
    // Add a product to the shop cart
    addToCart: function(shop_id, product_id, price, obj) {
        var amount = 1;
		
        // Cast
        product_id 	= Number(product_id);
        price		= Number(price);
		
		// Input is valid?
        if (!isNaN(shop_id)&&(shop_id>0)&&!isNaN(product_id)&&(product_id>0)&&!isNaN(price)&&!isNaN(amount)&&(amount>0)) {      
            // Temporary variables
            var cart_new = "", cart_item_split, found = false, total_amount = 0, ta, e;
		  
            // Read cookies	
            var total = readCookie('CART_TOTAL_'+shop_id);
            var cart = unescape(readCookie('CART_'+shop_id));
          
            // Split cart cookie into product_id=amount chunks
            var cart_split = cart.split(';');
          
            // Ensure total is of number data type 
            if (isNaN(total)) total = Number(total);
		  
            // Loop though cart item chunks	
            for (var i=0; i < cart_split.length; i++){
                // Split chunk into product_id and amount
                cart_item_split = cart_split[i].split("=");
			 
                // Valid chunk?
                if (cart_item_split.length == 2){
                    if (!found && cart_item_split[0] == product_id) {			// Already have such product in the cart?
                        total = Number(total) + price * amount;
                        ta = amount + Number(cart_item_split[1]);
                        found = true;

                        if (cart_new!="") cart_new = cart_new + ";";                     
                        cart_new = cart_new + product_id + "=" + ta;
                     
                        // Update total amount
                        total_amount += ta;
                    } else {													// This is another product_id. So keep it without modifications
                        if (cart_new!="") cart_new = cart_new + ";";                     
                        cart_new = cart_new + cart_item_split[0] + "=" + cart_item_split[1];
                     
                        // Update total amount
                        total_amount += Number(cart_item_split[1]);
                    }
                } // ## if valid chunk
            } // ## for
		  
            // The product_id is not found in the cart	
            if (!found) {
                if (cart_new!="") cart_new = cart_new + ";";                     
                cart_new = cart_new + product_id + "=" + amount;
                total = Number(total) + price * amount; 
                
                // Update total amount
                total_amount += amount;
            }    
          
            // Round total price           
            total = Math.round(total*100)/100;           
          
            // Write cookies          
            createCookie('CART_'+shop_id,cart_new,10); 
            createCookie('CART_TOTAL_'+shop_id,total,10);
            createCookie('CART_TOTAL_AMOUNT_'+shop_id,total_amount,10);
		  
            // Update DOM nodes
            e = document.getElementById('cart_total'); 	 
            if (e) e.innerHTML = total;
            e = document.getElementById('cart_total_amount'); 	 
            if (e) e.innerHTML = total_amount;
		    
		    // Show 'added' message
            var pos = findPos(obj);
            var d = document.createElement("DIV");
	        if (d) {
	            d.style.position = 'absolute';
                d.innerHTML = 'добавлено...';
                d.style.display = 'block';
                d.className = 'added-to-cart';
                d.style.left = (pos.x+obj.offsetWidth) + 'px';
                d.style.top = (pos.y+obj.offsetHeight) + 'px';
                document.body.appendChild(d);

                window.setTimeout(function(){
                    if (d&&d.parentNode)d.parentNode.removeChild(d); delete d;
                },1500);
		    }	
            
            // Success
            return true;  
        } // if ## input variables are valid
		
		// Failure
        return false;     
   },	// ## addToCart
   
   /**
   * Format price
   * @param str Mixed
   * @param ts String Thousands separator
   * @param dot String Dot symbol
   */ 
   formatPrice : function(str, ts, dot){
   		if(typeof str!='string') str = String(str);
   		if(ts==null) ts = ' ';
   		if(dot==null) dot = '.';
   		
   		var parts = str.split(dot), res = [], i;
		
		if (parts[0].length >= 4) {
		    for (i = (parts[0].length - 1), j=1; i>=0; --i, ++j) {
		        res.unshift(parts[0].charAt(i));
		        if (j % 3 == 0 && i>0)
		            res.unshift(ts);
		    }
		    
		    return res.join('') + (parts[1] ? dot + parts[1] : '');
		}
		return str;
	} // ## formatPrice()
}

function findPos(obj){
    var result = {};

    result.x = 0;
    result.y = 0;

    if (obj.offsetParent) {
		
        while (obj.offsetParent) {
            result.y += obj.offsetTop;
            result.x += obj.offsetLeft;
            obj = obj.offsetParent;
        }
			
    } else {
        if (obj.x) result.x += obj.x;
        if (obj.y) result.y += obj.y;
    }

    return result;

}

var A_TCALDEF = {
    'months': ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'],
    'weekdays': ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'],
    'yearscroll': true,
    'weekstart': 0,
    'centyear': 70,
    'imgpath': '/my/s3/images/calendar/'
};
var RU_TCALDEF = {
    'months': ['Январь', 'Февраль', 'Март', 'Апрель', 'Май', 'Июнь', 'Июль', 'Август', 'Сентябрь', 'Октябрь', 'Ноябрь', 'Декабрь'],
    'weekdays': ['Вс', 'Пн', 'Вт', 'Ср', 'Чт', 'Пт', 'Сб'],
    'yearscroll': true,
    'weekstart': 1,
    'centyear': 70,
    'imgpath': '/my/s3/images/calendar/'
};
function f_tcalParseDate(s_date) {
    var re_date = /^\s*(\d{1,2})\.(\d{1,2})\.(\d{2,4})\s*$/;
    if (!re_date.exec(s_date)) return alert("Invalid date: '" + s_date + "'.\nAccepted format is mm/dd/yyyy.");
    var n_day = Number(RegExp.$1),
    n_month = Number(RegExp.$2),
    n_year = Number(RegExp.$3);
    if (n_year < 100) n_year += (n_year < this.a_tpl.centyear ? 2000 : 1900);
    if (n_month < 1 || n_month > 12) return alert("Invalid month value: '" + n_month + "'.\nAllowed range is 01-12.");
    var d_numdays = new Date(n_year, n_month, 0);
    if (n_day > d_numdays.getDate()) return alert("Invalid day of month value: '" + n_day + "'.\nAllowed range for selected month is 01 - " + d_numdays.getDate() + ".");
    return new Date(n_year, n_month - 1, n_day)
}
function f_tcalGenerDate(d_date) {
    return ((d_date.getDate() < 10 ? '0': '') + d_date.getDate() + "." + (d_date.getMonth() < 9 ? '0': '') + (d_date.getMonth() + 1) + "." + d_date.getFullYear())
}
function tcal(a_cfg, a_tpl) {
    if (!a_tpl) {
        if (a_cfg.lang && a_cfg.lang == 'ru') {
            a_tpl = RU_TCALDEF
        } else {
            a_tpl = A_TCALDEF
        }
    }
    if (!window.A_TCALS) window.A_TCALS = [];
    if (!window.A_TCALSIDX) window.A_TCALSIDX = [];
    this.s_id = a_cfg.id ? a_cfg.id: A_TCALS.length;
    window.A_TCALS[this.s_id] = this;
    window.A_TCALSIDX[window.A_TCALSIDX.length] = this;
    this.f_show = f_tcalShow;
    this.f_hide = f_tcalHide;
    this.f_toggle = f_tcalToggle;
    this.f_update = f_tcalUpdate;
    this.f_relDate = f_tcalRelDate;
    this.f_parseDate = f_tcalParseDate;
    this.f_generDate = f_tcalGenerDate;
    this.s_iconId = 'tcalico_' + this.s_id;
    this.e_icon = f_getElement(this.s_iconId);
    if (!this.e_icon) {
        var divPlace = document.createElement('div');
        divPlace.innerHTML = '<img src="' + a_tpl.imgpath + 'cal.gif" id="' + this.s_iconId + '" onclick="A_TCALS[\'' + this.s_id + '\'].f_toggle()" class="tcalIcon" alt="Open Calendar" />';
        a_cfg['place'].appendChild(divPlace.firstChild);
        this.e_icon = f_getElement(this.s_iconId)
    }
    this.a_cfg = a_cfg;
    this.a_tpl = a_tpl
}
function f_tcalShow(d_date) {
    if (!this.a_cfg.controlname) throw ("TC: control name is not specified");
    if (this.a_cfg.formname) {
        var e_form = document.forms[this.a_cfg.formname];
        if (!e_form) throw ("TC: form '" + this.a_cfg.formname + "' can not be found");
        this.e_input = e_form.elements[this.a_cfg.controlname];
        if (this.a_cfg.intervalupdatecont && this.a_cfg.intervalpair && this.a_cfg.intervalpair.length == 2) {
            this.intervalpair = [e_form.elements[this.a_cfg.intervalpair[0]], e_form.elements[this.a_cfg.intervalpair[1]]];
            this.intervalupdatecont = e_form.elements[this.a_cfg.intervalupdatecont]
        }
    } else {
        this.e_input = f_getElement(this.a_cfg.controlname);
        if (this.a_cfg.intervalpair && this.a_cfg.intervalpair.length == 2) {
            this.intervalpair = [f_getElement(this.a_cfg.intervalpair[0]), f_getElement(this.a_cfg.intervalpair[1])]
        }
        this.intervalupdatecont = f_getElement(this.a_cfg.intervalupdatecont)
    }
    if (!this.e_input || !this.e_input.tagName || this.e_input.tagName != 'INPUT') throw ("TC: element '" + this.a_cfg.controlname + "' does not exist in " + (this.a_cfg.formname ? "form '" + this.a_cfg.controlname + "'": 'this document'));
    this.e_div = f_getElement('tcal');
    if (!this.e_div) {
        this.e_div = document.createElement("DIV");
        this.e_div.id = 'tcal';
        document.body.appendChild(this.e_div)
    }
    this.e_shade = f_getElement('tcalShade');
    if (!this.e_shade) {
        this.e_shade = document.createElement("DIV");
        this.e_shade.id = 'tcalShade';
        document.body.appendChild(this.e_shade)
    }
    this.e_iframe = f_getElement('tcalIF');
    if (b_ieFix && !this.e_iframe) {
        this.e_iframe = document.createElement("IFRAME");
        this.e_iframe.style.filter = 'alpha(opacity=0)';
        this.e_iframe.id = 'tcalIF';
        this.e_iframe.src = this.a_tpl.imgpath + 'pixel.gif';
        document.body.appendChild(this.e_iframe)
    }
    f_tcalHideAll();
    this.e_icon = f_getElement(this.s_iconId);
    this.e_div.style.display = 'block';
    this.e_shade.style.display = 'block';
    if (this.e_iframe) {
        this.e_iframe.style.display = 'block'
    }
    if (!this.f_update()) return;
    this.e_div.style.visibility = 'visible';
    this.e_div.style.display = 'block';
    this.e_shade.style.visibility = 'visible';
    this.e_shade.style.display = 'block';
    if (this.e_iframe) {
        this.e_iframe.style.visibility = 'visible';
        this.e_iframe.style.display = 'block'
    }
    this.e_icon.src = this.a_tpl.imgpath + 'no_cal.gif';
    this.e_icon.title = 'Close Calendar';
    this.b_visible = true
}
function f_tcalHide(n_date) {
    if (n_date) {
        this.e_input.value = this.f_generDate(new Date(n_date));
        if (this.intervalpair && this.intervalupdatecont && this.intervalpair[0].value != "" && this.intervalpair[1].value != "") this.intervalupdatecont.value = this.intervalpair[0].value + " -- " + this.intervalpair[1].value;
        else if (this.intervalupdatecont) this.intervalupdatecont.value = ""
    }
    if (!this.b_visible) return;
    if (this.e_iframe) {
        this.e_iframe.style.visibility = 'hidden';
        this.e_iframe.style.display = 'none'
    }
    if (this.e_shade) {
        this.e_shade.style.visibility = 'hidden';
        this.e_shade.style.display = 'none'
    }
    this.e_div.style.visibility = 'hidden';
    this.e_div.style.display = 'none';
    this.e_icon = f_getElement(this.s_iconId);
    this.e_icon.src = this.a_tpl.imgpath + 'cal.gif';
    this.e_icon.title = 'Open Calendar';
    this.b_visible = false
}
function f_tcalToggle() {
    return this.b_visible ? this.f_hide() : this.f_show()
}
function f_tcalUpdate(d_date) {
    var d_client = new Date();
    d_client.setHours(0);
    d_client.setMinutes(0);
    d_client.setSeconds(0);
    d_client.setMilliseconds(0);
    var d_today = this.a_cfg.today ? this.f_parseDate(this.a_cfg.today) : d_client;
    var d_selected = this.e_input.value == '' ? (this.a_cfg.selected ? this.f_parseDate(this.a_cfg.selected) : d_today) : this.f_parseDate(this.e_input.value);
    if (!d_date) d_date = d_selected;
    else if (typeof(d_date) == 'number') d_date = new Date(d_date);
    else if (typeof(d_date) == 'string') this.f_parseDate(d_date);
    if (!d_date) return false;
    var d_firstday = new Date(d_date);
    d_firstday.setDate(1);
    d_firstday.setDate(1 - (7 + d_firstday.getDay() - this.a_tpl.weekstart) % 7);
    var a_class, s_html = '<table class="ctrl"><tbody><tr>' + (this.a_tpl.yearscroll ? '<td' + this.f_relDate(d_date, -1, 'y') + ' title="Previous Year"><img src="' + this.a_tpl.imgpath + 'prev_year.gif" /></td>': '') + '<td' + this.f_relDate(d_date, -1) + ' title="Previous Month"><img src="' + this.a_tpl.imgpath + 'prev_mon.gif" /></td><th>' + this.a_tpl.months[d_date.getMonth()] + ' ' + d_date.getFullYear() + '</th><td' + this.f_relDate(d_date, 1) + ' title="Next Month"><img src="' + this.a_tpl.imgpath + 'next_mon.gif" /></td>' + (this.a_tpl.yearscroll ? '<td' + this.f_relDate(d_date, 1, 'y') + ' title="Next Year"><img src="' + this.a_tpl.imgpath + 'next_year.gif" /></td></td>': '') + '</tr></tbody></table><table><tbody><tr class="wd">';
    for (var i = 0; i < 7; i++) s_html += '<th>' + this.a_tpl.weekdays[(this.a_tpl.weekstart + i) % 7] + '</th>';
    s_html += '</tr>';
    var d_current = new Date(d_firstday);
    while (d_current.getMonth() == d_date.getMonth() || d_current.getMonth() == d_firstday.getMonth()) {
        s_html += '<tr>';
        for (var n_wday = 0; n_wday < 7; n_wday++) {
            a_class = [];
            if (d_current.getMonth() != d_date.getMonth()) a_class[a_class.length] = 'othermonth';
            if (d_current.getDay() == 0 || d_current.getDay() == 6) a_class[a_class.length] = 'weekend';
            if (d_current.valueOf() == d_today.valueOf()) a_class[a_class.length] = 'today';
            if (d_current.valueOf() == d_selected.valueOf()) a_class[a_class.length] = 'selected';
            s_html += '<td onclick="A_TCALS[\'' + this.s_id + '\'].f_hide(' + d_current.valueOf() + ')"' + (a_class.length ? ' class="' + a_class.join(' ') + '">': '>') + d_current.getDate() + '</td>';
            d_current.setDate(d_current.getDate() + 1)
        }
        s_html += '</tr>'
    }
    s_html += '</tbody></table>';
    this.e_div.innerHTML = s_html;
    var n_width = this.e_div.offsetWidth;
    var n_height = this.e_div.offsetHeight;
    var n_top = f_getPosition(this.e_icon, 'Top') + this.e_icon.offsetHeight;
    var n_left = f_getPosition(this.e_icon, 'Left') - n_width + this.e_icon.offsetWidth;
    if (n_left < 0) n_left = 0;
    this.e_div.style.left = n_left + 'px';
    this.e_div.style.top = n_top + 'px';
    this.e_shade.style.width = (n_width + 8) + 'px';
    this.e_shade.style.left = (n_left - 1) + 'px';
    this.e_shade.style.top = (n_top - 1) + 'px';
    this.e_shade.innerHTML = (b_ieFix ? '<table><tbody><tr><td rowspan="2" colspan="2" width="6"><img src="' + this.a_tpl.imgpath + 'pixel.gif"></td><td width="7" height="7" style="filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src=\'' + this.a_tpl.imgpath + 'shade_tr.png\', sizingMethod=\'scale\');"><img src="' + this.a_tpl.imgpath + 'pixel.gif"></td></tr><tr><td height="' + (n_height - 7) + '" style="filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src=\'' + this.a_tpl.imgpath + 'shade_mr.png\', sizingMethod=\'scale\');"><img src="' + this.a_tpl.imgpath + 'pixel.gif"></td></tr><tr><td width="7" style="filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src=\'' + this.a_tpl.imgpath + 'shade_bl.png\', sizingMethod=\'scale\');"><img src="' + this.a_tpl.imgpath + 'pixel.gif"></td><td style="filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src=\'' + this.a_tpl.imgpath + 'shade_bm.png\', sizingMethod=\'scale\');" height="7" align="left"><img src="' + this.a_tpl.imgpath + 'pixel.gif"></td><td style="filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src=\'' + this.a_tpl.imgpath + 'shade_br.png\', sizingMethod=\'scale\');"><img src="' + this.a_tpl.imgpath + 'pixel.gif"></td></tr><tbody></table>': '<table><tbody><tr><td rowspan="2" width="6"><img src="' + this.a_tpl.imgpath + 'pixel.gif"></td><td rowspan="2"><img src="' + this.a_tpl.imgpath + 'pixel.gif"></td><td width="7" height="7"><img src="' + this.a_tpl.imgpath + 'shade_tr.png"></td></tr><tr><td background="' + this.a_tpl.imgpath + 'shade_mr.png" height="' + (n_height - 7) + '"><img src="' + this.a_tpl.imgpath + 'pixel.gif"></td></tr><tr><td><img src="' + this.a_tpl.imgpath + 'shade_bl.png"></td><td background="' + this.a_tpl.imgpath + 'shade_bm.png" height="7" align="left"><img src="' + this.a_tpl.imgpath + 'pixel.gif"></td><td><img src="' + this.a_tpl.imgpath + 'shade_br.png"></td></tr><tbody></table>');
    if (this.e_iframe) {
        this.e_iframe.style.left = n_left + 'px';
        this.e_iframe.style.top = n_top + 'px';
        this.e_iframe.style.width = (n_width + 6) + 'px';
        this.e_iframe.style.height = (n_height + 6) + 'px'
    }
    return true
}
function f_getPosition(e_elemRef, s_coord) {
    var n_pos = 0,
    n_offset, e_elem = e_elemRef;
    while (e_elem) {
        n_offset = e_elem["offset" + s_coord];
        n_pos += n_offset;
        e_elem = e_elem.offsetParent
    }
    if (b_ieMac) n_pos += parseInt(document.body[s_coord.toLowerCase() + 'Margin']);
    else if (b_safari) n_pos -= n_offset;
    e_elem = e_elemRef;
    while (e_elem != document.body) {
        n_offset = e_elem["scroll" + s_coord];
        if (n_offset && e_elem.style.overflow == 'scroll') n_pos -= n_offset;
        e_elem = e_elem.parentNode
    }
    return n_pos
}
function f_tcalRelDate(d_date, d_diff, s_units) {
    var s_units = (s_units == 'y' ? 'FullYear': 'Month');
    var d_result = new Date(d_date);
    d_result['set' + s_units](d_date['get' + s_units]() + d_diff);
    if (d_result.getDate() != d_date.getDate()) d_result.setDate(0);
    return ' onclick="A_TCALS[\'' + this.s_id + '\'].f_update(' + d_result.valueOf() + ')"'
}
function f_tcalHideAll() {
    for (var i = 0; i < window.A_TCALSIDX.length; i++) window.A_TCALSIDX[i].f_hide()
}
f_getElement = document.all ?
function(s_id) {
    return document.all[s_id]
}: function(s_id) {
    return document.getElementById(s_id)
};
var s_userAgent = navigator.userAgent.toLowerCase(),
re_webkit = /WebKit\/(\d+)/i;
var b_mac = s_userAgent.indexOf('mac') != -1,
b_ie5 = s_userAgent.indexOf('msie 5') != -1,
b_ie6 = s_userAgent.indexOf('msie 6') != -1 && s_userAgent.indexOf('opera') == -1;
var b_ieFix = b_ie5 || b_ie6,
b_ieMac = b_mac && b_ie5,
b_safari = b_mac && re_webkit.exec(s_userAgent) && Number(RegExp.$1) < 500;

if (navigator && navigator.cookieEnabled == false) {
    document.write(no_cookies_message)
}
function addListToCart(shop_id) {
    if (!isNaN(shop_id) && document.f.elements['product_ids[]']) {
        var but = document.getElementById('submit_button');
        if (but) {
            but.disabled = true
        }
        var total = readCookie('CART_TOTAL_' + shop_id);
        var cart = unescape(readCookie('CART_' + shop_id));
        var cart_split = cart.split(';');
        var cart_item_split;
        var cart_hash = {};
        var found = false;
        for (var i = 0; i < cart_split.length; i++) {
            cart_item_split = cart_split[i].split("=");
            cart_hash[cart_item_split[0]] = cart_item_split[1]
        }
        cart = "";
        if (document.f.elements['product_ids[]']) {
            if (document.f.elements['product_ids[]'].nodeName != "INPUT") {
                for (var i = 0; i < document.f.elements['product_ids[]'].length; i++) {
                    if (document.f.elements['product_ids[]'][i]) {
                        var product_id = document.f.elements['product_ids[]'][i].value;
                        var price = document.f.elements['prices[]'][i].value;
                        var amount = document.f.elements['amounts[]'][i].value;
                        if (amount != "" && amount > 0) {
                            total = Number(total) + Number(price * amount);
                            if (cart_hash[product_id]) {
                                cart_hash[product_id] = Number(cart_hash[product_id]) + Number(amount)
                            } else {
                                cart_hash[product_id] = Number(amount)
                            }
                        }
                    }
                }
            } else {
                var product_id = document.f.elements['product_ids[]'].value;
                var price = document.f.elements['prices[]'].value;
                var amount = document.f.elements['amounts[]'].value;
                if (amount != "" && amount > 0) {
                    total = Number(total) + Number(price * amount);
                    if (cart_hash[product_id]) {
                        cart_hash[product_id] = Number(cart_hash[product_id]) + Number(amount)
                    } else {
                        cart_hash[product_id] = Number(amount)
                    }
                }
            }
        }
        cart = "";
        for (var i in cart_hash) {
            if (cart_hash[i]) {
                if (cart != "") cart = cart + ";";
                cart = cart + i + "=" + cart_hash[i]
            }
        }
        createCookie('CART_' + shop_id, cart, 10);
        createCookie('CART_TOTAL_' + shop_id, total, 10);
        if (document.getElementById('cart_total')) document.getElementById('cart_total').innerHTML = total;
        resetOrderList();
        return true
    }
    return false
}
function addToCart(shop_id, product_id, price, amount) {
    product_id = Number(product_id);
    if (!isNaN(shop_id) && (shop_id > 0) && !isNaN(product_id) && (product_id > 0) && !isNaN(price) && !isNaN(amount) && (amount > 0)) {
        var total = readCookie('CART_TOTAL_' + shop_id);
        var cart = unescape(readCookie('CART_' + shop_id));
        var cart_split = cart.split(';');
        var cart_new = "";
        var cart_item_split;
        var found = false;
        if (total == "") total = 0;
        for (var i = 0; i < cart_split.length; i++) {
            cart_item_split = cart_split[i].split("=");
            if (cart_item_split.length == 2) {
                if (!found && cart_item_split[0] == product_id) {
                    total = Number(total) + Number(price * amount);
                    var total_amount = Number(amount) + Number(cart_item_split[1]);
                    found = true;
                    if (cart_new != "") cart_new = cart_new + ";";
                    cart_new = cart_new + product_id + "=" + total_amount
                } else {
                    if (cart_new != "") cart_new = cart_new + ";";
                    cart_new = cart_new + cart_item_split[0] + "=" + cart_item_split[1]
                }
            }
        }
        if (!found) {
            if (cart_new != "") cart_new = cart_new + ";";
            cart_new = cart_new + product_id + "=" + amount;
            total = Number(total) + Number(price * amount)
        }
        createCookie('CART_' + shop_id, cart_new, 10);
        createCookie('CART_TOTAL_' + shop_id, total, 10);
        if (document.getElementById('cart_total')) document.getElementById('cart_total').innerHTML = total;
        return true
    }
    return false
}
function getParent(obj, tagName) {
    if (obj) {
        var par = obj.parentNode;
        while (par && (par.nodeName != tagName)) {
            par = par.parentNode
        }
        return par
    }
    return null
}
function deleteRaw(o) {
    v = getParent(o, "TR");
    if (v) {
        v.parentNode.removeChild(v)
    }
}
var dot = true;
var ttt = "2.23";
if (isNaN(ttt)) {
    dot = false
}
function getEventTarget(e) {
    if (!e) e = window.event;
    if (e.target) {
        if (e.target.nodeType == 3) e.target = e.target.parentNode;
        return e.target
    } else if (e.srcElement) return e.srcElement
}
function inputOnlyRealNumber(obj, e) {
    var target = getEventTarget(e);
    if (target && target.nodeName == "INPUT" && target.type == "text") {
        var valueBefore = target.value;
        var value = "";
        if (dot) {
            value = valueBefore.replace(",", ".")
        } else {
            value = valueBefore.replace(".", ",")
        }
        value = value.replace(/[^\d\.,]+/, "");
        if (value.length > 1) value = value.replace(/[0]*(\d*[\.,]?\d*).*/, "$1");
        if (value != valueBefore) {
            target.value = value
        }
        if (value != "" && valueBefore == value) {
            return true
        }
    }
    return false
}
function recountCart(shop_id) {
    var total = 0;
    var cart = "";
    if (document.f.elements['product_ids[]']) {
        if (document.f.elements['product_ids[]'].nodeName != "INPUT") {
            for (var i = 0; i < document.f.elements['product_ids[]'].length; i++) {
                if (document.f.elements['product_ids[]'][i]) {
                    var product_id = document.f.elements['product_ids[]'][i].value;
                    var price = document.f.elements['prices[]'][i].value;
                    var amount = document.f.elements['amounts[]'][i].value;
                    total = total + price * amount;
                    if (amount > 0) {
                        if (cart != "") cart = cart + ";";
                        cart = cart + product_id + "=" + amount
                    }
                    document.getElementById('res_' + product_id).innerHTML = (price * amount)
                }
            }
        } else {
            var product_id = document.f.elements['product_ids[]'].value;
            var price = document.f.elements['prices[]'].value;
            var amount = document.f.elements['amounts[]'].value;
            total = total + price * amount;
            cart = product_id + "=" + amount;
            document.getElementById('res_' + product_id).innerHTML = (price * amount)
        }
    } else {
        if (document.getElementById('cart_div')) document.getElementById('cart_div').innerHTML = ""
    }
    createCookie('CART_' + shop_id, cart, 10);
    createCookie('CART_TOTAL_' + shop_id, total, 10);
    if (document.getElementById('total')) document.getElementById('total').innerHTML = total;
    if (document.getElementById('cart_total')) document.getElementById('cart_total').innerHTML = total
}
function resetOrderList() {
    var but = document.getElementById('submit_button');
    if (but) {
        but.disabled = true
    }
    if (document.f.elements['amounts[]']) {
        if (document.f.elements['amounts[]'].nodeName != "INPUT") {

            for (var i = 0; i < document.f.elements['amounts[]'].length; i++) {
                if (document.f.elements['amounts[]'][i]) {
                    document.f.elements['amounts[]'][i].value = 0
                }
            }
        } else {
            document.f.elements['amounts[]'].value = 0
        }
    }
    var total_span = document.getElementById('total');
    if (total_span) total_span.innerHTML = 0
}
function recountOrderList() {
    var total = 0;
    if (document.f.elements['product_ids[]']) {
        if (document.f.elements['product_ids[]'].nodeName != "INPUT") {
            for (var i = 0; i < document.f.elements['product_ids[]'].length; i++) {
                if (document.f.elements['product_ids[]'][i]) {
                    var product_id = document.f.elements['product_ids[]'][i].value;
                    var price = document.f.elements['prices[]'][i].value;
                    var amount = document.f.elements['amounts[]'][i].value;
                    total = total + price * amount;
                    document.getElementById('res_' + product_id).innerHTML = (price * amount)
                }
            }
        } else {
            var product_id = document.f.elements['product_ids[]'].value;
            var price = document.f.elements['prices[]'].value;
            var amount = document.f.elements['amounts[]'].value;
            total = total + price * amount;
            document.getElementById('res_' + product_id).innerHTML = (price * amount)
        }
    }
    var total_span = document.getElementById('total');
    if (isNaN(total) || total == 0 || total == '') total = 0;
    if (total_span) total_span.innerHTML = total;
    var but = document.getElementById('submit_button');
    if (but) {
        if (total == 0) but.disabled = true;
        else but.disabled = false
    }
}
function findPos(obj) {
    var result = {};
    result.x = 0;
    result.y = 0;
    if (obj.offsetParent) {
        while (obj.offsetParent) {
            result.y += obj.offsetTop;
            result.x += obj.offsetLeft;
            obj = obj.offsetParent
        }
    } else {
        if (obj.x) result.x += obj.x;
        if (obj.y) result.y += obj.y
    }
    return result
}
function emptyInputBlur(obj, e) {
    var target = getEventTarget(e);
    if (target && target.nodeName == "INPUT" && target.type == "text") {
        if (target.value == "") target.value = 0;
        return true
    }
    return false
}
function showAddMessage(obj) {
    var pos = findPos(obj);
    var d = document.getElementById("shop-added");
    if (d) {
        d = d.cloneNode(true);
        d.style.display = 'block';
        d.style.left = (pos.x + 10) + 'px';
        d.style.top = (pos.y + obj.offsetHeight - d.offsetHeight) + 'px';
        document.body.appendChild(d);
        d.style.top = (parseInt(d.style.top) - d.offsetHeight - 10) + 'px';
        window.setTimeout(function() {
            if (d && d.parentNode) d.parentNode.removeChild(d);
            delete d
        },
        500)
    }
}
function addList(f, shop_id, func) {
    if (addListToCart(shop_id)) {
        if (func) func(f);
        else showAddMessage(f)
    }
    return false
}
function addProductForm(shop_id, product_id, product_price, f, func) {
    if (addToCart(shop_id, product_id, product_price, f.product_amount.value)) {
        if (func) func(f);
        else showAddMessage(f)
    }
    f.product_amount.value = "1";
    return false
}



$(function(){
		$('#menu_b ul').parent().each(function() {
				var o = $(this);
				var s = o.find('>ul');
				var k = false;
				o.hover(
					function() {
						o.find('>a').attr('class','over');
						for (i=$('#menu_b ul').length; i>=0; i--){
						o.parent().find('>li').not(o).find('ul').eq(i).hide();
						}
						k = true;
						var p = o.position();
						var ts, ls;
							ts =  p.top;
							ls = p.left + o.width();
						s.css({
							top: ts,
							left: ls
						}).show();
					},
					function() {
						o.find('>a').attr('class','normal');
						k = false;
						window.setTimeout(function() {
							if (!k) s.hide(); 						   
						}, 500);
					}
				);
			});
})

