/* jQuery JavaScript Library v1.4.4 */
(function (E, B) {
    function ka(a, b, d) {
        if (d === B && a.nodeType === 1) {
            d = a.getAttribute("data-" + b);
            if (typeof d === "string") {
                try {
                    d = d === "true" ? true : d === "false" ? false : d === "null" ? null : !c.isNaN(d) ? parseFloat(d) : Ja.test(d) ? c.parseJSON(d) : d
                } catch (e) {}
                c.data(a, b, d)
            } else d = B
        }
        return d
    }
    function U() {
        return false
    }
    function ca() {
        return true
    }
    function la(a, b, d) {
        d[0].type = a;
        return c.event.handle.apply(b, d)
    }
    function Ka(a) {
        var b, d, e, f, h, l, k, o, x, r, A, C = [];
        f = [];
        h = c.data(this, this.nodeType ? "events" : "__events__");
        if (typeof h === "function") h = h.events;
        if (!(a.liveFired === this || !h || !h.live || a.button && a.type === "click")) {
            if (a.namespace) A = RegExp("(^|\\.)" + a.namespace.split(".").join("\\.(?:.*\\.)?") + "(\\.|$)");
            a.liveFired = this;
            var J = h.live.slice(0);
            for (k = 0; k < J.length; k++) {
                h = J[k];
                h.origType.replace(X, "") === a.type ? f.push(h.selector) : J.splice(k--, 1)
            }
            f = c(a.target).closest(f, a.currentTarget);
            o = 0;
            for (x = f.length; o < x; o++) {
                r = f[o];
                for (k = 0; k < J.length; k++) {
                    h = J[k];
                    if (r.selector === h.selector && (!A || A.test(h.namespace))) {
                        l = r.elem;
                        e = null;
                        if (h.preType === "mouseenter" || h.preType === "mouseleave") {
                            a.type = h.preType;
                            e = c(a.relatedTarget).closest(h.selector)[0]
                        }
                        if (!e || e !== l) C.push({
                            elem: l,
                            handleObj: h,
                            level: r.level
                        })
                    }
                }
            }
            o = 0;
            for (x = C.length; o < x; o++) {
                f = C[o];
                if (d && f.level > d) break;
                a.currentTarget = f.elem;
                a.data = f.handleObj.data;
                a.handleObj = f.handleObj;
                A = f.handleObj.origHandler.apply(f.elem, arguments);
                if (A === false || a.isPropagationStopped()) {
                    d = f.level;
                    if (A === false) b = false;
                    if (a.isImmediatePropagationStopped()) break
                }
            }
            return b
        }
    }
    function Y(a, b) {
        return (a && a !== "*" ? a + "." : "") + b.replace(La, "`").replace(Ma, "&")
    }
    function ma(a, b, d) {
        if (c.isFunction(b)) return c.grep(a, function (f, h) {
            return !!b.call(f, h, f) === d
        });
        else if (b.nodeType) return c.grep(a, function (f) {
            return f === b === d
        });
        else if (typeof b === "string") {
            var e = c.grep(a, function (f) {
                return f.nodeType === 1
            });
            if (Na.test(b)) return c.filter(b, e, !d);
            else b = c.filter(b, e)
        }
        return c.grep(a, function (f) {
            return c.inArray(f, b) >= 0 === d
        })
    }
    function na(a, b) {
        var d = 0;
        b.each(function () {
            if (this.nodeName === (a[d] && a[d].nodeName)) {
                var e = c.data(a[d++]),
                    f = c.data(this, e);
                if (e = e && e.events) {
                    delete f.handle;
                    f.events = {};
                    for (var h in e) for (var l in e[h]) c.event.add(this, h, e[h][l], e[h][l].data)
                }
            }
        })
    }
    function Oa(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 oa(a, b, d) {
        var e = b === "width" ? a.offsetWidth : a.offsetHeight;
        if (d === "border") return e;
        c.each(b === "width" ? Pa : Qa, function () {
            d || (e -= parseFloat(c.css(a, "padding" + this)) || 0);
            if (d === "margin") e += parseFloat(c.css(a, "margin" + this)) || 0;
            else e -= parseFloat(c.css(a, "border" + this + "Width")) || 0
        });
        return e
    }
    function da(a, b, d, e) {
        if (c.isArray(b) && b.length) c.each(b, function (f, h) {
            d || Ra.test(a) ? e(a, h) : da(a + "[" + (typeof h === "object" || c.isArray(h) ? f : "") + "]", h, d, e)
        });
        else if (!d && b != null && typeof b === "object") c.isEmptyObject(b) ? e(a, "") : c.each(b, function (f, h) {
            da(a + "[" + f + "]", h, d, e)
        });
        else e(a, b)
    }
    function S(a, b) {
        var d = {};
        c.each(pa.concat.apply([], pa.slice(0, b)), function () {
            d[this] = a
        });
        return d
    }
    function qa(a) {
        if (!bk[a]) {
            var b = c("<" + a + ">").appendTo("body"),
                d = b.css("display");
            b.remove();
            if (d === "none" || d === "") d = "block";
            bk[a] = d
        }
        return bk[a]
    }
    function fa(a) {
        return c.isWindow(a) ? a : a.nodeType === 9 ? a.defaultView || a.parentWindow : false
    }
    var t = E.document,
        c = function () {
            function a() {
                if (!b.isReady) {
                    try {
                        t.documentElement.doScroll("left")
                    } catch (j) {
                        setTimeout(a, 1);
                        return
                    }
                    b.ready()
                }
            }
            var b = function (j, s) {
                    return new b.fn.init(j, s)
                },
                d = E.jQuery,
                e = E.$,
                f, h = /^(?:[^<]*(<[\w\W]+>)[^>]*$|#([\w\-]+)$)/,
                l = /\S/,
                k = /^\s+/,
                o = /\s+$/,
                x = /\W/,
                r = /\d/,
                A = /^<(\w+)\s*\/?>(?:<\/\1>)?$/,
                C = /^[\],:{}\s]*$/,
                J = /\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g,
                w = /"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g,
                I = /(?:^|:|,)(?:\s*\[)+/g,
                L = /(webkit)[ \/]([\w.]+)/,
                g = /(opera)(?:.*version)?[ \/]([\w.]+)/,
                i = /(msie) ([\w.]+)/,
                n = /(mozilla)(?:.*? rv:([\w.]+))?/,
                m = navigator.userAgent,
                p = false,
                q = [],
                u, y = Object.prototype.toString,
                F = Object.prototype.hasOwnProperty,
                M = Array.prototype.push,
                N = Array.prototype.slice,
                O = String.prototype.trim,
                D = Array.prototype.indexOf,
                R = {};
            b.fn = b.prototype = {
                init: function (j, s) {
                    var v, z, H;
                    if (!j) return this;
                    if (j.nodeType) {
                        this.context = this[0] = j;
                        this.length = 1;
                        return this
                    }
                    if (j === "body" && !s && t.body) {
                        this.context = t;
                        this[0] = t.body;
                        this.selector = "body";
                        this.length = 1;
                        return this
                    }
                    if (typeof j === "string") if ((v = h.exec(j)) && (v[1] || !s)) if (v[1]) {
                        H = s ? s.ownerDocument || s : t;
                        if (z = A.exec(j)) if (b.isPlainObject(s)) {
                            j = [t.createElement(z[1])];
                            b.fn.attr.call(j, s, true)
                        } else j = [H.createElement(z[1])];
                        else {
                            z = b.buildFragment([v[1]], [H]);
                            j = (z.cacheable ? z.fragment.cloneNode(true) : z.fragment).childNodes
                        }
                        return b.merge(this, j)
                    } else {
                        if ((z = t.getElementById(v[2])) && z.parentNode) {
                            if (z.id !== v[2]) return f.find(j);
                            this.length = 1;
                            this[0] = z
                        }
                        this.context = t;
                        this.selector = j;
                        return this
                    } else if (!s && !x.test(j)) {
                        this.selector = j;
                        this.context = t;
                        j = t.getElementsByTagName(j);
                        return b.merge(this, j)
                    } else return !s || s.jquery ? (s || f).find(j) : b(s).find(j);
                    else if (b.isFunction(j)) return f.ready(j);
                    if (j.selector !== B) {
                        this.selector = j.selector;
                        this.context = j.context
                    }
                    return b.makeArray(j, this)
                },
                selector: "",
                jquery: "1.4.4",
                length: 0,
                size: function () {
                    return this.length
                },
                toArray: function () {
                    return N.call(this, 0)
                },
                get: function (j) {
                    return j == null ? this.toArray() : j < 0 ? this.slice(j)[0] : this[j]
                },
                pushStack: function (j, s, v) {
                    var z = b();
                    b.isArray(j) ? M.apply(z, j) : b.merge(z, j);
                    z.prevObject = this;
                    z.context = this.context;
                    if (s === "find") z.selector = this.selector + (this.selector ? " " : "") + v;
                    else if (s) z.selector = this.selector + "." + s + "(" + v + ")";
                    return z
                },
                each: function (j, s) {
                    return b.each(this, j, s)
                },
                ready: function (j) {
                    b.bindReady();
                    if (b.isReady) j.call(t, b);
                    else q && q.push(j);
                    return this
                },
                eq: function (j) {
                    return j === -1 ? this.slice(j) : this.slice(j, +j + 1)
                },
                first: function () {
                    return this.eq(0)
                },
                last: function () {
                    return this.eq(-1)
                },
                slice: function () {
                    return this.pushStack(N.apply(this, arguments), "slice", N.call(arguments).join(","))
                },
                map: function (j) {
                    return this.pushStack(b.map(this, function (s, v) {
                        return j.call(s, v, s)
                    }))
                },
                end: function () {
                    return this.prevObject || b(null)
                },
                push: M,
                sort: [].sort,
                splice: [].splice
            };
            b.fn.init.prototype = b.fn;
            b.extend = b.fn.extend = function () {
                var j, s, v, z, H, G = arguments[0] || {},
                    K = 1,
                    Q = arguments.length,
                    ga = false;
                if (typeof G === "boolean") {
                    ga = G;
                    G = arguments[1] || {};
                    K = 2
                }
                if (typeof G !== "object" && !b.isFunction(G)) G = {};
                if (Q === K) {
                    G = this;
                    --K
                }
                for (; K < Q; K++) if ((j = arguments[K]) != null) for (s in j) {
                    v = G[s];
                    z = j[s];
                    if (G !== z) if (ga && z && (b.isPlainObject(z) || (H = b.isArray(z)))) {
                        if (H) {
                            H = false;
                            v = v && b.isArray(v) ? v : []
                        } else v = v && b.isPlainObject(v) ? v : {};
                        G[s] = b.extend(ga, v, z)
                    } else if (z !== B) G[s] = z
                }
                return G
            };
            b.extend({
                noConflict: function (j) {
                    E.$ = e;
                    if (j) E.jQuery = d;
                    return b
                },
                isReady: false,
                readyWait: 1,
                ready: function (j) {
                    j === true && b.readyWait--;
                    if (!b.readyWait || j !== true && !b.isReady) {
                        if (!t.body) return setTimeout(b.ready, 1);
                        b.isReady = true;
                        if (!(j !== true && --b.readyWait > 0)) if (q) {
                            var s = 0,
                                v = q;
                            for (q = null; j = v[s++];) j.call(t, b);
                            b.fn.trigger && b(t).trigger("ready").unbind("ready")
                        }
                    }
                },
                bindReady: function () {
                    if (!p) {
                        p = true;
                        if (t.readyState === "complete") return setTimeout(b.ready, 1);
                        if (t.addEventListener) {
                            t.addEventListener("DOMContentLoaded", u, false);
                            E.addEventListener("load", b.ready, false)
                        } else if (t.attachEvent) {
                            t.attachEvent("onreadystatechange", u);
                            E.attachEvent("onload", b.ready);
                            var j = false;
                            try {
                                j = E.frameElement == null
                            } catch (s) {}
                            t.documentElement.doScroll && j && a()
                        }
                    }
                },
                isFunction: function (j) {
                    return b.type(j) === "function"
                },
                isArray: Array.isArray ||
                function (j) {
                    return b.type(j) === "array"
                },
                isWindow: function (j) {
                    return j && typeof j === "object" && "setInterval" in j
                },
                isNaN: function (j) {
                    return j == null || !r.test(j) || isNaN(j)
                },
                type: function (j) {
                    return j == null ? String(j) : R[y.call(j)] || "object"
                },
                isPlainObject: function (j) {
                    if (!j || b.type(j) !== "object" || j.nodeType || b.isWindow(j)) return false;
                    if (j.constructor && !F.call(j, "constructor") && !F.call(j.constructor.prototype, "isPrototypeOf")) return false;
                    for (var s in j);
                    return s === B || F.call(j, s)
                },
                isEmptyObject: function (j) {
                    for (var s in j) return false;
                    return true
                },
                error: function (j) {
                    throw j;
                },
                parseJSON: function (j) {
                    if (typeof j !== "string" || !j) return null;
                    j = b.trim(j);
                    if (C.test(j.replace(J, "@").replace(w, "]").replace(I, ""))) return E.JSON && E.JSON.parse ? E.JSON.parse(j) : (new Function("return " + j))();
                    else b.error("Invalid JSON: " + j)
                },
                noop: function () {},
                globalEval: function (j) {
                    if (j && l.test(j)) {
                        var s = t.getElementsByTagName("head")[0] || t.documentElement,
                            v = t.createElement("script");
                        v.type = "text/javascript";
                        if (b.support.scriptEval) v.appendChild(t.createTextNode(j));
                        else v.text = j;
                        s.insertBefore(v, s.firstChild);
                        s.removeChild(v)
                    }
                },
                nodeName: function (j, s) {
                    return j.nodeName && j.nodeName.toUpperCase() === s.toUpperCase()
                },
                each: function (j, s, v) {
                    var z, H = 0,
                        G = j.length,
                        K = G === B || b.isFunction(j);
                    if (v) if (K) for (z in j) {
                        if (s.apply(j[z], v) === false) break
                    } else for (; H < G;) {
                        if (s.apply(j[H++], v) === false) break
                    } else if (K) for (z in j) {
                        if (s.call(j[z], z, j[z]) === false) break
                    } else for (v = j[0]; H < G && s.call(v, H, v) !== false; v = j[++H]);
                    return j
                },
                trim: O ?
                function (j) {
                    return j == null ? "" : O.call(j)
                } : function (j) {
                    return j == null ? "" : j.toString().replace(k, "").replace(o, "")
                },
                makeArray: function (j, s) {
                    var v = s || [];
                    if (j != null) {
                        var z = b.type(j);
                        j.length == null || z === "string" || z === "function" || z === "regexp" || b.isWindow(j) ? M.call(v, j) : b.merge(v, j)
                    }
                    return v
                },
                inArray: function (j, s) {
                    if (s.indexOf) return s.indexOf(j);
                    for (var v = 0, z = s.length; v < z; v++) if (s[v] === j) return v;
                    return -1
                },
                merge: function (j, s) {
                    var v = j.length,
                        z = 0;
                    if (typeof s.length === "number") for (var H = s.length; z < H; z++) j[v++] = s[z];
                    else for (; s[z] !== B;) j[v++] = s[z++];
                    j.length = v;
                    return j
                },
                grep: function (j, s, v) {
                    var z = [],
                        H;
                    v = !! v;
                    for (var G = 0, K = j.length; G < K; G++) {
                        H = !! s(j[G], G);
                        v !== H && z.push(j[G])
                    }
                    return z
                },
                map: function (j, s, v) {
                    for (var z = [], H, G = 0, K = j.length; G < K; G++) {
                        H = s(j[G], G, v);
                        if (H != null) z[z.length] = H
                    }
                    return z.concat.apply([], z)
                },
                guid: 1,
                proxy: function (j, s, v) {
                    if (arguments.length === 2) if (typeof s === "string") {
                        v = j;
                        j = v[s];
                        s = B
                    } else if (s && !b.isFunction(s)) {
                        v = s;
                        s = B
                    }
                    if (!s && j) s = function () {
                        return j.apply(v || this, arguments)
                    };
                    if (j) s.guid = j.guid = j.guid || s.guid || b.guid++;
                    return s
                },
                access: function (j, s, v, z, H, G) {
                    var K = j.length;
                    if (typeof s === "object") {
                        for (var Q in s) b.access(j, Q, s[Q], z, H, v);
                        return j
                    }
                    if (v !== B) {
                        z = !G && z && b.isFunction(v);
                        for (Q = 0; Q < K; Q++) H(j[Q], s, z ? v.call(j[Q], Q, H(j[Q], s)) : v, G);
                        return j
                    }
                    return K ? H(j[0], s) : B
                },
                now: function () {
                    return (new Date).getTime()
                },
                uaMatch: function (j) {
                    j = j.toLowerCase();
                    j = L.exec(j) || g.exec(j) || i.exec(j) || j.indexOf("compatible") < 0 && n.exec(j) || [];
                    return {
                        browser: j[1] || "",
                        version: j[2] || "0"
                    }
                },
                browser: {}
            });
            b.each("Boolean Number String Function Array Date RegExp Object".split(" "), function (j, s) {
                R["[object " + s + "]"] = s.toLowerCase()
            });
            m = b.uaMatch(m);
            if (m.browser) {
                b.browser[m.browser] = true;
                b.browser.version = m.version
            }
            if (b.browser.webkit) b.browser.safari = true;
            if (D) b.inArray = function (j, s) {
                return D.call(s, j)
            };
            if (!/\s/.test("\u00a0")) {
                k = /^[\s\xA0]+/;
                o = /[\s\xA0]+$/
            }
            f = b(t);
            if (t.addEventListener) u = function () {
                t.removeEventListener("DOMContentLoaded", u, false);
                b.ready()
            };
            else if (t.attachEvent) u = function () {
                if (t.readyState === "complete") {
                    t.detachEvent("onreadystatechange", u);
                    b.ready()
                }
            };
            return E.jQuery = E.$ = b
        }();
    (function () {
        c.support = {};
        var a = t.documentElement,
            b = t.createElement("script"),
            d = t.createElement("div"),
            e = "script" + c.now();
        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 f = d.getElementsByTagName("*"),
            h = d.getElementsByTagName("a")[0],
            l = t.createElement("select"),
            k = l.appendChild(t.createElement("option"));
        if (!(!f || !f.length || !h)) {
            c.support = {
                leadingWhitespace: d.firstChild.nodeType === 3,
                tbody: !d.getElementsByTagName("tbody").length,
                htmlSerialize: !! d.getElementsByTagName("link").length,
                style: /red/.test(h.getAttribute("style")),
                hrefNormalized: h.getAttribute("href") === "/a",
                opacity: /^0.55$/.test(h.style.opacity),
                cssFloat: !! h.style.cssFloat,
                checkOn: d.getElementsByTagName("input")[0].value === "on",
                optSelected: k.selected,
                deleteExpando: true,
                optDisabled: false,
                checkClone: false,
                scriptEval: false,
                noCloneEvent: true,
                boxModel: null,
                inlineBlockNeedsLayout: false,
                shrinkWrapBlocks: false,
                reliableHiddenOffsets: true
            };
            l.disabled = true;
            c.support.optDisabled = !k.disabled;
            b.type = "text/javascript";
            try {
                b.appendChild(t.createTextNode("window." + e + "=1;"))
            } catch (o) {}
            a.insertBefore(b, a.firstChild);
            if (E[e]) {
                c.support.scriptEval = true;
                delete E[e]
            }
            try {
                delete b.test
            } catch (x) {
                c.support.deleteExpando = false
            }
            a.removeChild(b);
            if (d.attachEvent && d.fireEvent) {
                d.attachEvent("onclick", function r() {
                    c.support.noCloneEvent = false;
                    d.detachEvent("onclick", r)
                });
                d.cloneNode(true).fireEvent("onclick")
            }
            d = t.createElement("div");
            d.innerHTML = "<input type='radio' name='radiotest' checked='checked'/>";
            a = t.createDocumentFragment();
            a.appendChild(d.firstChild);
            c.support.checkClone = a.cloneNode(true).cloneNode(true).lastChild.checked;
            c(function () {
                var r = t.createElement("div");
                r.style.width = r.style.paddingLeft = "1px";
                t.body.appendChild(r);
                c.boxModel = c.support.boxModel = r.offsetWidth === 2;
                if ("zoom" in r.style) {
                    r.style.display = "inline";
                    r.style.zoom = 1;
                    c.support.inlineBlockNeedsLayout = r.offsetWidth === 2;
                    r.style.display = "";
                    r.innerHTML = "<div style='width:4px;'></div>";
                    c.support.shrinkWrapBlocks = r.offsetWidth !== 2
                }
                r.innerHTML = "<table><tr><td style='padding:0;display:none'></td><td>t</td></tr></table>";
                var A = r.getElementsByTagName("td");
                c.support.reliableHiddenOffsets = A[0].offsetHeight === 0;
                A[0].style.display = "";
                A[1].style.display = "none";
                c.support.reliableHiddenOffsets = c.support.reliableHiddenOffsets && A[0].offsetHeight === 0;
                r.innerHTML = "";
                t.body.removeChild(r).style.display = "none"
            });
            a = function (r) {
                var A = t.createElement("div");
                r = "on" + r;
                var C = r in A;
                if (!C) {
                    A.setAttribute(r, "return;");
                    C = typeof A[r] === "function"
                }
                return C
            };
            c.support.submitBubbles = a("submit");
            c.support.changeBubbles = a("change");
            a = b = d = f = h = null
        }
    })();
    var bc = {},
        Ja = /^(?:\{.*\}|\[.*\])$/;
    c.extend({
        cache: {},
        uuid: 0,
        expando: "jQuery" + c.now(),
        noData: {
            embed: true,
            object: "clsid:D27CDB6E-AE6D-11cf-96B8-444553540000",
            applet: true
        },
        data: function (a, b, d) {
            if (c.acceptData(a)) {
                a = a == E ? bc : a;
                var e = a.nodeType,
                    f = e ? a[c.expando] : null,
                    h = c.cache;
                if (!(e && !f && typeof b === "string" && d === B)) {
                    if (e) f || (a[c.expando] = f = ++c.uuid);
                    else h = a;
                    if (typeof b === "object") if (e) h[f] = c.extend(h[f], b);
                    else c.extend(h, b);
                    else if (e && !h[f]) h[f] = {};
                    a = e ? h[f] : h;
                    if (d !== B) a[b] = d;
                    return typeof b === "string" ? a[b] : a
                }
            }
        },
        removeData: function (a, b) {
            if (c.acceptData(a)) {
                a = a == E ? bc : a;
                var d = a.nodeType,
                    e = d ? a[c.expando] : a,
                    f = c.cache,
                    h = d ? f[e] : e;
                if (b) {
                    if (h) {
                        delete h[b];
                        d && c.isEmptyObject(h) && c.removeData(a)
                    }
                } else if (d && c.support.deleteExpando) delete a[c.expando];
                else if (a.removeAttribute) a.removeAttribute(c.expando);
                else if (d) delete f[e];
                else for (var l in a) delete a[l]
            }
        },
        acceptData: function (a) {
            if (a.nodeName) {
                var b = c.noData[a.nodeName.toLowerCase()];
                if (b) return !(b === true || a.getAttribute("classid") !== b)
            }
            return true
        }
    });
    c.fn.extend({
        data: function (a, b) {
            var d = null;
            if (typeof a === "undefined") {
                if (this.length) {
                    var e = this[0].attributes,
                        f;
                    d = c.data(this[0]);
                    for (var h = 0, l = e.length; h < l; h++) {
                        f = e[h].name;
                        if (f.indexOf("data-") === 0) {
                            f = f.substr(5);
                            ka(this[0], f, d[f])
                        }
                    }
                }
                return d
            } else if (typeof a === "object") return this.each(function () {
                c.data(this, a)
            });
            var k = a.split(".");
            k[1] = k[1] ? "." + k[1] : "";
            if (b === B) {
                d = this.triggerHandler("getData" + k[1] + "!", [k[0]]);
                if (d === B && this.length) {
                    d = c.data(this[0], a);
                    d = ka(this[0], a, d)
                }
                return d === B && k[1] ? this.data(k[0]) : d
            } else return this.each(function () {
                var o = c(this),
                    x = [k[0], b];
                o.triggerHandler("setData" + k[1] + "!", x);
                c.data(this, a, b);
                o.triggerHandler("changeData" + k[1] + "!", x)
            })
        },
        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 e = c.data(a, b);
                if (!d) return e || [];
                if (!e || c.isArray(d)) e = c.data(a, b, c.makeArray(d));
                else e.push(d);
                return e
            }
        },
        dequeue: function (a, b) {
            b = b || "fx";
            var d = c.queue(a, b),
                e = d.shift();
            if (e === "inprogress") e = d.shift();
            if (e) {
                b === "fx" && d.unshift("inprogress");
                e.call(a, function () {
                    c.dequeue(a, b)
                })
            }
        }
    });
    c.fn.extend({
        queue: function (a, b) {
            if (typeof a !== "string") {
                b = a;
                a = "fx"
            }
            if (b === B) 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 bd = /[\n\t]/g,
        ha = /\s+/,
        Sa = /\r/g,
        Ta = /^(?:href|src|style)$/,
        Ua = /^(?:button|input)$/i,
        Va = /^(?:button|input|object|select|textarea)$/i,
        Wa = /^a(?:rea)?$/i,
        ta = /^(?:radio|checkbox)$/i;
    c.props = {
        "for": "htmlFor",
        "class": "className",
        readonly: "readOnly",
        maxlength: "maxLength",
        cellspacing: "cellSpacing",
        rowspan: "rowSpan",
        colspan: "colSpan",
        tabindex: "tabIndex",
        usemap: "useMap",
        frameborder: "frameBorder"
    };
    c.fn.extend({
        attr: function (a, b) {
            return c.access(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 (x) {
                var r = c(this);
                r.addClass(a.call(this, x, r.attr("class")))
            });
            if (a && typeof a === "string") for (var b = (a || "").split(ha), d = 0, e = this.length; d < e; d++) {
                var f = this[d];
                if (f.nodeType === 1) if (f.className) {
                    for (var h = " " + f.className + " ", l = f.className, k = 0, o = b.length; k < o; k++) if (h.indexOf(" " + b[k] + " ") < 0) l += " " + b[k];
                    f.className = c.trim(l)
                } else f.className = a
            }
            return this
        },
        removeClass: function (a) {
            if (c.isFunction(a)) return this.each(function (o) {
                var x = c(this);
                x.removeClass(a.call(this, o, x.attr("class")))
            });
            if (a && typeof a === "string" || a === B) for (var b = (a || "").split(ha), d = 0, e = this.length; d < e; d++) {
                var f = this[d];
                if (f.nodeType === 1 && f.className) if (a) {
                    for (var h = (" " + f.className + " ").replace(bd, " "), l = 0, k = b.length; l < k; l++) h = h.replace(" " + b[l] + " ", " ");
                    f.className = c.trim(h)
                } else f.className = ""
            }
            return this
        },
        toggleClass: function (a, b) {
            var d = typeof a,
                e = typeof b === "boolean";
            if (c.isFunction(a)) return this.each(function (f) {
                var h = c(this);
                h.toggleClass(a.call(this, f, h.attr("class"), b), b)
            });
            return this.each(function () {
                if (d === "string") for (var f, h = 0, l = c(this), k = b, o = a.split(ha); f = o[h++];) {
                    k = e ? k : !l.hasClass(f);
                    l[k ? "addClass" : "removeClass"](f)
                } 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(bd, " ").indexOf(a) > -1) return true;
            return false
        },
        val: function (a) {
            if (!arguments.length) {
                var b = this[0];
                if (b) {
                    if (c.nodeName(b, "option")) {
                        var d = b.attributes.value;
                        return !d || d.specified ? b.value : b.text
                    }
                    if (c.nodeName(b, "select")) {
                        var e = b.selectedIndex;
                        d = [];
                        var f = b.options;
                        b = b.type === "select-one";
                        if (e < 0) return null;
                        var h = b ? e : 0;
                        for (e = b ? e + 1 : f.length; h < e; h++) {
                            var l = f[h];
                            if (l.selected && (c.support.optDisabled ? !l.disabled : l.getAttribute("disabled") === null) && (!l.parentNode.disabled || !c.nodeName(l.parentNode, "optgroup"))) {
                                a = c(l).val();
                                if (b) return a;
                                d.push(a)
                            }
                        }
                        return d
                    }
                    if (ta.test(b.type) && !c.support.checkOn) return b.getAttribute("value") === null ? "on" : b.value;
                    return (b.value || "").replace(Sa, "")
                }
                return B
            }
            var k = c.isFunction(a);
            return this.each(function (o) {
                var x = c(this),
                    r = a;
                if (this.nodeType === 1) {
                    if (k) r = a.call(this, o, x.val());
                    if (r == null) r = "";
                    else if (typeof r === "number") r += "";
                    else if (c.isArray(r)) r = c.map(r, function (C) {
                        return C == null ? "" : C + ""
                    });
                    if (c.isArray(r) && ta.test(this.type)) this.checked = c.inArray(x.val(), r) >= 0;
                    else if (c.nodeName(this, "select")) {
                        var A = c.makeArray(r);
                        c("option", this).each(function () {
                            this.selected = c.inArray(c(this).val(), A) >= 0
                        });
                        if (!A.length) this.selectedIndex = -1
                    } else this.value = r
                }
            })
        }
    });
    c.extend({
        attrFn: {
            val: true,
            css: true,
            html: true,
            text: true,
            data: true,
            width: true,
            height: true,
            offset: true
        },
        attr: function (a, b, d, e) {
            if (!a || a.nodeType === 3 || a.nodeType === 8) return B;
            if (e && b in c.attrFn) return c(a)[b](d);
            e = a.nodeType !== 1 || !c.isXMLDoc(a);
            var f = d !== B;
            b = e && c.props[b] || b;
            var h = Ta.test(b);
            if ((b in a || a[b] !== B) && e && !h) {
                if (f) {
                    b === "type" && Ua.test(a.nodeName) && a.parentNode && c.error("type property can't be changed");
                    if (d === null) a.nodeType === 1 && a.removeAttribute(b);
                    else 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 : Va.test(a.nodeName) || Wa.test(a.nodeName) && a.href ? 0 : B;
                return a[b]
            }
            if (!c.support.style && e && b === "style") {
                if (f) a.style.cssText = "" + d;
                return a.style.cssText
            }
            f && a.setAttribute(b, "" + d);
            if (!a.attributes[b] && a.hasAttribute && !a.hasAttribute(b)) return B;
            a = !c.support.hrefNormalized && e && h ? a.getAttribute(b, 2) : a.getAttribute(b);
            return a === null ? B : a
        }
    });
    var X = /\.(.*)$/,
        ia = /^(?:textarea|input|select)$/i,
        La = /\./g,
        Ma = / /g,
        Xa = /[^\w\s.|`]/g,
        Ya = function (a) {
            return a.replace(Xa, "\\$&")
        },
        ua = {
            focusin: 0,
            focusout: 0
        };
    c.event = {
        add: function (a, b, d, e) {
            if (!(a.nodeType === 3 || a.nodeType === 8)) {
                if (c.isWindow(a) && a !== E && !a.frameElement) a = E;
                if (d === false) d = U;
                else if (!d) return;
                var f, h;
                if (d.handler) {
                    f = d;
                    d = f.handler
                }
                if (!d.guid) d.guid = c.guid++;
                if (h = c.data(a)) {
                    var l = a.nodeType ? "events" : "__events__",
                        k = h[l],
                        o = h.handle;
                    if (typeof k === "function") {
                        o = k.handle;
                        k = k.events
                    } else if (!k) {
                        a.nodeType || (h[l] = h = function () {});
                        h.events = k = {}
                    }
                    if (!o) h.handle = o = function () {
                        return typeof c !== "undefined" && !c.event.triggered ? c.event.handle.apply(o.elem, arguments) : B
                    };
                    o.elem = a;
                    b = b.split(" ");
                    for (var x = 0, r; l = b[x++];) {
                        h = f ? c.extend({}, f) : {
                            handler: d,
                            data: e
                        };
                        if (l.indexOf(".") > -1) {
                            r = l.split(".");
                            l = r.shift();
                            h.namespace = r.slice(0).sort().join(".")
                        } else {
                            r = [];
                            h.namespace = ""
                        }
                        h.type = l;
                        if (!h.guid) h.guid = d.guid;
                        var A = k[l],
                            C = c.event.special[l] || {};
                        if (!A) {
                            A = k[l] = [];
                            if (!C.setup || C.setup.call(a, e, r, o) === false) if (a.addEventListener) a.addEventListener(l, o, false);
                            else a.attachEvent && a.attachEvent("on" + l, o)
                        }
                        if (C.add) {
                            C.add.call(a, h);
                            if (!h.handler.guid) h.handler.guid = d.guid
                        }
                        A.push(h);
                        c.event.global[l] = true
                    }
                    a = null
                }
            }
        },
        global: {},
        remove: function (a, b, d, e) {
            if (!(a.nodeType === 3 || a.nodeType === 8)) {
                if (d === false) d = U;
                var f, h, l = 0,
                    k, o, x, r, A, C, J = a.nodeType ? "events" : "__events__",
                    w = c.data(a),
                    I = w && w[J];
                if (w && I) {
                    if (typeof I === "function") {
                        w = I;
                        I = I.events
                    }
                    if (b && b.type) {
                        d = b.handler;
                        b = b.type
                    }
                    if (!b || typeof b === "string" && b.charAt(0) === ".") {
                        b = b || "";
                        for (f in I) c.event.remove(a, f + b)
                    } else {
                        for (b = b.split(" "); f = b[l++];) {
                            r = f;
                            k = f.indexOf(".") < 0;
                            o = [];
                            if (!k) {
                                o = f.split(".");
                                f = o.shift();
                                x = RegExp("(^|\\.)" + c.map(o.slice(0).sort(), Ya).join("\\.(?:.*\\.)?") + "(\\.|$)")
                            }
                            if (A = I[f]) if (d) {
                                r = c.event.special[f] || {};
                                for (h = e || 0; h < A.length; h++) {
                                    C = A[h];
                                    if (d.guid === C.guid) {
                                        if (k || x.test(C.namespace)) {
                                            e == null && A.splice(h--, 1);
                                            r.remove && r.remove.call(a, C)
                                        }
                                        if (e != null) break
                                    }
                                }
                                if (A.length === 0 || e != null && A.length === 1) {
                                    if (!r.teardown || r.teardown.call(a, o) === false) c.removeEvent(a, f, w.handle);
                                    delete I[f]
                                }
                            } else for (h = 0; h < A.length; h++) {
                                C = A[h];
                                if (k || x.test(C.namespace)) {
                                    c.event.remove(a, r, C.handler, h);
                                    A.splice(h--, 1)
                                }
                            }
                        }
                        if (c.isEmptyObject(I)) {
                            if (b = w.handle) b.elem = null;
                            delete w.events;
                            delete w.handle;
                            if (typeof w === "function") c.removeData(a, J);
                            else c.isEmptyObject(w) && c.removeData(a)
                        }
                    }
                }
            }
        },
        trigger: function (a, b, d, e) {
            var f = a.type || a;
            if (!e) {
                a = typeof a === "object" ? a[c.expando] ? a : c.extend(c.Event(f), a) : c.Event(f);
                if (f.indexOf("!") >= 0) {
                    a.type = f = f.slice(0, -1);
                    a.exclusive = true
                }
                if (!d) {
                    a.stopPropagation();
                    c.event.global[f] && c.each(c.cache, function () {
                        this.events && this.events[f] && c.event.trigger(a, b, this.handle.elem)
                    })
                }
                if (!d || d.nodeType === 3 || d.nodeType === 8) return B;
                a.result = B;
                a.target = d;
                b = c.makeArray(b);
                b.unshift(a)
            }
            a.currentTarget = d;
            (e = d.nodeType ? c.data(d, "handle") : (c.data(d, "__events__") || {}).handle) && e.apply(d, b);
            e = d.parentNode || d.ownerDocument;
            try {
                if (!(d && d.nodeName && c.noData[d.nodeName.toLowerCase()])) if (d["on" + f] && d["on" + f].apply(d, b) === false) {
                    a.result = false;
                    a.preventDefault()
                }
            } catch (h) {}
            if (!a.isPropagationStopped() && e) c.event.trigger(a, b, e, true);
            else if (!a.isDefaultPrevented()) {
                var l;
                e = a.target;
                var k = f.replace(X, ""),
                    o = c.nodeName(e, "a") && k === "click",
                    x = c.event.special[k] || {};
                if ((!x._default || x._default.call(d, a) === false) && !o && !(e && e.nodeName && c.noData[e.nodeName.toLowerCase()])) {
                    try {
                        if (e[k]) {
                            if (l = e["on" + k]) e["on" + k] = null;
                            c.event.triggered = true;
                            e[k]()
                        }
                    } catch (r) {}
                    if (l) e["on" + k] = l;
                    c.event.triggered = false
                }
            }
        },
        handle: function (a) {
            var b, d, e, f;
            d = [];
            var h = c.makeArray(arguments);
            a = h[0] = c.event.fix(a || E.event);
            a.currentTarget = this;
            b = a.type.indexOf(".") < 0 && !a.exclusive;
            if (!b) {
                e = a.type.split(".");
                a.type = e.shift();
                d = e.slice(0).sort();
                e = RegExp("(^|\\.)" + d.join("\\.(?:.*\\.)?") + "(\\.|$)")
            }
            a.namespace = a.namespace || d.join(".");
            f = c.data(this, this.nodeType ? "events" : "__events__");
            if (typeof f === "function") f = f.events;
            d = (f || {})[a.type];
            if (f && d) {
                d = d.slice(0);
                f = 0;
                for (var l = d.length; f < l; f++) {
                    var k = d[f];
                    if (b || e.test(k.namespace)) {
                        a.handler = k.handler;
                        a.data = k.data;
                        a.handleObj = k;
                        k = k.handler.apply(this, h);
                        if (k !== B) {
                            a.result = k;
                            if (k === 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 pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which".split(" "),
        fix: function (a) {
            if (a[c.expando]) return a;
            var b = a;
            a = c.Event(b);
            for (var d = this.props.length, e; d;) {
                e = this.props[--d];
                a[e] = b[e]
            }
            if (!a.target) a.target = a.srcElement || t;
            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 = t.documentElement;
                d = t.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 == null && (a.charCode != null || a.keyCode != null)) a.which = a.charCode != null ? a.charCode : a.keyCode;
            if (!a.metaKey && a.ctrlKey) a.metaKey = a.ctrlKey;
            if (!a.which && a.button !== B) a.which = a.button & 1 ? 1 : a.button & 2 ? 3 : a.button & 4 ? 2 : 0;
            return a
        },
        guid: 1E8,
        proxy: c.proxy,
        special: {
            ready: {
                setup: c.bindReady,
                teardown: c.noop
            },
            live: {
                add: function (a) {
                    c.event.add(this, Y(a.origType, a.selector), c.extend({}, a, {
                        handler: Ka,
                        guid: a.handler.guid
                    }))
                },
                remove: function (a) {
                    c.event.remove(this, Y(a.origType, a.selector), a)
                }
            },
            beforeunload: {
                setup: function (a, b, d) {
                    if (c.isWindow(this)) this.onbeforeunload = d
                },
                teardown: function (a, b) {
                    if (this.onbeforeunload === b) this.onbeforeunload = null
                }
            }
        }
    };
    c.removeEvent = t.removeEventListener ?
    function (a, b, d) {
        a.removeEventListener && a.removeEventListener(b, d, false)
    } : function (a, b, d) {
        a.detachEvent && a.detachEvent("on" + b, d)
    };
    c.Event = function (a) {
        if (!this.preventDefault) return new c.Event(a);
        if (a && a.type) {
            this.originalEvent = a;
            this.type = a.type
        } else this.type = a;
        this.timeStamp = c.now();
        this[c.expando] = true
    };
    c.Event.prototype = {
        preventDefault: function () {
            this.isDefaultPrevented = ca;
            var a = this.originalEvent;
            if (a) if (a.preventDefault) a.preventDefault();
            else a.returnValue = false
        },
        stopPropagation: function () {
            this.isPropagationStopped = ca;
            var a = this.originalEvent;
            if (a) {
                a.stopPropagation && a.stopPropagation();
                a.cancelBubble = true
            }
        },
        stopImmediatePropagation: function () {
            this.isImmediatePropagationStopped = ca;
            this.stopPropagation()
        },
        isDefaultPrevented: U,
        isPropagationStopped: U,
        isImmediatePropagationStopped: U
    };
    var be = function (a) {
            var b = a.relatedTarget;
            try {
                for (; b && b !== this;) b = b.parentNode;
                if (b !== this) {
                    a.type = a.data;
                    c.event.handle.apply(this, arguments)
                }
            } catch (d) {}
        },
        wa = 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 ? wa : be, a)
            },
            teardown: function (d) {
                c.event.remove(this, b, d && d.selector ? wa : be)
            }
        }
    });
    if (!c.support.submitBubbles) c.event.special.submit = {
        setup: function () {
            if (this.nodeName.toLowerCase() !== "form") {
                c.event.add(this, "click.specialSubmit", function (a) {
                    var b = a.target,
                        d = b.type;
                    if ((d === "submit" || d === "image") && c(b).closest("form").length) {
                        a.liveFired = B;
                        return la("submit", this, arguments)
                    }
                });
                c.event.add(this, "keypress.specialSubmit", function (a) {
                    var b = a.target,
                        d = b.type;
                    if ((d === "text" || d === "password") && c(b).closest("form").length && a.keyCode === 13) {
                        a.liveFired = B;
                        return la("submit", this, arguments)
                    }
                })
            } else return false
        },
        teardown: function () {
            c.event.remove(this, ".specialSubmit")
        }
    };
    if (!c.support.changeBubbles) {
        var V, xa = function (a) {
                var b = a.type,
                    d = a.value;
                if (b === "radio" || b === "checkbox") d = a.checked;
                else if (b === "select-multiple") d = a.selectedIndex > -1 ? c.map(a.options, function (e) {
                    return e.selected
                }).join("-") : "";
                else if (a.nodeName.toLowerCase() === "select") d = a.selectedIndex;
                return d
            },
            Z = function (a, b) {
                var d = a.target,
                    e, f;
                if (!(!ia.test(d.nodeName) || d.readOnly)) {
                    e = c.data(d, "_change_data");
                    f = xa(d);
                    if (a.type !== "focusout" || d.type !== "radio") c.data(d, "_change_data", f);
                    if (!(e === B || f === e)) if (e != null || f) {
                        a.type = "change";
                        a.liveFired = B;
                        return c.event.trigger(a, b, d)
                    }
                }
            };
        c.event.special.change = {
            filters: {
                focusout: Z,
                beforedeactivate: Z,
                click: function (a) {
                    var b = a.target,
                        d = b.type;
                    if (d === "radio" || d === "checkbox" || b.nodeName.toLowerCase() === "select") return Z.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 Z.call(this, a)
                },
                beforeactivate: function (a) {
                    a = a.target;
                    c.data(a, "_change_data", xa(a))
                }
            },
            setup: function () {
                if (this.type === "file") return false;
                for (var a in V) c.event.add(this, a + ".specialChange", V[a]);
                return ia.test(this.nodeName)
            },
            teardown: function () {
                c.event.remove(this, ".specialChange");
                return ia.test(this.nodeName)
            }
        };
        V = c.event.special.change.filters;
        V.focus = V.beforeactivate
    }
    t.addEventListener && c.each({
        focus: "focusin",
        blur: "focusout"
    }, function (a, b) {
        function d(e) {
            e = c.event.fix(e);
            e.type = b;
            return c.event.trigger(e, null, e.target)
        }
        c.event.special[b] = {
            setup: function () {
                ua[b]++ === 0 && t.addEventListener(a, d, true)
            },
            teardown: function () {
                --ua[b] === 0 && t.removeEventListener(a, d, true)
            }
        }
    });
    c.each(["bind", "one"], function (a, b) {
        c.fn[b] = function (d, e, f) {
            if (typeof d === "object") {
                for (var h in d) this[b](h, e, d[h], f);
                return this
            }
            if (c.isFunction(e) || e === false) {
                f = e;
                e = B
            }
            var l = b === "one" ? c.proxy(f, function (o) {
                c(this).unbind(o, l);
                return f.apply(this, arguments)
            }) : f;
            if (d === "unload" && b !== "one") this.one(d, e, f);
            else {
                h = 0;
                for (var k = this.length; h < k; h++) c.event.add(this[h], d, l, e)
            }
            return this
        }
    });
    c.fn.extend({
        unbind: function (a, b) {
            if (typeof a === "object" && !a.preventDefault) for (var d in a) this.unbind(d, a[d]);
            else {
                d = 0;
                for (var e = this.length; d < e; d++) c.event.remove(this[d], a, b)
            }
            return this
        },
        delegate: function (a, b, d, e) {
            return this.live(b, d, e, a)
        },
        undelegate: function (a, b, d) {
            return arguments.length === 0 ? this.unbind("live") : this.die(b, null, d, a)
        },
        trigger: function (a, b) {
            return this.each(function () {
                c.event.trigger(a, b, this)
            })
        },
        triggerHandler: function (a, b) {
            if (this[0]) {
                var d = c.Event(a);
                d.preventDefault();
                d.stopPropagation();
                c.event.trigger(d, b, this[0]);
                return d.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 (e) {
                var f = (c.data(this, "lastToggle" + a.guid) || 0) % d;
                c.data(this, "lastToggle" + a.guid, f + 1);
                e.preventDefault();
                return b[f].apply(this, arguments) || false
            }))
        },
        hover: function (a, b) {
            return this.mouseenter(a).mouseleave(b || a)
        }
    });
    var bf = {
        focus: "focusin",
        blur: "focusout",
        mouseenter: "mouseover",
        mouseleave: "mouseout"
    };
    c.each(["live", "die"], function (a, b) {
        c.fn[b] = function (d, e, f, h) {
            var l, k = 0,
                o, x, r = h || this.selector;
            h = h ? this : c(this.context);
            if (typeof d === "object" && !d.preventDefault) {
                for (l in d) h[b](l, e, d[l], r);
                return this
            }
            if (c.isFunction(e)) {
                f = e;
                e = B
            }
            for (d = (d || "").split(" ");
            (l = d[k++]) != null;) {
                o = X.exec(l);
                x = "";
                if (o) {
                    x = o[0];
                    l = l.replace(X, "")
                }
                if (l === "hover") d.push("mouseenter" + x, "mouseleave" + x);
                else {
                    o = l;
                    if (l === "focus" || l === "blur") {
                        d.push(bf[l] + x);
                        l += x
                    } else l = (bf[l] || l) + x;
                    if (b === "live") {
                        x = 0;
                        for (var A = h.length; x < A; x++) c.event.add(h[x], "live." + Y(l, r), {
                            data: e,
                            selector: r,
                            handler: f,
                            origType: l,
                            origHandler: f,
                            preType: o
                        })
                    } else h.unbind("live." + Y(l, r), f)
                }
            }
            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, e) {
            if (e == null) {
                e = d;
                d = null
            }
            return arguments.length > 0 ? this.bind(b, d, e) : this.trigger(b)
        };
        if (c.attrFn) c.attrFn[b] = true
    });
    E.attachEvent && !E.addEventListener && c(E).bind("unload", 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, i, n, m, p, q) {
            p = 0;
            for (var u = m.length; p < u; p++) {
                var y = m[p];
                if (y) {
                    var F = false;
                    for (y = y[g]; y;) {
                        if (y.sizcache === n) {
                            F = m[y.sizset];
                            break
                        }
                        if (y.nodeType === 1 && !q) {
                            y.sizcache = n;
                            y.sizset = p
                        }
                        if (y.nodeName.toLowerCase() === i) {
                            F = y;
                            break
                        }
                        y = y[g]
                    }
                    m[p] = F
                }
            }
        }
        function b(g, i, n, m, p, q) {
            p = 0;
            for (var u = m.length; p < u; p++) {
                var y = m[p];
                if (y) {
                    var F = false;
                    for (y = y[g]; y;) {
                        if (y.sizcache === n) {
                            F = m[y.sizset];
                            break
                        }
                        if (y.nodeType === 1) {
                            if (!q) {
                                y.sizcache = n;
                                y.sizset = p
                            }
                            if (typeof i !== "string") {
                                if (y === i) {
                                    F = true;
                                    break
                                }
                            } else if (k.filter(i, [y]).length > 0) {
                                F = y;
                                break
                            }
                        }
                        y = y[g]
                    }
                    m[p] = F
                }
            }
        }
        var d = /((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^\[\]]*\]|['"][^'"]*['"]|[^\[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g,
            e = 0,
            f = Object.prototype.toString,
            h = false,
            l = true;
        [0, 0].sort(function () {
            l = false;
            return 0
        });
        var k = function (g, i, n, m) {
                n = n || [];
                var p = i = i || t;
                if (i.nodeType !== 1 && i.nodeType !== 9) return [];
                if (!g || typeof g !== "string") return n;
                var q, u, y, F, M, N = true,
                    O = k.isXML(i),
                    D = [],
                    R = g;
                do {
                    d.exec("");
                    if (q = d.exec(R)) {
                        R = q[3];
                        D.push(q[1]);
                        if (q[2]) {
                            F = q[3];
                            break
                        }
                    }
                } while (q);
                if (D.length > 1 && x.exec(g)) if (D.length === 2 && o.relative[D[0]]) u = L(D[0] + D[1], i);
                else for (u = o.relative[D[0]] ? [i] : k(D.shift(), i); D.length;) {
                    g = D.shift();
                    if (o.relative[g]) g += D.shift();
                    u = L(g, u)
                } else {
                    if (!m && D.length > 1 && i.nodeType === 9 && !O && o.match.ID.test(D[0]) && !o.match.ID.test(D[D.length - 1])) {
                        q = k.find(D.shift(), i, O);
                        i = q.expr ? k.filter(q.expr, q.set)[0] : q.set[0]
                    }
                    if (i) {
                        q = m ? {
                            expr: D.pop(),
                            set: C(m)
                        } : k.find(D.pop(), D.length === 1 && (D[0] === "~" || D[0] === "+") && i.parentNode ? i.parentNode : i, O);
                        u = q.expr ? k.filter(q.expr, q.set) : q.set;
                        if (D.length > 0) y = C(u);
                        else N = false;
                        for (; D.length;) {
                            q = M = D.pop();
                            if (o.relative[M]) q = D.pop();
                            else M = "";
                            if (q == null) q = i;
                            o.relative[M](y, q, O)
                        }
                    } else y = []
                }
                y || (y = u);
                y || k.error(M || g);
                if (f.call(y) === "[object Array]") if (N) if (i && i.nodeType === 1) for (g = 0; y[g] != null; g++) {
                    if (y[g] && (y[g] === true || y[g].nodeType === 1 && k.contains(i, y[g]))) n.push(u[g])
                } else for (g = 0; y[g] != null; g++) y[g] && y[g].nodeType === 1 && n.push(u[g]);
                else n.push.apply(n, y);
                else C(y, n);
                if (F) {
                    k(F, p, n, m);
                    k.uniqueSort(n)
                }
                return n
            };
        k.uniqueSort = function (g) {
            if (w) {
                h = l;
                g.sort(w);
                if (h) for (var i = 1; i < g.length; i++) g[i] === g[i - 1] && g.splice(i--, 1)
            }
            return g
        };
        k.matches = function (g, i) {
            return k(g, null, null, i)
        };
        k.matchesSelector = function (g, i) {
            return k(i, null, null, [g]).length > 0
        };
        k.find = function (g, i, n) {
            var m;
            if (!g) return [];
            for (var p = 0, q = o.order.length; p < q; p++) {
                var u, y = o.order[p];
                if (u = o.leftMatch[y].exec(g)) {
                    var F = u[1];
                    u.splice(1, 1);
                    if (F.substr(F.length - 1) !== "\\") {
                        u[1] = (u[1] || "").replace(/\\/g, "");
                        m = o.find[y](u, i, n);
                        if (m != null) {
                            g = g.replace(o.match[y], "");
                            break
                        }
                    }
                }
            }
            m || (m = i.getElementsByTagName("*"));
            return {
                set: m,
                expr: g
            }
        };
        k.filter = function (g, i, n, m) {
            for (var p, q, u = g, y = [], F = i, M = i && i[0] && k.isXML(i[0]); g && i.length;) {
                for (var N in o.filter) if ((p = o.leftMatch[N].exec(g)) != null && p[2]) {
                    var O, D, R = o.filter[N];
                    D = p[1];
                    q = false;
                    p.splice(1, 1);
                    if (D.substr(D.length - 1) !== "\\") {
                        if (F === y) y = [];
                        if (o.preFilter[N]) if (p = o.preFilter[N](p, F, n, y, m, M)) {
                            if (p === true) continue
                        } else q = O = true;
                        if (p) for (var j = 0;
                        (D = F[j]) != null; j++) if (D) {
                            O = R(D, p, j, F);
                            var s = m ^ !! O;
                            if (n && O != null) if (s) q = true;
                            else F[j] = false;
                            else if (s) {
                                y.push(D);
                                q = true
                            }
                        }
                        if (O !== B) {
                            n || (F = y);
                            g = g.replace(o.match[N], "");
                            if (!q) return [];
                            break
                        }
                    }
                }
                if (g === u) if (q == null) k.error(g);
                else break;
                u = g
            }
            return F
        };
        k.error = function (g) {
            throw "Syntax error, unrecognized expression: " + g;
        };
        var o = k.selectors = {
            order: ["ID", "NAME", "TAG"],
            match: {
                ID: /#((?:[\w\u00c0-\uFFFF\-]|\\.)+)/,
                CLASS: /\.((?:[\w\u00c0-\uFFFF\-]|\\.)+)/,
                NAME: /\[name=['"]*((?:[\w\u00c0-\uFFFF\-]|\\.)+)['"]*\]/,
                ATTR: /\[\s*((?:[\w\u00c0-\uFFFF\-]|\\.)+)\s*(?:(\S?=)\s*(['"]*)(.*?)\3|)\s*\]/,
                TAG: /^((?:[\w\u00c0-\uFFFF\*\-]|\\.)+)/,
                CHILD: /:(only|nth|last|first)-child(?:\((even|odd|[\dn+\-]*)\))?/,
                POS: /:(nth|eq|gt|lt|first|last|even|odd)(?:\((\d*)\))?(?=[^\-]|$)/,
                PSEUDO: /:((?:[\w\u00c0-\uFFFF\-]|\\.)+)(?:\((['"]?)((?:\([^\)]+\)|[^\(\)]*)+)\2\))?/
            },
            leftMatch: {},
            attrMap: {
                "class": "className",
                "for": "htmlFor"
            },
            attrHandle: {
                href: function (g) {
                    return g.getAttribute("href")
                }
            },
            relative: {
                "+": function (g, i) {
                    var n = typeof i === "string",
                        m = n && !/\W/.test(i);
                    n = n && !m;
                    if (m) i = i.toLowerCase();
                    m = 0;
                    for (var p = g.length, q; m < p; m++) if (q = g[m]) {
                        for (;
                        (q = q.previousSibling) && q.nodeType !== 1;);
                        g[m] = n || q && q.nodeName.toLowerCase() === i ? q || false : q === i
                    }
                    n && k.filter(i, g, true)
                },
                ">": function (g, i) {
                    var n, m = typeof i === "string",
                        p = 0,
                        q = g.length;
                    if (m && !/\W/.test(i)) for (i = i.toLowerCase(); p < q; p++) {
                        if (n = g[p]) {
                            n = n.parentNode;
                            g[p] = n.nodeName.toLowerCase() === i ? n : false
                        }
                    } else {
                        for (; p < q; p++) if (n = g[p]) g[p] = m ? n.parentNode : n.parentNode === i;
                        m && k.filter(i, g, true)
                    }
                },
                "": function (g, i, n) {
                    var m, p = e++,
                        q = b;
                    if (typeof i === "string" && !/\W/.test(i)) {
                        m = i = i.toLowerCase();
                        q = a
                    }
                    q("parentNode", i, p, g, m, n)
                },
                "~": function (g, i, n) {
                    var m, p = e++,
                        q = b;
                    if (typeof i === "string" && !/\W/.test(i)) {
                        m = i = i.toLowerCase();
                        q = a
                    }
                    q("previousSibling", i, p, g, m, n)
                }
            },
            find: {
                ID: function (g, i, n) {
                    if (typeof i.getElementById !== "undefined" && !n) return (g = i.getElementById(g[1])) && g.parentNode ? [g] : []
                },
                NAME: function (g, i) {
                    if (typeof i.getElementsByName !== "undefined") {
                        for (var n = [], m = i.getElementsByName(g[1]), p = 0, q = m.length; p < q; p++) m[p].getAttribute("name") === g[1] && n.push(m[p]);
                        return n.length === 0 ? null : n
                    }
                },
                TAG: function (g, i) {
                    return i.getElementsByTagName(g[1])
                }
            },
            preFilter: {
                CLASS: function (g, i, n, m, p, q) {
                    g = " " + g[1].replace(/\\/g, "") + " ";
                    if (q) return g;
                    q = 0;
                    for (var u;
                    (u = i[q]) != null; q++) if (u) if (p ^ (u.className && (" " + u.className + " ").replace(/[\t\n]/g, " ").indexOf(g) >= 0)) n || m.push(u);
                    else if (n) i[q] = 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 i = /(-?)(\d*)n((?:\+|-)?\d*)/.exec(g[2] === "even" && "2n" || g[2] === "odd" && "2n+1" || !/\D/.test(g[2]) && "0n+" + g[2] || g[2]);
                        g[2] = i[1] + (i[2] || 1) - 0;
                        g[3] = i[3] - 0
                    }
                    g[0] = e++;
                    return g
                },
                ATTR: function (g, i, n, m, p, q) {
                    i = g[1].replace(/\\/g, "");
                    if (!q && o.attrMap[i]) g[1] = o.attrMap[i];
                    if (g[2] === "~=") g[4] = " " + g[4] + " ";
                    return g
                },
                PSEUDO: function (g, i, n, m, p) {
                    if (g[1] === "not") if ((d.exec(g[3]) || "").length > 1 || /^\w/.test(g[3])) g[3] = k(g[3], null, null, i);
                    else {
                        g = k.filter(g[3], i, n, true ^ p);
                        n || m.push.apply(m, g);
                        return false
                    } else if (o.match.POS.test(g[0]) || o.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, i, n) {
                    return !!k(n[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, i) {
                    return i === 0
                },
                last: function (g, i, n, m) {
                    return i === m.length - 1
                },
                even: function (g, i) {
                    return i % 2 === 0
                },
                odd: function (g, i) {
                    return i % 2 === 1
                },
                lt: function (g, i, n) {
                    return i < n[3] - 0
                },
                gt: function (g, i, n) {
                    return i > n[3] - 0
                },
                nth: function (g, i, n) {
                    return n[3] - 0 === i
                },
                eq: function (g, i, n) {
                    return n[3] - 0 === i
                }
            },
            filter: {
                PSEUDO: function (g, i, n, m) {
                    var p = i[1],
                        q = o.filters[p];
                    if (q) return q(g, n, i, m);
                    else if (p === "contains") return (g.textContent || g.innerText || k.getText([g]) || "").indexOf(i[3]) >= 0;
                    else if (p === "not") {
                        i = i[3];
                        n = 0;
                        for (m = i.length; n < m; n++) if (i[n] === g) return false;
                        return true
                    } else k.error("Syntax error, unrecognized expression: " + p)
                },
                CHILD: function (g, i) {
                    var n = i[1],
                        m = g;
                    switch (n) {
                    case "only":
                    case "first":
                        for (; m = m.previousSibling;) if (m.nodeType === 1) return false;
                        if (n === "first") return true;
                        m = g;
                    case "last":
                        for (; m = m.nextSibling;) if (m.nodeType === 1) return false;
                        return true;
                    case "nth":
                        n = i[2];
                        var p = i[3];
                        if (n === 1 && p === 0) return true;
                        var q = i[0],
                            u = g.parentNode;
                        if (u && (u.sizcache !== q || !g.nodeIndex)) {
                            var y = 0;
                            for (m = u.firstChild; m; m = m.nextSibling) if (m.nodeType === 1) m.nodeIndex = ++y;
                            u.sizcache = q
                        }
                        m = g.nodeIndex - p;
                        return n === 0 ? m === 0 : m % n === 0 && m / n >= 0
                    }
                },
                ID: function (g, i) {
                    return g.nodeType === 1 && g.getAttribute("id") === i
                },
                TAG: function (g, i) {
                    return i === "*" && g.nodeType === 1 || g.nodeName.toLowerCase() === i
                },
                CLASS: function (g, i) {
                    return (" " + (g.className || g.getAttribute("class")) + " ").indexOf(i) > -1
                },
                ATTR: function (g, i) {
                    var n = i[1];
                    n = o.attrHandle[n] ? o.attrHandle[n](g) : g[n] != null ? g[n] : g.getAttribute(n);
                    var m = n + "",
                        p = i[2],
                        q = i[4];
                    return n == null ? p === "!=" : p === "=" ? m === q : p === "*=" ? m.indexOf(q) >= 0 : p === "~=" ? (" " + m + " ").indexOf(q) >= 0 : !q ? m && n !== false : p === "!=" ? m !== q : p === "^=" ? m.indexOf(q) === 0 : p === "$=" ? m.substr(m.length - q.length) === q : p === "|=" ? m === q || m.substr(0, q.length + 1) === q + "-" : false
                },
                POS: function (g, i, n, m) {
                    var p = o.setFilters[i[2]];
                    if (p) return p(g, n, i, m)
                }
            }
        },
            x = o.match.POS,
            r = function (g, i) {
                return "\\" + (i - 0 + 1)
            },
            A;
        for (A in o.match) {
            o.match[A] = RegExp(o.match[A].source + /(?![^\[]*\])(?![^\(]*\))/.source);
            o.leftMatch[A] = RegExp(/(^(?:.|\r|\n)*?)/.source + o.match[A].source.replace(/\\(\d+)/g, r))
        }
        var C = function (g, i) {
                g = Array.prototype.slice.call(g, 0);
                if (i) {
                    i.push.apply(i, g);
                    return i
                }
                return g
            };
        try {
            Array.prototype.slice.call(t.documentElement.childNodes, 0)
        } catch (J) {
            C = function (g, i) {
                var n = 0,
                    m = i || [];
                if (f.call(g) === "[object Array]") Array.prototype.push.apply(m, g);
                else if (typeof g.length === "number") for (var p = g.length; n < p; n++) m.push(g[n]);
                else for (; g[n]; n++) m.push(g[n]);
                return m
            }
        }
        var w, I;
        if (t.documentElement.compareDocumentPosition) w = function (g, i) {
            if (g === i) {
                h = true;
                return 0
            }
            if (!g.compareDocumentPosition || !i.compareDocumentPosition) return g.compareDocumentPosition ? -1 : 1;
            return g.compareDocumentPosition(i) & 4 ? -1 : 1
        };
        else {
            w = function (g, i) {
                var n, m, p = [],
                    q = [];
                n = g.parentNode;
                m = i.parentNode;
                var u = n;
                if (g === i) {
                    h = true;
                    return 0
                } else if (n === m) return I(g, i);
                else if (n) {
                    if (!m) return 1
                } else return -1;
                for (; u;) {
                    p.unshift(u);
                    u = u.parentNode
                }
                for (u = m; u;) {
                    q.unshift(u);
                    u = u.parentNode
                }
                n = p.length;
                m = q.length;
                for (u = 0; u < n && u < m; u++) if (p[u] !== q[u]) return I(p[u], q[u]);
                return u === n ? I(g, q[u], -1) : I(p[u], i, 1)
            };
            I = function (g, i, n) {
                if (g === i) return n;
                for (g = g.nextSibling; g;) {
                    if (g === i) return -1;
                    g = g.nextSibling
                }
                return 1
            }
        }
        k.getText = function (g) {
            for (var i = "", n, m = 0; g[m]; m++) {
                n = g[m];
                if (n.nodeType === 3 || n.nodeType === 4) i += n.nodeValue;
                else if (n.nodeType !== 8) i += k.getText(n.childNodes)
            }
            return i
        };
        (function () {
            var g = t.createElement("div"),
                i = "script" + (new Date).getTime(),
                n = t.documentElement;
            g.innerHTML = "<a name='" + i + "'/>";
            n.insertBefore(g, n.firstChild);
            if (t.getElementById(i)) {
                o.find.ID = function (m, p, q) {
                    if (typeof p.getElementById !== "undefined" && !q) return (p = p.getElementById(m[1])) ? p.id === m[1] || typeof p.getAttributeNode !== "undefined" && p.getAttributeNode("id").nodeValue === m[1] ? [p] : B : []
                };
                o.filter.ID = function (m, p) {
                    var q = typeof m.getAttributeNode !== "undefined" && m.getAttributeNode("id");
                    return m.nodeType === 1 && q && q.nodeValue === p
                }
            }
            n.removeChild(g);
            n = g = null
        })();
        (function () {
            var g = t.createElement("div");
            g.appendChild(t.createComment(""));
            if (g.getElementsByTagName("*").length > 0) o.find.TAG = function (i, n) {
                var m = n.getElementsByTagName(i[1]);
                if (i[1] === "*") {
                    for (var p = [], q = 0; m[q]; q++) m[q].nodeType === 1 && p.push(m[q]);
                    m = p
                }
                return m
            };
            g.innerHTML = "<a href='#'></a>";
            if (g.firstChild && typeof g.firstChild.getAttribute !== "undefined" && g.firstChild.getAttribute("href") !== "#") o.attrHandle.href = function (i) {
                return i.getAttribute("href", 2)
            };
            g = null
        })();
        t.querySelectorAll &&
        function () {
            var g = k,
                i = t.createElement("div");
            i.innerHTML = "<p class='TEST'></p>";
            if (!(i.querySelectorAll && i.querySelectorAll(".TEST").length === 0)) {
                k = function (m, p, q, u) {
                    p = p || t;
                    m = m.replace(/\=\s*([^'"\]]*)\s*\]/g, "='$1']");
                    if (!u && !k.isXML(p)) if (p.nodeType === 9) try {
                        return C(p.querySelectorAll(m), q)
                    } catch (y) {} else if (p.nodeType === 1 && p.nodeName.toLowerCase() !== "object") {
                        var F = p.getAttribute("id"),

                            M = F || "__sizzle__";
                        F || p.setAttribute("id", M);
                        try {
                            return C(p.querySelectorAll("#" + M + " " + m), q)
                        } catch (N) {} finally {
                            F || p.removeAttribute("id")
                        }
                    }
                    return g(m, p, q, u)
                };
                for (var n in g) k[n] = g[n];
                i = null
            }
        }();
        (function () {
            var g = t.documentElement,
                i = g.matchesSelector || g.mozMatchesSelector || g.webkitMatchesSelector || g.msMatchesSelector,
                n = false;
            try {
                i.call(t.documentElement, "[test!='']:sizzle")
            } catch (m) {
                n = true
            }
            if (i) k.matchesSelector = function (p, q) {
                q = q.replace(/\=\s*([^'"\]]*)\s*\]/g, "='$1']");
                if (!k.isXML(p)) try {
                    if (n || !o.match.PSEUDO.test(q) && !/!=/.test(q)) return i.call(p, q)
                } catch (u) {}
                return k(q, null, null, [p]).length > 0
            }
        })();
        (function () {
            var g = t.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) {
                    o.order.splice(1, 0, "CLASS");
                    o.find.CLASS = function (i, n, m) {
                        if (typeof n.getElementsByClassName !== "undefined" && !m) return n.getElementsByClassName(i[1])
                    };
                    g = null
                }
            }
        })();
        k.contains = t.documentElement.contains ?
        function (g, i) {
            return g !== i && (g.contains ? g.contains(i) : true)
        } : t.documentElement.compareDocumentPosition ?
        function (g, i) {
            return !!(g.compareDocumentPosition(i) & 16)
        } : function () {
            return false
        };
        k.isXML = function (g) {
            return (g = (g ? g.ownerDocument || g : 0).documentElement) ? g.nodeName !== "HTML" : false
        };
        var L = function (g, i) {
                for (var n, m = [], p = "", q = i.nodeType ? [i] : i; n = o.match.PSEUDO.exec(g);) {
                    p += n[0];
                    g = g.replace(o.match.PSEUDO, "")
                }
                g = o.relative[g] ? g + "*" : g;
                n = 0;
                for (var u = q.length; n < u; n++) k(g, q[n], m);
                return k.filter(p, m)
            };
        c.find = k;
        c.expr = k.selectors;
        c.expr[":"] = c.expr.filters;
        c.unique = k.uniqueSort;
        c.text = k.getText;
        c.isXMLDoc = k.isXML;
        c.contains = k.contains
    })();
    var bg = /Until$/,
        $a = /^(?:parents|prevUntil|prevAll)/,
        ab = /,/,
        Na = /^.[^:#\[\.,]*$/,
        bb = Array.prototype.slice,
        cb = c.expr.match.POS;
    c.fn.extend({
        find: function (a) {
            for (var b = this.pushStack("", "find", a), d = 0, e = 0, f = this.length; e < f; e++) {
                d = b.length;
                c.find(a, this[e], b);
                if (e > 0) for (var h = d; h < b.length; h++) for (var l = 0; l < d; l++) if (b[l] === b[h]) {
                    b.splice(h--, 1);
                    break
                }
            }
            return b
        },
        has: function (a) {
            var b = c(a);
            return this.filter(function () {
                for (var d = 0, e = b.length; d < e; d++) if (c.contains(this, b[d])) return true
            })
        },
        not: function (a) {
            return this.pushStack(ma(this, a, false), "not", a)
        },
        filter: function (a) {
            return this.pushStack(ma(this, a, true), "filter", a)
        },
        is: function (a) {
            return !!a && c.filter(a, this).length > 0
        },
        closest: function (a, b) {
            var d = [],
                e, f, h = this[0];
            if (c.isArray(a)) {
                var l, k = {},
                    o = 1;
                if (h && a.length) {
                    e = 0;
                    for (f = a.length; e < f; e++) {
                        l = a[e];
                        k[l] || (k[l] = c.expr.match.POS.test(l) ? c(l, b || this.context) : l)
                    }
                    for (; h && h.ownerDocument && h !== b;) {
                        for (l in k) {
                            e = k[l];
                            if (e.jquery ? e.index(h) > -1 : c(h).is(e)) d.push({
                                selector: l,
                                elem: h,
                                level: o
                            })
                        }
                        h = h.parentNode;
                        o++
                    }
                }
                return d
            }
            l = cb.test(a) ? c(a, b || this.context) : null;
            e = 0;
            for (f = this.length; e < f; e++) for (h = this[e]; h;) if (l ? l.index(h) > -1 : c.find.matchesSelector(h, a)) {
                d.push(h);
                break
            } else {
                h = h.parentNode;
                if (!h || !h.ownerDocument || h === b) break
            }
            d = d.length > 1 ? c.unique(d) : d;
            return this.pushStack(d, "closest", a)
        },
        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) {
            var d = typeof a === "string" ? c(a, b || this.context) : c.makeArray(a),
                e = c.merge(this.get(), d);
            return this.pushStack(!d[0] || !d[0].parentNode || d[0].parentNode.nodeType === 11 || !e[0] || !e[0].parentNode || e[0].parentNode.nodeType === 11 ? e : c.unique(e))
        },
        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, e) {
            var f = c.map(this, b, d);
            bg.test(a) || (e = d);
            if (e && typeof e === "string") f = c.filter(e, f);
            f = this.length > 1 ? c.unique(f) : f;
            if ((this.length > 1 || ab.test(e)) && $a.test(a)) f = f.reverse();
            return this.pushStack(f, a, bb.call(arguments).join(","))
        }
    });
    c.extend({
        filter: function (a, b, d) {
            if (d) a = ":not(" + a + ")";
            return b.length === 1 ? c.find.matchesSelector(b[0], a) ? [b[0]] : [] : c.find.matches(a, b)
        },
        dir: function (a, b, d) {
            var e = [];
            for (a = a[b]; a && a.nodeType !== 9 && (d === B || a.nodeType !== 1 || !c(a).is(d));) {
                a.nodeType === 1 && e.push(a);
                a = a[b]
            }
            return e
        },
        nth: function (a, b, d) {
            b = b || 1;
            for (var e = 0; a; a = a[d]) if (a.nodeType === 1 && ++e === 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 bh = / jQuery\d+="(?:\d+|null)"/g,
        $ = /^\s+/,
        Aa = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/ig,
        Ba = /<([\w:]+)/,
        db = /<tbody/i,
        eb = /<|&#?\w+;/,
        Ca = /<(?:script|object|embed|option|style)/i,
        Da = /checked\s*(?:[^=]|=\s*.checked.)/i,
        fb = /\=([^="'>\s]+\/)>/g,
        P = {
            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, "", ""]
        };
    P.optgroup = P.option;
    P.tbody = P.tfoot = P.colgroup = P.caption = P.thead;
    P.th = P.td;
    if (!c.support.htmlSerialize) P._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 !== B) return this.empty().append((this[0] && this[0].ownerDocument || t).createTextNode(a));
            return c.text(this)
        },
        wrapAll: function (a) {
            if (c.isFunction(a)) return this.each(function (d) {
                c(this).wrapAll(a.call(this, d))
            });
            if (this[0]) {
                var b = c(a, this[0].ownerDocument).eq(0).clone(true);
                this[0].parentNode && b.insertBefore(this[0]);
                b.map(function () {
                    for (var d = this; d.firstChild && d.firstChild.nodeType === 1;) d = d.firstChild;
                    return d
                }).append(this)
            }
            return this
        },
        wrapInner: function (a) {
            if (c.isFunction(a)) return this.each(function (b) {
                c(this).wrapInner(a.call(this, b))
            });
            return this.each(function () {
                var b = c(this),
                    d = b.contents();
                d.length ? d.wrapAll(a) : b.append(a)
            })
        },
        wrap: function (a) {
            return this.each(function () {
                c(this).wrapAll(a)
            })
        },
        unwrap: function () {
            return this.parent().each(function () {
                c.nodeName(this, "body") || c(this).replaceWith(this.childNodes)
            }).end()
        },
        append: function () {
            return this.domManip(arguments, true, function (a) {
                this.nodeType === 1 && this.appendChild(a)
            })
        },
        prepend: function () {
            return this.domManip(arguments, true, function (a) {
                this.nodeType === 1 && this.insertBefore(a, this.firstChild)
            })
        },
        before: function () {
            if (this[0] && this[0].parentNode) return this.domManip(arguments, false, function (b) {
                this.parentNode.insertBefore(b, this)
            });
            else if (arguments.length) {
                var a = c(arguments[0]);
                a.push.apply(a, this.toArray());
                return this.pushStack(a, "before", arguments)
            }
        },
        after: function () {
            if (this[0] && this[0].parentNode) return this.domManip(arguments, false, function (b) {
                this.parentNode.insertBefore(b, this.nextSibling)
            });
            else if (arguments.length) {
                var a = this.pushStack(this, "after", arguments);
                a.push.apply(a, c(arguments[0]).toArray());
                return a
            }
        },
        remove: function (a, b) {
            for (var d = 0, e;
            (e = this[d]) != null; d++) if (!a || c.filter(a, [e]).length) {
                if (!b && e.nodeType === 1) {
                    c.cleanData(e.getElementsByTagName("*"));
                    c.cleanData([e])
                }
                e.parentNode && e.parentNode.removeChild(e)
            }
            return this
        },
        empty: function () {
            for (var a = 0, b;
            (b = this[a]) != null; a++) for (b.nodeType === 1 && c.cleanData(b.getElementsByTagName("*")); b.firstChild;) b.removeChild(b.firstChild);
            return this
        },
        clone: function (a) {
            var b = this.map(function () {
                if (!c.support.noCloneEvent && !c.isXMLDoc(this)) {
                    var d = this.outerHTML,
                        e = this.ownerDocument;
                    if (!d) {
                        d = e.createElement("div");
                        d.appendChild(this.cloneNode(true));
                        d = d.innerHTML
                    }
                    return c.clean([d.replace(bh, "").replace(fb, '="$1">').replace($, "")], e)[0]
                } else return this.cloneNode(true)
            });
            if (a === true) {
                na(this, b);
                na(this.find("*"), b.find("*"))
            }
            return b
        },
        html: function (a) {
            if (a === B) return this[0] && this[0].nodeType === 1 ? this[0].innerHTML.replace(bh, "") : null;
            else if (typeof a === "string" && !Ca.test(a) && (c.support.leadingWhitespace || !$.test(a)) && !P[(Ba.exec(a) || ["", ""])[1].toLowerCase()]) {
                a = a.replace(Aa, "<$1></$2>");
                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 (e) {
                    this.empty().append(a)
                }
            } else c.isFunction(a) ? this.each(function (f) {
                var h = c(this);
                h.html(a.call(this, f, h.html()))
            }) : 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),
                        e = d.html();
                    d.replaceWith(a.call(this, b, e))
                });
                if (typeof a !== "string") a = c(a).detach();
                return this.each(function () {
                    var b = this.nextSibling,
                        d = this.parentNode;
                    c(this).remove();
                    b ? c(b).before(a) : c(d).append(a)
                })
            } else return this.pushStack(c(c.isFunction(a) ? a() : a), "replaceWith", a)
        },
        detach: function (a) {
            return this.remove(a, true)
        },
        domManip: function (a, b, d) {
            var e, f, h, l = a[0],
                k = [];
            if (!c.support.checkClone && arguments.length === 3 && typeof l === "string" && Da.test(l)) return this.each(function () {
                c(this).domManip(a, b, d, true)
            });
            if (c.isFunction(l)) return this.each(function (x) {
                var r = c(this);
                a[0] = l.call(this, x, b ? r.html() : B);
                r.domManip(a, b, d)
            });
            if (this[0]) {
                e = l && l.parentNode;
                e = c.support.parentNode && e && e.nodeType === 11 && e.childNodes.length === this.length ? {
                    fragment: e
                } : c.buildFragment(a, this, k);
                h = e.fragment;
                if (f = h.childNodes.length === 1 ? h = h.firstChild : h.firstChild) {
                    b = b && c.nodeName(f, "tr");
                    f = 0;
                    for (var o = this.length; f < o; f++) d.call(b ? c.nodeName(this[f], "table") ? this[f].getElementsByTagName("tbody")[0] || this[f].appendChild(this[f].ownerDocument.createElement("tbody")) : this[f] : this[f], f > 0 || e.cacheable || this.length > 1 ? h.cloneNode(true) : h)
                }
                k.length && c.each(k, Oa)
            }
            return this
        }
    });
    c.buildFragment = function (a, b, d) {
        var e, f, h;
        b = b && b[0] ? b[0].ownerDocument || b[0] : t;
        if (a.length === 1 && typeof a[0] === "string" && a[0].length < 512 && b === t && !Ca.test(a[0]) && (c.support.checkClone || !Da.test(a[0]))) {
            f = true;
            if (h = c.fragments[a[0]]) if (h !== 1) e = h
        }
        if (!e) {
            e = b.createDocumentFragment();
            c.clean(a, b, e, d)
        }
        if (f) c.fragments[a[0]] = h ? e : 1;
        return {
            fragment: e,
            cacheable: f
        }
    };
    c.fragments = {};
    c.each({
        appendTo: "append",
        prependTo: "prepend",
        insertBefore: "before",
        insertAfter: "after",
        replaceAll: "replaceWith"
    }, function (a, b) {
        c.fn[a] = function (d) {
            var e = [];
            d = c(d);
            var f = this.length === 1 && this[0].parentNode;
            if (f && f.nodeType === 11 && f.childNodes.length === 1 && d.length === 1) {
                d[b](this[0]);
                return this
            } else {
                f = 0;
                for (var h = d.length; f < h; f++) {
                    var l = (f > 0 ? this.clone(true) : this).get();
                    c(d[f])[b](l);
                    e = e.concat(l)
                }
                return this.pushStack(e, a, d.selector)
            }
        }
    });
    c.extend({
        clean: function (a, b, d, e) {
            b = b || t;
            if (typeof b.createElement === "undefined") b = b.ownerDocument || b[0] && b[0].ownerDocument || t;
            for (var f = [], h = 0, l;
            (l = a[h]) != null; h++) {
                if (typeof l === "number") l += "";
                if (l) {
                    if (typeof l === "string" && !eb.test(l)) l = b.createTextNode(l);
                    else if (typeof l === "string") {
                        l = l.replace(Aa, "<$1></$2>");
                        var k = (Ba.exec(l) || ["", ""])[1].toLowerCase(),
                            o = P[k] || P._default,
                            x = o[0],
                            r = b.createElement("div");
                        for (r.innerHTML = o[1] + l + o[2]; x--;) r = r.lastChild;
                        if (!c.support.tbody) {
                            x = db.test(l);
                            k = k === "table" && !x ? r.firstChild && r.firstChild.childNodes : o[1] === "<table>" && !x ? r.childNodes : [];
                            for (o = k.length - 1; o >= 0; --o) c.nodeName(k[o], "tbody") && !k[o].childNodes.length && k[o].parentNode.removeChild(k[o])
                        }!c.support.leadingWhitespace && $.test(l) && r.insertBefore(b.createTextNode($.exec(l)[0]), r.firstChild);
                        l = r.childNodes
                    }
                    if (l.nodeType) f.push(l);
                    else f = c.merge(f, l)
                }
            }
            if (d) for (h = 0; f[h]; h++) if (e && c.nodeName(f[h], "script") && (!f[h].type || f[h].type.toLowerCase() === "text/javascript")) e.push(f[h].parentNode ? f[h].parentNode.removeChild(f[h]) : f[h]);
            else {
                f[h].nodeType === 1 && f.splice.apply(f, [h + 1, 0].concat(c.makeArray(f[h].getElementsByTagName("script"))));
                d.appendChild(f[h])
            }
            return f
        },
        cleanData: function (a) {
            for (var b, d, e = c.cache, f = c.event.special, h = c.support.deleteExpando, l = 0, k;
            (k = a[l]) != null; l++) if (!(k.nodeName && c.noData[k.nodeName.toLowerCase()])) if (d = k[c.expando]) {
                if ((b = e[d]) && b.events) for (var o in b.events) f[o] ? c.event.remove(k, o) : c.removeEvent(k, o, b.handle);
                if (h) delete k[c.expando];
                else k.removeAttribute && k.removeAttribute(c.expando);
                delete e[d]
            }
        }
    });
    var bi = /alpha\([^)]*\)/i,
        gb = /opacity=([^)]*)/,
        hb = /-([a-z])/ig,
        ib = /([A-Z])/g,
        Fa = /^-?\d+(?:px)?$/i,
        jb = /^-?\d/,
        kb = {
            position: "absolute",
            visibility: "hidden",
            display: "block"
        },
        Pa = ["Left", "Right"],
        Qa = ["Top", "Bottom"],
        W, Ga, aa, lb = function (a, b) {
            return b.toUpperCase()
        };
    c.fn.css = function (a, b) {
        if (arguments.length === 2 && b === B) return this;
        return c.access(this, a, b, true, function (d, e, f) {
            return f !== B ? c.style(d, e, f) : c.css(d, e)
        })
    };
    c.extend({
        cssHooks: {
            opacity: {
                get: function (a, b) {
                    if (b) {
                        var d = W(a, "opacity", "opacity");
                        return d === "" ? "1" : d
                    } else return a.style.opacity
                }
            }
        },
        cssNumber: {
            zIndex: true,
            fontWeight: true,
            opacity: true,
            zoom: true,
            lineHeight: true
        },
        cssProps: {
            "float": c.support.cssFloat ? "cssFloat" : "styleFloat"
        },
        style: function (a, b, d, e) {
            if (!(!a || a.nodeType === 3 || a.nodeType === 8 || !a.style)) {
                var f, h = c.camelCase(b),
                    l = a.style,
                    k = c.cssHooks[h];
                b = c.cssProps[h] || h;
                if (d !== B) {
                    if (!(typeof d === "number" && isNaN(d) || d == null)) {
                        if (typeof d === "number" && !c.cssNumber[h]) d += "px";
                        if (!k || !("set" in k) || (d = k.set(a, d)) !== B) try {
                            l[b] = d
                        } catch (o) {}
                    }
                } else {
                    if (k && "get" in k && (f = k.get(a, false, e)) !== B) return f;
                    return l[b]
                }
            }
        },
        css: function (a, b, d) {
            var e, f = c.camelCase(b),
                h = c.cssHooks[f];
            b = c.cssProps[f] || f;
            if (h && "get" in h && (e = h.get(a, true, d)) !== B) return e;
            else if (W) return W(a, b, f)
        },
        swap: function (a, b, d) {
            var e = {},
                f;
            for (f in b) {
                e[f] = a.style[f];
                a.style[f] = b[f]
            }
            d.call(a);
            for (f in b) a.style[f] = e[f]
        },
        camelCase: function (a) {
            return a.replace(hb, lb)
        }
    });
    c.curCSS = c.css;
    c.each(["height", "width"], function (a, b) {
        c.cssHooks[b] = {
            get: function (d, e, f) {
                var h;
                if (e) {
                    if (d.offsetWidth !== 0) h = oa(d, b, f);
                    else c.swap(d, kb, function () {
                        h = oa(d, b, f)
                    });
                    if (h <= 0) {
                        h = W(d, b, b);
                        if (h === "0px" && aa) h = aa(d, b, b);
                        if (h != null) return h === "" || h === "auto" ? "0px" : h
                    }
                    if (h < 0 || h == null) {
                        h = d.style[b];
                        return h === "" || h === "auto" ? "0px" : h
                    }
                    return typeof h === "string" ? h : h + "px"
                }
            },
            set: function (d, e) {
                if (Fa.test(e)) {
                    e = parseFloat(e);
                    if (e >= 0) return e + "px"
                } else return e
            }
        }
    });
    if (!c.support.opacity) c.cssHooks.opacity = {
        get: function (a, b) {
            return gb.test((b && a.currentStyle ? a.currentStyle.filter : a.style.filter) || "") ? parseFloat(RegExp.$1) / 100 + "" : b ? "1" : ""
        },
        set: function (a, b) {
            var d = a.style;
            d.zoom = 1;
            var e = c.isNaN(b) ? "" : "alpha(opacity=" + b * 100 + ")",
                f = d.filter || "";
            d.filter = bi.test(f) ? f.replace(bi, e) : d.filter + " " + e
        }
    };
    if (t.defaultView && t.defaultView.getComputedStyle) Ga = function (a, b, d) {
        var e;
        d = d.replace(ib, "-$1").toLowerCase();
        if (!(b = a.ownerDocument.defaultView)) return B;
        if (b = b.getComputedStyle(a, null)) {
            e = b.getPropertyValue(d);
            if (e === "" && !c.contains(a.ownerDocument.documentElement, a)) e = c.style(a, d)
        }
        return e
    };
    if (t.documentElement.currentStyle) aa = function (a, b) {
        var d, e, f = a.currentStyle && a.currentStyle[b],
            h = a.style;
        if (!Fa.test(f) && jb.test(f)) {
            d = h.left;
            e = a.runtimeStyle.left;
            a.runtimeStyle.left = a.currentStyle.left;
            h.left = b === "fontSize" ? "1em" : f || 0;
            f = h.pixelLeft + "px";
            h.left = d;
            a.runtimeStyle.left = e
        }
        return f === "" ? "auto" : f
    };
    W = Ga || aa;
    if (c.expr && c.expr.filters) {
        c.expr.filters.hidden = function (a) {
            var b = a.offsetHeight;
            return a.offsetWidth === 0 && b === 0 || !c.support.reliableHiddenOffsets && (a.style.display || c.css(a, "display")) === "none"
        };
        c.expr.filters.visible = function (a) {
            return !c.expr.filters.hidden(a)
        }
    }
    var bj = c.now(),
        nb = /<script\b[^<]*(?:(?!<\/script>)<[^<]*)*<\/script>/gi,
        ob = /^(?:select|textarea)/i,
        pb = /^(?:color|date|datetime|email|hidden|month|number|password|range|search|tel|text|time|url|week)$/i,
        qb = /^(?:GET|HEAD)$/,
        Ra = /\[\]$/,
        T = /\=\?(&|$)/,
        ja = /\?/,
        rb = /([?&])_=[^&]*/,
        sb = /^(\w+:)?\/\/([^\/?#]+)/,
        tb = /%20/g,
        ub = /#.*$/,
        Ha = c.fn.load;
    c.fn.extend({
        load: function (a, b, d) {
            if (typeof a !== "string" && Ha) return Ha.apply(this, arguments);
            else if (!this.length) return this;
            var e = a.indexOf(" ");
            if (e >= 0) {
                var f = a.slice(e, a.length);
                a = a.slice(0, e)
            }
            e = "GET";
            if (b) if (c.isFunction(b)) {
                d = b;
                b = null
            } else if (typeof b === "object") {
                b = c.param(b, c.ajaxSettings.traditional);
                e = "POST"
            }
            var h = this;
            c.ajax({
                url: a,
                type: e,
                dataType: "html",
                data: b,
                complete: function (l, k) {
                    if (k === "success" || k === "notmodified") h.html(f ? c("<div>").append(l.responseText.replace(nb, "")).find(f) : l.responseText);
                    d && h.each(d, [l.responseText, k, l])
                }
            });
            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 || ob.test(this.nodeName) || pb.test(this.type))
            }).map(function (a, b) {
                var d = c(this).val();
                return d == null ? null : c.isArray(d) ? c.map(d, function (e) {
                    return {
                        name: b.name,
                        value: e
                    }
                }) : {
                    name: b.name,
                    value: d
                }
            }).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, e) {
            if (c.isFunction(b)) {
                e = e || d;
                d = b;
                b = null
            }
            return c.ajax({
                type: "GET",
                url: a,
                data: b,
                success: d,
                dataType: e
            })
        },
        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, e) {
            if (c.isFunction(b)) {
                e = e || d;
                d = b;
                b = {}
            }
            return c.ajax({
                type: "POST",
                url: a,
                data: b,
                success: d,
                dataType: e
            })
        },
        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: function () {
                return new E.XMLHttpRequest
            },
            accepts: {
                xml: "application/xml, text/xml",
                html: "text/html",
                script: "text/javascript, application/javascript",
                json: "application/json, text/javascript",
                text: "text/plain",
                _default: "*/*"
            }
        },
        ajax: function (a) {
            var b = c.extend(true, {}, c.ajaxSettings, a),
                d, e, f, h = b.type.toUpperCase(),
                l = qb.test(h);
            b.url = b.url.replace(ub, "");
            b.context = a && a.context != null ? a.context : b;
            if (b.data && b.processData && typeof b.data !== "string") b.data = c.param(b.data, b.traditional);
            if (b.dataType === "jsonp") {
                if (h === "GET") T.test(b.url) || (b.url += (ja.test(b.url) ? "&" : "?") + (b.jsonp || "callback") + "=?");
                else if (!b.data || !T.test(b.data)) b.data = (b.data ? b.data + "&" : "") + (b.jsonp || "callback") + "=?";
                b.dataType = "json"
            }
            if (b.dataType === "json" && (b.data && T.test(b.data) || T.test(b.url))) {
                d = b.jsonpCallback || "jsonp" + bj++;
                if (b.data) b.data = (b.data + "").replace(T, "=" + d + "$1");
                b.url = b.url.replace(T, "=" + d + "$1");
                b.dataType = "script";
                var k = E[d];
                E[d] = function (m) {
                    if (c.isFunction(k)) k(m);
                    else {
                        E[d] = B;
                        try {
                            delete E[d]
                        } catch (p) {}
                    }
                    f = m;
                    c.handleSuccess(b, w, e, f);
                    c.handleComplete(b, w, e, f);
                    r && r.removeChild(A)
                }
            }
            if (b.dataType === "script" && b.cache === null) b.cache = false;
            if (b.cache === false && l) {
                var o = c.now(),
                    x = b.url.replace(rb, "$1_=" + o);
                b.url = x + (x === b.url ? (ja.test(b.url) ? "&" : "?") + "_=" + o : "")
            }
            if (b.data && l) b.url += (ja.test(b.url) ? "&" : "?") + b.data;
            b.global && c.active++ === 0 && c.event.trigger("ajaxStart");
            o = (o = sb.exec(b.url)) && (o[1] && o[1].toLowerCase() !== location.protocol || o[2].toLowerCase() !== location.host);
            if (b.dataType === "script" && h === "GET" && o) {
                var r = t.getElementsByTagName("head")[0] || t.documentElement,
                    A = t.createElement("script");
                if (b.scriptCharset) A.charset = b.scriptCharset;
                A.src = b.url;
                if (!d) {
                    var C = false;
                    A.onload = A.onreadystatechange = function () {
                        if (!C && (!this.readyState || this.readyState === "loaded" || this.readyState === "complete")) {
                            C = true;
                            c.handleSuccess(b, w, e, f);
                            c.handleComplete(b, w, e, f);
                            A.onload = A.onreadystatechange = null;
                            r && A.parentNode && r.removeChild(A)
                        }
                    }
                }
                r.insertBefore(A, r.firstChild);
                return B
            }
            var J = false,
                w = b.xhr();
            if (w) {
                b.username ? w.open(h, b.url, b.async, b.username, b.password) : w.open(h, b.url, b.async);
                try {
                    if (b.data != null && !l || a && a.contentType) w.setRequestHeader("Content-Type", b.contentType);
                    if (b.ifModified) {
                        c.lastModified[b.url] && w.setRequestHeader("If-Modified-Since", c.lastModified[b.url]);
                        c.etag[b.url] && w.setRequestHeader("If-None-Match", c.etag[b.url])
                    }
                    o || w.setRequestHeader("X-Requested-With", "XMLHttpRequest");
                    w.setRequestHeader("Accept", b.dataType && b.accepts[b.dataType] ? b.accepts[b.dataType] + ", */*; q=0.01" : b.accepts._default)
                } catch (I) {}
                if (b.beforeSend && b.beforeSend.call(b.context, w, b) === false) {
                    b.global && c.active-- === 1 && c.event.trigger("ajaxStop");
                    w.abort();
                    return false
                }
                b.global && c.triggerGlobal(b, "ajaxSend", [w, b]);
                var L = w.onreadystatechange = function (m) {
                        if (!w || w.readyState === 0 || m === "abort") {
                            J || c.handleComplete(b, w, e, f);
                            J = true;
                            if (w) w.onreadystatechange = c.noop
                        } else if (!J && w && (w.readyState === 4 || m === "timeout")) {
                            J = true;
                            w.onreadystatechange = c.noop;
                            e = m === "timeout" ? "timeout" : !c.httpSuccess(w) ? "error" : b.ifModified && c.httpNotModified(w, b.url) ? "notmodified" : "success";
                            var p;
                            if (e === "success") try {
                                f = c.httpData(w, b.dataType, b)
                            } catch (q) {
                                e = "parsererror";
                                p = q
                            }
                            if (e === "success" || e === "notmodified") d || c.handleSuccess(b, w, e, f);
                            else c.handleError(b, w, e, p);
                            d || c.handleComplete(b, w, e, f);
                            m === "timeout" && w.abort();
                            if (b.async) w = null
                        }
                    };
                try {
                    var g = w.abort;
                    w.abort = function () {
                        w && Function.prototype.call.call(g, w);
                        L("abort")
                    }
                } catch (i) {}
                b.async && b.timeout > 0 && setTimeout(function () {
                    w && !J && L("timeout")
                }, b.timeout);
                try {
                    w.send(l || b.data == null ? null : b.data)
                } catch (n) {
                    c.handleError(b, w, null, n);
                    c.handleComplete(b, w, e, f)
                }
                b.async || L();
                return w
            }
        },
        param: function (a, b) {
            var d = [],
                e = function (h, l) {
                    l = c.isFunction(l) ? l() : l;
                    d[d.length] = encodeURIComponent(h) + "=" + encodeURIComponent(l)
                };
            if (b === B) b = c.ajaxSettings.traditional;
            if (c.isArray(a) || a.jquery) c.each(a, function () {
                e(this.name, this.value)
            });
            else for (var f in a) da(f, a[f], b, e);
            return d.join("&").replace(tb, "+")
        }
    });
    c.extend({
        active: 0,
        lastModified: {},
        etag: {},
        handleError: function (a, b, d, e) {
            a.error && a.error.call(a.context, b, d, e);
            a.global && c.triggerGlobal(a, "ajaxError", [b, a, e])
        },
        handleSuccess: function (a, b, d, e) {
            a.success && a.success.call(a.context, e, d, b);
            a.global && c.triggerGlobal(a, "ajaxSuccess", [b, a])
        },
        handleComplete: function (a, b, d) {
            a.complete && a.complete.call(a.context, b, d);
            a.global && c.triggerGlobal(a, "ajaxComplete", [b, a]);
            a.global && c.active-- === 1 && c.event.trigger("ajaxStop")
        },
        triggerGlobal: function (a, b, d) {
            (a.context && a.context.url == null ? c(a.context) : c.event).trigger(b, d)
        },
        httpSuccess: function (a) {
            try {
                return !a.status && location.protocol === "file:" || a.status >= 200 && a.status < 300 || a.status === 304 || a.status === 1223
            } catch (b) {}
            return false
        },
        httpNotModified: function (a, b) {
            var d = a.getResponseHeader("Last-Modified"),
                e = a.getResponseHeader("Etag");
            if (d) c.lastModified[b] = d;
            if (e) c.etag[b] = e;
            return a.status === 304
        },
        httpData: function (a, b, d) {
            var e = a.getResponseHeader("content-type") || "",
                f = b === "xml" || !b && e.indexOf("xml") >= 0;
            a = f ? a.responseXML : a.responseText;
            f && a.documentElement.nodeName === "parsererror" && c.error("parsererror");
            if (d && d.dataFilter) a = d.dataFilter(a, b);
            if (typeof a === "string") if (b === "json" || !b && e.indexOf("json") >= 0) a = c.parseJSON(a);
            else if (b === "script" || !b && e.indexOf("javascript") >= 0) c.globalEval(a);
            return a
        }
    });
    if (E.ActiveXObject) c.ajaxSettings.xhr = function () {
        if (E.location.protocol !== "file:") try {
            return new E.XMLHttpRequest
        } catch (a) {}
        try {
            return new E.ActiveXObject("Microsoft.XMLHTTP")
        } catch (b) {}
    };
    c.support.ajax = !! c.ajaxSettings.xhr();
    var bk = {},
        vb = /^(?:toggle|show|hide)$/,
        wb = /^([+\-]=)?([\d+.\-]+)(.*)$/,
        ba, pa = [
            ["height", "marginTop", "marginBottom", "paddingTop", "paddingBottom"],
            ["width", "marginLeft", "marginRight", "paddingLeft", "paddingRight"],
            ["opacity"]
        ];
    c.fn.extend({
        show: function (a, b, d) {
            if (a || a === 0) return this.animate(S("show", 3), a, b, d);
            else {
                d = 0;
                for (var e = this.length; d < e; d++) {
                    a = this[d];
                    b = a.style.display;
                    if (!c.data(a, "olddisplay") && b === "none") b = a.style.display = "";
                    b === "" && c.css(a, "display") === "none" && c.data(a, "olddisplay", qa(a.nodeName))
                }
                for (d = 0; d < e; d++) {
                    a = this[d];
                    b = a.style.display;
                    if (b === "" || b === "none") a.style.display = c.data(a, "olddisplay") || ""
                }
                return this
            }
        },
        hide: function (a, b, d) {
            if (a || a === 0) return this.animate(S("hide", 3), a, b, d);
            else {
                a = 0;
                for (b = this.length; a < b; a++) {
                    d = c.css(this[a], "display");
                    d !== "none" && c.data(this[a], "olddisplay", d)
                }
                for (a = 0; a < b; a++) this[a].style.display = "none";
                return this
            }
        },
        _toggle: c.fn.toggle,
        toggle: function (a, b, d) {
            var e = typeof a === "boolean";
            if (c.isFunction(a) && c.isFunction(b)) this._toggle.apply(this, arguments);
            else a == null || e ? this.each(function () {
                var f = e ? a : c(this).is(":hidden");
                c(this)[f ? "show" : "hide"]()
            }) : this.animate(S("toggle", 3), a, b, d);
            return this
        },
        fadeTo: function (a, b, d, e) {
            return this.filter(":hidden").css("opacity", 0).show().end().animate({
                opacity: b
            }, a, d, e)
        },
        animate: function (a, b, d, e) {
            var f = c.speed(b, d, e);
            if (c.isEmptyObject(a)) return this.each(f.complete);
            return this[f.queue === false ? "each" : "queue"](function () {
                var h = c.extend({}, f),
                    l, k = this.nodeType === 1,
                    o = k && c(this).is(":hidden"),
                    x = this;
                for (l in a) {
                    var r = c.camelCase(l);
                    if (l !== r) {
                        a[r] = a[l];
                        delete a[l];
                        l = r
                    }
                    if (a[l] === "hide" && o || a[l] === "show" && !o) return h.complete.call(this);
                    if (k && (l === "height" || l === "width")) {
                        h.overflow = [this.style.overflow, this.style.overflowX, this.style.overflowY];
                        if (c.css(this, "display") === "inline" && c.css(this, "float") === "none") if (c.support.inlineBlockNeedsLayout) if (qa(this.nodeName) === "inline") this.style.display = "inline-block";
                        else {
                            this.style.display = "inline";
                            this.style.zoom = 1
                        } else this.style.display = "inline-block"
                    }
                    if (c.isArray(a[l])) {
                        (h.specialEasing = h.specialEasing || {})[l] = a[l][1];
                        a[l] = a[l][0]
                    }
                }
                if (h.overflow != null) this.style.overflow = "hidden";
                h.curAnim = c.extend({}, a);
                c.each(a, function (A, C) {
                    var J = new c.fx(x, h, A);
                    if (vb.test(C)) J[C === "toggle" ? o ? "show" : "hide" : C](a);
                    else {
                        var w = wb.exec(C),
                            I = J.cur() || 0;
                        if (w) {
                            var L = parseFloat(w[2]),
                                g = w[3] || "px";
                            if (g !== "px") {
                                c.style(x, A, (L || 1) + g);
                                I = (L || 1) / J.cur() * I;
                                c.style(x, A, I + g)
                            }
                            if (w[1]) L = (w[1] === "-=" ? -1 : 1) * L + I;
                            J.custom(I, L, g)
                        } else J.custom(I, C, "")
                    }
                });
                return true
            })
        },
        stop: function (a, b) {
            var d = c.timers;
            a && this.queue([]);
            this.each(function () {
                for (var e = d.length - 1; e >= 0; e--) if (d[e].elem === this) {
                    b && d[e](true);
                    d.splice(e, 1)
                }
            });
            b || this.dequeue();
            return this
        }
    });
    c.each({
        slideDown: S("show", 1),
        slideUp: S("hide", 1),
        slideToggle: S("toggle", 1),
        fadeIn: {
            opacity: "show"
        },
        fadeOut: {
            opacity: "hide"
        },
        fadeToggle: {
            opacity: "toggle"
        }
    }, function (a, b) {
        c.fn[a] = function (d, e, f) {
            return this.animate(b, d, e, f)
        }
    });
    c.extend({
        speed: function (a, b, d) {
            var e = a && typeof a === "object" ? c.extend({}, a) : {
                complete: d || !d && b || c.isFunction(a) && a,
                duration: a,
                easing: d && b || b && !c.isFunction(b) && b
            };
            e.duration = c.fx.off ? 0 : typeof e.duration === "number" ? e.duration : e.duration in c.fx.speeds ? c.fx.speeds[e.duration] : c.fx.speeds._default;
            e.old = e.complete;
            e.complete = function () {
                e.queue !== false && c(this).dequeue();
                c.isFunction(e.old) && e.old.call(this)
            };
            return e
        },
        easing: {
            linear: function (a, b, d, e) {
                return d + e * a
            },
            swing: function (a, b, d, e) {
                return (-Math.cos(a * Math.PI) / 2 + 0.5) * e + 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)
        },
        cur: function () {
            if (this.elem[this.prop] != null && (!this.elem.style || this.elem.style[this.prop] == null)) return this.elem[this.prop];
            var a = parseFloat(c.css(this.elem, this.prop));
            return a && a > -1E4 ? a : 0
        },
        custom: function (a, b, d) {
            function e(l) {
                return f.step(l)
            }
            var f = this,
                h = c.fx;
            this.startTime = c.now();
            this.start = a;
            this.end = b;
            this.unit = d || this.unit || "px";
            this.now = this.start;
            this.pos = this.state = 0;
            e.elem = this.elem;
            if (e() && c.timers.push(e) && !ba) ba = setInterval(h.tick, h.interval)
        },
        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 = c.now(),
                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 e in this.options.curAnim) if (this.options.curAnim[e] !== true) d = false;
                if (d) {
                    if (this.options.overflow != null && !c.support.shrinkWrapBlocks) {
                        var f = this.elem,
                            h = this.options;
                        c.each(["", "X", "Y"], function (k, o) {
                            f.style["overflow" + o] = h.overflow[k]
                        })
                    }
                    this.options.hide && c(this.elem).hide();
                    if (this.options.hide || this.options.show) for (var l in this.options.curAnim) c.style(this.elem, l, this.options.orig[l]);
                    this.options.complete.call(this.elem)
                }
                return false
            } else {
                a = b - this.startTime;
                this.state = a / this.options.duration;
                b = this.options.easing || (c.easing.swing ? "swing" : "linear");
                this.pos = c.easing[this.options.specialEasing && this.options.specialEasing[this.prop] || b](this.state, a, 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()
        },
        interval: 13,
        stop: function () {
            clearInterval(ba);
            ba = 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
    };
    var bl = /^t(?:able|d|h)$/i,
        Ia = /^(?:body|html)$/i;
    c.fn.offset = "getBoundingClientRect" in t.documentElement ?
    function (a) {
        var b = this[0],
            d;
        if (a) return this.each(function (l) {
            c.offset.setOffset(this, a, l)
        });
        if (!b || !b.ownerDocument) return null;
        if (b === b.ownerDocument.body) return c.offset.bodyOffset(b);
        try {
            d = b.getBoundingClientRect()
        } catch (e) {}
        var f = b.ownerDocument,
            h = f.documentElement;
        if (!d || !c.contains(h, b)) return d || {
            top: 0,
            left: 0
        };
        b = f.body;
        f = fa(f);
        return {
            top: d.top + (f.pageYOffset || c.support.boxModel && h.scrollTop || b.scrollTop) - (h.clientTop || b.clientTop || 0),
            left: d.left + (f.pageXOffset || c.support.boxModel && h.scrollLeft || b.scrollLeft) - (h.clientLeft || b.clientLeft || 0)
        }
    } : function (a) {
        var b = this[0];
        if (a) return this.each(function (x) {
            c.offset.setOffset(this, a, x)
        });
        if (!b || !b.ownerDocument) return null;
        if (b === b.ownerDocument.body) return c.offset.bodyOffset(b);
        c.offset.initialize();
        var d, e = b.offsetParent,
            f = b.ownerDocument,
            h = f.documentElement,
            l = f.body;
        d = (f = f.defaultView) ? f.getComputedStyle(b, null) : b.currentStyle;
        for (var k = b.offsetTop, o = b.offsetLeft;
        (b = b.parentNode) && b !== l && b !== h;) {
            if (c.offset.supportsFixedPosition && d.position === "fixed") break;
            d = f ? f.getComputedStyle(b, null) : b.currentStyle;
            k -= b.scrollTop;
            o -= b.scrollLeft;
            if (b === e) {
                k += b.offsetTop;
                o += b.offsetLeft;
                if (c.offset.doesNotAddBorder && !(c.offset.doesAddBorderForTableAndCells && bl.test(b.nodeName))) {
                    k += parseFloat(d.borderTopWidth) || 0;
                    o += parseFloat(d.borderLeftWidth) || 0
                }
                e = b.offsetParent
            }
            if (c.offset.subtractsBorderForOverflowNotVisible && d.overflow !== "visible") {
                k += parseFloat(d.borderTopWidth) || 0;
                o += parseFloat(d.borderLeftWidth) || 0
            }
            d = d
        }
        if (d.position === "relative" || d.position === "static") {
            k += l.offsetTop;
            o += l.offsetLeft
        }
        if (c.offset.supportsFixedPosition && d.position === "fixed") {
            k += Math.max(h.scrollTop, l.scrollTop);
            o += Math.max(h.scrollLeft, l.scrollLeft)
        }
        return {
            top: k,
            left: o
        }
    };
    c.offset = {
        initialize: function () {
            var a = t.body,
                b = t.createElement("div"),
                d, e, f, h = parseFloat(c.css(a, "marginTop")) || 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;
            e = d.firstChild;
            f = d.nextSibling.firstChild.firstChild;
            this.doesNotAddBorder = e.offsetTop !== 5;
            this.doesAddBorderForTableAndCells = f.offsetTop === 5;
            e.style.position = "fixed";
            e.style.top = "20px";
            this.supportsFixedPosition = e.offsetTop === 20 || e.offsetTop === 15;
            e.style.position = e.style.top = "";
            d.style.overflow = "hidden";
            d.style.position = "relative";
            this.subtractsBorderForOverflowNotVisible = e.offsetTop === -5;
            this.doesNotIncludeMarginInBodyOffset = a.offsetTop !== h;
            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.css(a, "marginTop")) || 0;
                d += parseFloat(c.css(a, "marginLeft")) || 0
            }
            return {
                top: b,
                left: d
            }
        },
        setOffset: function (a, b, d) {
            var e = c.css(a, "position");
            if (e === "static") a.style.position = "relative";
            var f = c(a),
                h = f.offset(),
                l = c.css(a, "top"),
                k = c.css(a, "left"),
                o = e === "absolute" && c.inArray("auto", [l, k]) > -1;
            e = {};
            var x = {};
            if (o) x = f.position();
            l = o ? x.top : parseInt(l, 10) || 0;
            k = o ? x.left : parseInt(k, 10) || 0;
            if (c.isFunction(b)) b = b.call(a, d, h);
            if (b.top != null) e.top = b.top - h.top + l;
            if (b.left != null) e.left = b.left - h.left + k;
            "using" in b ? b.using.call(a, e) : f.css(e)
        }
    };
    c.fn.extend({
        position: function () {
            if (!this[0]) return null;
            var a = this[0],
                b = this.offsetParent(),
                d = this.offset(),
                e = Ia.test(b[0].nodeName) ? {
                    top: 0,
                    left: 0
                } : b.offset();
            d.top -= parseFloat(c.css(a, "marginTop")) || 0;
            d.left -= parseFloat(c.css(a, "marginLeft")) || 0;
            e.top += parseFloat(c.css(b[0], "borderTopWidth")) || 0;
            e.left += parseFloat(c.css(b[0], "borderLeftWidth")) || 0;
            return {
                top: d.top - e.top,
                left: d.left - e.left
            }
        },
        offsetParent: function () {
            return this.map(function () {
                for (var a = this.offsetParent || t.body; a && !Ia.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 (e) {
            var f = this[0],
                h;
            if (!f) return null;
            if (e !== B) return this.each(function () {
                if (h = fa(this)) h.scrollTo(!a ? e : c(h).scrollLeft(), a ? e : c(h).scrollTop());
                else this[d] = e
            });
            else return (h = fa(f)) ? "pageXOffset" in h ? h[a ? "pageYOffset" : "pageXOffset"] : c.support.boxModel && h.document.documentElement[d] || h.document.body[d] : f[d]
        }
    });
    c.each(["Height", "Width"], function (a, b) {
        var d = b.toLowerCase();
        c.fn["inner" + b] = function () {
            return this[0] ? parseFloat(c.css(this[0], d, "padding")) : null
        };
        c.fn["outer" + b] = function (e) {
            return this[0] ? parseFloat(c.css(this[0], d, e ? "margin" : "border")) : null
        };
        c.fn[d] = function (e) {
            var f = this[0];
            if (!f) return e == null ? null : this;
            if (c.isFunction(e)) return this.each(function (l) {
                var k = c(this);
                k[d](e.call(this, l, k[d]()))
            });
            if (c.isWindow(f)) return f.document.compatMode === "CSS1Compat" && f.document.documentElement["client" + b] || f.document.body["client" + b];
            else if (f.nodeType === 9) return Math.max(f.documentElement["client" + b], f.body["scroll" + b], f.documentElement["scroll" + b], f.body["offset" + b], f.documentElement["offset" + b]);
            else if (e === B) {
                f = c.css(f, d);
                var h = parseFloat(f);
                return c.isNaN(h) ? f : h
            } else return this.css(d, typeof e === "string" ? e : e + "px")
        }
    })
})(window);

/* jCarouselLite 1.1 */
(function ($) {
    $.jCarouselLite = {
        version: '1.1',
        defaults: {
            btnPrev: null,
            btnNext: null,
            btnGo: null,
            mouseWheel: false,
            speed: 200,
            easing: null,
            auto: false,
            autoStop: false,
            timeout: 4000,
            pause: true,
            stop: false,
            vertical: false,
            circular: true,
            visible: 3,
            start: 0,
            scroll: 1,
            beforeStart: null,
            afterEnd: null
        }
    };
    $.fn.jCarouselLite = function (n) {
        var o = $.extend({}, $.jCarouselLite.defaults, n);
        return this.each(function () {
            var b = false,
                animCss = o.vertical ? "top" : "left",
                sizeCss = o.vertical ? "height" : "width";
            var c = $(this),
                ul = c.find('ul'),
                tLi = ul.children('li'),
                tl = tLi.length,
                v = o.visible;
            var f = $(".project-title");
            if (o.circular) {
                ul.prepend(tLi.slice(tl - v - 1 + 1).clone(true)).append(tLi.slice(0, v).clone(true));
                o.start += v
            }
            var g = ul.children('li'),
                itemLength = g.length,
                curr = o.start;
            c.css("visibility", "visible");
            g.css({
                overflow: o.vertical ? "hidden" : 'visible',
                'float': o.vertical ? "none" : "left"
            });
            ul.css({
                margin: "0",
                padding: "0",
                position: "relative",
                "list-style-type": "none",
                "z-index": "1"
            });
            c.css({
                overflow: "hidden",
                position: "relative",
                "z-index": "2",
                left: "0px"
            });
            var h = o.vertical ? height(g) : width(g);
            var j = h * itemLength;
            var k = h * v;
            g.css({
                width: g.width(),
                height: g.height()
            });
            ul.css(sizeCss, j + "px").css(animCss, -(curr * h));
            c.css(sizeCss, k + "px");
            if (o.btnPrev) {
                $(o.btnPrev).click(function () {
                    return go(curr - o.scroll)
                })
            }
            if (o.btnNext) {
                $(o.btnNext).click(function () {
                    return go(curr + o.scroll)
                })
            }
            if (o.btnGo) {
                $.each(o.btnGo, function (i, a) {
                    $(a).click(function () {
                        return go(o.circular ? o.visible + i : i)
                    })
                })
            }
            if (o.mouseWheel && c.mousewheel) {
                c.mousewheel(function (e, d) {
                    return d > 0 ? go(curr - o.scroll) : go(curr + o.scroll)
                })
            }
            if (o.auto) {
                var l, advanceCounter = 0,
                    autoStop = iterations(tl, o);
                var m = function () {
                        l = setTimeout(function () {
                            if (!autoStop || autoStop > advanceCounter) {
                                go(curr + o.scroll);
                                advanceCounter++;
                                m()
                            }
                        }, o.timeout + o.speed)
                    };
                m();
                $(document).bind('pauseCarousel', function () {
                    clearTimeout(l);
                    c.data('paused', true)
                }).bind('stopCarousel', function () {
                    clearTimeout(l);
                    o.stop = true
                }).bind('resumeCarousel', function () {
                    m();
                    c.data('paused', true)
                });
                if (o.pause) {
                    (c, f).mouseenter(function () {
                        if (!o.stop) c.trigger('pauseCarousel')
                    }).mouseleave(function () {
                        if (!o.stop) c.trigger('resumeCarousel')
                    })
                }
            }
            function vis() {
                return g.slice(curr).slice(0, v)
            }
            function go(a) {
                if (!b) {
                    if (o.beforeStart) {
                        o.beforeStart.call(this, vis())
                    }
                    if (o.circular) {
                        if (a <= o.start - v - 1) {
                            ul.css(animCss, -((itemLength - (v * 2)) * h) + "px");
                            curr = a == o.start - v - 1 ? itemLength - (v * 2) - 1 : itemLength - (v * 2) - o.scroll
                        } else if (a >= itemLength - v + 1) {
                            ul.css(animCss, -((v) * h) + "px");
                            curr = a == itemLength - v + 1 ? v + 1 : v + o.scroll
                        } else {
                            curr = a
                        }
                    } else {
                        if (a < 0) {
                            curr = 0
                        } else if (a > itemLength - v) {
                            curr = itemLength - v
                        } else {
                            curr = a
                        }
                    }
                    b = true;
                    ul.animate(animCss == "left" ? {
                        left: -(curr * h)
                    } : {
                        top: -(curr * h)
                    }, o.speed, o.easing, function () {
                        if (o.afterEnd) {
                            o.afterEnd.call(this, vis())
                        }
                        b = false
                    });
                    if (!o.circular) {
                        $(o.btnPrev + "," + o.btnNext).removeClass("disabled");
                        $((curr - o.scroll < 0 && o.btnPrev) || (curr + o.scroll > itemLength - v && o.btnNext) || []).addClass("disabled")
                    }
                }
                return false
            }
        })
    };

    function css(a, b) {
        return parseInt($.css(a[0], b), 10) || 0
    }
    function width(a) {
        return a[0].offsetWidth + css(a, 'marginLeft') + css(a, 'marginRight')
    }
    function height(a) {
        return a[0].offsetHeight + css(a, 'marginTop') + css(a, 'marginBottom')
    }
    function iterations(a, b) {
        return b.autoStop && (b.circular ? b.autoStop : Math.min(a, b.autoStop))
    }
})(jQuery);

/* jQuery FancyBox 1.3.4 */
;
(function ($) {
    var f, loading, overlay, wrap, outer, content, close, title, nav_left, nav_right, selectedIndex = 0,
        selectedOpts = {},
        selectedArray = [],
        currentIndex = 0,
        currentOpts = {},
        currentArray = [],
        ajaxLoader = null,
        imgPreloader = new Image(),
        imgRegExp = /\.(jpg|gif|png|bmp|jpeg)(.*)?$/i,
        swfRegExp = /[^\.]\.(swf)\s*$/i,
        loadingTimer, loadingFrame = 1,
        titleHeight = 0,
        titleStr = '',
        start_pos, final_pos, busy = false,
        fx = $.extend($('<div/>')[0], {
            prop: 0
        }),
        isIE6 = $.browser.msie && $.browser.version < 7 && !window.XMLHttpRequest,
        _abort = function () {
            loading.hide();
            imgPreloader.onerror = imgPreloader.onload = null;
            if (ajaxLoader) {
                ajaxLoader.abort()
            }
            f.empty()
        },
        _error = function () {
            if (false === selectedOpts.onError(selectedArray, selectedIndex, selectedOpts)) {
                loading.hide();
                busy = false;
                return
            }
            selectedOpts.titleShow = false;
            selectedOpts.width = 'auto';
            selectedOpts.height = 'auto';
            f.html('<p id="fancybox-error">The requested content cannot be loaded.<br />Please try again later.</p>');
            _process_inline()
        },
        _start = function () {
            var d = selectedArray[selectedIndex],
                href, type, title, str, emb, ret;
            _abort();
            selectedOpts = $.extend({}, $.fn.fancybox.defaults, (typeof $(d).data('fancybox') == 'undefined' ? selectedOpts : $(d).data('fancybox')));
            ret = selectedOpts.onStart(selectedArray, selectedIndex, selectedOpts);
            if (ret === false) {
                busy = false;
                return
            } else if (typeof ret == 'object') {
                selectedOpts = $.extend(selectedOpts, ret)
            }
            title = selectedOpts.title || (d.nodeName ? $(d).attr('title') : d.title) || '';
            if (d.nodeName && !selectedOpts.orig) {
                selectedOpts.orig = $(d).children("img:first").length ? $(d).children("img:first") : $(d)
            }
            if (title === '' && selectedOpts.orig && selectedOpts.titleFromAlt) {
                title = selectedOpts.orig.attr('alt')
            }
            href = selectedOpts.href || (d.nodeName ? $(d).attr('href') : d.href) || null;
            if ((/^(?:javascript)/i).test(href) || href == '#') {
                href = null
            }
            if (selectedOpts.type) {
                type = selectedOpts.type;
                if (!href) {
                    href = selectedOpts.content
                }
            } else if (selectedOpts.content) {
                type = 'html'
            } else if (href) {
                if (href.match(imgRegExp)) {
                    type = 'image'
                } else if (href.match(swfRegExp)) {
                    type = 'swf'
                } else if ($(d).hasClass("iframe")) {
                    type = 'iframe'
                } else if (href.indexOf("#") === 0) {
                    type = 'inline'
                } else {
                    type = 'ajax'
                }
            }
            if (!type) {
                _error();
                return
            }
            if (type == 'inline') {
                d = href.substr(href.indexOf("#"));
                type = $(d).length > 0 ? 'inline' : 'ajax'
            }
            selectedOpts.type = type;
            selectedOpts.href = href;
            selectedOpts.title = title;
            if (selectedOpts.autoDimensions) {
                if (selectedOpts.type == 'html' || selectedOpts.type == 'inline' || selectedOpts.type == 'ajax') {
                    selectedOpts.width = 'auto';
                    selectedOpts.height = 'auto'
                } else {
                    selectedOpts.autoDimensions = false
                }
            }
            if (selectedOpts.modal) {
                selectedOpts.overlayShow = true;
                selectedOpts.hideOnOverlayClick = false;
                selectedOpts.hideOnContentClick = false;
                selectedOpts.enableEscapeButton = false;
                selectedOpts.showCloseButton = false
            }
            selectedOpts.padding = parseInt(selectedOpts.padding, 10);
            selectedOpts.margin = parseInt(selectedOpts.margin, 10);
            f.css('padding', (selectedOpts.padding + selectedOpts.margin));
            $('.fancybox-inline-tmp').unbind('fancybox-cancel').bind('fancybox-change', function () {
                $(this).replaceWith(content.children())
            });
            switch (type) {
            case 'html':
                f.html(selectedOpts.content);
                _process_inline();
                break;
            case 'inline':
                if ($(d).parent().is('#fancybox-content') === true) {
                    busy = false;
                    return
                }
                $('<div class="fancybox-inline-tmp" />').hide().insertBefore($(d)).bind('fancybox-cleanup', function () {
                    $(this).replaceWith(content.children())
                }).bind('fancybox-cancel', function () {
                    $(this).replaceWith(f.children())
                });
                $(d).appendTo(f);
                _process_inline();
                break;
            case 'image':
                busy = false;
                $.fancybox.showActivity();
                imgPreloader = new Image();
                imgPreloader.onerror = function () {
                    _error()
                };
                imgPreloader.onload = function () {
                    busy = true;
                    imgPreloader.onerror = imgPreloader.onload = null;
                    _process_image()
                };
                imgPreloader.src = href;
                break;
            case 'swf':
                selectedOpts.scrolling = 'no';
                str = '<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" width="' + selectedOpts.width + '" height="' + selectedOpts.height + '"><param name="movie" value="' + href + '"></param>';
                emb = '';
                $.each(selectedOpts.swf, function (a, b) {
                    str += '<param name="' + a + '" value="' + b + '"></param>';
                    emb += ' ' + a + '="' + b + '"'
                });
                str += '<embed src="' + href + '" type="application/x-shockwave-flash" width="' + selectedOpts.width + '" height="' + selectedOpts.height + '"' + emb + '></embed></object>';
                f.html(str);
                _process_inline();
                break;
            case 'ajax':
                busy = false;
                $.fancybox.showActivity();
                selectedOpts.ajax.win = selectedOpts.ajax.success;
                ajaxLoader = $.ajax($.extend({}, selectedOpts.ajax, {
                    url: href,
                    data: selectedOpts.ajax.data || {},
                    error: function (a, b, c) {
                        if (a.status > 0) {
                            _error()
                        }
                    },
                    success: function (a, b, c) {
                        var o = typeof c == 'object' ? c : ajaxLoader;
                        if (o.status == 200) {
                            if (typeof selectedOpts.ajax.win == 'function') {
                                ret = selectedOpts.ajax.win(href, a, b, c);
                                if (ret === false) {
                                    loading.hide();
                                    return
                                } else if (typeof ret == 'string' || typeof ret == 'object') {
                                    a = ret
                                }
                            }
                            f.html(a);
                            _process_inline()
                        }
                    }
                }));
                break;
            case 'iframe':
                _show();
                break
            }
        },
        _process_inline = function () {
            var w = selectedOpts.width,
                h = selectedOpts.height;
            if (w.toString().indexOf('%') > -1) {
                w = parseInt(($(window).width() - (selectedOpts.margin * 2)) * parseFloat(w) / 100, 10) + 'px'
            } else {
                w = w == 'auto' ? 'auto' : w + 'px'
            }
            if (h.toString().indexOf('%') > -1) {
                h = parseInt(($(window).height() - (selectedOpts.margin * 2)) * parseFloat(h) / 100, 10) + 'px'
            } else {
                h = h == 'auto' ? 'auto' : h + 'px'
            }
            f.wrapInner('<div style="width:' + w + ';height:' + h + ';overflow: ' + (selectedOpts.scrolling == 'auto' ? 'auto' : (selectedOpts.scrolling == 'yes' ? 'scroll' : 'hidden')) + ';position:relative;"></div>');
            selectedOpts.width = f.width();
            selectedOpts.height = f.height();
            _show()
        },
        _process_image = function () {
            selectedOpts.width = imgPreloader.width;
            selectedOpts.height = imgPreloader.height;
            $("<img />").attr({
                'id': 'fancybox-img',
                'src': imgPreloader.src,
                'alt': selectedOpts.title
            }).appendTo(f);
            _show()
        },
        _show = function () {
            var b, equal;
            loading.hide();
            if (wrap.is(":visible") && false === currentOpts.onCleanup(currentArray, currentIndex, currentOpts)) {
                $.event.trigger('fancybox-cancel');
                busy = false;
                return
            }
            busy = true;
            $(content.add(overlay)).unbind();
            $(window).unbind("resize.fb scroll.fb");
            $(document).unbind('keydown.fb');
            if (wrap.is(":visible") && currentOpts.titlePosition !== 'outside') {
                wrap.css('height', wrap.height())
            }
            currentArray = selectedArray;
            currentIndex = selectedIndex;
            currentOpts = selectedOpts;
            if (currentOpts.overlayShow) {
                overlay.css({
                    'background-color': currentOpts.overlayColor,
                    'opacity': currentOpts.overlayOpacity,
                    'cursor': currentOpts.hideOnOverlayClick ? 'pointer' : 'auto',
                    'height': $(document).height()
                });
                if (!overlay.is(':visible')) {
                    if (isIE6) {
                        $('select:not(#fancybox-tmp select)').filter(function () {
                            return this.style.visibility !== 'hidden'
                        }).css({
                            'visibility': 'hidden'
                        }).one('fancybox-cleanup', function () {
                            this.style.visibility = 'inherit'
                        })
                    }
                    overlay.show()
                }
            } else {
                overlay.hide()
            }
            final_pos = _get_zoom_to();
            _process_title();
            if (wrap.is(":visible")) {
                $(close.add(nav_left).add(nav_right)).hide();
                b = wrap.position(), start_pos = {
                    top: b.top,
                    left: b.left,
                    width: wrap.width(),
                    height: wrap.height()
                };
                equal = (start_pos.width == final_pos.width && start_pos.height == final_pos.height);
                content.fadeTo(currentOpts.changeFade, 0.3, function () {
                    var a = function () {
                            content.html(f.contents()).fadeTo(currentOpts.changeFade, 1, _finish)
                        };
                    $.event.trigger('fancybox-change');
                    content.empty().removeAttr('filter').css({
                        'border-width': currentOpts.padding,
                        'width': final_pos.width - currentOpts.padding * 2,
                        'height': selectedOpts.autoDimensions ? 'auto' : final_pos.height - titleHeight - currentOpts.padding * 2
                    });
                    if (equal) {
                        a()
                    } else {
                        fx.prop = 0;
                        $(fx).animate({
                            prop: 1
                        }, {
                            duration: currentOpts.changeSpeed,
                            easing: currentOpts.easingChange,
                            step: _draw,
                            complete: a
                        })
                    }
                });
                return
            }
            wrap.removeAttr("style");
            content.css('border-width', currentOpts.padding);
            if (currentOpts.transitionIn == 'elastic') {
                start_pos = _get_zoom_from();
                content.html(f.contents());
                wrap.show();
                if (currentOpts.opacity) {
                    final_pos.opacity = 0
                }
                fx.prop = 0;
                $(fx).animate({
                    prop: 1
                }, {
                    duration: currentOpts.speedIn,
                    easing: currentOpts.easingIn,
                    step: _draw,
                    complete: _finish
                });
                return
            }
            if (currentOpts.titlePosition == 'inside' && titleHeight > 0) {
                title.show()
            }
            content.css({
                'width': final_pos.width - currentOpts.padding * 2,
                'height': selectedOpts.autoDimensions ? 'auto' : final_pos.height - titleHeight - currentOpts.padding * 2
            }).html(f.contents());
            wrap.css(final_pos).fadeIn(currentOpts.transitionIn == 'none' ? 0 : currentOpts.speedIn, _finish)
        },
        _format_title = function (a) {
            if (a && a.length) {
                if (currentOpts.titlePosition == 'float') {
                    return '<table id="fancybox-title-float-wrap" cellpadding="0" cellspacing="0"><tr><td id="fancybox-title-float-left"></td><td id="fancybox-title-float-main">' + a + '</td><td id="fancybox-title-float-right"></td></tr></table>'
                }
                return '<div id="fancybox-title-' + currentOpts.titlePosition + '">' + a + '</div>'
            }
            return false
        },
        _process_title = function () {
            titleStr = currentOpts.title || '';
            titleHeight = 0;
            title.empty().removeAttr('style').removeClass();
            if (currentOpts.titleShow === false) {
                title.hide();
                return
            }
            titleStr = $.isFunction(currentOpts.titleFormat) ? currentOpts.titleFormat(titleStr, currentArray, currentIndex, currentOpts) : _format_title(titleStr);
            if (!titleStr || titleStr === '') {
                title.hide();
                return
            }
            title.addClass('fancybox-title-' + currentOpts.titlePosition).html(titleStr).appendTo('body').show();
            switch (currentOpts.titlePosition) {
            case 'inside':
                title.css({
                    'width': final_pos.width - (currentOpts.padding * 2),
                    'marginLeft': currentOpts.padding,
                    'marginRight': currentOpts.padding
                });
                titleHeight = title.outerHeight(true);
                title.appendTo(outer);
                final_pos.height += titleHeight;
                break;
            case 'over':
                title.css({
                    'marginLeft': currentOpts.padding,
                    'width': final_pos.width - (currentOpts.padding * 2),
                    'bottom': currentOpts.padding
                }).appendTo(outer);
                break;
            case 'float':
                title.css('left', parseInt((title.width() - final_pos.width - 40) / 2, 10) * -1).appendTo(wrap);
                break;
            default:
                title.css({
                    'width': final_pos.width - (currentOpts.padding * 2),
                    'paddingLeft': currentOpts.padding,
                    'paddingRight': currentOpts.padding
                }).appendTo(wrap);
                break
            }
            title.hide()
        },
        _set_navigation = function () {
            if (currentOpts.enableEscapeButton || currentOpts.enableKeyboardNav) {
                $(document).bind('keydown.fb', function (e) {
                    if (e.keyCode == 27 && currentOpts.enableEscapeButton) {
                        e.preventDefault();
                        $.fancybox.close()
                    } else if ((e.keyCode == 37 || e.keyCode == 39) && currentOpts.enableKeyboardNav && e.target.tagName !== 'INPUT' && e.target.tagName !== 'TEXTAREA' && e.target.tagName !== 'SELECT') {
                        e.preventDefault();
                        $.fancybox[e.keyCode == 37 ? 'prev' : 'next']()
                    }
                })
            }
            if (!currentOpts.showNavArrows) {
                nav_left.hide();
                nav_right.hide();
                return
            }
            if ((currentOpts.cyclic && currentArray.length > 1) || currentIndex !== 0) {
                nav_left.show()
            }
            if ((currentOpts.cyclic && currentArray.length > 1) || currentIndex != (currentArray.length - 1)) {
                nav_right.show()
            }
        },
        _finish = function () {
            if (!$.support.opacity) {
                content.get(0).style.removeAttribute('filter');
                wrap.get(0).style.removeAttribute('filter')
            }
            if (selectedOpts.autoDimensions) {
                content.css('height', 'auto')
            }
            wrap.css('height', 'auto');
            if (titleStr && titleStr.length) {
                title.show()
            }
            if (currentOpts.showCloseButton) {
                close.show()
            }
            _set_navigation();
            if (currentOpts.hideOnContentClick) {
                content.bind('click', $.fancybox.close)
            }
            if (currentOpts.hideOnOverlayClick) {
                overlay.bind('click', $.fancybox.close)
            }
            $(window).bind("resize.fb", $.fancybox.resize);
            if (currentOpts.centerOnScroll) {
                $(window).bind("scroll.fb", $.fancybox.center)
            }
            if (currentOpts.type == 'iframe') {
                $('<iframe id="fancybox-frame" name="fancybox-frame' + new Date().getTime() + '" frameborder="0" hspace="0" ' + ($.browser.msie ? 'allowtransparency="true""' : '') + ' scrolling="' + selectedOpts.scrolling + '" src="' + currentOpts.href + '"></iframe>').appendTo(content)
            }
            wrap.show();
            busy = false;
            $.fancybox.center();
            currentOpts.onComplete(currentArray, currentIndex, currentOpts);
            _preload_images()
        },
        _preload_images = function () {
            var a, objNext;
            if ((currentArray.length - 1) > currentIndex) {
                a = currentArray[currentIndex + 1].href;
                if (typeof a !== 'undefined' && a.match(imgRegExp)) {
                    objNext = new Image();
                    objNext.src = a
                }
            }
            if (currentIndex > 0) {
                a = currentArray[currentIndex - 1].href;
                if (typeof a !== 'undefined' && a.match(imgRegExp)) {
                    objNext = new Image();
                    objNext.src = a
                }
            }
        },
        _draw = function (a) {
            var b = {
                width: parseInt(start_pos.width + (final_pos.width - start_pos.width) * a, 10),
                height: parseInt(start_pos.height + (final_pos.height - start_pos.height) * a, 10),
                top: parseInt(start_pos.top + (final_pos.top - start_pos.top) * a, 10),
                left: parseInt(start_pos.left + (final_pos.left - start_pos.left) * a, 10)
            };
            if (typeof final_pos.opacity !== 'undefined') {
                b.opacity = a < 0.5 ? 0.5 : a
            }
            wrap.css(b);
            content.css({
                'width': b.width - currentOpts.padding * 2,
                'height': b.height - (titleHeight * a) - currentOpts.padding * 2
            })
        },
        _get_viewport = function () {
            return [$(window).width() - (currentOpts.margin * 2), $(window).height() - (currentOpts.margin * 2), $(document).scrollLeft() + currentOpts.margin, $(document).scrollTop() + currentOpts.margin]
        },
        _get_zoom_to = function () {
            var a = _get_viewport(),
                to = {},
                resize = currentOpts.autoScale,
                double_padding = currentOpts.padding * 2,
                ratio;
            if (currentOpts.width.toString().indexOf('%') > -1) {
                to.width = parseInt((a[0] * parseFloat(currentOpts.width)) / 100, 10)
            } else {
                to.width = currentOpts.width + double_padding
            }
            if (currentOpts.height.toString().indexOf('%') > -1) {
                to.height = parseInt((a[1] * parseFloat(currentOpts.height)) / 100, 10)
            } else {
                to.height = currentOpts.height + double_padding
            }
            if (resize && (to.width > a[0] || to.height > a[1])) {
                if (selectedOpts.type == 'image' || selectedOpts.type == 'swf') {
                    ratio = (currentOpts.width) / (currentOpts.height);
                    if ((to.width) > a[0]) {
                        to.width = a[0];
                        to.height = parseInt(((to.width - double_padding) / ratio) + double_padding, 10)
                    }
                    if ((to.height) > a[1]) {
                        to.height = a[1];
                        to.width = parseInt(((to.height - double_padding) * ratio) + double_padding, 10)
                    }
                } else {
                    to.width = Math.min(to.width, a[0]);
                    to.height = Math.min(to.height, a[1])
                }
            }
            to.top = parseInt(Math.max(a[3] - 20, a[3] + ((a[1] - to.height - 40) * 0.5)), 10);
            to.left = parseInt(Math.max(a[2] - 20, a[2] + ((a[0] - to.width - 40) * 0.5)), 10);
            return to
        },
        _get_obj_pos = function (a) {
            var b = a.offset();
            b.top += parseInt(a.css('paddingTop'), 10) || 0;
            b.left += parseInt(a.css('paddingLeft'), 10) || 0;
            b.top += parseInt(a.css('border-top-width'), 10) || 0;
            b.left += parseInt(a.css('border-left-width'), 10) || 0;
            b.width = a.width();
            b.height = a.height();
            return b
        },
        _get_zoom_from = function () {
            var a = selectedOpts.orig ? $(selectedOpts.orig) : false,
                from = {},
                pos, view;
            if (a && a.length) {
                pos = _get_obj_pos(a);
                from = {
                    width: pos.width + (currentOpts.padding * 2),
                    height: pos.height + (currentOpts.padding * 2),
                    top: pos.top - currentOpts.padding - 20,
                    left: pos.left - currentOpts.padding - 20
                }
            } else {
                view = _get_viewport();
                from = {
                    width: currentOpts.padding * 2,
                    height: currentOpts.padding * 2,
                    top: parseInt(view[3] + view[1] * 0.5, 10),
                    left: parseInt(view[2] + view[0] * 0.5, 10)
                }
            }
            return from
        },
        _animate_loading = function () {
            if (!loading.is(':visible')) {
                clearInterval(loadingTimer);
                return
            }
            $('div', loading).css('top', (loadingFrame * -40) + 'px');
            loadingFrame = (loadingFrame + 1) % 12
        };
    $.fn.fancybox = function (b) {
        if (!$(this).length) {
            return this
        }
        $(this).data('fancybox', $.extend({}, b, ($.metadata ? $(this).metadata() : {}))).unbind('click.fb').bind('click.fb', function (e) {
            e.preventDefault();
            if (busy) {
                return
            }
            busy = true;
            $(this).blur();
            selectedArray = [];
            selectedIndex = 0;
            var a = $(this).attr('rel') || '';
            if (!a || a == '' || a === 'nofollow') {
                selectedArray.push(this)
            } else {
                selectedArray = $("a[rel=" + a + "], area[rel=" + a + "]");
                selectedIndex = selectedArray.index(this)
            }
            _start();
            return
        });
        return this
    };
    $.fancybox = function (a) {
        var b;
        if (busy) {
            return
        }
        busy = true;
        b = typeof arguments[1] !== 'undefined' ? arguments[1] : {};
        selectedArray = [];
        selectedIndex = parseInt(b.index, 10) || 0;
        if ($.isArray(a)) {
            for (var i = 0, j = a.length; i < j; i++) {
                if (typeof a[i] == 'object') {
                    $(a[i]).data('fancybox', $.extend({}, b, a[i]))
                } else {
                    a[i] = $({}).data('fancybox', $.extend({
                        content: a[i]
                    }, b))
                }
            }
            selectedArray = jQuery.merge(selectedArray, a)
        } else {
            if (typeof a == 'object') {
                $(a).data('fancybox', $.extend({}, b, a))
            } else {
                a = $({}).data('fancybox', $.extend({
                    content: a
                }, b))
            }
            selectedArray.push(a)
        }
        if (selectedIndex > selectedArray.length || selectedIndex < 0) {
            selectedIndex = 0
        }
        _start()
    };
    $.fancybox.showActivity = function () {
        clearInterval(loadingTimer);
        loading.show();
        loadingTimer = setInterval(_animate_loading, 66)
    };
    $.fancybox.hideActivity = function () {
        loading.hide()
    };
    $.fancybox.next = function () {
        return $.fancybox.pos(currentIndex + 1)
    };
    $.fancybox.prev = function () {
        return $.fancybox.pos(currentIndex - 1)
    };
    $.fancybox.pos = function (a) {
        if (busy) {
            return
        }
        a = parseInt(a);
        selectedArray = currentArray;
        if (a > -1 && a < currentArray.length) {
            selectedIndex = a;
            _start()
        } else if (currentOpts.cyclic && currentArray.length > 1) {
            selectedIndex = a >= currentArray.length ? 0 : currentArray.length - 1;
            _start()
        }
        return
    };
    $.fancybox.cancel = function () {
        if (busy) {
            return
        }
        busy = true;
        $.event.trigger('fancybox-cancel');
        _abort();
        selectedOpts.onCancel(selectedArray, selectedIndex, selectedOpts);
        busy = false
    };
    $.fancybox.close = function () {
        if (busy || wrap.is(':hidden')) {
            return
        }
        busy = true;
        if (currentOpts && false === currentOpts.onCleanup(currentArray, currentIndex, currentOpts)) {
            busy = false;
            return
        }
        _abort();
        $(close.add(nav_left).add(nav_right)).hide();
        $(content.add(overlay)).unbind();
        $(window).unbind("resize.fb scroll.fb");
        $(document).unbind('keydown.fb');
        content.find('iframe').attr('src', isIE6 && /^https/i.test(window.location.href || '') ? 'javascript:void(false)' : 'about:blank');
        if (currentOpts.titlePosition !== 'inside') {
            title.empty()
        }
        wrap.stop();

        function _cleanup() {
            overlay.fadeOut('fast');
            title.empty().hide();
            wrap.hide();
            $.event.trigger('fancybox-cleanup');
            content.empty();
            currentOpts.onClosed(currentArray, currentIndex, currentOpts);
            currentArray = selectedOpts = [];
            currentIndex = selectedIndex = 0;
            currentOpts = selectedOpts = {};
            busy = false
        }
        if (currentOpts.transitionOut == 'elastic') {
            start_pos = _get_zoom_from();
            var a = wrap.position();
            final_pos = {
                top: a.top,
                left: a.left,
                width: wrap.width(),
                height: wrap.height()
            };
            if (currentOpts.opacity) {
                final_pos.opacity = 1
            }
            title.empty().hide();
            fx.prop = 1;
            $(fx).animate({
                prop: 0
            }, {
                duration: currentOpts.speedOut,
                easing: currentOpts.easingOut,
                step: _draw,
                complete: _cleanup
            })
        } else {
            wrap.fadeOut(currentOpts.transitionOut == 'none' ? 0 : currentOpts.speedOut, _cleanup)
        }
    };
    $.fancybox.resize = function () {
        if (overlay.is(':visible')) {
            overlay.css('height', $(document).height())
        }
        $.fancybox.center(true)
    };
    $.fancybox.center = function () {
        var a, align;
        if (busy) {
            return
        }
        align = arguments[0] === true ? 1 : 0;
        a = _get_viewport();
        if (!align && (wrap.width() > a[0] || wrap.height() > a[1])) {
            return
        }
        wrap.stop().animate({
            'top': parseInt(Math.max(a[3] - 20, a[3] + ((a[1] - content.height() - 40) * 0.5) - currentOpts.padding)),
            'left': parseInt(Math.max(a[2] - 20, a[2] + ((a[0] - content.width() - 40) * 0.5) - currentOpts.padding))
        }, typeof arguments[0] == 'number' ? arguments[0] : 200)
    };
    $.fancybox.init = function () {
        if ($("#fancybox-wrap").length) {
            return
        }
        $('body').append(f = $('<div id="fancybox-tmp"></div>'), loading = $('<div id="fancybox-loading"><div></div></div>'), overlay = $('<div id="fancybox-overlay"></div>'), wrap = $('<div id="fancybox-wrap"></div>'));
        outer = $('<div id="fancybox-outer"></div>').append('<div class="fancybox-bg" id="fancybox-bg-n"></div><div class="fancybox-bg" id="fancybox-bg-ne"></div><div class="fancybox-bg" id="fancybox-bg-e"></div><div class="fancybox-bg" id="fancybox-bg-se"></div><div class="fancybox-bg" id="fancybox-bg-s"></div><div class="fancybox-bg" id="fancybox-bg-sw"></div><div class="fancybox-bg" id="fancybox-bg-w"></div><div class="fancybox-bg" id="fancybox-bg-nw"></div>').appendTo(wrap);
        outer.append(content = $('<div id="fancybox-content"></div>'), close = $('<a id="fancybox-close"></a>'), title = $('<div id="fancybox-title"></div>'), nav_left = $('<a href="javascript:;" id="fancybox-left"><span class="fancy-ico" id="fancybox-left-ico"></span></a>'), nav_right = $('<a href="javascript:;" id="fancybox-right"><span class="fancy-ico" id="fancybox-right-ico"></span></a>'));
        close.click($.fancybox.close);
        loading.click($.fancybox.cancel);
        nav_left.click(function (e) {
            e.preventDefault();
            $.fancybox.prev()
        });
        nav_right.click(function (e) {
            e.preventDefault();
            $.fancybox.next()
        });
        if ($.fn.mousewheel) {
            wrap.bind('mousewheel.fb', function (e, a) {
                if (busy) {
                    e.preventDefault()
                } else if ($(e.target).get(0).clientHeight == 0 || $(e.target).get(0).scrollHeight === $(e.target).get(0).clientHeight) {
                    e.preventDefault();
                    $.fancybox[a > 0 ? 'prev' : 'next']()
                }
            })
        }
        if (!$.support.opacity) {
            wrap.addClass('fancybox-ie')
        }
        if (isIE6) {
            loading.addClass('fancybox-ie6');
            wrap.addClass('fancybox-ie6');
            $('<iframe id="fancybox-hide-sel-frame" src="' + (/^https/i.test(window.location.href || '') ? 'javascript:void(false)' : 'about:blank') + '" scrolling="no" border="0" frameborder="0" tabindex="-1"></iframe>').prependTo(outer)
        }
    };
    $.fn.fancybox.defaults = {
        padding: 10,
        margin: 40,
        opacity: false,
        modal: false,
        cyclic: false,
        scrolling: 'auto',
        width: 560,
        height: 340,
        autoScale: true,
        autoDimensions: true,
        centerOnScroll: false,
        ajax: {},
        swf: {
            wmode: 'transparent'
        },
        hideOnOverlayClick: true,
        hideOnContentClick: false,
        overlayShow: true,
        overlayOpacity: 0.7,
        overlayColor: '#777',
        titleShow: true,
        titlePosition: 'float',
        titleFormat: null,
        titleFromAlt: false,
        transitionIn: 'fade',
        transitionOut: 'fade',
        speedIn: 300,
        speedOut: 300,
        changeSpeed: 300,
        changeFade: 'fast',
        easingIn: 'swing',
        easingOut: 'swing',
        showCloseButton: true,
        showNavArrows: true,
        enableEscapeButton: true,
        enableKeyboardNav: true,
        onStart: function () {},
        onCancel: function () {},
        onComplete: function () {},
        onCleanup: function () {},
        onClosed: function () {},
        onError: function () {}
    };
    $(document).ready(function () {
        $.fancybox.init()
    })
})(jQuery);

/* jQuery Cycle 2.88 */
(function ($) {
    var y = "2.88";
    if ($.support == undefined) {
        $.support = {
            opacity: !($.browser.msie)
        }
    }
    function debug(s) {
        if ($.fn.cycle.debug) {
            log(s)
        }
    }
    function log() {
        if (window.console && window.console.log) {
            window.console.log("[cycle] " + Array.prototype.join.call(arguments, " "))
        }
    }
    $.fn.cycle = function (g, h) {
        var o = {
            s: this.selector,
            c: this.context
        };
        if (this.length === 0 && g != "stop") {
            if (!$.isReady && o.s) {
                log("DOM not ready, queuing slideshow");
                $(function () {
                    $(o.s, o.c).cycle(g, h)
                });
                return this
            }
            log("terminating; zero elements found by selector" + ($.isReady ? "" : " (DOM not ready)"));
            return this
        }
        return this.each(function () {
            var a = handleArguments(this, g, h);
            if (a === false) {
                return
            }
            a.updateActivePagerLink = a.updateActivePagerLink || $.fn.cycle.updateActivePagerLink;
            if (this.cycleTimeout) {
                clearTimeout(this.cycleTimeout)
            }
            this.cycleTimeout = this.cyclePause = 0;
            var b = $(this);
            var c = a.slideExpr ? $(a.slideExpr, this) : b.children();
            var d = c.get();
            if (d.length < 2) {
                log("terminating; too few slides: " + d.length);
                return
            }
            var e = buildOptions(b, c, d, a, o);
            if (e === false) {
                return
            }
            var f = e.continuous ? 10 : getTimeout(d[e.currSlide], d[e.nextSlide], e, !e.rev);
            if (f) {
                f += (e.delay || 0);
                if (f < 10) {
                    f = 10
                }
                debug("first timeout: " + f);
                this.cycleTimeout = setTimeout(function () {
                    go(d, e, 0, (!e.rev && !a.backwards))
                }, f)
            }
        })
    };

    function handleArguments(e, f, g) {
        if (e.cycleStop == undefined) {
            e.cycleStop = 0
        }
        if (f === undefined || f === null) {
            f = {}
        }
        if (f.constructor == String) {
            switch (f) {
            case "destroy":
            case "stop":
                var h = $(e).data("cycle.opts");
                if (!h) {
                    return false
                }
                e.cycleStop++;
                if (e.cycleTimeout) {
                    clearTimeout(e.cycleTimeout)
                }
                e.cycleTimeout = 0;
                $(e).removeData("cycle.opts");
                if (f == "destroy") {
                    destroy(h)
                }
                return false;
            case "toggle":
                e.cyclePause = (e.cyclePause === 1) ? 0 : 1;
                checkInstantResume(e.cyclePause, g, e);
                return false;
            case "pause":
                e.cyclePause = 1;
                return false;
            case "resume":
                e.cyclePause = 0;
                checkInstantResume(false, g, e);
                return false;
            case "prev":
            case "next":
                var h = $(e).data("cycle.opts");
                if (!h) {
                    log('options not found, "prev/next" ignored');
                    return false
                }
                $.fn.cycle[f](h);
                return false;
            default:
                f = {
                    fx: f
                }
            }
            return f
        } else {
            if (f.constructor == Number) {
                var i = f;
                f = $(e).data("cycle.opts");
                if (!f) {
                    log("options not found, can not advance slide");
                    return false
                }
                if (i < 0 || i >= f.elements.length) {
                    log("invalid slide index: " + i);
                    return false
                }
                f.nextSlide = i;
                if (e.cycleTimeout) {
                    clearTimeout(e.cycleTimeout);
                    e.cycleTimeout = 0
                }
                if (typeof g == "string") {
                    f.oneTimeFx = g
                }
                go(f.elements, f, 1, i >= f.currSlide);
                return false
            }
        }
        return f;

        function checkInstantResume(a, b, c) {
            if (!a && b === true) {
                var d = $(c).data("cycle.opts");
                if (!d) {
                    log("options not found, can not resume");
                    return false
                }
                if (c.cycleTimeout) {
                    clearTimeout(c.cycleTimeout);
                    c.cycleTimeout = 0
                }
                go(d.elements, d, 1, (!h.rev && !h.backwards))
            }
        }
    }
    function removeFilter(a, b) {
        if (!$.support.opacity && b.cleartype && a.style.filter) {
            try {
                a.style.removeAttribute("filter")
            } catch (smother) {}
        }
    }
    function destroy(a) {
        if (a.next) {
            $(a.next).unbind(a.prevNextEvent)
        }
        if (a.prev) {
            $(a.prev).unbind(a.prevNextEvent)
        }
        if (a.pager || a.pagerAnchorBuilder) {
            $.each(a.pagerAnchors || [], function () {
                this.unbind().remove()
            })
        }
        a.pagerAnchors = null;
        if (a.destroy) {
            a.destroy(a)
        }
    }
    function buildOptions(f, g, k, l, o) {
        var m = $.extend({}, $.fn.cycle.defaults, l || {}, $.metadata ? f.metadata() : $.meta ? f.data() : {});
        if (m.autostop) {
            m.countdown = m.autostopCount || k.length
        }
        var n = f[0];
        f.data("cycle.opts", m);
        m.$cont = f;
        m.stopCount = n.cycleStop;
        m.elements = k;
        m.before = m.before ? [m.before] : [];
        m.after = m.after ? [m.after] : [];
        m.after.unshift(function () {
            m.busy = 0
        });
        if (!$.support.opacity && m.cleartype) {
            m.after.push(function () {
                removeFilter(this, m)
            })
        }
        if (m.continuous) {
            m.after.push(function () {
                go(k, m, 0, (!m.rev && !m.backwards))
            })
        }
        saveOriginalOpts(m);
        if (!$.support.opacity && m.cleartype && !m.cleartypeNoBg) {
            clearTypeFix(g)
        }
        if (f.css("position") == "static") {
            f.css("position", "relative")
        }
        if (m.width) {
            f.width(m.width)
        }
        if (m.height && m.height != "auto") {
            f.height(m.height)
        }
        if (m.startingSlide) {
            m.startingSlide = parseInt(m.startingSlide)
        } else {
            if (m.backwards) {
                m.startingSlide = k.length - 1
            }
        }
        if (m.random) {
            m.randomMap = [];
            for (var i = 0; i < k.length; i++) {
                m.randomMap.push(i)
            }
            m.randomMap.sort(function (a, b) {
                return Math.random() - 0.5
            });
            m.randomIndex = 1;
            m.startingSlide = m.randomMap[1]
        } else {
            if (m.startingSlide >= k.length) {
                m.startingSlide = 0
            }
        }
        m.currSlide = m.startingSlide || 0;
        var p = m.startingSlide;
        g.css({
            position: "absolute",
            top: 0,
            left: 0
        }).hide().each(function (i) {
            var z;
            if (m.backwards) {
                z = p ? i <= p ? k.length + (i - p) : p - i : k.length - i
            } else {
                z = p ? i >= p ? k.length - (i - p) : p - i : k.length - i
            }
            $(this).css("z-index", z)
        });
        $(k[p]).css("opacity", 1).show();
        removeFilter(k[p], m);
        if (m.fit && m.width) {
            g.width(m.width)
        }
        if (m.fit && m.height && m.height != "auto") {
            g.height(m.height)
        }
        var q = m.containerResize && !f.innerHeight();
        if (q) {
            var r = 0,
                maxh = 0;
            for (var j = 0; j < k.length; j++) {
                var s = $(k[j]),
                    e = s[0],
                    w = s.outerWidth(),
                    h = s.outerHeight();
                if (!w) {
                    w = e.offsetWidth || e.width || s.attr("width")
                }
                if (!h) {
                    h = e.offsetHeight || e.height || s.attr("height")
                }
                r = w > r ? w : r;
                maxh = h > maxh ? h : maxh
            }
            if (r > 0 && maxh > 0) {
                f.css({
                    width: r + "px",
                    height: maxh + "px"
                })
            }
        }
        if (m.pause) {
            f.hover(function () {
                this.cyclePause++
            }, function () {
                this.cyclePause--
            })
        }
        if (supportMultiTransitions(m) === false) {
            return false
        }
        var t = false;
        l.requeueAttempts = l.requeueAttempts || 0;
        g.each(function () {
            var a = $(this);
            this.cycleH = (m.fit && m.height) ? m.height : (a.height() || this.offsetHeight || this.height || a.attr("height") || 0);
            this.cycleW = (m.fit && m.width) ? m.width : (a.width() || this.offsetWidth || this.width || a.attr("width") || 0);
            if (a.is("img")) {
                var b = ($.browser.msie && this.cycleW == 28 && this.cycleH == 30 && !this.complete);
                var c = ($.browser.mozilla && this.cycleW == 34 && this.cycleH == 19 && !this.complete);
                var d = ($.browser.opera && ((this.cycleW == 42 && this.cycleH == 19) || (this.cycleW == 37 && this.cycleH == 17)) && !this.complete);
                var e = (this.cycleH == 0 && this.cycleW == 0 && !this.complete);
                if (b || c || d || e) {
                    if (o.s && m.requeueOnImageNotLoaded && ++l.requeueAttempts < 100) {
                        log(l.requeueAttempts, " - img slide not loaded, requeuing slideshow: ", this.src, this.cycleW, this.cycleH);
                        setTimeout(function () {
                            $(o.s, o.c).cycle(l)
                        }, m.requeueTimeout);
                        t = true;
                        return false
                    } else {
                        log("could not determine size of image: " + this.src, this.cycleW, this.cycleH)
                    }
                }
            }
            return true
        });
        if (t) {
            return false
        }
        m.cssBefore = m.cssBefore || {};
        m.animIn = m.animIn || {};
        m.animOut = m.animOut || {};
        g.not(":eq(" + p + ")").css(m.cssBefore);
        if (m.cssFirst) {
            $(g[p]).css(m.cssFirst)
        }
        if (m.timeout) {
            m.timeout = parseInt(m.timeout);
            if (m.speed.constructor == String) {
                m.speed = $.fx.speeds[m.speed] || parseInt(m.speed)
            }
            if (!m.sync) {
                m.speed = m.speed / 2
            }
            var u = m.fx == "shuffle" ? 500 : 250;
            while ((m.timeout - m.speed) < u) {
                m.timeout += m.speed
            }
        }
        if (m.easing) {
            m.easeIn = m.easeOut = m.easing
        }
        if (!m.speedIn) {
            m.speedIn = m.speed
        }
        if (!m.speedOut) {
            m.speedOut = m.speed
        }
        m.slideCount = k.length;
        m.currSlide = m.lastSlide = p;
        if (m.random) {
            if (++m.randomIndex == k.length) {
                m.randomIndex = 0
            }
            m.nextSlide = m.randomMap[m.randomIndex]
        } else {
            if (m.backwards) {
                m.nextSlide = m.startingSlide == 0 ? (k.length - 1) : m.startingSlide - 1
            } else {
                m.nextSlide = m.startingSlide >= (k.length - 1) ? 0 : m.startingSlide + 1
            }
        }
        if (!m.multiFx) {
            var v = $.fn.cycle.transitions[m.fx];
            if ($.isFunction(v)) {
                v(f, g, m)
            } else {
                if (m.fx != "custom" && !m.multiFx) {
                    log("unknown transition: " + m.fx, "; slideshow terminating");
                    return false
                }
            }
        }
        var x = g[p];
        if (m.before.length) {
            m.before[0].apply(x, [x, x, m, true])
        }
        if (m.after.length > 1) {
            m.after[1].apply(x, [x, x, m, true])
        }
        if (m.next) {
            $(m.next).bind(m.prevNextEvent, function () {
                return advance(m, m.rev ? -1 : 1)
            })
        }
        if (m.prev) {
            $(m.prev).bind(m.prevNextEvent, function () {
                return advance(m, m.rev ? 1 : -1)
            })
        }
        if (m.pager || m.pagerAnchorBuilder) {
            buildPager(k, m)
        }
        exposeAddSlide(m, k);
        return m
    }
    function saveOriginalOpts(a) {
        a.original = {
            before: [],
            after: []
        };
        a.original.cssBefore = $.extend({}, a.cssBefore);
        a.original.cssAfter = $.extend({}, a.cssAfter);
        a.original.animIn = $.extend({}, a.animIn);
        a.original.animOut = $.extend({}, a.animOut);
        $.each(a.before, function () {
            a.original.before.push(this)
        });
        $.each(a.after, function () {
            a.original.after.push(this)
        })
    }
    function supportMultiTransitions(a) {
        var i, tx, txs = $.fn.cycle.transitions;
        if (a.fx.indexOf(",") > 0) {
            a.multiFx = true;
            a.fxs = a.fx.replace(/\s*/g, "").split(",");
            for (i = 0; i < a.fxs.length; i++) {
                var b = a.fxs[i];
                tx = txs[b];
                if (!tx || !txs.hasOwnProperty(b) || !$.isFunction(tx)) {
                    log("discarding unknown transition: ", b);
                    a.fxs.splice(i, 1);
                    i--
                }
            }
            if (!a.fxs.length) {
                log("No valid transitions named; slideshow terminating.");
                return false
            }
        } else {
            if (a.fx == "all") {
                a.multiFx = true;
                a.fxs = [];
                for (p in txs) {
                    tx = txs[p];
                    if (txs.hasOwnProperty(p) && $.isFunction(tx)) {
                        a.fxs.push(p)
                    }
                }
            }
        }
        if (a.multiFx && a.randomizeEffects) {
            var c = Math.floor(Math.random() * 20) + 30;
            for (i = 0; i < c; i++) {
                var d = Math.floor(Math.random() * a.fxs.length);
                a.fxs.push(a.fxs.splice(d, 1)[0])
            }
            debug("randomized fx sequence: ", a.fxs)
        }
        return true
    }
    function exposeAddSlide(d, e) {
        d.addSlide = function (a, b) {
            var c = $(a),
                s = c[0];
            if (!d.autostopCount) {
                d.countdown++
            }
            e[b ? "unshift" : "push"](s);
            if (d.els) {
                d.els[b ? "unshift" : "push"](s)
            }
            d.slideCount = e.length;
            c.css("position", "absolute");
            c[b ? "prependTo" : "appendTo"](d.$cont);
            if (b) {
                d.currSlide++;
                d.nextSlide++
            }
            if (!$.support.opacity && d.cleartype && !d.cleartypeNoBg) {
                clearTypeFix(c)
            }
            if (d.fit && d.width) {
                c.width(d.width)
            }
            if (d.fit && d.height && d.height != "auto") {
                $slides.height(d.height)
            }
            s.cycleH = (d.fit && d.height) ? d.height : c.height();
            s.cycleW = (d.fit && d.width) ? d.width : c.width();
            c.css(d.cssBefore);
            if (d.pager || d.pagerAnchorBuilder) {
                $.fn.cycle.createPagerAnchor(e.length - 1, s, $(d.pager), e, d)
            }
            if ($.isFunction(d.onAddSlide)) {
                d.onAddSlide(c)
            } else {
                c.hide()
            }
        }
    }
    $.fn.cycle.resetState = function (a, b) {
        b = b || a.fx;
        a.before = [];
        a.after = [];
        a.cssBefore = $.extend({}, a.original.cssBefore);
        a.cssAfter = $.extend({}, a.original.cssAfter);
        a.animIn = $.extend({}, a.original.animIn);
        a.animOut = $.extend({}, a.original.animOut);
        a.fxFn = null;
        $.each(a.original.before, function () {
            a.before.push(this)
        });
        $.each(a.original.after, function () {
            a.after.push(this)
        });
        var c = $.fn.cycle.transitions[b];
        if ($.isFunction(c)) {
            c(a.$cont, $(a.elements), a)
        }
    };

    function go(a, b, c, d) {
        if (c && b.busy && b.manualTrump) {
            debug("manualTrump in go(), stopping active transition");
            $(a).stop(true, true);
            b.busy = false
        }
        if (b.busy) {
            debug("transition active, ignoring new tx request");
            return
        }
        var p = b.$cont[0],
            curr = a[b.currSlide],
            next = a[b.nextSlide];
        if (p.cycleStop != b.stopCount || p.cycleTimeout === 0 && !c) {
            return
        }
        if (!c && !p.cyclePause && !b.bounce && ((b.autostop && (--b.countdown <= 0)) || (b.nowrap && !b.random && b.nextSlide < b.currSlide))) {
            if (b.end) {
                b.end(b)
            }
            return
        }
        var e = false;
        if ((c || !p.cyclePause) && (b.nextSlide != b.currSlide)) {
            e = true;
            var f = b.fx;
            curr.cycleH = curr.cycleH || $(curr).height();
            curr.cycleW = curr.cycleW || $(curr).width();
            next.cycleH = next.cycleH || $(next).height();
            next.cycleW = next.cycleW || $(next).width();
            if (b.multiFx) {
                if (b.lastFx == undefined || ++b.lastFx >= b.fxs.length) {
                    b.lastFx = 0
                }
                f = b.fxs[b.lastFx];
                b.currFx = f
            }
            if (b.oneTimeFx) {
                f = b.oneTimeFx;
                b.oneTimeFx = null
            }
            $.fn.cycle.resetState(b, f);
            if (b.before.length) {
                $.each(b.before, function (i, o) {
                    if (p.cycleStop != b.stopCount) {
                        return
                    }
                    o.apply(next, [curr, next, b, d])
                })
            }
            var g = function () {
                    $.each(b.after, function (i, o) {
                        if (p.cycleStop != b.stopCount) {
                            return
                        }
                        o.apply(next, [curr, next, b, d])
                    })
                };
            debug("tx firing; currSlide: " + b.currSlide + "; nextSlide: " + b.nextSlide);
            b.busy = 1;
            if (b.fxFn) {
                b.fxFn(curr, next, b, g, d, c && b.fastOnEvent)
            } else {
                if ($.isFunction($.fn.cycle[b.fx])) {
                    $.fn.cycle[b.fx](curr, next, b, g, d, c && b.fastOnEvent)
                } else {
                    $.fn.cycle.custom(curr, next, b, g, d, c && b.fastOnEvent)
                }
            }
        }
        if (e || b.nextSlide == b.currSlide) {
            b.lastSlide = b.currSlide;
            if (b.random) {
                b.currSlide = b.nextSlide;
                if (++b.randomIndex == a.length) {
                    b.randomIndex = 0
                }
                b.nextSlide = b.randomMap[b.randomIndex];
                if (b.nextSlide == b.currSlide) {
                    b.nextSlide = (b.currSlide == b.slideCount - 1) ? 0 : b.currSlide + 1
                }
            } else {
                if (b.backwards) {
                    var h = (b.nextSlide - 1) < 0;
                    if (h && b.bounce) {
                        b.backwards = !b.backwards;
                        b.nextSlide = 1;
                        b.currSlide = 0
                    } else {
                        b.nextSlide = h ? (a.length - 1) : b.nextSlide - 1;
                        b.currSlide = h ? 0 : b.nextSlide + 1
                    }
                } else {
                    var h = (b.nextSlide + 1) == a.length;
                    if (h && b.bounce) {
                        b.backwards = !b.backwards;
                        b.nextSlide = a.length - 2;
                        b.currSlide = a.length - 1
                    } else {
                        b.nextSlide = h ? 0 : b.nextSlide + 1;
                        b.currSlide = h ? a.length - 1 : b.nextSlide - 1
                    }
                }
            }
        }
        if (e && b.pager) {
            b.updateActivePagerLink(b.pager, b.currSlide, b.activePagerClass)
        }
        var j = 0;
        if (b.timeout && !b.continuous) {
            j = getTimeout(a[b.currSlide], a[b.nextSlide], b, d)
        } else {
            if (b.continuous && p.cyclePause) {
                j = 10
            }
        }
        if (j > 0) {
            p.cycleTimeout = setTimeout(function () {
                go(a, b, 0, (!b.rev && !b.backwards))
            }, j)
        }
    }
    $.fn.cycle.updateActivePagerLink = function (a, b, c) {
        $(a).each(function () {
            $(this).children().removeClass(c).eq(b).addClass(c)
        })
    };

    function getTimeout(a, b, c, d) {
        if (c.timeoutFn) {
            var t = c.timeoutFn.call(a, a, b, c, d);
            while ((t - c.speed) < 250) {
                t += c.speed
            }
            debug("calculated timeout: " + t + "; speed: " + c.speed);
            if (t !== false) {
                return t
            }
        }
        return c.timeout
    }
    $.fn.cycle.next = function (a) {
        advance(a, a.rev ? -1 : 1)
    };
    $.fn.cycle.prev = function (a) {
        advance(a, a.rev ? 1 : -1)
    };

    function advance(a, b) {
        var c = a.elements;
        var p = a.$cont[0],
            timeout = p.cycleTimeout;
        if (timeout) {
            clearTimeout(timeout);
            p.cycleTimeout = 0
        }
        if (a.random && b < 0) {
            a.randomIndex--;
            if (--a.randomIndex == -2) {
                a.randomIndex = c.length - 2
            } else {
                if (a.randomIndex == -1) {
                    a.randomIndex = c.length - 1
                }
            }
            a.nextSlide = a.randomMap[a.randomIndex]
        } else {
            if (a.random) {
                a.nextSlide = a.randomMap[a.randomIndex]
            } else {
                a.nextSlide = a.currSlide + b;
                if (a.nextSlide < 0) {
                    if (a.nowrap) {
                        return false
                    }
                    a.nextSlide = c.length - 1
                } else {
                    if (a.nextSlide >= c.length) {
                        if (a.nowrap) {
                            return false
                        }
                        a.nextSlide = 0
                    }
                }
            }
        }
        var d = a.onPrevNextEvent || a.prevNextClick;
        if ($.isFunction(d)) {
            d(b > 0, a.nextSlide, c[a.nextSlide])
        }
        go(c, a, 1, b >= 0);
        return false
    }
    function buildPager(a, b) {
        var c = $(b.pager);
        $.each(a, function (i, o) {
            $.fn.cycle.createPagerAnchor(i, o, c, a, b)
        });
        b.updateActivePagerLink(b.pager, b.startingSlide, b.activePagerClass)
    }
    $.fn.cycle.createPagerAnchor = function (i, b, c, d, f) {
        var a;
        if ($.isFunction(f.pagerAnchorBuilder)) {
            a = f.pagerAnchorBuilder(i, b);
            debug("pagerAnchorBuilder(" + i + ", el) returned: " + a)
        } else {
            a = '<a href="#">' + (i + 1) + "</a>"
        }
        if (!a) {
            return
        }
        var g = $(a);
        if (g.parents("body").length === 0) {
            var h = [];
            if (c.length > 1) {
                c.each(function () {
                    var a = g.clone(true);
                    $(this).append(a);
                    h.push(a[0])
                });
                g = $(h)
            } else {
                g.appendTo(c)
            }
        }
        f.pagerAnchors = f.pagerAnchors || [];
        f.pagerAnchors.push(g);
        g.bind(f.pagerEvent, function (e) {
            e.preventDefault();
            f.nextSlide = i;
            var p = f.$cont[0],
                timeout = p.cycleTimeout;
            if (timeout) {
                clearTimeout(timeout);
                p.cycleTimeout = 0
            }
            var a = f.onPagerEvent || f.pagerClick;
            if ($.isFunction(a)) {
                a(f.nextSlide, d[f.nextSlide])
            }
            go(d, f, 1, f.currSlide < i)
        });
        if (!/^click/.test(f.pagerEvent) && !f.allowPagerClickBubble) {
            g.bind("click.cycle", function () {
                return false
            })
        }
        if (f.pauseOnPagerHover) {
            g.hover(function () {
                f.$cont[0].cyclePause++
            }, function () {
                f.$cont[0].cyclePause--
            })
        }
    };
    $.fn.cycle.hopsFromLast = function (a, b) {
        var d, l = a.lastSlide,
            c = a.currSlide;
        if (b) {
            d = c > l ? c - l : a.slideCount - l
        } else {
            d = c < l ? l - c : l + a.slideCount - c
        }
        return d
    };

    function clearTypeFix(b) {
        debug("applying clearType background-color hack");

        function hex(s) {
            s = parseInt(s).toString(16);
            return s.length < 2 ? "0" + s : s
        }
        function getBg(e) {
            for (; e && e.nodeName.toLowerCase() != "html"; e = e.parentNode) {
                var v = $.css(e, "background-color");
                if (v.indexOf("rgb") >= 0) {
                    var a = v.match(/\d+/g);
                    return "#" + hex(a[0]) + hex(a[1]) + hex(a[2])
                }
                if (v && v != "transparent") {
                    return v
                }
            }
            return "#ffffff"
        }
        b.each(function () {
            $(this).css("background-color", getBg(this))
        })
    }
    $.fn.cycle.commonReset = function (a, b, c, w, h, d) {
        $(c.elements).not(a).hide();
        c.cssBefore.opacity = 1;
        c.cssBefore.display = "block";
        if (w !== false && b.cycleW > 0) {
            c.cssBefore.width = b.cycleW
        }
        if (h !== false && b.cycleH > 0) {
            c.cssBefore.height = b.cycleH
        }
        c.cssAfter = c.cssAfter || {};
        c.cssAfter.display = "none";
        $(a).css("zIndex", c.slideCount + (d === true ? 1 : 0));
        $(b).css("zIndex", c.slideCount + (d === true ? 0 : 1))
    };
    $.fn.cycle.custom = function (a, b, c, d, e, f) {
        var g = $(a),
            $n = $(b);
        var h = c.speedIn,
            speedOut = c.speedOut,
            easeIn = c.easeIn,
            easeOut = c.easeOut;
        $n.css(c.cssBefore);
        if (f) {
            if (typeof f == "number") {
                h = speedOut = f
            } else {
                h = speedOut = 1
            }
            easeIn = easeOut = null
        }
        var i = function () {
                $n.animate(c.animIn, h, easeIn, d)
            };
        g.animate(c.animOut, speedOut, easeOut, function () {
            if (c.cssAfter) {
                g.css(c.cssAfter)
            }
            if (!c.sync) {
                i()
            }
        });
        if (c.sync) {
            i()
        }
    };
    $.fn.cycle.transitions = {
        fade: function (d, e, f) {
            e.not(":eq(" + f.currSlide + ")").css("opacity", 0);
            f.before.push(function (a, b, c) {
                $.fn.cycle.commonReset(a, b, c);
                c.cssBefore.opacity = 0
            });
            f.animIn = {
                opacity: 1
            };
            f.animOut = {
                opacity: 0
            };
            f.cssBefore = {
                top: 0,
                left: 0
            }
        }
    };
    $.fn.cycle.ver = function () {
        return y
    };
    $.fn.cycle.defaults = {
        fx: "fade",
        timeout: 4000,
        timeoutFn: null,
        continuous: 0,
        speed: 1000,
        speedIn: null,
        speedOut: null,
        next: null,
        prev: null,
        onPrevNextEvent: null,
        prevNextEvent: "click.cycle",
        pager: null,
        onPagerEvent: null,
        pagerEvent: "click.cycle",
        allowPagerClickBubble: false,
        pagerAnchorBuilder: null,
        before: null,
        after: null,
        end: null,
        easing: null,
        easeIn: null,
        easeOut: null,
        shuffle: null,
        animIn: null,
        animOut: null,
        cssBefore: null,
        cssAfter: null,
        fxFn: null,
        height: "auto",
        startingSlide: 0,
        sync: 1,
        random: 0,
        fit: 0,
        containerResize: 1,
        pause: 0,
        pauseOnPagerHover: 0,
        autostop: 0,
        autostopCount: 0,
        delay: 0,
        slideExpr: null,
        cleartype: !$.support.opacity,
        cleartypeNoBg: false,
        nowrap: 0,
        fastOnEvent: 0,
        randomizeEffects: 1,
        rev: 0,
        manualTrump: true,
        requeueOnImageNotLoaded: true,
        requeueTimeout: 250,
        activePagerClass: "activeSlide",
        updateActivePagerLink: null,
        backwards: false
    }
})(jQuery);
(function ($) {
    $.fn.cycle.transitions.none = function (e, f, g) {
        g.fxFn = function (a, b, c, d) {
            $(b).show();
            $(a).hide();
            d()
        }
    };
    $.fn.cycle.transitions.scrollUp = function (a, b, c) {
        a.css("overflow", "hidden");
        c.before.push($.fn.cycle.commonReset);
        var h = a.height();
        c.cssBefore = {
            top: h,
            left: 0
        };
        c.cssFirst = {
            top: 0
        };
        c.animIn = {
            top: 0
        };
        c.animOut = {
            top: -h
        }
    };
    $.fn.cycle.transitions.scrollDown = function (a, b, c) {
        a.css("overflow", "hidden");
        c.before.push($.fn.cycle.commonReset);
        var h = a.height();
        c.cssFirst = {
            top: 0
        };
        c.cssBefore = {
            top: -h,
            left: 0
        };
        c.animIn = {
            top: 0
        };
        c.animOut = {
            top: h
        }
    };
    $.fn.cycle.transitions.scrollLeft = function (a, b, c) {
        a.css("overflow", "hidden");
        c.before.push($.fn.cycle.commonReset);
        var w = a.width();
        c.cssFirst = {
            left: 0
        };
        c.cssBefore = {
            left: w,
            top: 0
        };
        c.animIn = {
            left: 0
        };
        c.animOut = {
            left: 0 - w
        }
    };
    $.fn.cycle.transitions.scrollRight = function (a, b, c) {
        a.css("overflow", "hidden");
        c.before.push($.fn.cycle.commonReset);
        var w = a.width();
        c.cssFirst = {
            left: 0
        };
        c.cssBefore = {
            left: -w,
            top: 0
        };
        c.animIn = {
            left: 0
        };
        c.animOut = {
            left: w
        }
    };
    $.fn.cycle.transitions.scrollHorz = function (e, f, g) {
        e.css("overflow", "hidden").width();
        g.before.push(function (a, b, c, d) {
            $.fn.cycle.commonReset(a, b, c);
            c.cssBefore.left = d ? (b.cycleW - 1) : (1 - b.cycleW);
            c.animOut.left = d ? -a.cycleW : a.cycleW
        });
        g.cssFirst = {
            left: 0
        };
        g.cssBefore = {
            top: 0
        };
        g.animIn = {
            left: 0
        };
        g.animOut = {
            top: 0
        }
    };
    $.fn.cycle.transitions.scrollVert = function (e, f, g) {
        e.css("overflow", "hidden");
        g.before.push(function (a, b, c, d) {
            $.fn.cycle.commonReset(a, b, c);
            c.cssBefore.top = d ? (1 - b.cycleH) : (b.cycleH - 1);
            c.animOut.top = d ? a.cycleH : -a.cycleH
        });
        g.cssFirst = {
            top: 0
        };
        g.cssBefore = {
            left: 0
        };
        g.animIn = {
            top: 0
        };
        g.animOut = {
            left: 0
        }
    };
    $.fn.cycle.transitions.slideX = function (d, e, f) {
        f.before.push(function (a, b, c) {
            $(c.elements).not(a).hide();
            $.fn.cycle.commonReset(a, b, c, false, true);
            c.animIn.width = b.cycleW
        });
        f.cssBefore = {
            left: 0,
            top: 0,
            width: 0
        };
        f.animIn = {
            width: "show"
        };
        f.animOut = {
            width: 0
        }
    };
    $.fn.cycle.transitions.slideY = function (d, e, f) {
        f.before.push(function (a, b, c) {
            $(c.elements).not(a).hide();
            $.fn.cycle.commonReset(a, b, c, true, false);
            c.animIn.height = b.cycleH
        });
        f.cssBefore = {
            left: 0,
            top: 0,
            height: 0
        };
        f.animIn = {
            height: "show"
        };
        f.animOut = {
            height: 0
        }
    };
    $.fn.cycle.transitions.shuffle = function (j, l, m) {
        var i, w = j.css("overflow", "visible").width();
        l.css({
            left: 0,
            top: 0
        });
        m.before.push(function (a, b, c) {
            $.fn.cycle.commonReset(a, b, c, true, true, true)
        });
        if (!m.speedAdjusted) {
            m.speed = m.speed / 2;
            m.speedAdjusted = true
        }
        m.random = 0;
        m.shuffle = m.shuffle || {
            left: -w,
            top: 15
        };
        m.els = [];
        for (i = 0; i < l.length; i++) {
            m.els.push(l[i])
        }
        for (i = 0; i < m.currSlide; i++) {
            m.els.push(m.els.shift())
        }
        m.fxFn = function (b, c, d, e, f) {
            var g = f ? $(b) : $(c);
            $(c).css(d.cssBefore);
            var h = d.slideCount;
            g.animate(d.shuffle, d.speedIn, d.easeIn, function () {
                var a = $.fn.cycle.hopsFromLast(d, f);
                for (var k = 0; k < a; k++) {
                    f ? d.els.push(d.els.shift()) : d.els.unshift(d.els.pop())
                }
                if (f) {
                    for (var i = 0, len = d.els.length; i < len; i++) {
                        $(d.els[i]).css("z-index", len - i + h)
                    }
                } else {
                    var z = $(b).css("z-index");
                    g.css("z-index", parseInt(z) + 1 + h)
                }
                g.animate({
                    left: 0,
                    top: 0
                }, d.speedOut, d.easeOut, function () {
                    $(f ? this : b).hide();
                    if (e) {
                        e()
                    }
                })
            })
        };
        m.cssBefore = {
            display: "block",
            opacity: 1,
            top: 0,
            left: 0
        }
    };
    $.fn.cycle.transitions.turnUp = function (d, e, f) {
        f.before.push(function (a, b, c) {
            $.fn.cycle.commonReset(a, b, c, true, false);
            c.cssBefore.top = b.cycleH;
            c.animIn.height = b.cycleH
        });
        f.cssFirst = {
            top: 0
        };
        f.cssBefore = {
            left: 0,
            height: 0
        };
        f.animIn = {
            top: 0
        };
        f.animOut = {
            height: 0
        }
    };
    $.fn.cycle.transitions.turnDown = function (d, e, f) {
        f.before.push(function (a, b, c) {
            $.fn.cycle.commonReset(a, b, c, true, false);
            c.animIn.height = b.cycleH;
            c.animOut.top = a.cycleH
        });
        f.cssFirst = {
            top: 0
        };
        f.cssBefore = {
            left: 0,
            top: 0,
            height: 0
        };
        f.animOut = {
            height: 0
        }
    };
    $.fn.cycle.transitions.turnLeft = function (d, e, f) {
        f.before.push(function (a, b, c) {
            $.fn.cycle.commonReset(a, b, c, false, true);
            c.cssBefore.left = b.cycleW;
            c.animIn.width = b.cycleW
        });
        f.cssBefore = {
            top: 0,
            width: 0
        };
        f.animIn = {
            left: 0
        };
        f.animOut = {
            width: 0
        }
    };
    $.fn.cycle.transitions.turnRight = function (d, e, f) {
        f.before.push(function (a, b, c) {
            $.fn.cycle.commonReset(a, b, c, false, true);
            c.animIn.width = b.cycleW;
            c.animOut.left = a.cycleW
        });
        f.cssBefore = {
            top: 0,
            left: 0,
            width: 0
        };
        f.animIn = {
            left: 0
        };
        f.animOut = {
            width: 0
        }
    };
    $.fn.cycle.transitions.zoom = function (d, e, f) {
        f.before.push(function (a, b, c) {
            $.fn.cycle.commonReset(a, b, c, false, false, true);
            c.cssBefore.top = b.cycleH / 2;
            c.cssBefore.left = b.cycleW / 2;
            c.animIn = {
                top: 0,
                left: 0,
                width: b.cycleW,
                height: b.cycleH
            };
            c.animOut = {
                width: 0,
                height: 0,
                top: a.cycleH / 2,
                left: a.cycleW / 2
            }
        });
        f.cssFirst = {
            top: 0,
            left: 0
        };
        f.cssBefore = {
            width: 0,
            height: 0
        }
    };
    $.fn.cycle.transitions.fadeZoom = function (d, e, f) {
        f.before.push(function (a, b, c) {
            $.fn.cycle.commonReset(a, b, c, false, false);
            c.cssBefore.left = b.cycleW / 2;
            c.cssBefore.top = b.cycleH / 2;
            c.animIn = {
                top: 0,
                left: 0,
                width: b.cycleW,
                height: b.cycleH
            }
        });
        f.cssBefore = {
            width: 0,
            height: 0
        };
        f.animOut = {
            opacity: 0
        }
    };
    $.fn.cycle.transitions.blindX = function (d, e, f) {
        var w = d.css("overflow", "hidden").width();
        f.before.push(function (a, b, c) {
            $.fn.cycle.commonReset(a, b, c);
            c.animIn.width = b.cycleW;
            c.animOut.left = a.cycleW
        });
        f.cssBefore = {
            left: w,
            top: 0
        };
        f.animIn = {
            left: 0
        };
        f.animOut = {
            left: w
        }
    };
    $.fn.cycle.transitions.blindY = function (d, e, f) {
        var h = d.css("overflow", "hidden").height();
        f.before.push(function (a, b, c) {
            $.fn.cycle.commonReset(a, b, c);
            c.animIn.height = b.cycleH;
            c.animOut.top = a.cycleH
        });
        f.cssBefore = {
            top: h,
            left: 0
        };
        f.animIn = {
            top: 0
        };
        f.animOut = {
            top: h
        }
    };
    $.fn.cycle.transitions.blindZ = function (d, e, f) {
        var h = d.css("overflow", "hidden").height();
        var w = d.width();
        f.before.push(function (a, b, c) {
            $.fn.cycle.commonReset(a, b, c);
            c.animIn.height = b.cycleH;
            c.animOut.top = a.cycleH
        });
        f.cssBefore = {
            top: h,
            left: w
        };
        f.animIn = {
            top: 0,
            left: 0
        };
        f.animOut = {
            top: h,
            left: w
        }
    };
    $.fn.cycle.transitions.growX = function (d, e, f) {
        f.before.push(function (a, b, c) {
            $.fn.cycle.commonReset(a, b, c, false, true);
            c.cssBefore.left = this.cycleW / 2;
            c.animIn = {
                left: 0,
                width: this.cycleW
            };
            c.animOut = {
                left: 0
            }
        });
        f.cssBefore = {
            width: 0,
            top: 0
        }
    };
    $.fn.cycle.transitions.growY = function (d, e, f) {
        f.before.push(function (a, b, c) {
            $.fn.cycle.commonReset(a, b, c, true, false);
            c.cssBefore.top = this.cycleH / 2;
            c.animIn = {
                top: 0,
                height: this.cycleH
            };
            c.animOut = {
                top: 0
            }
        });
        f.cssBefore = {
            height: 0,
            left: 0
        }
    };
    $.fn.cycle.transitions.curtainX = function (d, e, f) {
        f.before.push(function (a, b, c) {
            $.fn.cycle.commonReset(a, b, c, false, true, true);
            c.cssBefore.left = b.cycleW / 2;
            c.animIn = {
                left: 0,
                width: this.cycleW
            };
            c.animOut = {
                left: a.cycleW / 2,
                width: 0
            }
        });
        f.cssBefore = {
            top: 0,
            width: 0
        }
    };
    $.fn.cycle.transitions.curtainY = function (d, e, f) {
        f.before.push(function (a, b, c) {
            $.fn.cycle.commonReset(a, b, c, true, false, true);
            c.cssBefore.top = b.cycleH / 2;
            c.animIn = {
                top: 0,
                height: b.cycleH
            };
            c.animOut = {
                top: a.cycleH / 2,
                height: 0
            }
        });
        f.cssBefore = {
            left: 0,
            height: 0
        }
    };
    $.fn.cycle.transitions.cover = function (e, f, g) {
        var d = g.direction || "left";
        var w = e.css("overflow", "hidden").width();
        var h = e.height();
        g.before.push(function (a, b, c) {
            $.fn.cycle.commonReset(a, b, c);
            if (d == "right") {
                c.cssBefore.left = -w
            } else {
                if (d == "up") {
                    c.cssBefore.top = h
                } else {
                    if (d == "down") {
                        c.cssBefore.top = -h
                    } else {
                        c.cssBefore.left = w
                    }
                }
            }
        });
        g.animIn = {
            left: 0,
            top: 0
        };
        g.animOut = {
            opacity: 1
        };
        g.cssBefore = {
            top: 0,
            left: 0
        }
    };
    $.fn.cycle.transitions.uncover = function (e, f, g) {
        var d = g.direction || "left";
        var w = e.css("overflow", "hidden").width();
        var h = e.height();
        g.before.push(function (a, b, c) {
            $.fn.cycle.commonReset(a, b, c, true, true, true);
            if (d == "right") {
                c.animOut.left = w
            } else {
                if (d == "up") {
                    c.animOut.top = -h
                } else {
                    if (d == "down") {
                        c.animOut.top = h
                    } else {
                        c.animOut.left = -w
                    }
                }
            }
        });
        g.animIn = {
            left: 0,
            top: 0
        };
        g.animOut = {
            opacity: 1
        };
        g.cssBefore = {
            top: 0,
            left: 0
        }
    };
    $.fn.cycle.transitions.toss = function (d, e, f) {
        var w = d.css("overflow", "visible").width();
        var h = d.height();
        f.before.push(function (a, b, c) {
            $.fn.cycle.commonReset(a, b, c, true, true, true);
            if (!c.animOut.left && !c.animOut.top) {
                c.animOut = {
                    left: w * 2,
                    top: -h / 2,
                    opacity: 0
                }
            } else {
                c.animOut.opacity = 0
            }
        });
        f.cssBefore = {
            left: 0,
            top: 0
        };
        f.animIn = {
            left: 0
        }
    };
    $.fn.cycle.transitions.wipe = function (n, o, p) {
        var w = n.css("overflow", "hidden").width();
        var h = n.height();
        p.cssBefore = p.cssBefore || {};
        var q;
        if (p.clip) {
            if (/l2r/.test(p.clip)) {
                q = "rect(0px 0px " + h + "px 0px)"
            } else {
                if (/r2l/.test(p.clip)) {
                    q = "rect(0px " + w + "px " + h + "px " + w + "px)"
                } else {
                    if (/t2b/.test(p.clip)) {
                        q = "rect(0px " + w + "px 0px 0px)"
                    } else {
                        if (/b2t/.test(p.clip)) {
                            q = "rect(" + h + "px " + w + "px " + h + "px 0px)"
                        } else {
                            if (/zoom/.test(p.clip)) {
                                var s = parseInt(h / 2);
                                var u = parseInt(w / 2);
                                q = "rect(" + s + "px " + u + "px " + s + "px " + u + "px)"
                            }
                        }
                    }
                }
            }
        }
        p.cssBefore.clip = p.cssBefore.clip || q || "rect(0px 0px 0px 0px)";
        var d = p.cssBefore.clip.match(/(\d+)/g);
        var t = parseInt(d[0]),
            r = parseInt(d[1]),
            b = parseInt(d[2]),
            l = parseInt(d[3]);
        p.before.push(function (g, i, j) {
            if (g == i) {
                return
            }
            var k = $(g),
                $next = $(i);
            $.fn.cycle.commonReset(g, i, j, true, true, false);
            j.cssAfter.display = "block";
            var m = 1,
                count = parseInt((j.speedIn / 13)) - 1;
            (function f() {
                var a = t ? t - parseInt(m * (t / count)) : 0;
                var c = l ? l - parseInt(m * (l / count)) : 0;
                var d = b < h ? b + parseInt(m * ((h - b) / count || 1)) : h;
                var e = r < w ? r + parseInt(m * ((w - r) / count || 1)) : w;
                $next.css({
                    clip: "rect(" + a + "px " + e + "px " + d + "px " + c + "px)"
                });
                (m++ <= count) ? setTimeout(f, 13) : k.css("display", "none")
            })()
        });
        p.cssBefore = {
            display: "block",
            opacity: 1,
            top: 0,
            left: 0
        };
        p.animIn = {
            left: 0
        };
        p.animOut = {
            left: 0
        }
    }
})(jQuery);

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

            function t(a) {
                r.animate(g, j, b.easing, a &&
                function () {
                    a.call(this, n, b)
                })
            }
        }).end()
    };
    k.max = function (a, i) {
        var e = i == 'x' ? 'Width' : 'Height',
            h = 'scroll' + e;
        if (!d(a).is('html,body')) return a[h] - d(a)[e.toLowerCase()]();
        var c = 'client' + e,
            l = a.ownerDocument.documentElement,
            m = a.ownerDocument.body;
        return Math.max(l[h], m[h]) - Math.min(l[c], m[c])
    };

    function p(a) {
        return typeof a == 'object' ? a : {
            top: a,
            left: a
        }
    }
})(jQuery);

/* jQuery Timers */
jQuery.fn.extend({
    everyTime: function (a, b, c, d, e) {
        return this.each(function () {
            jQuery.timer.add(this, a, b, c, d, e)
        })
    },
    oneTime: function (a, b, c) {
        return this.each(function () {
            jQuery.timer.add(this, a, b, c, 1)
        })
    },
    stopTime: function (a, b) {
        return this.each(function () {
            jQuery.timer.remove(this, a, b)
        })
    }
});
jQuery.extend({
    timer: {
        guid: 1,
        global: {},
        regex: /^([0-9]+)\s*(.*s)?$/,
        powers: {
            'ms': 1,
            'cs': 10,
            'ds': 100,
            's': 1000,
            'das': 10000,
            'hs': 100000,
            'ks': 1000000
        },
        timeParse: function (a) {
            if (a == undefined || a == null) return null;
            var b = this.regex.exec(jQuery.trim(a.toString()));
            if (b[2]) {
                var c = parseInt(b[1], 10);
                var d = this.powers[b[2]] || 1;
                return c * d
            } else {
                return a
            }
        },
        add: function (a, b, c, d, e, f) {
            var g = 0;
            if (jQuery.isFunction(c)) {
                if (!e) e = d;
                d = c;
                c = b
            }
            b = jQuery.timer.timeParse(b);
            if (typeof b != 'number' || isNaN(b) || b <= 0) return;
            if (e && e.constructor != Number) {
                f = !! e;
                e = 0
            }
            e = e || 0;
            f = f || false;
            if (!a.$timers) a.$timers = {};
            if (!a.$timers[c]) a.$timers[c] = {};
            d.$timerID = d.$timerID || this.guid++;
            var h = function () {
                    if (f && this.inProgress) return;
                    this.inProgress = true;
                    if ((++g > e && e !== 0) || d.call(a, g) === false) jQuery.timer.remove(a, c, d);
                    this.inProgress = false
                };
            h.$timerID = d.$timerID;
            if (!a.$timers[c][d.$timerID]) a.$timers[c][d.$timerID] = window.setInterval(h, b);
            if (!this.global[c]) this.global[c] = [];
            this.global[c].push(a)
        },
        remove: function (a, b, c) {
            var d = a.$timers,
                ret;
            if (d) {
                if (!b) {
                    for (b in d) this.remove(a, b, c)
                } else if (d[b]) {
                    if (c) {
                        if (c.$timerID) {
                            window.clearInterval(d[b][c.$timerID]);
                            delete d[b][c.$timerID]
                        }
                    } else {
                        for (var c in d[b]) {
                            window.clearInterval(d[b][c]);
                            delete d[b][c]
                        }
                    }
                    for (ret in d[b]) break;
                    if (!ret) {
                        ret = null;
                        delete d[b]
                    }
                }
                for (ret in d) break;
                if (!ret) a.$timers = null
            }
        }
    }
});
if (jQuery.browser.msie) jQuery(window).one("unload", function () {
    var a = jQuery.timer.global;
    for (var b in a) {
        var c = a[b],
            i = c.length;
        while (--i) jQuery.timer.remove(c[i], b)
    }
});

/* Pixastic */
var Pixastic = (function () {
    function d(m, n, l) {
        if (m.addEventListener) {
            m.addEventListener(n, l, false)
        } else {
            if (m.attachEvent) {
                m.attachEvent("on" + n, l)
            }
        }
    }
    function g(n) {
        var l = false;
        var o = function () {
                if (!l) {
                    l = true;
                    n()
                }
            };
        document.write('<script defer src="//:" id="__onload_ie_pixastic__"><\/script>');
        var m = document.getElementById("__onload_ie_pixastic__");
        m.onreadystatechange = function () {
            if (m.readyState == "complete") {
                m.parentNode.removeChild(m);
                o()
            }
        };
        if (document.addEventListener) {
            document.addEventListener("DOMContentLoaded", o, false)
        }
        d(window, "load", o)
    }
    function k() {
        var l = c("pixastic", null, "img");
        var o = c("pixastic", null, "canvas");
        var n = l.concat(o);
        for (var m = 0; m < n.length; m++) {
            (function () {
                var q = n[m];
                var s = [];
                var r = q.className.split(" ");
                for (var v = 0; v < r.length; v++) {
                    var x = r[v];
                    if (x.substring(0, 9) == "pixastic-") {
                        var u = x.substring(9);
                        if (u != "") {
                            s.push(u)
                        }
                    }
                }
                if (s.length) {
                    if (q.tagName.toLowerCase() == "img") {
                        var p = new Image();
                        p.src = q.src;
                        if (p.complete) {
                            for (var w = 0; w < s.length; w++) {
                                var t = Pixastic.applyAction(q, q, s[w], null);
                                if (t) {
                                    q = t
                                }
                            }
                        } else {
                            p.onload = function () {
                                for (var y = 0; y < s.length; y++) {
                                    var z = Pixastic.applyAction(q, q, s[y], null);
                                    if (z) {
                                        q = z
                                    }
                                }
                            }
                        }
                    } else {
                        setTimeout(function () {
                            for (var y = 0; y < s.length; y++) {
                                var z = Pixastic.applyAction(q, q, s[y], null);
                                if (z) {
                                    q = z
                                }
                            }
                        }, 1)
                    }
                }
            })()
        }
    }
    if (typeof pixastic_parseonload != "undefined" && pixastic_parseonload) {
        g(k)
    }
    function c(r, p, l) {
        var o = new Array();
        if (p == null) {
            p = document
        }
        if (l == null) {
            l = "*"
        }
        var n = p.getElementsByTagName(l);
        var m = n.length;
        var q = new RegExp("(^|\\s)" + r + "(\\s|$)");
        for (i = 0, j = 0; i < m; i++) {
            if (q.test(n[i].className)) {
                o[j] = n[i];
                j++
            }
        }
        return o
    }
    var e;

    function a(m, n) {
        if (!Pixastic.debug) {
            return
        }
        try {
            switch (n) {
            case "warn":
                console.warn("Pixastic:", m);
                break;
            case "error":
                console.error("Pixastic:", m);
                break;
            default:
                console.log("Pixastic:", m)
            }
        } catch (l) {}
        if (!e) {}
    }
    var b = (function () {
        var n = document.createElement("canvas");
        var m = false;
        try {
            m = !! ((typeof n.getContext == "function") && n.getContext("2d"))
        } catch (l) {}
        return function () {
            return m
        }
    })();
    var f = (function () {
        var o = document.createElement("canvas");
        var n = false;
        var l;
        try {
            if (typeof o.getContext == "function" && (l = o.getContext("2d"))) {
                n = (typeof l.getImageData == "function")
            }
        } catch (m) {}
        return function () {
            return n
        }
    })();
    var h = (function () {
        var n = false;
        var p = document.createElement("canvas");
        if (b() && f()) {
            p.width = p.height = 1;
            var o = p.getContext("2d");
            o.fillStyle = "rgb(255,0,0)";
            o.fillRect(0, 0, 1, 1);
            var l = document.createElement("canvas");
            l.width = l.height = 1;
            var q = l.getContext("2d");
            q.fillStyle = "rgb(0,0,255)";
            q.fillRect(0, 0, 1, 1);
            o.globalAlpha = 0.5;
            o.drawImage(l, 0, 0);
            var m = o.getImageData(0, 0, 1, 1).data;
            n = (m[2] != 255)
        }
        return function () {
            return n
        }
    })();
    return {
        parseOnLoad: false,
        debug: false,
        applyAction: function (E, p, o, n) {
            n = n || {};
            var r = (E.tagName.toLowerCase() == "canvas");
            if (r && Pixastic.Client.isIE()) {
                if (Pixastic.debug) {
                    a("Tried to process a canvas element but browser is IE.")
                }
                return false
            }
            var m, v;
            var u = false;
            if (Pixastic.Client.hasCanvas()) {
                u = !! n.resultCanvas;
                m = n.resultCanvas || document.createElement("canvas");
                v = m.getContext("2d")
            }
            var t = E.offsetWidth;
            var x = E.offsetHeight;
            if (r) {
                t = E.width;
                x = E.height
            }
            if (t == 0 || x == 0) {
                if (E.parentNode == null) {
                    var s = E.style.position;
                    var C = E.style.left;
                    E.style.position = "absolute";
                    E.style.left = "-9999px";
                    document.body.appendChild(E);
                    t = E.offsetWidth;
                    x = E.offsetHeight;
                    document.body.removeChild(E);
                    E.style.position = s;
                    E.style.left = C
                } else {
                    if (Pixastic.debug) {
                        a("Image has 0 width and/or height.")
                    }
                    return
                }
            }
            if (o.indexOf("(") > -1) {
                var A = o;
                o = A.substr(0, A.indexOf("("));
                var q = A.match(/\((.*?)\)/);
                if (q[1]) {
                    q = q[1].split(";");
                    for (var B = 0; B < q.length; B++) {
                        thisArg = q[B].split("=");
                        if (thisArg.length == 2) {
                            if (thisArg[0] == "rect") {
                                var l = thisArg[1].split(",");
                                n[thisArg[0]] = {
                                    left: parseInt(l[0], 10) || 0,
                                    top: parseInt(l[1], 10) || 0,
                                    width: parseInt(l[2], 10) || 0,
                                    height: parseInt(l[3], 10) || 0
                                }
                            } else {
                                n[thisArg[0]] = thisArg[1]
                            }
                        }
                    }
                }
            }
            if (!n.rect) {
                n.rect = {
                    left: 0,
                    top: 0,
                    width: t,
                    height: x
                }
            } else {
                n.rect.left = Math.round(n.rect.left);
                n.rect.top = Math.round(n.rect.top);
                n.rect.width = Math.round(n.rect.width);
                n.rect.height = Math.round(n.rect.height)
            }
            var y = false;
            if (Pixastic.Actions[o] && typeof Pixastic.Actions[o].process == "function") {
                y = true
            }
            if (!y) {
                if (Pixastic.debug) {
                    a('Invalid action "' + o + '". Maybe file not included?')
                }
                return false
            }
            if (!Pixastic.Actions[o].checkSupport()) {
                if (Pixastic.debug) {
                    a('Action "' + o + '" not supported by this browser.')
                }
                return false
            }
            if (Pixastic.Client.hasCanvas()) {
                if (m !== E) {
                    m.width = t;
                    m.height = x
                }
                if (!u) {
                    m.style.width = t + "px";
                    m.style.height = x + "px"
                }
                v.drawImage(p, 0, 0, t, x);
                if (!E.__pixastic_org_image) {
                    m.__pixastic_org_image = E;
                    m.__pixastic_org_width = t;
                    m.__pixastic_org_height = x
                } else {
                    m.__pixastic_org_image = E.__pixastic_org_image;
                    m.__pixastic_org_width = E.__pixastic_org_width;
                    m.__pixastic_org_height = E.__pixastic_org_height
                }
            } else {
                if (Pixastic.Client.isIE() && typeof E.__pixastic_org_style == "undefined") {
                    E.__pixastic_org_style = E.style.cssText
                }
            }
            var z = {
                image: E,
                canvas: m,
                width: t,
                height: x,
                useData: true,
                options: n
            };
            var D = Pixastic.Actions[o].process(z);
            if (!D) {
                return false
            }
            if (Pixastic.Client.hasCanvas()) {
                if (z.useData) {
                    if (Pixastic.Client.hasCanvasImageData()) {
                        m.getContext("2d").putImageData(z.canvasData, n.rect.left, n.rect.top);
                        m.getContext("2d").fillRect(0, 0, 0, 0)
                    }
                }
                if (!n.leaveDOM) {
                    m.title = E.title;
                    m.imgsrc = E.imgsrc;
                    if (!r) {
                        m.alt = E.alt
                    }
                    if (!r) {
                        m.imgsrc = E.src
                    }
                    m.className = E.className;
                    m.style.cssText = E.style.cssText;
                    m.name = E.name;
                    m.tabIndex = E.tabIndex;
                    m.id = E.id;
                    if (E.parentNode && E.parentNode.replaceChild) {
                        E.parentNode.replaceChild(m, E)
                    }
                }
                n.resultCanvas = m;
                return m
            }
            return E
        },
        prepareData: function (q, m) {
            var l = q.canvas.getContext("2d");
            var o = q.options.rect;
            var n = l.getImageData(o.left, o.top, o.width, o.height);
            var p = n.data;
            if (!m) {
                q.canvasData = n
            }
            return p
        },
        process: function (m, l, n, q) {
            if (m.tagName.toLowerCase() == "img") {
                var p = new Image();
                p.src = m.src;
                if (p.complete) {
                    var o = Pixastic.applyAction(m, p, l, n);
                    if (q) {
                        q(o)
                    }
                    return o
                } else {
                    p.onload = function () {
                        var r = Pixastic.applyAction(m, p, l, n);
                        if (q) {
                            q(r)
                        }
                    }
                }
            }
            if (m.tagName.toLowerCase() == "canvas") {
                var o = Pixastic.applyAction(m, m, l, n);
                if (q) {
                    q(o)
                }
                return o
            }
        },
        revert: function (l) {
            if (Pixastic.Client.hasCanvas()) {
                if (l.tagName.toLowerCase() == "canvas" && l.__pixastic_org_image) {
                    l.width = l.__pixastic_org_width;
                    l.height = l.__pixastic_org_height;
                    l.getContext("2d").drawImage(l.__pixastic_org_image, 0, 0);
                    if (l.parentNode && l.parentNode.replaceChild) {
                        l.parentNode.replaceChild(l.__pixastic_org_image, l)
                    }
                    return l
                }
            } else {
                if (Pixastic.Client.isIE()) {
                    if (typeof l.__pixastic_org_style != "undefined") {
                        l.style.cssText = l.__pixastic_org_style
                    }
                }
            }
        },
        Client: {
            hasCanvas: b,
            hasCanvasImageData: f,
            hasGlobalAlpha: h,
            isIE: function () {
                return !!document.all && !! window.attachEvent && !window.opera
            }
        },
        Actions: {}
    }
})();
if (typeof jQuery != "undefined" && jQuery && jQuery.fn) {
    jQuery.fn.pixastic = function (c, b) {
        var a = [];
        this.each(function () {
            if (this.tagName.toLowerCase() == "img" && !this.complete) {
                return
            }
            var d = Pixastic.process(this, c, b);
            if (d) {
                a.push(d)
            }
        });
        if (a.length > 0) {
            return jQuery(a)
        } else {
            return this
        }
    }
}
Pixastic.Actions.desaturate = {
    process: function (b) {
        var c = !! (b.options.average && b.options.average != "false");
        if (Pixastic.Client.hasCanvasImageData()) {
            var d = Pixastic.prepareData(b);
            var l = b.options.rect;
            var m = l.width;
            var e = l.height;
            var a = m * e;
            var f = a * 4,
                k, g;
            if (c) {
                while (a--) {
                    d[f -= 4] = d[k = f + 1] = d[g = f + 2] = (d[f] + d[k] + d[g]) / 3
                }
            } else {
                while (a--) {
                    d[f -= 4] = d[k = f + 1] = d[g = f + 2] = (d[f] * 0.3 + d[k] * 0.59 + d[g] * 0.11)
                }
            }
            return true
        } else {
            if (Pixastic.Client.isIE()) {
                b.image.style.filter += " gray";
                return true
            }
        }
    },
    checkSupport: function () {
        return (Pixastic.Client.hasCanvasImageData() || Pixastic.Client.isIE())
    }
};
		$(document).ready(function() {

		
			/* init dropdown */
			var defaultValues = [];
			$(".dropdown").each(function(e) {
				defaultValues[e] = $(this).find("span").text();
				$(this).find("ul").width(($(this).find("li").length-1) * 9 + 135);
				$(this).find("li").each(function(e) {
					$(this).css({marginRight: e * 9});
				});
			});
			
			
			/* show dropdown */
			$(".dropdown div").click(function() {
				$(this).next().toggle();
			});
			
	
			/* change dropdown value */
			$(".dropdown li a").click(function() {
				$(this)
						.parent().parent().hide()
						.prev().find("span").text($(this).text());
				$(".reset").show();
				$("#portfolio").removeClass("border");
				$("#fold").slideUp(function() {
					$(this).empty();
					$("#menu li, #portfolio a").removeClass("active");
				});
				return false
			});
			
			
			/* filtr works */
			var workType = "";
			var workCategory = "";
			function filterWorks() {
				var itemSelector = "#portfolio li";
				$(itemSelector).hide();
				if (workType) {
					itemSelector += "." + workType;
				}
				if (workCategory) {
					itemSelector += "." + workCategory;
				}
				$(itemSelector).show();
			}
			$("#workType a").click(function() {
				workType = $(this).attr("href"); 
				filterWorks();
			});
			$("#workCategory a").click(function() {
				workCategory = $(this).attr("href");
				filterWorks();
			});

			
			/* reset filter */
			$(".reset a").click(function() {
				workType = "";
				workCategory = "";
				$("#portfolio li").show();
				$(".dropdown").each(function(e) {
					$(this)
						.find("span").text(defaultValues[e]).end()
				});
				$(this).parent().hide();
				return false;
			});
			
			/* stop dropdown timer */
			$(".dropdown").mouseover(function() {
				$(this).stopTime("sectionTimer");	
			});
			
			
			/* start dropdown timer */
			$(".dropdown").mouseleave(function() {
				$(this).oneTime(500, "sectionTimer", function() {
					$(this).find("ul").hide();
				});				
			});
			
			
			/* function to run posts slider */
			function runPostSlider() {
				if ($("#posts .slider li").length > 1) {
					$("#posts .slider li").find("img").css({opacity: 0});
					$("#posts .slider li:first").find("img").each(function() {
						$(this).attr("src", $(this).attr("longdesc")).load(function() {
							$(this).animate({opacity: 1});
						});
					});
					$("#posts .slider").jCarouselLite({
						circular: false,
						btnPrev: "#postsNav .prev",
						btnNext: "#postsNav .next",
						visible: 1,
						speed: 500,
						scroll: 1,
						afterEnd: function(a) {
							a.find("img").each(function() {
								$(this).attr("src", $(this).attr("longdesc")).load(function() {
									$(this).animate({opacity: 1});
								});
							});
						}
					});			
				}									
			}	

			
			/* function to run folio cycle */
			function runFolioCycle() {
				$("#cycle ul").cycle({
					fx: "fade",
					speed: 300,
					timeout: 0,
					pager:  "#cycle .pager div"
				});									
			}
			

			/* function to run testimonials cycle */
			function runTestimonialsCycle() {
				$("#testimonials ul").cycle({
					fx: "none",
					speed: 300,
					timeout: 0,
					prev:  "#testimonials .prev",
					next:  "#testimonials .next"
				});									
			}

			
			/* function to style content images */			
			function styleContentImgs() {
				$(".post .text img").each(function(e) {
					var imgClass = $(this).attr("class");
					$(this).attr("class", "");
					$(this).wrap("<span class='post-image "+ imgClass +"'></span>");
					$(".post-image").eq(e).prepend("<span class='pattern'></span>");
				});								
			}
			
			
			/* function to convert image mode */
			function convertImgMode(selector) {			

				$(selector + " img").load(function() {
					$(this).addClass("loaded").parent().css({background: "none"});
					$(this).after("<img src='" + $(this).attr('src') + "' class='loaded clone' alt='' />");
					$(this).pixastic("desaturate");
				});


				
				$(window).load(function () {
					$(selector + " img").each(function(index) {
						if (!$(this).hasClass("loaded")) {
							$(this).addClass("loaded").parent().css({background: "none"});
							$(this).after("<img src='" + $(this).attr('src') + "' class='loaded clone' alt='' />");
							$(this).pixastic("desaturate");
						}
						
						if ($.browser.msie) {
							$(selector + " img:not('.clone')").pixastic("desaturate");
						 } 				
					});
					
				});
			}			
			
	
			/* ajax menu */
			function ajaxMenu(link) {
				$("#portfolio").removeClass("border");
				$("#fold").slideUp(function() {
					$(".loader").show();
					$.ajax({
						url: "ajax/" + link.attr("target") + ".html",
						success: function(data){
							$(".loader").hide();
							$("#fold").html(data).slideDown(function() {
								$("#portfolio").addClass("border");
							});
							runPostSlider();
							runTestimonialsCycle();
							convertImgMode(".team .image");
						}
					});	
				});
			}		
			
			
			
			/* portfolio effects */
			$("#portfolio li a").mouseenter(function() {
				$(this)
					.find(".clone").show().end()
					.parent().stop().animate({marginTop: 0}, 300).end()
					.stop().animate({height: 210}, 300)
					.find(".title").css({opacity: 0}).show().stop().animate({opacity: 1}, 300);
			});
		
			$("#portfolio li a").mouseleave(function() {
				$(this)
					.find(".clone").hide().end()
					.parent().stop().animate({marginTop: 25}, 300).end()
					.stop().animate({height: 170}, 300)
					.find(".title").stop().animate({opacity: 0}, 300, function() {
						$(this).hide();
					});
			});
			
			$("#portfolio li img").css({opacity: 0.7});
			
						
			/* team effects */
			$(".team .image").live("mouseenter", function() {
				$(this)
					.find(".clone").show()
			});
		
			$(".team .image").live("mouseleave", function() {
				$(this)
					.find(".clone").hide();
			});			
		
			/* contacts */
			$(".pmap").live("click", function() {
				var shiftHeight = $(".column-map").height();
				$(this).slideUp(function() {
					$(".column-text").animate({marginTop: shiftHeight}, 300, function() {
						$(".column-map").css({marginBottom: -shiftHeight}).animate({width: 730}, 300, function() {
							$(".gmap").slideDown();
						});
					});
				});
				return false
			});
			
			
			runPostSlider();		
			runFolioCycle();		
			runTestimonialsCycle();
			styleContentImgs();
			convertImgMode("#portfolio");
			convertImgMode(".team .image");
			
		
			/* comments popup */	
			$(".popupLink").live("click", function() {
				var link = $(this);
				$.ajax({
				  url: "ajax/" + link.attr("target") + ".html",
				  success: function(data) {
					$.fancybox(
						data,
						{
							'centerOnScroll'    : true,
							'showCloseButton'   : false,
							'overlayColor'		: '#000',
							'overlayOpacity'	: 0.6,
							'padding'           : 20
						});					
					}
				});	
				return false;
			});

			
			/* close current section */
			$(".close a").live("click", function() {
				$("#portfolio").removeClass("border");
				$("#fold").slideUp(function() {
					$(this).empty();
					$("#menu li, #portfolio a").removeClass("active");
				});
				return false;
			});

			
			/* close popup form */
			$(".popup-close a").live("click", function() {
				$.fancybox.close();
				return false;
			});


			/* show back-link */
			$(window).scroll(function () { 
				if($(window).scrollTop()) {
					$(".back-link").fadeIn(100);
				}
				else {
					$(".back-link").fadeOut(100);
				}
			});
				
				
			/* hide back-link */
			$(".back-link a").click(function() {
				$.scrollTo({top: 0, left: 0}, 300, function() {
					$(".back-link").fadeOut(100);
				});
				return false;
			});
			
			
			/* tabs */
			$("dl.tabs dt").live("click", function(){
				$(this)
					.siblings().removeClass("active").end()
					.next("dd").andSelf().addClass("active");
			}).first().click();
			
			
			/* accordeon */
			$("dl.accordeon dt").live("click", function(){
				$(this)
					.toggleClass("active")
					.next("dd").slideToggle(100)
			});
			
		});
		

