/** * owl carousel v2.2.1 * copyright 2013-2017 david deutsch * licensed under () */ ! function(a, b, c, d) { function e(b, c) { this.settings = null, this.options = a.extend({}, e.defaults, c), this.$element = a(b), this._handlers = {}, this._plugins = {}, this._supress = {}, this._current = null, this._speed = null, this._coordinates = [], this._breakpoint = null, this._width = null, this._items = [], this._clones = [], this._mergers = [], this._widths = [], this._invalidated = {}, this._pipe = [], this._drag = { time: null, target: null, pointer: null, stage: { start: null, current: null }, direction: null }, this._states = { current: {}, tags: { initializing: ["busy"], animating: ["busy"], dragging: ["interacting"] } }, a.each(["onresize", "onthrottledresize"], a.proxy(function(b, c) { this._handlers[c] = a.proxy(this[c], this) }, this)), a.each(e.plugins, a.proxy(function(a, b) { this._plugins[a.charat(0).tolowercase() + a.slice(1)] = new b(this) }, this)), a.each(e.workers, a.proxy(function(b, c) { this._pipe.push({ filter: c.filter, run: a.proxy(c.run, this) }) }, this)), this.setup(), this.initialize() } e.defaults = { items: 3, loop: !1, center: !1, rewind: !1, mousedrag: !0, touchdrag: !0, pulldrag: !0, freedrag: !1, margin: 0, stagepadding: 0, merge: !1, mergefit: !0, autowidth: !1, startposition: 0, rtl: !1, smartspeed: 250, fluidspeed: !1, dragendspeed: !1, responsive: {}, responsiverefreshrate: 200, responsivebaseelement: b, fallbackeasing: "swing", info: !1, nesteditemselector: !1, itemelement: "div", stageelement: "div", refreshclass: "owl-refresh", loadedclass: "owl-loaded", loadingclass: "owl-loading", rtlclass: "owl-rtl", responsiveclass: "owl-responsive", dragclass: "owl-drag", itemclass: "owl-item", stageclass: "owl-stage", stageouterclass: "owl-stage-outer", grabclass: "owl-grab" }, e.width = { default: "default", inner: "inner", outer: "outer" }, e.type = { event: "event", state: "state" }, e.plugins = {}, e.workers = [{ filter: ["width", "settings"], run: function() { this._width = this.$element.width() } }, { filter: ["width", "items", "settings"], run: function(a) { a.current = this._items && this._items[this.relative(this._current)] } }, { filter: ["items", "settings"], run: function() { this.$stage.children(".cloned").remove() } }, { filter: ["width", "items", "settings"], run: function(a) { var b = this.settings.margin || "", c = !this.settings.autowidth, d = this.settings.rtl, e = { width: "auto", "margin-left": d ? b : "", "margin-right": d ? "" : b }; !c && this.$stage.children().css(e), a.css = e } }, { filter: ["width", "items", "settings"], run: function(a) { var b = (this.width() / this.settings.items).tofixed(3) - this.settings.margin, c = null, d = this._items.length, e = !this.settings.autowidth, f = []; for (a.items = { merge: !1, width: b }; d--;) c = this._mergers[d], c = this.settings.mergefit && math.min(c, this.settings.items) || c, a.items.merge = c > 1 || a.items.merge, f[d] = e ? b * c : this._items[d].width(); this._widths = f } }, { filter: ["items", "settings"], run: function() { var b = [], c = this._items, d = this.settings, e = math.max(2 * d.items, 4), f = 2 * math.ceil(c.length / 2), g = d.loop && c.length ? d.rewind ? e : math.max(e, f) : 0, h = "", i = ""; for (g /= 2; g--;) b.push(this.normalize(b.length / 2, !0)), h += c[b[b.length - 1]][0].outerhtml, b.push(this.normalize(c.length - 1 - (b.length - 1) / 2, !0)), i = c[b[b.length - 1]][0].outerhtml + i; this._clones = b, a(h).addclass("cloned").appendto(this.$stage), a(i).addclass("cloned").prependto(this.$stage) } }, { filter: ["width", "items", "settings"], run: function() { for (var a = this.settings.rtl ? 1 : -1, b = this._clones.length + this._items.length, c = -1, d = 0, e = 0, f = []; ++c < b;) d = f[c - 1] || 0, e = this._widths[this.relative(c)] + this.settings.margin, f.push(d + e * a); this._coordinates = f } }, { filter: ["width", "items", "settings"], run: function() { var a = this.settings.stagepadding, b = this._coordinates, c = { width: math.ceil(math.abs(b[b.length - 1])) + 2 * a, "padding-left": a || "", "padding-right": a || "" }; this.$stage.css(c) } }, { filter: ["width", "items", "settings"], run: function(a) { var b = this._coordinates.length, c = !this.settings.autowidth, d = this.$stage.children(); if (c && a.items.merge) for (; b--;) a.css.width = this._widths[this.relative(b)], d.eq(b).css(a.css); else c && (a.css.width = a.items.width, d.css(a.css)) } }, { filter: ["items"], run: function() { this._coordinates.length < 1 && this.$stage.removeattr("style") } }, { filter: ["width", "items", "settings"], run: function(a) { a.current = a.current ? this.$stage.children().index(a.current) : 0, a.current = math.max(this.minimum(), math.min(this.maximum(), a.current)), this.reset(a.current) } }, { filter: ["position"], run: function() { this.animate(this.coordinates(this._current)) } }, { filter: ["width", "position", "items", "settings"], run: function() { var a, b, c, d, e = this.settings.rtl ? 1 : -1, f = 2 * this.settings.stagepadding, g = this.coordinates(this.current()) + f, h = g + this.width() * e, i = []; for (c = 0, d = this._coordinates.length; c < d; c++) a = this._coordinates[c - 1] || 0, b = math.abs(this._coordinates[c]) + f * e, (this.op(a, "<=", g) && this.op(a, ">", h) || this.op(b, "<", g) && this.op(b, ">", h)) && i.push(c); this.$stage.children(".active").removeclass("active"), this.$stage.children(":eq(" + i.join("), :eq(") + ")").addclass("active"), this.settings.center && (this.$stage.children(".center").removeclass("center"), this.$stage.children().eq(this.current()).addclass("center")) } }], e.prototype.initialize = function() { if (this.enter("initializing"), this.trigger("initialize"), this.$element.toggleclass(this.settings.rtlclass, this.settings.rtl), this.settings.autowidth && !this.is("pre-loading")) { var b, c, e; b = this.$element.find("img"), c = this.settings.nesteditemselector ? "." + this.settings.nesteditemselector : d, e = this.$element.children(c).width(), b.length && e <= 0 && this.preloadautowidthimages(b) } this.$element.addclass(this.options.loadingclass), this.$stage = a("<" + this.settings.stageelement + ' class="' + this.settings.stageclass + '"/>').wrap('
'), this.$element.append(this.$stage.parent()), this.replace(this.$element.children().not(this.$stage.parent())), this.$element.is(":visible") ? this.refresh() : this.invalidate("width"), this.$element.removeclass(this.options.loadingclass).addclass(this.options.loadedclass), this.registereventhandlers(), this.leave("initializing"), this.trigger("initialized") }, e.prototype.setup = function() { var b = this.viewport(), c = this.options.responsive, d = -1, e = null; c ? (a.each(c, function(a) { a <= b && a > d && (d = number(a)) }), e = a.extend({}, this.options, c[d]), "function" == typeof e.stagepadding && (e.stagepadding = e.stagepadding()), delete e.responsive, e.responsiveclass && this.$element.attr("class", this.$element.attr("class").replace(new regexp("(" + this.options.responsiveclass + "-)\\s+\\s", "g"), "$1" + d))) : e = a.extend({}, this.options), this.trigger("change", { property: { name: "settings", value: e } }), this._breakpoint = d, this.settings = e, this.invalidate("settings"), this.trigger("changed", { property: { name: "settings", value: this.settings } }) }, e.prototype.optionslogic = function() { this.settings.autowidth && (this.settings.stagepadding = !1, this.settings.merge = !1) }, e.prototype.prepare = function(b) { var c = this.trigger("prepare", { content: b }); return c.data || (c.data = a("<" + this.settings.itemelement + "/>").addclass(this.options.itemclass).append(b)), this.trigger("prepared", { content: c.data }), c.data }, e.prototype.update = function() { for (var b = 0, c = this._pipe.length, d = a.proxy(function(a) { return this[a] }, this._invalidated), e = {}; b < c;)(this._invalidated.all || a.grep(this._pipe[b].filter, d).length > 0) && this._pipe[b].run(e), b++; this._invalidated = {}, !this.is("valid") && this.enter("valid") }, e.prototype.width = function(a) { switch (a = a || e.width.default) { case e.width.inner: case e.width.outer: return this._width; default: return this._width - 2 * this.settings.stagepadding + this.settings.margin } }, e.prototype.refresh = function() { this.enter("refreshing"), this.trigger("refresh"), this.setup(), this.optionslogic(), this.$element.addclass(this.options.refreshclass), this.update(), this.$element.removeclass(this.options.refreshclass), this.leave("refreshing"), this.trigger("refreshed") }, e.prototype.onthrottledresize = function() { b.cleartimeout(this.resizetimer), this.resizetimer = b.settimeout(this._handlers.onresize, this.settings.responsiverefreshrate) }, e.prototype.onresize = function() { return !!this._items.length && (this._width !== this.$element.width() && ( !! this.$element.is(":visible") && (this.enter("resizing"), this.trigger("resize").isdefaultprevented() ? (this.leave("resizing"), !1) : (this.invalidate("width"), this.refresh(), this.leave("resizing"), void this.trigger("resized"))))) }, e.prototype.registereventhandlers = function() { a.support.transition && this.$stage.on(a.support.transition.end + ".owl.core", a.proxy(this.ontransitionend, this)), this.settings.responsive !== !1 && this.on(b, "resize", this._handlers.onthrottledresize), this.settings.mousedrag && (this.$element.addclass(this.options.dragclass), this.$stage.on("mousedown.owl.core", a.proxy(this.ondragstart, this)), this.$stage.on("dragstart.owl.core selectstart.owl.core", function() { return !1 })), this.settings.touchdrag && (this.$stage.on("touchstart.owl.core", a.proxy(this.ondragstart, this)), this.$stage.on("touchcancel.owl.core", a.proxy(this.ondragend, this))) }, e.prototype.ondragstart = function(b) { var d = null; 3 !== b.which && (a.support.transform ? (d = this.$stage.css("transform").replace(/.*\(|\)| /g, "").split(","), d = { x: d[16 === d.length ? 12 : 4], y: d[16 === d.length ? 13 : 5] }) : (d = this.$stage.position(), d = { x: this.settings.rtl ? d.left + this.$stage.width() - this.width() + this.settings.margin : d.left, y: d.top }), this.is("animating") && (a.support.transform ? this.animate(d.x) : this.$stage.stop(), this.invalidate("position")), this.$element.toggleclass(this.options.grabclass, "mousedown" === b.type), this.speed(0), this._drag.time = (new date).gettime(), this._drag.target = a(b.target), this._drag.stage.start = d, this._drag.stage.current = d, this._drag.pointer = this.pointer(b), a(c).on("mouseup.owl.core touchend.owl.core", a.proxy(this.ondragend, this)), a(c).one("mousemove.owl.core touchmove.owl.core", a.proxy(function(b) { var d = this.difference(this._drag.pointer, this.pointer(b)); a(c).on("mousemove.owl.core touchmove.owl.core", a.proxy(this.ondragmove, this)), math.abs(d.x) < math.abs(d.y) && this.is("valid") || (b.preventdefault(), this.enter("dragging"), this.trigger("drag")) }, this))) }, e.prototype.ondragmove = function(a) { var b = null, c = null, d = null, e = this.difference(this._drag.pointer, this.pointer(a)), f = this.difference(this._drag.stage.start, e); this.is("dragging") && (a.preventdefault(), this.settings.loop ? (b = this.coordinates(this.minimum()), c = this.coordinates(this.maximum() + 1) - b, f.x = ((f.x - b) % c + c) % c + b) : (b = this.settings.rtl ? this.coordinates(this.maximum()) : this.coordinates(this.minimum()), c = this.settings.rtl ? this.coordinates(this.minimum()) : this.coordinates(this.maximum()), d = this.settings.pulldrag ? -1 * e.x / 5 : 0, f.x = math.max(math.min(f.x, b + d), c + d)), this._drag.stage.current = f, this.animate(f.x)) }, e.prototype.ondragend = function(b) { var d = this.difference(this._drag.pointer, this.pointer(b)), e = this._drag.stage.current, f = d.x > 0 ^ this.settings.rtl ? "left" : "right"; a(c).off(".owl.core"), this.$element.removeclass(this.options.grabclass), (0 !== d.x && this.is("dragging") || !this.is("valid")) && (this.speed(this.settings.dragendspeed || this.settings.smartspeed), this.current(this.closest(e.x, 0 !== d.x ? f : this._drag.direction)), this.invalidate("position"), this.update(), this._drag.direction = f, (math.abs(d.x) > 3 || (new date).gettime() - this._drag.time > 300) && this._drag.target.one("click.owl.core", function() { return !1 })), this.is("dragging") && (this.leave("dragging"), this.trigger("dragged")) }, e.prototype.closest = function(b, c) { var d = -1, e = 30, f = this.width(), g = this.coordinates(); return this.settings.freedrag || a.each(g, a.proxy(function(a, h) { return "left" === c && b > h - e && b < h + e ? d = a : "right" === c && b > h - f - e && b < h - f + e ? d = a + 1 : this.op(b, "<", h) && this.op(b, ">", g[a + 1] || h - f) && (d = "left" === c ? a + 1 : a), d === -1 }, this)), this.settings.loop || (this.op(b, ">", g[this.minimum()]) ? d = b = this.minimum() : this.op(b, "<", g[this.maximum()]) && (d = b = this.maximum())), d }, e.prototype.animate = function(b) { var c = this.speed() > 0; this.is("animating") && this.ontransitionend(), c && (this.enter("animating"), this.trigger("translate")), a.support.transform3d && a.support.transition ? this.$stage.css({ transform: "translate3d(" + b + "px,0px,0px)", transition: this.speed() / 1e3 + "s" }) : c ? this.$stage.animate({ left: b + "px" }, this.speed(), this.settings.fallbackeasing, a.proxy(this.ontransitionend, this)) : this.$stage.css({ left: b + "px" }) }, e.prototype.is = function(a) { return this._states.current[a] && this._states.current[a] > 0 }, e.prototype.current = function(a) { if (a === d) return this._current; if (0 === this._items.length) return d; if (a = this.normalize(a), this._current !== a) { var b = this.trigger("change", { property: { name: "position", value: a } }); b.data !== d && (a = this.normalize(b.data)), this._current = a, this.invalidate("position"), this.trigger("changed", { property: { name: "position", value: this._current } }) } return this._current }, e.prototype.invalidate = function(b) { return "string" === a.type(b) && (this._invalidated[b] = !0, this.is("valid") && this.leave("valid")), a.map(this._invalidated, function(a, b) { return b }) }, e.prototype.reset = function(a) { a = this.normalize(a), a !== d && (this._speed = 0, this._current = a, this.suppress(["translate", "translated"]), this.animate(this.coordinates(a)), this.release(["translate", "translated"])) }, e.prototype.normalize = function(a, b) { var c = this._items.length, e = b ? 0 : this._clones.length; return !this.isnumeric(a) || c < 1 ? a = d : (a < 0 || a >= c + e) && (a = ((a - e / 2) % c + c) % c + e / 2), a }, e.prototype.relative = function(a) { return a -= this._clones.length / 2, this.normalize(a, !0) }, e.prototype.maximum = function(a) { var b, c, d, e = this.settings, f = this._coordinates.length; if (e.loop) f = this._clones.length / 2 + this._items.length - 1; else if (e.autowidth || e.merge) { for (b = this._items.length, c = this._items[--b].width(), d = this.$element.width(); b-- && (c += this._items[b].width() + this.settings.margin, !(c > d));); f = b + 1 } else f = e.center ? this._items.length - 1 : this._items.length - e.items; return a && (f -= this._clones.length / 2), math.max(f, 0) }, e.prototype.minimum = function(a) { return a ? 0 : this._clones.length / 2 }, e.prototype.items = function(a) { return a === d ? this._items.slice() : (a = this.normalize(a, !0), this._items[a]) }, e.prototype.mergers = function(a) { return a === d ? this._mergers.slice() : (a = this.normalize(a, !0), this._mergers[a]) }, e.prototype.clones = function(b) { var c = this._clones.length / 2, e = c + this._items.length, f = function(a) { return a % 2 === 0 ? e + a / 2 : c - (a + 1) / 2 }; return b === d ? a.map(this._clones, function(a, b) { return f(b) }) : a.map(this._clones, function(a, c) { return a === b ? f(c) : null }) }, e.prototype.speed = function(a) { return a !== d && (this._speed = a), this._speed }, e.prototype.coordinates = function(b) { var c, e = 1, f = b - 1; return b === d ? a.map(this._coordinates, a.proxy(function(a, b) { return this.coordinates(b) }, this)) : (this.settings.center ? (this.settings.rtl && (e = -1, f = b + 1), c = this._coordinates[b], c += (this.width() - c + (this._coordinates[f] || 0)) / 2 * e) : c = this._coordinates[f] || 0, c = math.ceil(c)) }, e.prototype.duration = function(a, b, c) { return 0 === c ? 0 : math.min(math.max(math.abs(b - a), 1), 6) * math.abs(c || this.settings.smartspeed) }, e.prototype.to = function(a, b) { var c = this.current(), d = null, e = a - this.relative(c), f = (e > 0) - (e < 0), g = this._items.length, h = this.minimum(), i = this.maximum(); this.settings.loop ? (!this.settings.rewind && math.abs(e) > g / 2 && (e += f * -1 * g), a = c + e, d = ((a - h) % g + g) % g + h, d !== a && d - e <= i && d - e > 0 && (c = d - e, a = d, this.reset(c))) : this.settings.rewind ? (i += 1, a = (a % i + i) % i) : a = math.max(h, math.min(i, a)), this.speed(this.duration(c, a, b)), this.current(a), this.$element.is(":visible") && this.update() }, e.prototype.next = function(a) { a = a || !1, this.to(this.relative(this.current()) + 1, a) }, e.prototype.prev = function(a) { a = a || !1, this.to(this.relative(this.current()) - 1, a) }, e.prototype.ontransitionend = function(a) { if (a !== d && (a.stoppropagation(), (a.target || a.srcelement || a.originaltarget) !== this.$stage.get(0))) return !1; this.leave("animating"), this.trigger("translated") }, e.prototype.viewport = function() { var d; return this.options.responsivebaseelement !== b ? d = a(this.options.responsivebaseelement).width() : b.innerwidth ? d = b.innerwidth : c.documentelement && c.documentelement.clientwidth ? d = c.documentelement.clientwidth : console.warn("can not detect viewport width."), d }, e.prototype.replace = function(b) { this.$stage.empty(), this._items = [], b && (b = b instanceof jquery ? b : a(b)), this.settings.nesteditemselector && (b = b.find("." + this.settings.nesteditemselector)), b.filter(function() { return 1 === this.nodetype }).each(a.proxy(function(a, b) { b = this.prepare(b), this.$stage.append(b), this._items.push(b), this._mergers.push(1 * b.find("[data-merge]").addback("[data-merge]").attr("data-merge") || 1) }, this)), this.reset(this.isnumeric(this.settings.startposition) ? this.settings.startposition : 0), this.invalidate("items") }, e.prototype.add = function(b, c) { var e = this.relative(this._current); c = c === d ? this._items.length : this.normalize(c, !0), b = b instanceof jquery ? b : a(b), this.trigger("add", { content: b, position: c }), b = this.prepare(b), 0 === this._items.length || c === this._items.length ? (0 === this._items.length && this.$stage.append(b), 0 !== this._items.length && this._items[c - 1].after(b), this._items.push(b), this._mergers.push(1 * b.find("[data-merge]").addback("[data-merge]").attr("data-merge") || 1)) : (this._items[c].before(b), this._items.splice(c, 0, b), this._mergers.splice(c, 0, 1 * b.find("[data-merge]").addback("[data-merge]").attr("data-merge") || 1)), this._items[e] && this.reset(this._items[e].index()), this.invalidate("items"), this.trigger("added", { content: b, position: c }) }, e.prototype.remove = function(a) { a = this.normalize(a, !0), a !== d && (this.trigger("remove", { content: this._items[a], position: a }), this._items[a].remove(), this._items.splice(a, 1), this._mergers.splice(a, 1), this.invalidate("items"), this.trigger("removed", { content: null, position: a })) }, e.prototype.preloadautowidthimages = function(b) { b.each(a.proxy(function(b, c) { this.enter("pre-loading"), c = a(c), a(new image).one("load", a.proxy(function(a) { c.attr("src", a.target.src), c.css("opacity", 1), this.leave("pre-loading"), !this.is("pre-loading") && !this.is("initializing") && this.refresh() }, this)).attr("src", c.attr("src") || c.attr("data-src") || c.attr("data-src-retina")) }, this)) }, e.prototype.destroy = function() { this.$element.off(".owl.core"), this.$stage.off(".owl.core"), a(c).off(".owl.core"), this.settings.responsive !== !1 && (b.cleartimeout(this.resizetimer), this.off(b, "resize", this._handlers.onthrottledresize)); for (var d in this._plugins) this._plugins[d].destroy(); this.$stage.children(".cloned").remove(), this.$stage.unwrap(), this.$stage.children().contents().unwrap(), this.$stage.children().unwrap(), this.$element.removeclass(this.options.refreshclass).removeclass(this.options.loadingclass).removeclass(this.options.loadedclass).removeclass(this.options.rtlclass).removeclass(this.options.dragclass).removeclass(this.options.grabclass).attr("class", this.$element.attr("class").replace(new regexp(this.options.responsiveclass + "-\\s+\\s", "g"), "")).removedata("owl.carousel") }, e.prototype.op = function(a, b, c) { var d = this.settings.rtl; switch (b) { case "<": return d ? a > c : a < c; case ">": return d ? a < c : a > c; case ">=": return d ? a <= c : a >= c; case "<=": return d ? a >= c : a <= c } }, e.prototype.on = function(a, b, c, d) { a.addeventlistener ? a.addeventlistener(b, c, d) : a.attachevent && a.attachevent("on" + b, c) }, e.prototype.off = function(a, b, c, d) { a.removeeventlistener ? a.removeeventlistener(b, c, d) : a.detachevent && a.detachevent("on" + b, c) }, e.prototype.trigger = function(b, c, d, f, g) { var h = { item: { count: this._items.length, index: this.current() } }, i = a.camelcase(a.grep(["on", b, d], function(a) { return a }).join("-").tolowercase()), j = a.event([b, "owl", d || "carousel"].join(".").tolowercase(), a.extend({ relatedtarget: this }, h, c)); return this._supress[b] || (a.each(this._plugins, function(a, b) { b.ontrigger && b.ontrigger(j) }), this.register({ type: e.type.event, name: b }), this.$element.trigger(j), this.settings && "function" == typeof this.settings[i] && this.settings[i].call(this, j)), j }, e.prototype.enter = function(b) { a.each([b].concat(this._states.tags[b] || []), a.proxy(function(a, b) { this._states.current[b] === d && (this._states.current[b] = 0), this._states.current[b]++ }, this)) }, e.prototype.leave = function(b) { a.each([b].concat(this._states.tags[b] || []), a.proxy(function(a, b) { this._states.current[b]-- }, this)) }, e.prototype.register = function(b) { if (b.type === e.type.event) { if (a.event.special[b.name] || (a.event.special[b.name] = {}), !a.event.special[b.name].owl) { var c = a.event.special[b.name]._default; a.event.special[b.name]._default = function(a) { return !c || !c.apply || a.namespace && a.namespace.indexof("owl") !== -1 ? a.namespace && a.namespace.indexof("owl") > -1 : c.apply(this, arguments) }, a.event.special[b.name].owl = !0 } } else b.type === e.type.state && (this._states.tags[b.name] ? this._states.tags[b.name] = this._states.tags[b.name].concat(b.tags) : this._states.tags[b.name] = b.tags, this._states.tags[b.name] = a.grep(this._states.tags[b.name], a.proxy(function(c, d) { return a.inarray(c, this._states.tags[b.name]) === d }, this))) }, e.prototype.suppress = function(b) { a.each(b, a.proxy(function(a, b) { this._supress[b] = !0 }, this)) }, e.prototype.release = function(b) { a.each(b, a.proxy(function(a, b) { delete this._supress[b] }, this)) }, e.prototype.pointer = function(a) { var c = { x: null, y: null }; return a = a.originalevent || a || b.event, a = a.touches && a.touches.length ? a.touches[0] : a.changedtouches && a.changedtouches.length ? a.changedtouches[0] : a, a.pagex ? (c.x = a.pagex, c.y = a.pagey) : (c.x = a.clientx, c.y = a.clienty), c }, e.prototype.isnumeric = function(a) { return !isnan(parsefloat(a)) }, e.prototype.difference = function(a, b) { return { x: a.x - b.x, y: a.y - b.y } }, a.fn.owlcarousel = function(b) { var c = array.prototype.slice.call(arguments, 1); return this.each(function() { var d = a(this), f = d.data("owl.carousel"); f || (f = new e(this, "object" == typeof b && b), d.data("owl.carousel", f), a.each(["next", "prev", "to", "destroy", "refresh", "replace", "add", "remove"], function(b, c) { f.register({ type: e.type.event, name: c }), f.$element.on(c + ".owl.carousel.core", a.proxy(function(a) { a.namespace && a.relatedtarget !== this && (this.suppress([c]), f[c].apply(this, [].slice.call(arguments, 1)), this.release([c])) }, f)) })), "string" == typeof b && "_" !== b.charat(0) && f[b].apply(f, c) }) }, a.fn.owlcarousel.constructor = e }(window.zepto || window.jquery, window, document), function(a, b, c, d) { var e = function(b) { this._core = b, this._interval = null, this._visible = null, this._handlers = { "initialized.owl.carousel": a.proxy(function(a) { a.namespace && this._core.settings.autorefresh && this.watch() }, this) }, this._core.options = a.extend({}, e.defaults, this._core.options), this._core.$element.on(this._handlers) }; e.defaults = { autorefresh: !0, autorefreshinterval: 500 }, e.prototype.watch = function() { this._interval || (this._visible = this._core.$element.is(":visible"), this._interval = b.setinterval(a.proxy(this.refresh, this), this._core.settings.autorefreshinterval)) }, e.prototype.refresh = function() { this._core.$element.is(":visible") !== this._visible && (this._visible = !this._visible, this._core.$element.toggleclass("owl-hidden", !this._visible), this._visible && this._core.invalidate("width") && this._core.refresh()) }, e.prototype.destroy = function() { var a, c; b.clearinterval(this._interval); for (a in this._handlers) this._core.$element.off(a, this._handlers[a]); for (c in object.getownpropertynames(this))"function" != typeof this[c] && (this[c] = null) }, a.fn.owlcarousel.constructor.plugins.autorefresh = e }(window.zepto || window.jquery, window, document), function(a, b, c, d) { var e = function(b) { this._core = b, this._loaded = [], this._handlers = { "initialized.owl.carousel change.owl.carousel resized.owl.carousel": a.proxy(function(b) { if (b.namespace && this._core.settings && this._core.settings.lazyload && (b.property && "position" == b.property.name || "initialized" == b.type)) for (var c = this._core.settings, e = c.center && math.ceil(c.items / 2) || c.items, f = c.center && e * -1 || 0, g = (b.property && b.property.value !== d ? b.property.value : this._core.current()) + f, h = this._core.clones().length, i = a.proxy(function(a, b) { this.load(b) }, this); f++ < e;) this.load(h / 2 + this._core.relative(g)), h && a.each(this._core.clones(this._core.relative(g)), i), g++ }, this) }, this._core.options = a.extend({}, e.defaults, this._core.options), this._core.$element.on(this._handlers) }; e.defaults = { lazyload: !1 }, e.prototype.load = function(c) { var d = this._core.$stage.children().eq(c), e = d && d.find(".owl-lazy"); !e || a.inarray(d.get(0), this._loaded) > -1 || (e.each(a.proxy(function(c, d) { var e, f = a(d), g = b.devicepixelratio > 1 && f.attr("data-src-retina") || f.attr("data-src"); this._core.trigger("load", { element: f, url: g }, "lazy"), f.is("img") ? f.one("load.owl.lazy", a.proxy(function() { f.css("opacity", 1), this._core.trigger("loaded", { element: f, url: g }, "lazy") }, this)).attr("src", g) : (e = new image, e.onload = a.proxy(function() { f.css({ "background-image": 'url("' + g + '")', opacity: "1" }), this._core.trigger("loaded", { element: f, url: g }, "lazy") }, this), e.src = g) }, this)), this._loaded.push(d.get(0))) }, e.prototype.destroy = function() { var a, b; for (a in this.handlers) this._core.$element.off(a, this.handlers[a]); for (b in object.getownpropertynames(this))"function" != typeof this[b] && (this[b] = null) }, a.fn.owlcarousel.constructor.plugins.lazy = e }(window.zepto || window.jquery, window, document), function(a, b, c, d) { var e = function(b) { this._core = b, this._handlers = { "initialized.owl.carousel refreshed.owl.carousel": a.proxy(function(a) { a.namespace && this._core.settings.autoheight && this.update() }, this), "changed.owl.carousel": a.proxy(function(a) { a.namespace && this._core.settings.autoheight && "position" == a.property.name && this.update() }, this), "loaded.owl.lazy": a.proxy(function(a) { a.namespace && this._core.settings.autoheight && a.element.closest("." + this._core.settings.itemclass).index() === this._core.current() && this.update() }, this) }, this._core.options = a.extend({}, e.defaults, this._core.options), this._core.$element.on(this._handlers) }; e.defaults = { autoheight: !1, autoheightclass: "owl-height" }, e.prototype.update = function() { var b = this._core._current, c = b + this._core.settings.items, d = this._core.$stage.children().toarray().slice(b, c), e = [], f = 0; a.each(d, function(b, c) { e.push(a(c).height()) }), f = math.max.apply(null, e), this._core.$stage.parent().height(f).addclass(this._core.settings.autoheightclass) }, e.prototype.destroy = function() { var a, b; for (a in this._handlers) this._core.$element.off(a, this._handlers[a]); for (b in object.getownpropertynames(this))"function" != typeof this[b] && (this[b] = null) }, a.fn.owlcarousel.constructor.plugins.autoheight = e }(window.zepto || window.jquery, window, document), function(a, b, c, d) { var e = function(b) { this._core = b, this._videos = {}, this._playing = null, this._handlers = { "initialized.owl.carousel": a.proxy(function(a) { a.namespace && this._core.register({ type: "state", name: "playing", tags: ["interacting"] }) }, this), "resize.owl.carousel": a.proxy(function(a) { a.namespace && this._core.settings.video && this.isinfullscreen() && a.preventdefault() }, this), "refreshed.owl.carousel": a.proxy(function(a) { a.namespace && this._core.is("resizing") && this._core.$stage.find(".cloned .owl-video-frame").remove() }, this), "changed.owl.carousel": a.proxy(function(a) { a.namespace && "position" === a.property.name && this._playing && this.stop() }, this), "prepared.owl.carousel": a.proxy(function(b) { if (b.namespace) { var c = a(b.content).find(".owl-video"); c.length && (c.css("display", "none"), this.fetch(c, a(b.content))) } }, this) }, this._core.options = a.extend({}, e.defaults, this._core.options), this._core.$element.on(this._handlers), this._core.$element.on("click.owl.video", ".owl-video-play-icon", a.proxy(function(a) { this.play(a) }, this)) }; e.defaults = { video: !1, videoheight: !1, videowidth: !1 }, e.prototype.fetch = function(a, b) { var c = function() { return a.attr("data-vimeo-id") ? "vimeo" : a.attr("data-vzaar-id") ? "vzaar" : "youtube" }(), d = a.attr("data-vimeo-id") || a.attr("data-youtube-id") || a.attr("data-vzaar-id"), e = a.attr("data-width") || this._core.settings.videowidth, f = a.attr("data-height") || this._core.settings.videoheight, g = a.attr("href"); if (!g) throw new error("missing video url."); if (d = g.match(/(http:|https:|)\/\/(player.|www.|app.)?(vimeo\.com|youtu(be\.com|\.be|be\.googleapis\.com)|vzaar\.com)\/(video\/|videos\/|embed\/|channels\/.+\/|groups\/.+\/|watch\?v=|v\/)?([a-za-z0-9._%-]*)(\&\s+)?/), d[3].indexof("youtu") > -1) c = "youtube"; else if (d[3].indexof("vimeo") > -1) c = "vimeo"; else { if (!(d[3].indexof("vzaar") > -1)) throw new error("video url not supported."); c = "vzaar" } d = d[6], this._videos[g] = { type: c, id: d, width: e, height: f }, b.attr("data-video", g), this.thumbnail(a, this._videos[g]) }, e.prototype.thumbnail = function(b, c) { var d, e, f, g = c.width && c.height ? 'style="width:' + c.width + "px;height:" + c.height + 'px;"' : "", h = b.find("img"), i = "src", j = "", k = this._core.settings, l = function(a) { e = '
', d = k.lazyload ? '
' : '
', b.after(d), b.after(e) }; if (b.wrap('
"), this._core.settings.lazyload && (i = "data-src", j = "owl-lazy"), h.length) return l(h.attr(i)), h.remove(), !1; "youtube" === c.type ? (f = "//img.youtube.com/vi/" + c.id + "/hqdefault.jpg", l(f)) : "vimeo" === c.type ? a.ajax({ type: "get", url: "//vimeo.com/api/v2/video/" + c.id + ".json", jsonp: "callback", datatype: "jsonp", success: function(a) { f = a[0].thumbnail_large, l(f) } }) : "vzaar" === c.type && a.ajax({ type: "get", url: "//vzaar.com/api/videos/" + c.id + ".json", jsonp: "callback", datatype: "jsonp", success: function(a) { f = a.framegrab_url, l(f) } }) }, e.prototype.stop = function() { this._core.trigger("stop", null, "video"), this._playing.find(".owl-video-frame").remove(), this._playing.removeclass("owl-video-playing"), this._playing = null, this._core.leave("playing"), this._core.trigger("stopped", null, "video") }, e.prototype.play = function(b) { var c, d = a(b.target), e = d.closest("." + this._core.settings.itemclass), f = this._videos[e.attr("data-video")], g = f.width || "100%", h = f.height || this._core.$stage.height(); this._playing || (this._core.enter("playing"), this._core.trigger("play", null, "video"), e = this._core.items(this._core.relative(e.index())), this._core.reset(e.index()), "youtube" === f.type ? c = '' : "vimeo" === f.type ? c = '' : "vzaar" === f.type && (c = ''), a('
' + c + "
").insertafter(e.find(".owl-video")), this._playing = e.addclass("owl-video-playing")) }, e.prototype.isinfullscreen = function() { var b = c.fullscreenelement || c.mozfullscreenelement || c.webkitfullscreenelement; return b && a(b).parent().hasclass("owl-video-frame") }, e.prototype.destroy = function() { var a, b; this._core.$element.off("click.owl.video"); for (a in this._handlers) this._core.$element.off(a, this._handlers[a]); for (b in object.getownpropertynames(this))"function" != typeof this[b] && (this[b] = null) }, a.fn.owlcarousel.constructor.plugins.video = e }(window.zepto || window.jquery, window, document), function(a, b, c, d) { var e = function(b) { this.core = b, this.core.options = a.extend({}, e.defaults, this.core.options), this.swapping = !0, this.previous = d, this.next = d, this.handlers = { "change.owl.carousel": a.proxy(function(a) { a.namespace && "position" == a.property.name && (this.previous = this.core.current(), this.next = a.property.value) }, this), "drag.owl.carousel dragged.owl.carousel translated.owl.carousel": a.proxy(function(a) { a.namespace && (this.swapping = "translated" == a.type) }, this), "translate.owl.carousel": a.proxy(function(a) { a.namespace && this.swapping && (this.core.options.animateout || this.core.options.animatein) && this.swap() }, this) }, this.core.$element.on(this.handlers) }; e.defaults = { animateout: !1, animatein: !1 }, e.prototype.swap = function() { if (1 === this.core.settings.items && a.support.animation && a.support.transition) { this.core.speed(0); var b, c = a.proxy(this.clear, this), d = this.core.$stage.children().eq(this.previous), e = this.core.$stage.children().eq(this.next), f = this.core.settings.animatein, g = this.core.settings.animateout; this.core.current() !== this.previous && (g && (b = this.core.coordinates(this.previous) - this.core.coordinates(this.next), d.one(a.support.animation.end, c).css({ left: b + "px" }).addclass("animated owl-animated-out").addclass(g)), f && e.one(a.support.animation.end, c).addclass("animated owl-animated-in").addclass(f)) } }, e.prototype.clear = function(b) { a(b.target).css({ left: "" }).removeclass("animated owl-animated-out owl-animated-in").removeclass(this.core.settings.animatein).removeclass(this.core.settings.animateout), this.core.ontransitionend() }, e.prototype.destroy = function() { var a, b; for (a in this.handlers) this.core.$element.off(a, this.handlers[a]); for (b in object.getownpropertynames(this))"function" != typeof this[b] && (this[b] = null) }, a.fn.owlcarousel.constructor.plugins.animate = e }(window.zepto || window.jquery, window, document), function(a, b, c, d) { var e = function(b) { this._core = b, this._timeout = null, this._paused = !1, this._handlers = { "changed.owl.carousel": a.proxy(function(a) { a.namespace && "settings" === a.property.name ? this._core.settings.autoplay ? this.play() : this.stop() : a.namespace && "position" === a.property.name && this._core.settings.autoplay && this._setautoplayinterval() }, this), "initialized.owl.carousel": a.proxy(function(a) { a.namespace && this._core.settings.autoplay && this.play() }, this), "play.owl.autoplay": a.proxy(function(a, b, c) { a.namespace && this.play(b, c) }, this), "stop.owl.autoplay": a.proxy(function(a) { a.namespace && this.stop() }, this), "mouseover.owl.autoplay": a.proxy(function() { this._core.settings.autoplayhoverpause && this._core.is("rotating") && this.pause() }, this), "mouseleave.owl.autoplay": a.proxy(function() { this._core.settings.autoplayhoverpause && this._core.is("rotating") && this.play() }, this), "touchstart.owl.core": a.proxy(function() { this._core.settings.autoplayhoverpause && this._core.is("rotating") && this.pause() }, this), "touchend.owl.core": a.proxy(function() { this._core.settings.autoplayhoverpause && this.play() }, this) }, this._core.$element.on(this._handlers), this._core.options = a.extend({}, e.defaults, this._core.options) }; e.defaults = { autoplay: !1, autoplaytimeout: 5e3, autoplayhoverpause: !1, autoplayspeed: !1 }, e.prototype.play = function(a, b) { this._paused = !1, this._core.is("rotating") || (this._core.enter("rotating"), this._setautoplayinterval()) }, e.prototype._getnexttimeout = function(d, e) { return this._timeout && b.cleartimeout(this._timeout), b.settimeout(a.proxy(function() { this._paused || this._core.is("busy") || this._core.is("interacting") || c.hidden || this._core.next(e || this._core.settings.autoplayspeed) }, this), d || this._core.settings.autoplaytimeout) }, e.prototype._setautoplayinterval = function() { this._timeout = this._getnexttimeout() }, e.prototype.stop = function() { this._core.is("rotating") && (b.cleartimeout(this._timeout), this._core.leave("rotating")) }, e.prototype.pause = function() { this._core.is("rotating") && (this._paused = !0) }, e.prototype.destroy = function() { var a, b; this.stop(); for (a in this._handlers) this._core.$element.off(a, this._handlers[a]); for (b in object.getownpropertynames(this))"function" != typeof this[b] && (this[b] = null) }, a.fn.owlcarousel.constructor.plugins.autoplay = e }(window.zepto || window.jquery, window, document), function(a, b, c, d) { "use strict"; var e = function(b) { this._core = b, this._initialized = !1, this._pages = [], this._controls = {}, this._templates = [], this.$element = this._core.$element, this._overrides = { next: this._core.next, prev: this._core.prev, to: this._core.to }, this._handlers = { "prepared.owl.carousel": a.proxy(function(b) { b.namespace && this._core.settings.dotsdata && this._templates.push('
' + a(b.content).find("[data-dot]").addback("[data-dot]").attr("data-dot") + "
") }, this), "added.owl.carousel": a.proxy(function(a) { a.namespace && this._core.settings.dotsdata && this._templates.splice(a.position, 0, this._templates.pop()) }, this), "remove.owl.carousel": a.proxy(function(a) { a.namespace && this._core.settings.dotsdata && this._templates.splice(a.position, 1) }, this), "changed.owl.carousel": a.proxy(function(a) { a.namespace && "position" == a.property.name && this.draw() }, this), "initialized.owl.carousel": a.proxy(function(a) { a.namespace && !this._initialized && (this._core.trigger("initialize", null, "navigation"), this.initialize(), this.update(), this.draw(), this._initialized = !0, this._core.trigger("initialized", null, "navigation")) }, this), "refreshed.owl.carousel": a.proxy(function(a) { a.namespace && this._initialized && (this._core.trigger("refresh", null, "navigation"), this.update(), this.draw(), this._core.trigger("refreshed", null, "navigation")) }, this) }, this._core.options = a.extend({}, e.defaults, this._core.options), this.$element.on(this._handlers) }; e.defaults = { nav: !1, navtext: ["prev", "next"], navspeed: !1, navelement: "div", navcontainer: !1, navcontainerclass: "owl-nav", navclass: ["owl-prev", "owl-next"], slideby: 1, dotclass: "owl-dot", dotsclass: "owl-dots", dots: !0, dotseach: !1, dotsdata: !1, dotsspeed: !1, dotscontainer: !1 }, e.prototype.initialize = function() { var b, c = this._core.settings; this._controls.$relative = (c.navcontainer ? a(c.navcontainer) : a("
").addclass(c.navcontainerclass).appendto(this.$element)).addclass("disabled"), this._controls.$previous = a("<" + c.navelement + ">").addclass(c.navclass[0]).html(c.navtext[0]).prependto(this._controls.$relative).on("click", a.proxy(function(a) { this.prev(c.navspeed) }, this)), this._controls.$next = a("<" + c.navelement + ">").addclass(c.navclass[1]).html(c.navtext[1]).appendto(this._controls.$relative).on("click", a.proxy(function(a) { this.next(c.navspeed) }, this)), c.dotsdata || (this._templates = [a("
").addclass(c.dotclass).append(a("")).prop("outerhtml")]), this._controls.$absolute = (c.dotscontainer ? a(c.dotscontainer) : a("
").addclass(c.dotsclass).appendto(this.$element)).addclass("disabled"), this._controls.$absolute.on("click", "div", a.proxy(function(b) { var d = a(b.target).parent().is(this._controls.$absolute) ? a(b.target).index() : a(b.target).parent().index(); b.preventdefault(), this.to(d, c.dotsspeed) }, this)); for (b in this._overrides) this._core[b] = a.proxy(this[b], this) }, e.prototype.destroy = function() { var a, b, c, d; for (a in this._handlers) this.$element.off(a, this._handlers[a]); for (b in this._controls) this._controls[b].remove(); for (d in this.overides) this._core[d] = this._overrides[d]; for (c in object.getownpropertynames(this))"function" != typeof this[c] && (this[c] = null) }, e.prototype.update = function() { var a, b, c, d = this._core.clones().length / 2, e = d + this._core.items().length, f = this._core.maximum(!0), g = this._core.settings, h = g.center || g.autowidth || g.dotsdata ? 1 : g.dotseach || g.items; if ("page" !== g.slideby && (g.slideby = math.min(g.slideby, g.items)), g.dots || "page" == g.slideby) for (this._pages = [], a = d, b = 0, c = 0; a < e; a++) { if (b >= h || 0 === b) { if (this._pages.push({ start: math.min(f, a - d), end: a - d + h - 1 }), math.min(f, a - d) === f) break; b = 0, ++c } b += this._core.mergers(this._core.relative(a)) } }, e.prototype.draw = function() { var b, c = this._core.settings, d = this._core.items().length <= c.items, e = this._core.relative(this._core.current()), f = c.loop || c.rewind; this._controls.$relative.toggleclass("disabled", !c.nav || d), c.nav && (this._controls.$previous.toggleclass("disabled", !f && e <= this._core.minimum(!0)), this._controls.$next.toggleclass("disabled", !f && e >= this._core.maximum(!0))), this._controls.$absolute.toggleclass("disabled", !c.dots || d), c.dots && (b = this._pages.length - this._controls.$absolute.children().length, c.dotsdata && 0 !== b ? this._controls.$absolute.html(this._templates.join("")) : b > 0 ? this._controls.$absolute.append(new array(b + 1).join(this._templates[0])) : b < 0 && this._controls.$absolute.children().slice(b).remove(), this._controls.$absolute.find(".active").removeclass("active"), this._controls.$absolute.children().eq(a.inarray(this.current(), this._pages)).addclass("active")) }, e.prototype.ontrigger = function(b) { var c = this._core.settings; b.page = { index: a.inarray(this.current(), this._pages), count: this._pages.length, size: c && (c.center || c.autowidth || c.dotsdata ? 1 : c.dotseach || c.items) } }, e.prototype.current = function() { var b = this._core.relative(this._core.current()); return a.grep(this._pages, a.proxy(function(a, c) { return a.start <= b && a.end >= b }, this)).pop() }, e.prototype.getposition = function(b) { var c, d, e = this._core.settings; return "page" == e.slideby ? (c = a.inarray(this.current(), this._pages), d = this._pages.length, b ? ++c : --c, c = this._pages[(c % d + d) % d].start) : (c = this._core.relative(this._core.current()), d = this._core.items().length, b ? c += e.slideby : c -= e.slideby), c }, e.prototype.next = function(b) { a.proxy(this._overrides.to, this._core)(this.getposition(!0), b) }, e.prototype.prev = function(b) { a.proxy(this._overrides.to, this._core)(this.getposition(!1), b) }, e.prototype.to = function(b, c, d) { var e; !d && this._pages.length ? (e = this._pages.length, a.proxy(this._overrides.to, this._core)(this._pages[(b % e + e) % e].start, c)) : a.proxy(this._overrides.to, this._core)(b, c) }, a.fn.owlcarousel.constructor.plugins.navigation = e }(window.zepto || window.jquery, window, document), function(a, b, c, d) { "use strict"; var e = function(c) { this._core = c, this._hashes = {}, this.$element = this._core.$element, this._handlers = { "initialized.owl.carousel": a.proxy(function(c) { c.namespace && "urlhash" === this._core.settings.startposition && a(b).trigger("hashchange.owl.navigation") }, this), "prepared.owl.carousel": a.proxy(function(b) { if (b.namespace) { var c = a(b.content).find("[data-hash]").addback("[data-hash]").attr("data-hash"); if (!c) return; this._hashes[c] = b.content } }, this), "changed.owl.carousel": a.proxy(function(c) { if (c.namespace && "position" === c.property.name) { var d = this._core.items(this._core.relative(this._core.current())), e = a.map(this._hashes, function(a, b) { return a === d ? b : null }).join(); if (!e || b.location.hash.slice(1) === e) return; b.location.hash = e } }, this) }, this._core.options = a.extend({}, e.defaults, this._core.options), this.$element.on(this._handlers), a(b).on("hashchange.owl.navigation", a.proxy(function(a) { var c = b.location.hash.substring(1), e = this._core.$stage.children(), f = this._hashes[c] && e.index(this._hashes[c]); f !== d && f !== this._core.current() && this._core.to(this._core.relative(f), !1, !0) }, this)) }; e.defaults = { urlhashlistener: !1 }, e.prototype.destroy = function() { var c, d; a(b).off("hashchange.owl.navigation"); for (c in this._handlers) this._core.$element.off(c, this._handlers[c]); for (d in object.getownpropertynames(this))"function" != typeof this[d] && (this[d] = null) }, a.fn.owlcarousel.constructor.plugins.hash = e }(window.zepto || window.jquery, window, document), function(a, b, c, d) { function e(b, c) { var e = !1, f = b.charat(0).touppercase() + b.slice(1); return a.each((b + " " + h.join(f + " ") + f).split(" "), function(a, b) { if (g[b] !== d) return e = !c || b, !1 }), e } function f(a) { return e(a, !0) } var g = a("").get(0).style, h = "webkit moz o ms".split(" "), i = { transition: { end: { webkittransition: "webkittransitionend", moztransition: "transitionend", otransition: "otransitionend", transition: "transitionend" } }, animation: { end: { webkitanimation: "webkitanimationend", mozanimation: "animationend", oanimation: "oanimationend", animation: "animationend" } } }, j = { csstransforms: function() { return !!e("transform") }, csstransforms3d: function() { return !!e("perspective") }, csstransitions: function() { return !!e("transition") }, cssanimations: function() { return !!e("animation") } }; j.csstransitions() && (a.support.transition = new string(f("transition")), a.support.transition.end = i.transition.end[a.support.transition]), j.cssanimations() && (a.support.animation = new string(f("animation")), a.support.animation.end = i.animation.end[a.support.animation]), j.csstransforms() && (a.support.transform = new string(f("transform")), a.support.transform3d = j.csstransforms3d()) }(window.zepto || window.jquery, window, document);