\n I'm a diligent, passionate, and team-oriented game programmer/developer. Building tools, gameplay programming, and 'juicing' the gameplay is right up my alley. Currently, I am working on educational math learning games for the United States based company, {' '}\n Legends of Learning.\n
\n I am 23 years old. I loved playing video games from the day I can remember, and that derived a passion towards making them.\n I set about building games when I was a teenager using Unity and Unreal game engines, and In college, I decided to pursue my career as a game developer. \n From that day on, I have been a part of around 10 projects. \n\n During these projects taking on roles such as environment and level designer, and product manager in addition to programming.\n Also, I have a good deal of experience in working on teams of up to four. \n\n Besides developing games, I have some experience in game engine programming and architecture, such as Entity Component System (ECS) and Data-Driven design. \n I have always had the mindset of clean, concise, resource-friendly, and optimized programming. \n\n Here are a few technologies and languages I've been working with recently:\n \n
Co-founder of University of Tabriz's Innovation center's Game Lab \n
\n
Achieved bronze level in Codingame - Code Royale game [Link] \n
\n
Two times participant of The ICPC International Collegiate Programming Contest. [Link] \n
\n
\n\n\n
\n {achivs && achivs.map((achiv, i) =>
{achiv}
)}\n
\n \n\n
Hobbies
\n
\n I play electric guitar in my spare time. I mostly play and listen to progressive rock/metal. 🤟\n I Played a little basketball in high school. Also of course playing video games (big fan of management simulation, city-building, and RTS) and board games is my main passion.\n
\n\n\n
\n\n\n \n\n \n
\n \n
\n \n
\n \n );\n};\n\nexport default About;\n","module.exports = __webpack_public_path__ + \"static/Calibre-Regular-b63c62e591d0c8fbe2c8f009883346d5.woff2\";","var unitlessKeys = {\n animationIterationCount: 1,\n borderImageOutset: 1,\n borderImageSlice: 1,\n borderImageWidth: 1,\n boxFlex: 1,\n boxFlexGroup: 1,\n boxOrdinalGroup: 1,\n columnCount: 1,\n columns: 1,\n flex: 1,\n flexGrow: 1,\n flexPositive: 1,\n flexShrink: 1,\n flexNegative: 1,\n flexOrder: 1,\n gridRow: 1,\n gridRowEnd: 1,\n gridRowSpan: 1,\n gridRowStart: 1,\n gridColumn: 1,\n gridColumnEnd: 1,\n gridColumnSpan: 1,\n gridColumnStart: 1,\n msGridRow: 1,\n msGridRowSpan: 1,\n msGridColumn: 1,\n msGridColumnSpan: 1,\n fontWeight: 1,\n lineHeight: 1,\n opacity: 1,\n order: 1,\n orphans: 1,\n tabSize: 1,\n widows: 1,\n zIndex: 1,\n zoom: 1,\n WebkitLineClamp: 1,\n // SVG-related properties\n fillOpacity: 1,\n floodOpacity: 1,\n stopOpacity: 1,\n strokeDasharray: 1,\n strokeDashoffset: 1,\n strokeMiterlimit: 1,\n strokeOpacity: 1,\n strokeWidth: 1\n};\nexport default unitlessKeys;","module.exports = __webpack_public_path__ + \"static/Calibre-Semibold-d8b856473a51d7eec2a9bccf2fbea54c.woff2\";","var isObject = require('../internals/is-object');\n\nmodule.exports = function (it) {\n if (!isObject(it) && it !== null) {\n throw TypeError(\"Can't set \" + String(it) + ' as a prototype');\n } return it;\n};\n","module.exports = __webpack_public_path__ + \"static/SFMono-Semibold-cebe2bfbe8a283427e3c5ad8a1b8ae2f.woff2\";","/*! smooth-scroll v16.1.3 | (c) 2020 Chris Ferdinandi | MIT License | http://github.com/cferdinandi/smooth-scroll */\nwindow.Element && !Element.prototype.closest && (Element.prototype.closest = function (e) {\n var t,\n n = (this.document || this.ownerDocument).querySelectorAll(e),\n o = this;\n\n do {\n for (t = n.length; 0 <= --t && n.item(t) !== o;) {\n ;\n }\n } while (t < 0 && (o = o.parentElement));\n\n return o;\n}), function () {\n if (\"function\" == typeof window.CustomEvent) return;\n\n function e(e, t) {\n t = t || {\n bubbles: !1,\n cancelable: !1,\n detail: void 0\n };\n var n = document.createEvent(\"CustomEvent\");\n return n.initCustomEvent(e, t.bubbles, t.cancelable, t.detail), n;\n }\n\n e.prototype = window.Event.prototype, window.CustomEvent = e;\n}(), function () {\n for (var r = 0, e = [\"ms\", \"moz\", \"webkit\", \"o\"], t = 0; t < e.length && !window.requestAnimationFrame; ++t) {\n window.requestAnimationFrame = window[e[t] + \"RequestAnimationFrame\"], window.cancelAnimationFrame = window[e[t] + \"CancelAnimationFrame\"] || window[e[t] + \"CancelRequestAnimationFrame\"];\n }\n\n window.requestAnimationFrame || (window.requestAnimationFrame = function (e, t) {\n var n = new Date().getTime(),\n o = Math.max(0, 16 - (n - r)),\n a = window.setTimeout(function () {\n e(n + o);\n }, o);\n return r = n + o, a;\n }), window.cancelAnimationFrame || (window.cancelAnimationFrame = function (e) {\n clearTimeout(e);\n });\n}(), function (e, t) {\n \"function\" == typeof define && define.amd ? define([], function () {\n return t(e);\n }) : \"object\" == typeof exports ? module.exports = t(e) : e.SmoothScroll = t(e);\n}(\"undefined\" != typeof global ? global : \"undefined\" != typeof window ? window : this, function (M) {\n \"use strict\";\n\n var q = {\n ignore: \"[data-scroll-ignore]\",\n header: null,\n topOnEmptyHash: !0,\n speed: 500,\n speedAsDuration: !1,\n durationMax: null,\n durationMin: null,\n clip: !0,\n offset: 0,\n easing: \"easeInOutCubic\",\n customEasing: null,\n updateURL: !0,\n popstate: !0,\n emitEvents: !0\n },\n I = function I() {\n var n = {};\n return Array.prototype.forEach.call(arguments, function (e) {\n for (var t in e) {\n if (!e.hasOwnProperty(t)) return;\n n[t] = e[t];\n }\n }), n;\n },\n r = function r(e) {\n \"#\" === e.charAt(0) && (e = e.substr(1));\n\n for (var t, n = String(e), o = n.length, a = -1, r = \"\", i = n.charCodeAt(0); ++a < o;) {\n if (0 === (t = n.charCodeAt(a))) throw new InvalidCharacterError(\"Invalid character: the input contains U+0000.\");\n 1 <= t && t <= 31 || 127 == t || 0 === a && 48 <= t && t <= 57 || 1 === a && 48 <= t && t <= 57 && 45 === i ? r += \"\\\\\" + t.toString(16) + \" \" : r += 128 <= t || 45 === t || 95 === t || 48 <= t && t <= 57 || 65 <= t && t <= 90 || 97 <= t && t <= 122 ? n.charAt(a) : \"\\\\\" + n.charAt(a);\n }\n\n return \"#\" + r;\n },\n F = function F() {\n return Math.max(document.body.scrollHeight, document.documentElement.scrollHeight, document.body.offsetHeight, document.documentElement.offsetHeight, document.body.clientHeight, document.documentElement.clientHeight);\n },\n L = function L(e) {\n return e ? (t = e, parseInt(M.getComputedStyle(t).height, 10) + e.offsetTop) : 0;\n var t;\n },\n x = function x(e, t, n) {\n 0 === e && document.body.focus(), n || (e.focus(), document.activeElement !== e && (e.setAttribute(\"tabindex\", \"-1\"), e.focus(), e.style.outline = \"none\"), M.scrollTo(0, t));\n },\n H = function H(e, t, n, o) {\n if (t.emitEvents && \"function\" == typeof M.CustomEvent) {\n var a = new CustomEvent(e, {\n bubbles: !0,\n detail: {\n anchor: n,\n toggle: o\n }\n });\n document.dispatchEvent(a);\n }\n };\n\n return function (o, e) {\n var b,\n a,\n A,\n O,\n C = {};\n C.cancelScroll = function (e) {\n cancelAnimationFrame(O), O = null, e || H(\"scrollCancel\", b);\n }, C.animateScroll = function (a, r, e) {\n C.cancelScroll();\n var i = I(b || q, e || {}),\n c = \"[object Number]\" === Object.prototype.toString.call(a),\n t = c || !a.tagName ? null : a;\n\n if (c || t) {\n var s = M.pageYOffset;\n i.header && !A && (A = document.querySelector(i.header));\n\n var n,\n o,\n u,\n l,\n m,\n d,\n f,\n h,\n p = L(A),\n g = c ? a : function (e, t, n, o) {\n var a = 0;\n if (e.offsetParent) for (; a += e.offsetTop, e = e.offsetParent;) {\n ;\n }\n return a = Math.max(a - t - n, 0), o && (a = Math.min(a, F() - M.innerHeight)), a;\n }(t, p, parseInt(\"function\" == typeof i.offset ? i.offset(a, r) : i.offset, 10), i.clip),\n y = g - s,\n v = F(),\n w = 0,\n S = (n = y, u = (o = i).speedAsDuration ? o.speed : Math.abs(n / 1e3 * o.speed), o.durationMax && u > o.durationMax ? o.durationMax : o.durationMin && u < o.durationMin ? o.durationMin : parseInt(u, 10)),\n E = function E(e) {\n var t, n, o;\n l || (l = e), w += e - l, d = s + y * (n = m = 1 < (m = 0 === S ? 0 : w / S) ? 1 : m, \"easeInQuad\" === (t = i).easing && (o = n * n), \"easeOutQuad\" === t.easing && (o = n * (2 - n)), \"easeInOutQuad\" === t.easing && (o = n < .5 ? 2 * n * n : (4 - 2 * n) * n - 1), \"easeInCubic\" === t.easing && (o = n * n * n), \"easeOutCubic\" === t.easing && (o = --n * n * n + 1), \"easeInOutCubic\" === t.easing && (o = n < .5 ? 4 * n * n * n : (n - 1) * (2 * n - 2) * (2 * n - 2) + 1), \"easeInQuart\" === t.easing && (o = n * n * n * n), \"easeOutQuart\" === t.easing && (o = 1 - --n * n * n * n), \"easeInOutQuart\" === t.easing && (o = n < .5 ? 8 * n * n * n * n : 1 - 8 * --n * n * n * n), \"easeInQuint\" === t.easing && (o = n * n * n * n * n), \"easeOutQuint\" === t.easing && (o = 1 + --n * n * n * n * n), \"easeInOutQuint\" === t.easing && (o = n < .5 ? 16 * n * n * n * n * n : 1 + 16 * --n * n * n * n * n), t.customEasing && (o = t.customEasing(n)), o || n), M.scrollTo(0, Math.floor(d)), function (e, t) {\n var n = M.pageYOffset;\n if (e == t || n == t || (s < t && M.innerHeight + n) >= v) return C.cancelScroll(!0), x(a, t, c), H(\"scrollStop\", i, a, r), !(O = l = null);\n }(d, g) || (O = M.requestAnimationFrame(E), l = e);\n };\n\n 0 === M.pageYOffset && M.scrollTo(0, 0), f = a, h = i, c || history.pushState && h.updateURL && history.pushState({\n smoothScroll: JSON.stringify(h),\n anchor: f.id\n }, document.title, f === document.documentElement ? \"#top\" : \"#\" + f.id), \"matchMedia\" in M && M.matchMedia(\"(prefers-reduced-motion)\").matches ? x(a, Math.floor(g), !1) : (H(\"scrollStart\", i, a, r), C.cancelScroll(!0), M.requestAnimationFrame(E));\n }\n };\n\n var t = function t(e) {\n if (!e.defaultPrevented && !(0 !== e.button || e.metaKey || e.ctrlKey || e.shiftKey) && \"closest\" in e.target && (a = e.target.closest(o)) && \"a\" === a.tagName.toLowerCase() && !e.target.closest(b.ignore) && a.hostname === M.location.hostname && a.pathname === M.location.pathname && /#/.test(a.href)) {\n var t, n;\n\n try {\n t = r(decodeURIComponent(a.hash));\n } catch (e) {\n t = r(a.hash);\n }\n\n if (\"#\" === t) {\n if (!b.topOnEmptyHash) return;\n n = document.documentElement;\n } else n = document.querySelector(t);\n\n (n = n || \"#top\" !== t ? n : document.documentElement) && (e.preventDefault(), function (e) {\n if (history.replaceState && e.updateURL && !history.state) {\n var t = M.location.hash;\n t = t || \"\", history.replaceState({\n smoothScroll: JSON.stringify(e),\n anchor: t || M.pageYOffset\n }, document.title, t || M.location.href);\n }\n }(b), C.animateScroll(n, a));\n }\n },\n n = function n(e) {\n if (null !== history.state && history.state.smoothScroll && history.state.smoothScroll === JSON.stringify(b)) {\n var t = history.state.anchor;\n \"string\" == typeof t && t && !(t = document.querySelector(r(history.state.anchor))) || C.animateScroll(t, null, {\n updateURL: !1\n });\n }\n };\n\n C.destroy = function () {\n b && (document.removeEventListener(\"click\", t, !1), M.removeEventListener(\"popstate\", n, !1), C.cancelScroll(), O = A = a = b = null);\n };\n\n return function () {\n if (!(\"querySelector\" in document && \"addEventListener\" in M && \"requestAnimationFrame\" in M && \"closest\" in M.Element.prototype)) throw \"Smooth Scroll: This browser does not support the required JavaScript methods and browser APIs.\";\n C.destroy(), b = I(q, e || {}), A = b.header ? document.querySelector(b.header) : null, document.addEventListener(\"click\", t, !1), b.updateURL && b.popstate && M.addEventListener(\"popstate\", n, !1);\n }(), C;\n };\n});","/* eslint-disable es/no-symbol -- required for testing */\nvar V8_VERSION = require('../internals/engine-v8-version');\nvar fails = require('../internals/fails');\n\n// eslint-disable-next-line es/no-object-getownpropertysymbols -- required for testing\nmodule.exports = !!Object.getOwnPropertySymbols && !fails(function () {\n var symbol = Symbol();\n // Chrome 38 Symbol has incorrect toString conversion\n // `get-own-property-symbols` polyfill symbols converted to object are not Symbol instances\n return !String(symbol) || !(Object(symbol) instanceof Symbol) ||\n // Chrome 38-40 symbols are not inherited from DOM collections prototypes to instances\n !Symbol.sham && V8_VERSION && V8_VERSION < 41;\n});\n","(function (factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module['exports'] = factory() : typeof define === 'function' && define['amd'] ? define(factory()) : window['stylisRuleSheet'] = factory();\n})(function () {\n 'use strict';\n\n return function (insertRule) {\n var delimiter = '/*|*/';\n var needle = delimiter + '}';\n\n function toSheet(block) {\n if (block) try {\n insertRule(block + '}');\n } catch (e) {}\n }\n\n return function ruleSheet(context, content, selectors, parents, line, column, length, ns, depth, at) {\n switch (context) {\n // property\n case 1:\n // @import\n if (depth === 0 && content.charCodeAt(0) === 64) return insertRule(content + ';'), '';\n break;\n // selector\n\n case 2:\n if (ns === 0) return content + delimiter;\n break;\n // at-rule\n\n case 3:\n switch (ns) {\n // @font-face, @page\n case 102:\n case 112:\n return insertRule(selectors[0] + content), '';\n\n default:\n return content + (at === 0 ? delimiter : '');\n }\n\n case -2:\n content.split(needle).forEach(toSheet);\n }\n };\n };\n});","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.min.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}","module.exports = __webpack_public_path__ + \"static/Calibre-SemiboldItalic-6473be72d5216d0ec21d273af09b9fa3.woff\";","var userAgent = require('../internals/engine-user-agent');\n\nvar webkit = userAgent.match(/AppleWebKit\\/(\\d+)\\./);\n\nmodule.exports = !!webkit && +webkit[1];\n","import { Children, cloneElement, isValidElement } from 'react';\n/**\n * Given `this.props.children`, return an object mapping key to child.\n *\n * @param {*} children `this.props.children`\n * @return {object} Mapping of key to child\n */\n\nexport function getChildMapping(children, mapFn) {\n var mapper = function mapper(child) {\n return mapFn && isValidElement(child) ? mapFn(child) : child;\n };\n\n var result = Object.create(null);\n if (children) Children.map(children, function (c) {\n return c;\n }).forEach(function (child) {\n // run the map function here instead so that the key is the computed one\n result[child.key] = mapper(child);\n });\n return result;\n}\n/**\n * When you're adding or removing children some may be added or removed in the\n * same render pass. We want to show *both* since we want to simultaneously\n * animate elements in and out. This function takes a previous set of keys\n * and a new set of keys and merges them with its best guess of the correct\n * ordering. In the future we may expose some of the utilities in\n * ReactMultiChild to make this easy, but for now React itself does not\n * directly have this concept of the union of prevChildren and nextChildren\n * so we implement it here.\n *\n * @param {object} prev prev children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @param {object} next next children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @return {object} a key set that contains all keys in `prev` and all keys\n * in `next` in a reasonable order.\n */\n\nexport function mergeChildMappings(prev, next) {\n prev = prev || {};\n next = next || {};\n\n function getValueForKey(key) {\n return key in next ? next[key] : prev[key];\n } // For each key of `next`, the list of keys to insert before that key in\n // the combined list\n\n\n var nextKeysPending = Object.create(null);\n var pendingKeys = [];\n\n for (var prevKey in prev) {\n if (prevKey in next) {\n if (pendingKeys.length) {\n nextKeysPending[prevKey] = pendingKeys;\n pendingKeys = [];\n }\n } else {\n pendingKeys.push(prevKey);\n }\n }\n\n var i;\n var childMapping = {};\n\n for (var nextKey in next) {\n if (nextKeysPending[nextKey]) {\n for (i = 0; i < nextKeysPending[nextKey].length; i++) {\n var pendingNextKey = nextKeysPending[nextKey][i];\n childMapping[nextKeysPending[nextKey][i]] = getValueForKey(pendingNextKey);\n }\n }\n\n childMapping[nextKey] = getValueForKey(nextKey);\n } // Finally, add the keys which didn't appear before any key in `next`\n\n\n for (i = 0; i < pendingKeys.length; i++) {\n childMapping[pendingKeys[i]] = getValueForKey(pendingKeys[i]);\n }\n\n return childMapping;\n}\n\nfunction getProp(child, prop, props) {\n return props[prop] != null ? props[prop] : child.props[prop];\n}\n\nexport function getInitialChildMapping(props, onExited) {\n return getChildMapping(props.children, function (child) {\n return cloneElement(child, {\n onExited: onExited.bind(null, child),\n in: true,\n appear: getProp(child, 'appear', props),\n enter: getProp(child, 'enter', props),\n exit: getProp(child, 'exit', props)\n });\n });\n}\nexport function getNextChildMapping(nextProps, prevChildMapping, onExited) {\n var nextChildMapping = getChildMapping(nextProps.children);\n var children = mergeChildMappings(prevChildMapping, nextChildMapping);\n Object.keys(children).forEach(function (key) {\n var child = children[key];\n if (!isValidElement(child)) return;\n var hasPrev = (key in prevChildMapping);\n var hasNext = (key in nextChildMapping);\n var prevChild = prevChildMapping[key];\n var isLeaving = isValidElement(prevChild) && !prevChild.props.in; // item is new (entering)\n\n if (hasNext && (!hasPrev || isLeaving)) {\n // console.log('entering', key)\n children[key] = cloneElement(child, {\n onExited: onExited.bind(null, child),\n in: true,\n exit: getProp(child, 'exit', nextProps),\n enter: getProp(child, 'enter', nextProps)\n });\n } else if (!hasNext && hasPrev && !isLeaving) {\n // item is old (exiting)\n // console.log('leaving', key)\n children[key] = cloneElement(child, {\n in: false\n });\n } else if (hasNext && hasPrev && isValidElement(prevChild)) {\n // item hasn't changed transition states\n // copy over the last transition props;\n // console.log('unchanged', key)\n children[key] = cloneElement(child, {\n onExited: onExited.bind(null, child),\n in: prevChild.props.in,\n exit: getProp(child, 'exit', nextProps),\n enter: getProp(child, 'enter', nextProps)\n });\n }\n });\n return children;\n}","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/esm/assertThisInitialized\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport React from 'react';\nimport TransitionGroupContext from './TransitionGroupContext';\nimport { getChildMapping, getInitialChildMapping, getNextChildMapping } from './utils/ChildMapping';\n\nvar values = Object.values || function (obj) {\n return Object.keys(obj).map(function (k) {\n return obj[k];\n });\n};\n\nvar defaultProps = {\n component: 'div',\n childFactory: function childFactory(child) {\n return child;\n }\n};\n/**\n * The `` component manages a set of transition components\n * (`` and ``) in a list. Like with the transition\n * components, `` is a state machine for managing the mounting\n * and unmounting of components over time.\n *\n * Consider the example below. As items are removed or added to the TodoList the\n * `in` prop is toggled automatically by the ``.\n *\n * Note that `` does not define any animation behavior!\n * Exactly _how_ a list item animates is up to the individual transition\n * component. This means you can mix and match animations across different list\n * items.\n */\n\nvar TransitionGroup = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(TransitionGroup, _React$Component);\n\n function TransitionGroup(props, context) {\n var _this;\n\n _this = _React$Component.call(this, props, context) || this;\n\n var handleExited = _this.handleExited.bind(_assertThisInitialized(_this)); // Initial children should all be entering, dependent on appear\n\n\n _this.state = {\n contextValue: {\n isMounting: true\n },\n handleExited: handleExited,\n firstRender: true\n };\n return _this;\n }\n\n var _proto = TransitionGroup.prototype;\n\n _proto.componentDidMount = function componentDidMount() {\n this.mounted = true;\n this.setState({\n contextValue: {\n isMounting: false\n }\n });\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n this.mounted = false;\n };\n\n TransitionGroup.getDerivedStateFromProps = function getDerivedStateFromProps(nextProps, _ref) {\n var prevChildMapping = _ref.children,\n handleExited = _ref.handleExited,\n firstRender = _ref.firstRender;\n return {\n children: firstRender ? getInitialChildMapping(nextProps, handleExited) : getNextChildMapping(nextProps, prevChildMapping, handleExited),\n firstRender: false\n };\n } // node is `undefined` when user provided `nodeRef` prop\n ;\n\n _proto.handleExited = function handleExited(child, node) {\n var currentChildMapping = getChildMapping(this.props.children);\n if (child.key in currentChildMapping) return;\n\n if (child.props.onExited) {\n child.props.onExited(node);\n }\n\n if (this.mounted) {\n this.setState(function (state) {\n var children = _extends({}, state.children);\n\n delete children[child.key];\n return {\n children: children\n };\n });\n }\n };\n\n _proto.render = function render() {\n var _this$props = this.props,\n Component = _this$props.component,\n childFactory = _this$props.childFactory,\n props = _objectWithoutPropertiesLoose(_this$props, [\"component\", \"childFactory\"]);\n\n var contextValue = this.state.contextValue;\n var children = values(this.state.children).map(childFactory);\n delete props.appear;\n delete props.enter;\n delete props.exit;\n\n if (Component === null) {\n return /*#__PURE__*/React.createElement(TransitionGroupContext.Provider, {\n value: contextValue\n }, children);\n }\n\n return /*#__PURE__*/React.createElement(TransitionGroupContext.Provider, {\n value: contextValue\n }, /*#__PURE__*/React.createElement(Component, props, children));\n };\n\n return TransitionGroup;\n}(React.Component);\n\nTransitionGroup.defaultProps = defaultProps;\nexport default TransitionGroup;","export default function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}","var safeIsNaN = Number.isNaN || function ponyfill(value) {\n return typeof value === 'number' && value !== value;\n};\n\nfunction isEqual(first, second) {\n if (first === second) {\n return true;\n }\n\n if (safeIsNaN(first) && safeIsNaN(second)) {\n return true;\n }\n\n return false;\n}\n\nfunction areInputsEqual(newInputs, lastInputs) {\n if (newInputs.length !== lastInputs.length) {\n return false;\n }\n\n for (var i = 0; i < newInputs.length; i++) {\n if (!isEqual(newInputs[i], lastInputs[i])) {\n return false;\n }\n }\n\n return true;\n}\n\nfunction memoizeOne(resultFn, isEqual) {\n if (isEqual === void 0) {\n isEqual = areInputsEqual;\n }\n\n var lastThis;\n var lastArgs = [];\n var lastResult;\n var calledOnce = false;\n\n function memoized() {\n var newArgs = [];\n\n for (var _i = 0; _i < arguments.length; _i++) {\n newArgs[_i] = arguments[_i];\n }\n\n if (calledOnce && lastThis === this && isEqual(newArgs, lastArgs)) {\n return lastResult;\n }\n\n lastResult = resultFn.apply(this, newArgs);\n calledOnce = true;\n lastThis = this;\n lastArgs = newArgs;\n return lastResult;\n }\n\n return memoized;\n}\n\nexport default memoizeOne;","!function (e) {\n \"object\" == typeof exports && \"undefined\" != typeof module ? module.exports = e(null) : \"function\" == typeof define && define.amd ? define(e(null)) : window.stylis = e(null);\n}(function e(a) {\n \"use strict\";\n\n var r = /^\\0+/g,\n c = /[\\0\\r\\f]/g,\n s = /: */g,\n t = /zoo|gra/,\n i = /([,: ])(transform)/g,\n f = /,+\\s*(?![^(]*[)])/g,\n n = / +\\s*(?![^(]*[)])/g,\n l = / *[\\0] */g,\n o = /,\\r+?/g,\n h = /([\\t\\r\\n ])*\\f?&/g,\n u = /:global\\(((?:[^\\(\\)\\[\\]]*|\\[.*\\]|\\([^\\(\\)]*\\))*)\\)/g,\n d = /\\W+/g,\n b = /@(k\\w+)\\s*(\\S*)\\s*/,\n p = /::(place)/g,\n k = /:(read-only)/g,\n g = /\\s+(?=[{\\];=:>])/g,\n A = /([[}=:>])\\s+/g,\n C = /(\\{[^{]+?);(?=\\})/g,\n w = /\\s{2,}/g,\n v = /([^\\(])(:+) */g,\n m = /[svh]\\w+-[tblr]{2}/,\n x = /\\(\\s*(.*)\\s*\\)/g,\n $ = /([\\s\\S]*?);/g,\n y = /-self|flex-/g,\n O = /[^]*?(:[rp][el]a[\\w-]+)[^]*/,\n j = /stretch|:\\s*\\w+\\-(?:conte|avail)/,\n z = /([^-])(image-set\\()/,\n N = \"-webkit-\",\n S = \"-moz-\",\n F = \"-ms-\",\n W = 59,\n q = 125,\n B = 123,\n D = 40,\n E = 41,\n G = 91,\n H = 93,\n I = 10,\n J = 13,\n K = 9,\n L = 64,\n M = 32,\n P = 38,\n Q = 45,\n R = 95,\n T = 42,\n U = 44,\n V = 58,\n X = 39,\n Y = 34,\n Z = 47,\n _ = 62,\n ee = 43,\n ae = 126,\n re = 0,\n ce = 12,\n se = 11,\n te = 107,\n ie = 109,\n fe = 115,\n ne = 112,\n le = 111,\n oe = 105,\n he = 99,\n ue = 100,\n de = 112,\n be = 1,\n pe = 1,\n ke = 0,\n ge = 1,\n Ae = 1,\n Ce = 1,\n we = 0,\n ve = 0,\n me = 0,\n xe = [],\n $e = [],\n ye = 0,\n Oe = null,\n je = -2,\n ze = -1,\n Ne = 0,\n Se = 1,\n Fe = 2,\n We = 3,\n qe = 0,\n Be = 1,\n De = \"\",\n Ee = \"\",\n Ge = \"\";\n\n function He(e, a, s, t, i) {\n for (var f, n, o = 0, h = 0, u = 0, d = 0, g = 0, A = 0, C = 0, w = 0, m = 0, $ = 0, y = 0, O = 0, j = 0, z = 0, R = 0, we = 0, $e = 0, Oe = 0, je = 0, ze = s.length, Je = ze - 1, Re = \"\", Te = \"\", Ue = \"\", Ve = \"\", Xe = \"\", Ye = \"\"; R < ze;) {\n if (C = s.charCodeAt(R), R === Je) if (h + d + u + o !== 0) {\n if (0 !== h) C = h === Z ? I : Z;\n d = u = o = 0, ze++, Je++;\n }\n\n if (h + d + u + o === 0) {\n if (R === Je) {\n if (we > 0) Te = Te.replace(c, \"\");\n\n if (Te.trim().length > 0) {\n switch (C) {\n case M:\n case K:\n case W:\n case J:\n case I:\n break;\n\n default:\n Te += s.charAt(R);\n }\n\n C = W;\n }\n }\n\n if (1 === $e) switch (C) {\n case B:\n case q:\n case W:\n case Y:\n case X:\n case D:\n case E:\n case U:\n $e = 0;\n\n case K:\n case J:\n case I:\n case M:\n break;\n\n default:\n for ($e = 0, je = R, g = C, R--, C = W; je < ze;) {\n switch (s.charCodeAt(je++)) {\n case I:\n case J:\n case W:\n ++R, C = g, je = ze;\n break;\n\n case V:\n if (we > 0) ++R, C = g;\n\n case B:\n je = ze;\n }\n }\n\n }\n\n switch (C) {\n case B:\n for (g = (Te = Te.trim()).charCodeAt(0), y = 1, je = ++R; R < ze;) {\n switch (C = s.charCodeAt(R)) {\n case B:\n y++;\n break;\n\n case q:\n y--;\n break;\n\n case Z:\n switch (A = s.charCodeAt(R + 1)) {\n case T:\n case Z:\n R = Qe(A, R, Je, s);\n }\n\n break;\n\n case G:\n C++;\n\n case D:\n C++;\n\n case Y:\n case X:\n for (; R++ < Je && s.charCodeAt(R) !== C;) {\n ;\n }\n\n }\n\n if (0 === y) break;\n R++;\n }\n\n if (Ue = s.substring(je, R), g === re) g = (Te = Te.replace(r, \"\").trim()).charCodeAt(0);\n\n switch (g) {\n case L:\n if (we > 0) Te = Te.replace(c, \"\");\n\n switch (A = Te.charCodeAt(1)) {\n case ue:\n case ie:\n case fe:\n case Q:\n f = a;\n break;\n\n default:\n f = xe;\n }\n\n if (je = (Ue = He(a, f, Ue, A, i + 1)).length, me > 0 && 0 === je) je = Te.length;\n if (ye > 0) if (f = Ie(xe, Te, Oe), n = Pe(We, Ue, f, a, pe, be, je, A, i, t), Te = f.join(\"\"), void 0 !== n) if (0 === (je = (Ue = n.trim()).length)) A = 0, Ue = \"\";\n if (je > 0) switch (A) {\n case fe:\n Te = Te.replace(x, Me);\n\n case ue:\n case ie:\n case Q:\n Ue = Te + \"{\" + Ue + \"}\";\n break;\n\n case te:\n if (Ue = (Te = Te.replace(b, \"$1 $2\" + (Be > 0 ? De : \"\"))) + \"{\" + Ue + \"}\", 1 === Ae || 2 === Ae && Le(\"@\" + Ue, 3)) Ue = \"@\" + N + Ue + \"@\" + Ue;else Ue = \"@\" + Ue;\n break;\n\n default:\n if (Ue = Te + Ue, t === de) Ve += Ue, Ue = \"\";\n } else Ue = \"\";\n break;\n\n default:\n Ue = He(a, Ie(a, Te, Oe), Ue, t, i + 1);\n }\n\n Xe += Ue, O = 0, $e = 0, z = 0, we = 0, Oe = 0, j = 0, Te = \"\", Ue = \"\", C = s.charCodeAt(++R);\n break;\n\n case q:\n case W:\n if ((je = (Te = (we > 0 ? Te.replace(c, \"\") : Te).trim()).length) > 1) {\n if (0 === z) if ((g = Te.charCodeAt(0)) === Q || g > 96 && g < 123) je = (Te = Te.replace(\" \", \":\")).length;\n if (ye > 0) if (void 0 !== (n = Pe(Se, Te, a, e, pe, be, Ve.length, t, i, t))) if (0 === (je = (Te = n.trim()).length)) Te = \"\\0\\0\";\n\n switch (g = Te.charCodeAt(0), A = Te.charCodeAt(1), g) {\n case re:\n break;\n\n case L:\n if (A === oe || A === he) {\n Ye += Te + s.charAt(R);\n break;\n }\n\n default:\n if (Te.charCodeAt(je - 1) === V) break;\n Ve += Ke(Te, g, A, Te.charCodeAt(2));\n }\n }\n\n O = 0, $e = 0, z = 0, we = 0, Oe = 0, Te = \"\", C = s.charCodeAt(++R);\n }\n }\n\n switch (C) {\n case J:\n case I:\n if (h + d + u + o + ve === 0) switch ($) {\n case E:\n case X:\n case Y:\n case L:\n case ae:\n case _:\n case T:\n case ee:\n case Z:\n case Q:\n case V:\n case U:\n case W:\n case B:\n case q:\n break;\n\n default:\n if (z > 0) $e = 1;\n }\n if (h === Z) h = 0;else if (ge + O === 0 && t !== te && Te.length > 0) we = 1, Te += \"\\0\";\n if (ye * qe > 0) Pe(Ne, Te, a, e, pe, be, Ve.length, t, i, t);\n be = 1, pe++;\n break;\n\n case W:\n case q:\n if (h + d + u + o === 0) {\n be++;\n break;\n }\n\n default:\n switch (be++, Re = s.charAt(R), C) {\n case K:\n case M:\n if (d + o + h === 0) switch (w) {\n case U:\n case V:\n case K:\n case M:\n Re = \"\";\n break;\n\n default:\n if (C !== M) Re = \" \";\n }\n break;\n\n case re:\n Re = \"\\\\0\";\n break;\n\n case ce:\n Re = \"\\\\f\";\n break;\n\n case se:\n Re = \"\\\\v\";\n break;\n\n case P:\n if (d + h + o === 0 && ge > 0) Oe = 1, we = 1, Re = \"\\f\" + Re;\n break;\n\n case 108:\n if (d + h + o + ke === 0 && z > 0) switch (R - z) {\n case 2:\n if (w === ne && s.charCodeAt(R - 3) === V) ke = w;\n\n case 8:\n if (m === le) ke = m;\n }\n break;\n\n case V:\n if (d + h + o === 0) z = R;\n break;\n\n case U:\n if (h + u + d + o === 0) we = 1, Re += \"\\r\";\n break;\n\n case Y:\n case X:\n if (0 === h) d = d === C ? 0 : 0 === d ? C : d;\n break;\n\n case G:\n if (d + h + u === 0) o++;\n break;\n\n case H:\n if (d + h + u === 0) o--;\n break;\n\n case E:\n if (d + h + o === 0) u--;\n break;\n\n case D:\n if (d + h + o === 0) {\n if (0 === O) switch (2 * w + 3 * m) {\n case 533:\n break;\n\n default:\n y = 0, O = 1;\n }\n u++;\n }\n\n break;\n\n case L:\n if (h + u + d + o + z + j === 0) j = 1;\n break;\n\n case T:\n case Z:\n if (d + o + u > 0) break;\n\n switch (h) {\n case 0:\n switch (2 * C + 3 * s.charCodeAt(R + 1)) {\n case 235:\n h = Z;\n break;\n\n case 220:\n je = R, h = T;\n }\n\n break;\n\n case T:\n if (C === Z && w === T && je + 2 !== R) {\n if (33 === s.charCodeAt(je + 2)) Ve += s.substring(je, R + 1);\n Re = \"\", h = 0;\n }\n\n }\n\n }\n\n if (0 === h) {\n if (ge + d + o + j === 0 && t !== te && C !== W) switch (C) {\n case U:\n case ae:\n case _:\n case ee:\n case E:\n case D:\n if (0 === O) {\n switch (w) {\n case K:\n case M:\n case I:\n case J:\n Re += \"\\0\";\n break;\n\n default:\n Re = \"\\0\" + Re + (C === U ? \"\" : \"\\0\");\n }\n\n we = 1;\n } else switch (C) {\n case D:\n if (z + 7 === R && 108 === w) z = 0;\n O = ++y;\n break;\n\n case E:\n if (0 == (O = --y)) we = 1, Re += \"\\0\";\n }\n\n break;\n\n case K:\n case M:\n switch (w) {\n case re:\n case B:\n case q:\n case W:\n case U:\n case ce:\n case K:\n case M:\n case I:\n case J:\n break;\n\n default:\n if (0 === O) we = 1, Re += \"\\0\";\n }\n\n }\n if (Te += Re, C !== M && C !== K) $ = C;\n }\n\n }\n\n m = w, w = C, R++;\n }\n\n if (je = Ve.length, me > 0) if (0 === je && 0 === Xe.length && 0 === a[0].length == false) if (t !== ie || 1 === a.length && (ge > 0 ? Ee : Ge) === a[0]) je = a.join(\",\").length + 2;\n\n if (je > 0) {\n if (f = 0 === ge && t !== te ? function (e) {\n for (var a, r, s = 0, t = e.length, i = Array(t); s < t; ++s) {\n for (var f = e[s].split(l), n = \"\", o = 0, h = 0, u = 0, d = 0, b = f.length; o < b; ++o) {\n if (0 === (h = (r = f[o]).length) && b > 1) continue;\n if (u = n.charCodeAt(n.length - 1), d = r.charCodeAt(0), a = \"\", 0 !== o) switch (u) {\n case T:\n case ae:\n case _:\n case ee:\n case M:\n case D:\n break;\n\n default:\n a = \" \";\n }\n\n switch (d) {\n case P:\n r = a + Ee;\n\n case ae:\n case _:\n case ee:\n case M:\n case E:\n case D:\n break;\n\n case G:\n r = a + r + Ee;\n break;\n\n case V:\n switch (2 * r.charCodeAt(1) + 3 * r.charCodeAt(2)) {\n case 530:\n if (Ce > 0) {\n r = a + r.substring(8, h - 1);\n break;\n }\n\n default:\n if (o < 1 || f[o - 1].length < 1) r = a + Ee + r;\n }\n\n break;\n\n case U:\n a = \"\";\n\n default:\n if (h > 1 && r.indexOf(\":\") > 0) r = a + r.replace(v, \"$1\" + Ee + \"$2\");else r = a + r + Ee;\n }\n\n n += r;\n }\n\n i[s] = n.replace(c, \"\").trim();\n }\n\n return i;\n }(a) : a, ye > 0) if (void 0 !== (n = Pe(Fe, Ve, f, e, pe, be, je, t, i, t)) && 0 === (Ve = n).length) return Ye + Ve + Xe;\n\n if (Ve = f.join(\",\") + \"{\" + Ve + \"}\", Ae * ke != 0) {\n if (2 === Ae && !Le(Ve, 2)) ke = 0;\n\n switch (ke) {\n case le:\n Ve = Ve.replace(k, \":\" + S + \"$1\") + Ve;\n break;\n\n case ne:\n Ve = Ve.replace(p, \"::\" + N + \"input-$1\") + Ve.replace(p, \"::\" + S + \"$1\") + Ve.replace(p, \":\" + F + \"input-$1\") + Ve;\n }\n\n ke = 0;\n }\n }\n\n return Ye + Ve + Xe;\n }\n\n function Ie(e, a, r) {\n var c = a.trim().split(o),\n s = c,\n t = c.length,\n i = e.length;\n\n switch (i) {\n case 0:\n case 1:\n for (var f = 0, n = 0 === i ? \"\" : e[0] + \" \"; f < t; ++f) {\n s[f] = Je(n, s[f], r, i).trim();\n }\n\n break;\n\n default:\n f = 0;\n var l = 0;\n\n for (s = []; f < t; ++f) {\n for (var h = 0; h < i; ++h) {\n s[l++] = Je(e[h] + \" \", c[f], r, i).trim();\n }\n }\n\n }\n\n return s;\n }\n\n function Je(e, a, r, c) {\n var s = a,\n t = s.charCodeAt(0);\n if (t < 33) t = (s = s.trim()).charCodeAt(0);\n\n switch (t) {\n case P:\n switch (ge + c) {\n case 0:\n case 1:\n if (0 === e.trim().length) break;\n\n default:\n return s.replace(h, \"$1\" + e.trim());\n }\n\n break;\n\n case V:\n switch (s.charCodeAt(1)) {\n case 103:\n if (Ce > 0 && ge > 0) return s.replace(u, \"$1\").replace(h, \"$1\" + Ge);\n break;\n\n default:\n return e.trim() + s.replace(h, \"$1\" + e.trim());\n }\n\n default:\n if (r * ge > 0 && s.indexOf(\"\\f\") > 0) return s.replace(h, (e.charCodeAt(0) === V ? \"\" : \"$1\") + e.trim());\n }\n\n return e + s;\n }\n\n function Ke(e, a, r, c) {\n var l,\n o = 0,\n h = e + \";\",\n u = 2 * a + 3 * r + 4 * c;\n if (944 === u) return function (e) {\n var a = e.length,\n r = e.indexOf(\":\", 9) + 1,\n c = e.substring(0, r).trim(),\n s = e.substring(r, a - 1).trim();\n\n switch (e.charCodeAt(9) * Be) {\n case 0:\n break;\n\n case Q:\n if (110 !== e.charCodeAt(10)) break;\n\n default:\n for (var t = s.split((s = \"\", f)), i = 0, r = 0, a = t.length; i < a; r = 0, ++i) {\n for (var l = t[i], o = l.split(n); l = o[r];) {\n var h = l.charCodeAt(0);\n if (1 === Be && (h > L && h < 90 || h > 96 && h < 123 || h === R || h === Q && l.charCodeAt(1) !== Q)) switch (isNaN(parseFloat(l)) + (-1 !== l.indexOf(\"(\"))) {\n case 1:\n switch (l) {\n case \"infinite\":\n case \"alternate\":\n case \"backwards\":\n case \"running\":\n case \"normal\":\n case \"forwards\":\n case \"both\":\n case \"none\":\n case \"linear\":\n case \"ease\":\n case \"ease-in\":\n case \"ease-out\":\n case \"ease-in-out\":\n case \"paused\":\n case \"reverse\":\n case \"alternate-reverse\":\n case \"inherit\":\n case \"initial\":\n case \"unset\":\n case \"step-start\":\n case \"step-end\":\n break;\n\n default:\n l += De;\n }\n\n }\n o[r++] = l;\n }\n\n s += (0 === i ? \"\" : \",\") + o.join(\" \");\n }\n\n }\n\n if (s = c + s + \";\", 1 === Ae || 2 === Ae && Le(s, 1)) return N + s + s;\n return s;\n }(h);else if (0 === Ae || 2 === Ae && !Le(h, 1)) return h;\n\n switch (u) {\n case 1015:\n return 97 === h.charCodeAt(10) ? N + h + h : h;\n\n case 951:\n return 116 === h.charCodeAt(3) ? N + h + h : h;\n\n case 963:\n return 110 === h.charCodeAt(5) ? N + h + h : h;\n\n case 1009:\n if (100 !== h.charCodeAt(4)) break;\n\n case 969:\n case 942:\n return N + h + h;\n\n case 978:\n return N + h + S + h + h;\n\n case 1019:\n case 983:\n return N + h + S + h + F + h + h;\n\n case 883:\n if (h.charCodeAt(8) === Q) return N + h + h;\n if (h.indexOf(\"image-set(\", 11) > 0) return h.replace(z, \"$1\" + N + \"$2\") + h;\n return h;\n\n case 932:\n if (h.charCodeAt(4) === Q) switch (h.charCodeAt(5)) {\n case 103:\n return N + \"box-\" + h.replace(\"-grow\", \"\") + N + h + F + h.replace(\"grow\", \"positive\") + h;\n\n case 115:\n return N + h + F + h.replace(\"shrink\", \"negative\") + h;\n\n case 98:\n return N + h + F + h.replace(\"basis\", \"preferred-size\") + h;\n }\n return N + h + F + h + h;\n\n case 964:\n return N + h + F + \"flex-\" + h + h;\n\n case 1023:\n if (99 !== h.charCodeAt(8)) break;\n return l = h.substring(h.indexOf(\":\", 15)).replace(\"flex-\", \"\").replace(\"space-between\", \"justify\"), N + \"box-pack\" + l + N + h + F + \"flex-pack\" + l + h;\n\n case 1005:\n return t.test(h) ? h.replace(s, \":\" + N) + h.replace(s, \":\" + S) + h : h;\n\n case 1e3:\n switch (o = (l = h.substring(13).trim()).indexOf(\"-\") + 1, l.charCodeAt(0) + l.charCodeAt(o)) {\n case 226:\n l = h.replace(m, \"tb\");\n break;\n\n case 232:\n l = h.replace(m, \"tb-rl\");\n break;\n\n case 220:\n l = h.replace(m, \"lr\");\n break;\n\n default:\n return h;\n }\n\n return N + h + F + l + h;\n\n case 1017:\n if (-1 === h.indexOf(\"sticky\", 9)) return h;\n\n case 975:\n switch (o = (h = e).length - 10, u = (l = (33 === h.charCodeAt(o) ? h.substring(0, o) : h).substring(e.indexOf(\":\", 7) + 1).trim()).charCodeAt(0) + (0 | l.charCodeAt(7))) {\n case 203:\n if (l.charCodeAt(8) < 111) break;\n\n case 115:\n h = h.replace(l, N + l) + \";\" + h;\n break;\n\n case 207:\n case 102:\n h = h.replace(l, N + (u > 102 ? \"inline-\" : \"\") + \"box\") + \";\" + h.replace(l, N + l) + \";\" + h.replace(l, F + l + \"box\") + \";\" + h;\n }\n\n return h + \";\";\n\n case 938:\n if (h.charCodeAt(5) === Q) switch (h.charCodeAt(6)) {\n case 105:\n return l = h.replace(\"-items\", \"\"), N + h + N + \"box-\" + l + F + \"flex-\" + l + h;\n\n case 115:\n return N + h + F + \"flex-item-\" + h.replace(y, \"\") + h;\n\n default:\n return N + h + F + \"flex-line-pack\" + h.replace(\"align-content\", \"\").replace(y, \"\") + h;\n }\n break;\n\n case 973:\n case 989:\n if (h.charCodeAt(3) !== Q || 122 === h.charCodeAt(4)) break;\n\n case 931:\n case 953:\n if (true === j.test(e)) if (115 === (l = e.substring(e.indexOf(\":\") + 1)).charCodeAt(0)) return Ke(e.replace(\"stretch\", \"fill-available\"), a, r, c).replace(\":fill-available\", \":stretch\");else return h.replace(l, N + l) + h.replace(l, S + l.replace(\"fill-\", \"\")) + h;\n break;\n\n case 962:\n if (h = N + h + (102 === h.charCodeAt(5) ? F + h : \"\") + h, r + c === 211 && 105 === h.charCodeAt(13) && h.indexOf(\"transform\", 10) > 0) return h.substring(0, h.indexOf(\";\", 27) + 1).replace(i, \"$1\" + N + \"$2\") + h;\n }\n\n return h;\n }\n\n function Le(e, a) {\n var r = e.indexOf(1 === a ? \":\" : \"{\"),\n c = e.substring(0, 3 !== a ? r : 10),\n s = e.substring(r + 1, e.length - 1);\n return Oe(2 !== a ? c : c.replace(O, \"$1\"), s, a);\n }\n\n function Me(e, a) {\n var r = Ke(a, a.charCodeAt(0), a.charCodeAt(1), a.charCodeAt(2));\n return r !== a + \";\" ? r.replace($, \" or ($1)\").substring(4) : \"(\" + a + \")\";\n }\n\n function Pe(e, a, r, c, s, t, i, f, n, l) {\n for (var o, h = 0, u = a; h < ye; ++h) {\n switch (o = $e[h].call(Te, e, u, r, c, s, t, i, f, n, l)) {\n case void 0:\n case false:\n case true:\n case null:\n break;\n\n default:\n u = o;\n }\n }\n\n if (u !== a) return u;\n }\n\n function Qe(e, a, r, c) {\n for (var s = a + 1; s < r; ++s) {\n switch (c.charCodeAt(s)) {\n case Z:\n if (e === T) if (c.charCodeAt(s - 1) === T && a + 2 !== s) return s + 1;\n break;\n\n case I:\n if (e === Z) return s + 1;\n }\n }\n\n return s;\n }\n\n function Re(e) {\n for (var a in e) {\n var r = e[a];\n\n switch (a) {\n case \"keyframe\":\n Be = 0 | r;\n break;\n\n case \"global\":\n Ce = 0 | r;\n break;\n\n case \"cascade\":\n ge = 0 | r;\n break;\n\n case \"compress\":\n we = 0 | r;\n break;\n\n case \"semicolon\":\n ve = 0 | r;\n break;\n\n case \"preserve\":\n me = 0 | r;\n break;\n\n case \"prefix\":\n if (Oe = null, !r) Ae = 0;else if (\"function\" != typeof r) Ae = 1;else Ae = 2, Oe = r;\n }\n }\n\n return Re;\n }\n\n function Te(a, r) {\n if (void 0 !== this && this.constructor === Te) return e(a);\n var s = a,\n t = s.charCodeAt(0);\n if (t < 33) t = (s = s.trim()).charCodeAt(0);\n if (Be > 0) De = s.replace(d, t === G ? \"\" : \"-\");\n if (t = 1, 1 === ge) Ge = s;else Ee = s;\n var i,\n f = [Ge];\n if (ye > 0) if (void 0 !== (i = Pe(ze, r, f, f, pe, be, 0, 0, 0, 0)) && \"string\" == typeof i) r = i;\n var n = He(xe, f, r, 0, 0);\n if (ye > 0) if (void 0 !== (i = Pe(je, n, f, f, pe, be, n.length, 0, 0, 0)) && \"string\" != typeof (n = i)) t = 0;\n return De = \"\", Ge = \"\", Ee = \"\", ke = 0, pe = 1, be = 1, we * t == 0 ? n : n.replace(c, \"\").replace(g, \"\").replace(A, \"$1\").replace(C, \"$1\").replace(w, \" \");\n }\n\n if (Te.use = function e(a) {\n switch (a) {\n case void 0:\n case null:\n ye = $e.length = 0;\n break;\n\n default:\n if (\"function\" == typeof a) $e[ye++] = a;else if (\"object\" == typeof a) for (var r = 0, c = a.length; r < c; ++r) {\n e(a[r]);\n } else qe = 0 | !!a;\n }\n\n return e;\n }, Te.set = Re, void 0 !== a) Re(a);\n return Te;\n});","/* global Map:readonly, Set:readonly, ArrayBuffer:readonly */\nvar hasElementType = typeof Element !== 'undefined';\nvar hasMap = typeof Map === 'function';\nvar hasSet = typeof Set === 'function';\nvar hasArrayBuffer = typeof ArrayBuffer === 'function' && !!ArrayBuffer.isView; // Note: We **don't** need `envHasBigInt64Array` in fde es6/index.js\n\nfunction equal(a, b) {\n // START: fast-deep-equal es6/index.js 3.1.1\n if (a === b) return true;\n\n if (a && b && typeof a == 'object' && typeof b == 'object') {\n if (a.constructor !== b.constructor) return false;\n var length, i, keys;\n\n if (Array.isArray(a)) {\n length = a.length;\n if (length != b.length) return false;\n\n for (i = length; i-- !== 0;) {\n if (!equal(a[i], b[i])) return false;\n }\n\n return true;\n } // START: Modifications:\n // 1. Extra `has &&` helpers in initial condition allow es6 code\n // to co-exist with es5.\n // 2. Replace `for of` with es5 compliant iteration using `for`.\n // Basically, take:\n //\n // ```js\n // for (i of a.entries())\n // if (!b.has(i[0])) return false;\n // ```\n //\n // ... and convert to:\n //\n // ```js\n // it = a.entries();\n // while (!(i = it.next()).done)\n // if (!b.has(i.value[0])) return false;\n // ```\n //\n // **Note**: `i` access switches to `i.value`.\n\n\n var it;\n\n if (hasMap && a instanceof Map && b instanceof Map) {\n if (a.size !== b.size) return false;\n it = a.entries();\n\n while (!(i = it.next()).done) {\n if (!b.has(i.value[0])) return false;\n }\n\n it = a.entries();\n\n while (!(i = it.next()).done) {\n if (!equal(i.value[1], b.get(i.value[0]))) return false;\n }\n\n return true;\n }\n\n if (hasSet && a instanceof Set && b instanceof Set) {\n if (a.size !== b.size) return false;\n it = a.entries();\n\n while (!(i = it.next()).done) {\n if (!b.has(i.value[0])) return false;\n }\n\n return true;\n } // END: Modifications\n\n\n if (hasArrayBuffer && ArrayBuffer.isView(a) && ArrayBuffer.isView(b)) {\n length = a.length;\n if (length != b.length) return false;\n\n for (i = length; i-- !== 0;) {\n if (a[i] !== b[i]) return false;\n }\n\n return true;\n }\n\n if (a.constructor === RegExp) return a.source === b.source && a.flags === b.flags;\n if (a.valueOf !== Object.prototype.valueOf) return a.valueOf() === b.valueOf();\n if (a.toString !== Object.prototype.toString) return a.toString() === b.toString();\n keys = Object.keys(a);\n length = keys.length;\n if (length !== Object.keys(b).length) return false;\n\n for (i = length; i-- !== 0;) {\n if (!Object.prototype.hasOwnProperty.call(b, keys[i])) return false;\n } // END: fast-deep-equal\n // START: react-fast-compare\n // custom handling for DOM elements\n\n\n if (hasElementType && a instanceof Element) return false; // custom handling for React/Preact\n\n for (i = length; i-- !== 0;) {\n if ((keys[i] === '_owner' || keys[i] === '__v' || keys[i] === '__o') && a.$$typeof) {\n // React-specific: avoid traversing React elements' _owner\n // Preact-specific: avoid traversing Preact elements' __v and __o\n // __v = $_original / $_vnode\n // __o = $_owner\n // These properties contain circular references and are not needed when\n // comparing the actual elements (and not their owners)\n // .$$typeof and ._store on just reasonable markers of elements\n continue;\n } // all other properties should be traversed as usual\n\n\n if (!equal(a[keys[i]], b[keys[i]])) return false;\n } // END: react-fast-compare\n // START: fast-deep-equal\n\n\n return true;\n }\n\n return a !== a && b !== b;\n} // end fast-deep-equal\n\n\nmodule.exports = function isEqual(a, b) {\n try {\n return equal(a, b);\n } catch (error) {\n if ((error.message || '').match(/stack|recursion/i)) {\n // warn on circular references, don't crash\n // browsers give this different errors name and messages:\n // chrome/safari: \"RangeError\", \"Maximum call stack size exceeded\"\n // firefox: \"InternalError\", too much recursion\"\n // edge: \"Error\", \"Out of stack space\"\n console.warn('react-fast-compare cannot handle circular refs');\n return false;\n } // some other error. we should definitely know about these\n\n\n throw error;\n }\n};","module.exports = __webpack_public_path__ + \"static/SFMono-Semibold-2d4bff46a7a9ba9dc7701f75726a7815.woff\";","import React from 'react';\n\nconst IconAppStore = () => (\n \n);\n\nexport default IconAppStore;\n","import React from 'react';\n\nconst IconCodepen = () => (\n\n);\n\nexport default IconCodepen;\n","import React from 'react';\n\nconst IconExternal = () => (\n \n);\n\nexport default IconExternal;\n","import React from 'react';\n\nconst IconFolder = () => (\n \n);\n\nexport default IconFolder;\n","import React from 'react';\n\nconst IconFork = () => (\n \n);\n\nexport default IconFork;\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport {\n IconAppStore,\n IconCodepen,\n IconExternal,\n IconFolder,\n IconFork,\n IconGitHub,\n IconInstagram,\n IconLinkedin,\n IconLoader,\n IconLogo,\n IconPlayStore,\n IconStar,\n IconTwitter,\n IconZap,\n} from '@components/icons';\n\nconst Icon = ({ name }) => {\n switch (name) {\n case 'AppStore':\n return ;\n case 'Codepen':\n return ;\n case 'External':\n return ;\n case 'Folder':\n return ;\n case 'Fork':\n return ;\n case 'GitHub':\n return ;\n case 'Instagram':\n return ;\n case 'Linkedin':\n return ;\n case 'Loader':\n return ;\n case 'Logo':\n return ;\n case 'PlayStore':\n return ;\n case 'Star':\n return ;\n case 'Twitter':\n return ;\n case 'Zap':\n return ;\n default:\n return ;\n }\n};\n\nIcon.propTypes = {\n name: PropTypes.string.isRequired,\n};\n\nexport default Icon;\n","import React from 'react';\n\nconst IconGitHub = () => (\n \n);\n\nexport default IconGitHub;\n","import React from 'react';\n\nconst IconInstagram = () => (\n \n);\n\nexport default IconInstagram;\n","import React from 'react';\n\nconst IconLinkedin = () => (\n \n);\n\nexport default IconLinkedin;\n","import React from 'react';\n\nconst IconLoader = () => (\n \n);\n\nexport default IconLoader;\n","import React from 'react';\n\nconst IconLogo = () => (\n \n);\n\nexport default IconLogo;\n","import React from 'react';\n\nconst IconPlayStore = () => (\n \n);\n\nexport default IconPlayStore;\n","import React from 'react';\n\nconst IconStar = () => (\n \n);\n\nexport default IconStar;\n","import React from 'react';\n\nconst IconTwitter = () => (\n \n);\n\nexport default IconTwitter;\n","import React from 'react';\n// I use zap icon for steam icon, so don't try to change IconZap name, and SVG\nconst IconZap = () => (\n \n);\n\nexport default IconZap;\n","module.exports = __webpack_public_path__ + \"static/SFMono-SemiboldItalic-2fd68bed64aeaceadc6402efc4d82767.woff2\";","module.exports = __webpack_public_path__ + \"static/Calibre-SemiboldItalic-8f3e4b3eaed73e67bbc4fc81f308a35f.woff2\";","module.exports = __webpack_public_path__ + \"static/Calibre-Medium-115d37180a9c07e2f480ca81b032babe.woff\";","module.exports = __webpack_public_path__ + \"static/Calibre-MediumItalic-4afe8032c647b57de924543c052e0ee4.woff\";","/*! @license is-dom-node v1.0.4\n\n\tCopyright 2018 Fisssion LLC.\n\n\tPermission is hereby granted, free of charge, to any person obtaining a copy\n\tof this software and associated documentation files (the \"Software\"), to deal\n\tin the Software without restriction, including without limitation the rights\n\tto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n\tcopies of the Software, and to permit persons to whom the Software is\n\tfurnished to do so, subject to the following conditions:\n\n\tThe above copyright notice and this permission notice shall be included in all\n\tcopies or substantial portions of the Software.\n\n\tTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n\tIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n\tFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n\tAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n\tLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n\tOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n\tSOFTWARE.\n\n*/\nfunction isDomNode(x) {\n return typeof window.Node === 'object' ? x instanceof window.Node : x !== null && typeof x === 'object' && typeof x.nodeType === 'number' && typeof x.nodeName === 'string';\n}\n\nexport default isDomNode;","/*! @license is-dom-node-list v1.2.1\n\n\tCopyright 2018 Fisssion LLC.\n\n\tPermission is hereby granted, free of charge, to any person obtaining a copy\n\tof this software and associated documentation files (the \"Software\"), to deal\n\tin the Software without restriction, including without limitation the rights\n\tto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n\tcopies of the Software, and to permit persons to whom the Software is\n\tfurnished to do so, subject to the following conditions:\n\n\tThe above copyright notice and this permission notice shall be included in all\n\tcopies or substantial portions of the Software.\n\n\tTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n\tIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n\tFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n\tAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n\tLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n\tOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n\tSOFTWARE.\n\n*/\nimport isDomNode from 'is-dom-node';\n\nfunction isDomNodeList(x) {\n var prototypeToString = Object.prototype.toString.call(x);\n var regex = /^\\[object (HTMLCollection|NodeList|Object)\\]$/;\n return typeof window.NodeList === 'object' ? x instanceof window.NodeList : x !== null && typeof x === 'object' && typeof x.length === 'number' && regex.test(prototypeToString) && (x.length === 0 || isDomNode(x[0]));\n}\n\nexport default isDomNodeList;","/*! @license Tealight v0.3.6\n\n\tCopyright 2018 Fisssion LLC.\n\n\tPermission is hereby granted, free of charge, to any person obtaining a copy\n\tof this software and associated documentation files (the \"Software\"), to deal\n\tin the Software without restriction, including without limitation the rights\n\tto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n\tcopies of the Software, and to permit persons to whom the Software is\n\tfurnished to do so, subject to the following conditions:\n\n\tThe above copyright notice and this permission notice shall be included in all\n\tcopies or substantial portions of the Software.\n\n\tTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n\tIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n\tFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n\tAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n\tLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n\tOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n\tSOFTWARE.\n\n*/\nimport isDomNode from 'is-dom-node';\nimport isDomNodeList from 'is-dom-node-list';\n\nfunction tealight(target, context) {\n if (context === void 0) context = document;\n\n if (target instanceof Array) {\n return target.filter(isDomNode);\n }\n\n if (isDomNode(target)) {\n return [target];\n }\n\n if (isDomNodeList(target)) {\n return Array.prototype.slice.call(target);\n }\n\n if (typeof target === \"string\") {\n try {\n var query = context.querySelectorAll(target);\n return Array.prototype.slice.call(query);\n } catch (err) {\n return [];\n }\n }\n\n return [];\n}\n\nexport default tealight;","/*! @license Rematrix v0.3.0\n\n\tCopyright 2018 Julian Lloyd.\n\n\tPermission is hereby granted, free of charge, to any person obtaining a copy\n\tof this software and associated documentation files (the \"Software\"), to deal\n\tin the Software without restriction, including without limitation the rights\n\tto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n\tcopies of the Software, and to permit persons to whom the Software is\n\tfurnished to do so, subject to the following conditions:\n\n\tThe above copyright notice and this permission notice shall be included in\n\tall copies or substantial portions of the Software.\n\n\tTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n\tIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n\tFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n\tAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n\tLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n\tOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n\tTHE SOFTWARE.\n*/\n\n/**\n * @module Rematrix\n */\n\n/**\n * Transformation matrices in the browser come in two flavors:\n *\n * - `matrix` using 6 values (short)\n * - `matrix3d` using 16 values (long)\n *\n * This utility follows this [conversion guide](https://goo.gl/EJlUQ1)\n * to expand short form matrices to their equivalent long form.\n *\n * @param {array} source - Accepts both short and long form matrices.\n * @return {array}\n */\nfunction format(source) {\n if (source.constructor !== Array) {\n throw new TypeError('Expected array.');\n }\n\n if (source.length === 16) {\n return source;\n }\n\n if (source.length === 6) {\n var matrix = identity();\n matrix[0] = source[0];\n matrix[1] = source[1];\n matrix[4] = source[2];\n matrix[5] = source[3];\n matrix[12] = source[4];\n matrix[13] = source[5];\n return matrix;\n }\n\n throw new RangeError('Expected array with either 6 or 16 values.');\n}\n/**\n * Returns a matrix representing no transformation. The product of any matrix\n * multiplied by the identity matrix will be the original matrix.\n *\n * > **Tip:** Similar to how `5 * 1 === 5`, where `1` is the identity.\n *\n * @return {array}\n */\n\n\nfunction identity() {\n var matrix = [];\n\n for (var i = 0; i < 16; i++) {\n i % 5 == 0 ? matrix.push(1) : matrix.push(0);\n }\n\n return matrix;\n}\n/**\n * Returns a matrix describing the inverse transformation of the source\n * matrix. The product of any matrix multiplied by its inverse will be the\n * identity matrix.\n *\n * > **Tip:** Similar to how `5 * (1/5) === 1`, where `1/5` is the inverse.\n *\n * @param {array} source - Accepts both short and long form matrices.\n * @return {array}\n */\n\n\nfunction inverse(source) {\n var m = format(source);\n var s0 = m[0] * m[5] - m[4] * m[1];\n var s1 = m[0] * m[6] - m[4] * m[2];\n var s2 = m[0] * m[7] - m[4] * m[3];\n var s3 = m[1] * m[6] - m[5] * m[2];\n var s4 = m[1] * m[7] - m[5] * m[3];\n var s5 = m[2] * m[7] - m[6] * m[3];\n var c5 = m[10] * m[15] - m[14] * m[11];\n var c4 = m[9] * m[15] - m[13] * m[11];\n var c3 = m[9] * m[14] - m[13] * m[10];\n var c2 = m[8] * m[15] - m[12] * m[11];\n var c1 = m[8] * m[14] - m[12] * m[10];\n var c0 = m[8] * m[13] - m[12] * m[9];\n var determinant = 1 / (s0 * c5 - s1 * c4 + s2 * c3 + s3 * c2 - s4 * c1 + s5 * c0);\n\n if (isNaN(determinant) || determinant === Infinity) {\n throw new Error('Inverse determinant attempted to divide by zero.');\n }\n\n return [(m[5] * c5 - m[6] * c4 + m[7] * c3) * determinant, (-m[1] * c5 + m[2] * c4 - m[3] * c3) * determinant, (m[13] * s5 - m[14] * s4 + m[15] * s3) * determinant, (-m[9] * s5 + m[10] * s4 - m[11] * s3) * determinant, (-m[4] * c5 + m[6] * c2 - m[7] * c1) * determinant, (m[0] * c5 - m[2] * c2 + m[3] * c1) * determinant, (-m[12] * s5 + m[14] * s2 - m[15] * s1) * determinant, (m[8] * s5 - m[10] * s2 + m[11] * s1) * determinant, (m[4] * c4 - m[5] * c2 + m[7] * c0) * determinant, (-m[0] * c4 + m[1] * c2 - m[3] * c0) * determinant, (m[12] * s4 - m[13] * s2 + m[15] * s0) * determinant, (-m[8] * s4 + m[9] * s2 - m[11] * s0) * determinant, (-m[4] * c3 + m[5] * c1 - m[6] * c0) * determinant, (m[0] * c3 - m[1] * c1 + m[2] * c0) * determinant, (-m[12] * s3 + m[13] * s1 - m[14] * s0) * determinant, (m[8] * s3 - m[9] * s1 + m[10] * s0) * determinant];\n}\n/**\n * Returns a 4x4 matrix describing the combined transformations\n * of both arguments.\n *\n * > **Note:** Order is very important. For example, rotating 45°\n * along the Z-axis, followed by translating 500 pixels along the\n * Y-axis... is not the same as translating 500 pixels along the\n * Y-axis, followed by rotating 45° along on the Z-axis.\n *\n * @param {array} m - Accepts both short and long form matrices.\n * @param {array} x - Accepts both short and long form matrices.\n * @return {array}\n */\n\n\nfunction multiply(m, x) {\n var fm = format(m);\n var fx = format(x);\n var product = [];\n\n for (var i = 0; i < 4; i++) {\n var row = [fm[i], fm[i + 4], fm[i + 8], fm[i + 12]];\n\n for (var j = 0; j < 4; j++) {\n var k = j * 4;\n var col = [fx[k], fx[k + 1], fx[k + 2], fx[k + 3]];\n var result = row[0] * col[0] + row[1] * col[1] + row[2] * col[2] + row[3] * col[3];\n product[i + k] = result;\n }\n }\n\n return product;\n}\n/**\n * Attempts to return a 4x4 matrix describing the CSS transform\n * matrix passed in, but will return the identity matrix as a\n * fallback.\n *\n * > **Tip:** This method is used to convert a CSS matrix (retrieved as a\n * `string` from computed styles) to its equivalent array format.\n *\n * @param {string} source - `matrix` or `matrix3d` CSS Transform value.\n * @return {array}\n */\n\n\nfunction parse(source) {\n if (typeof source === 'string') {\n var match = source.match(/matrix(3d)?\\(([^)]+)\\)/);\n\n if (match) {\n var raw = match[2].split(', ').map(parseFloat);\n return format(raw);\n }\n }\n\n return identity();\n}\n/**\n * Returns a 4x4 matrix describing Z-axis rotation.\n *\n * > **Tip:** This is just an alias for `Rematrix.rotateZ` for parity with CSS\n *\n * @param {number} angle - Measured in degrees.\n * @return {array}\n */\n\n\nfunction rotate(angle) {\n return rotateZ(angle);\n}\n/**\n * Returns a 4x4 matrix describing X-axis rotation.\n *\n * @param {number} angle - Measured in degrees.\n * @return {array}\n */\n\n\nfunction rotateX(angle) {\n var theta = Math.PI / 180 * angle;\n var matrix = identity();\n matrix[5] = matrix[10] = Math.cos(theta);\n matrix[6] = matrix[9] = Math.sin(theta);\n matrix[9] *= -1;\n return matrix;\n}\n/**\n * Returns a 4x4 matrix describing Y-axis rotation.\n *\n * @param {number} angle - Measured in degrees.\n * @return {array}\n */\n\n\nfunction rotateY(angle) {\n var theta = Math.PI / 180 * angle;\n var matrix = identity();\n matrix[0] = matrix[10] = Math.cos(theta);\n matrix[2] = matrix[8] = Math.sin(theta);\n matrix[2] *= -1;\n return matrix;\n}\n/**\n * Returns a 4x4 matrix describing Z-axis rotation.\n *\n * @param {number} angle - Measured in degrees.\n * @return {array}\n */\n\n\nfunction rotateZ(angle) {\n var theta = Math.PI / 180 * angle;\n var matrix = identity();\n matrix[0] = matrix[5] = Math.cos(theta);\n matrix[1] = matrix[4] = Math.sin(theta);\n matrix[4] *= -1;\n return matrix;\n}\n/**\n * Returns a 4x4 matrix describing 2D scaling. The first argument\n * is used for both X and Y-axis scaling, unless an optional\n * second argument is provided to explicitly define Y-axis scaling.\n *\n * @param {number} scalar - Decimal multiplier.\n * @param {number} [scalarY] - Decimal multiplier.\n * @return {array}\n */\n\n\nfunction scale(scalar, scalarY) {\n var matrix = identity();\n matrix[0] = scalar;\n matrix[5] = typeof scalarY === 'number' ? scalarY : scalar;\n return matrix;\n}\n/**\n * Returns a 4x4 matrix describing X-axis scaling.\n *\n * @param {number} scalar - Decimal multiplier.\n * @return {array}\n */\n\n\nfunction scaleX(scalar) {\n var matrix = identity();\n matrix[0] = scalar;\n return matrix;\n}\n/**\n * Returns a 4x4 matrix describing Y-axis scaling.\n *\n * @param {number} scalar - Decimal multiplier.\n * @return {array}\n */\n\n\nfunction scaleY(scalar) {\n var matrix = identity();\n matrix[5] = scalar;\n return matrix;\n}\n/**\n * Returns a 4x4 matrix describing Z-axis scaling.\n *\n * @param {number} scalar - Decimal multiplier.\n * @return {array}\n */\n\n\nfunction scaleZ(scalar) {\n var matrix = identity();\n matrix[10] = scalar;\n return matrix;\n}\n/**\n * Returns a 4x4 matrix describing shear. The first argument\n * defines X-axis shearing, and an optional second argument\n * defines Y-axis shearing.\n *\n * @param {number} angleX - Measured in degrees.\n * @param {number} [angleY] - Measured in degrees.\n * @return {array}\n */\n\n\nfunction skew(angleX, angleY) {\n var thetaX = Math.PI / 180 * angleX;\n var matrix = identity();\n matrix[4] = Math.tan(thetaX);\n\n if (angleY) {\n var thetaY = Math.PI / 180 * angleY;\n matrix[1] = Math.tan(thetaY);\n }\n\n return matrix;\n}\n/**\n * Returns a 4x4 matrix describing X-axis shear.\n *\n * @param {number} angle - Measured in degrees.\n * @return {array}\n */\n\n\nfunction skewX(angle) {\n var theta = Math.PI / 180 * angle;\n var matrix = identity();\n matrix[4] = Math.tan(theta);\n return matrix;\n}\n/**\n * Returns a 4x4 matrix describing Y-axis shear.\n *\n * @param {number} angle - Measured in degrees\n * @return {array}\n */\n\n\nfunction skewY(angle) {\n var theta = Math.PI / 180 * angle;\n var matrix = identity();\n matrix[1] = Math.tan(theta);\n return matrix;\n}\n/**\n * Returns a CSS Transform property value equivalent to the source matrix.\n *\n * @param {array} source - Accepts both short and long form matrices.\n * @return {string}\n */\n\n\nfunction toString(source) {\n return \"matrix3d(\" + format(source).join(', ') + \")\";\n}\n/**\n * Returns a 4x4 matrix describing 2D translation. The first\n * argument defines X-axis translation, and an optional second\n * argument defines Y-axis translation.\n *\n * @param {number} distanceX - Measured in pixels.\n * @param {number} [distanceY] - Measured in pixels.\n * @return {array}\n */\n\n\nfunction translate(distanceX, distanceY) {\n var matrix = identity();\n matrix[12] = distanceX;\n\n if (distanceY) {\n matrix[13] = distanceY;\n }\n\n return matrix;\n}\n/**\n * Returns a 4x4 matrix describing X-axis translation.\n *\n * @param {number} distance - Measured in pixels.\n * @return {array}\n */\n\n\nfunction translateX(distance) {\n var matrix = identity();\n matrix[12] = distance;\n return matrix;\n}\n/**\n * Returns a 4x4 matrix describing Y-axis translation.\n *\n * @param {number} distance - Measured in pixels.\n * @return {array}\n */\n\n\nfunction translateY(distance) {\n var matrix = identity();\n matrix[13] = distance;\n return matrix;\n}\n/**\n * Returns a 4x4 matrix describing Z-axis translation.\n *\n * @param {number} distance - Measured in pixels.\n * @return {array}\n */\n\n\nfunction translateZ(distance) {\n var matrix = identity();\n matrix[14] = distance;\n return matrix;\n}\n\nexport { format, identity, inverse, multiply, parse, rotate, rotateX, rotateY, rotateZ, scale, scaleX, scaleY, scaleZ, skew, skewX, skewY, toString, translate, translateX, translateY, translateZ };","/*! @license miniraf v1.0.0\n\n\tCopyright 2018 Fisssion LLC.\n\n\tPermission is hereby granted, free of charge, to any person obtaining a copy\n\tof this software and associated documentation files (the \"Software\"), to deal\n\tin the Software without restriction, including without limitation the rights\n\tto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n\tcopies of the Software, and to permit persons to whom the Software is\n\tfurnished to do so, subject to the following conditions:\n\n\tThe above copyright notice and this permission notice shall be included in all\n\tcopies or substantial portions of the Software.\n\n\tTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n\tIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n\tFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n\tAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n\tLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n\tOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n\tSOFTWARE.\n\n*/\nvar polyfill = function () {\n var clock = Date.now();\n return function (callback) {\n var currentTime = Date.now();\n\n if (currentTime - clock > 16) {\n clock = currentTime;\n callback(currentTime);\n } else {\n setTimeout(function () {\n return polyfill(callback);\n }, 0);\n }\n };\n}();\n\nvar index = window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || polyfill;\nexport default index;","import \"core-js/modules/es.array.reduce.js\";\n\n/*! @license ScrollReveal v4.0.9\n\n\tCopyright 2021 Fisssion LLC.\n\n\tLicensed under the GNU General Public License 3.0 for\n\tcompatible open source projects and non-commercial use.\n\n\tFor commercial sites, themes, projects, and applications,\n\tkeep your source code private/proprietary by purchasing\n\ta commercial license from https://scrollrevealjs.org/\n*/\nimport $ from 'tealight';\nimport { translateY, translateX, rotateX, rotateY, rotateZ, scale, parse, multiply } from 'rematrix';\nimport raf from 'miniraf';\nvar defaults = {\n delay: 0,\n distance: '0',\n duration: 600,\n easing: 'cubic-bezier(0.5, 0, 0, 1)',\n interval: 0,\n opacity: 0,\n origin: 'bottom',\n rotate: {\n x: 0,\n y: 0,\n z: 0\n },\n scale: 1,\n cleanup: false,\n container: document.documentElement,\n desktop: true,\n mobile: true,\n reset: false,\n useDelay: 'always',\n viewFactor: 0.0,\n viewOffset: {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n },\n afterReset: function afterReset() {},\n afterReveal: function afterReveal() {},\n beforeReset: function beforeReset() {},\n beforeReveal: function beforeReveal() {}\n};\n\nfunction failure() {\n document.documentElement.classList.remove('sr');\n return {\n clean: function clean() {},\n destroy: function destroy() {},\n reveal: function reveal() {},\n sync: function sync() {},\n\n get noop() {\n return true;\n }\n\n };\n}\n\nfunction success() {\n document.documentElement.classList.add('sr');\n\n if (document.body) {\n document.body.style.height = '100%';\n } else {\n document.addEventListener('DOMContentLoaded', function () {\n document.body.style.height = '100%';\n });\n }\n}\n\nvar mount = {\n success: success,\n failure: failure\n};\n\nfunction isObject(x) {\n return x !== null && x instanceof Object && (x.constructor === Object || Object.prototype.toString.call(x) === '[object Object]');\n}\n\nfunction each(collection, callback) {\n if (isObject(collection)) {\n var keys = Object.keys(collection);\n return keys.forEach(function (key) {\n return callback(collection[key], key, collection);\n });\n }\n\n if (collection instanceof Array) {\n return collection.forEach(function (item, i) {\n return callback(item, i, collection);\n });\n }\n\n throw new TypeError('Expected either an array or object literal.');\n}\n\nfunction logger(message) {\n var details = [],\n len = arguments.length - 1;\n\n while (len-- > 0) {\n details[len] = arguments[len + 1];\n }\n\n if (this.constructor.debug && console) {\n var report = \"%cScrollReveal: \" + message;\n details.forEach(function (detail) {\n return report += \"\\n — \" + detail;\n });\n console.log(report, 'color: #ea654b;'); // eslint-disable-line no-console\n }\n}\n\nfunction rinse() {\n var this$1 = this;\n\n var struct = function struct() {\n return {\n active: [],\n stale: []\n };\n };\n\n var elementIds = struct();\n var sequenceIds = struct();\n var containerIds = struct();\n /**\n * Take stock of active element IDs.\n */\n\n try {\n each($('[data-sr-id]'), function (node) {\n var id = parseInt(node.getAttribute('data-sr-id'));\n elementIds.active.push(id);\n });\n } catch (e) {\n throw e;\n }\n /**\n * Destroy stale elements.\n */\n\n\n each(this.store.elements, function (element) {\n if (elementIds.active.indexOf(element.id) === -1) {\n elementIds.stale.push(element.id);\n }\n });\n each(elementIds.stale, function (staleId) {\n return delete this$1.store.elements[staleId];\n });\n /**\n * Take stock of active container and sequence IDs.\n */\n\n each(this.store.elements, function (element) {\n if (containerIds.active.indexOf(element.containerId) === -1) {\n containerIds.active.push(element.containerId);\n }\n\n if (element.hasOwnProperty('sequence')) {\n if (sequenceIds.active.indexOf(element.sequence.id) === -1) {\n sequenceIds.active.push(element.sequence.id);\n }\n }\n });\n /**\n * Destroy stale containers.\n */\n\n each(this.store.containers, function (container) {\n if (containerIds.active.indexOf(container.id) === -1) {\n containerIds.stale.push(container.id);\n }\n });\n each(containerIds.stale, function (staleId) {\n var stale = this$1.store.containers[staleId].node;\n stale.removeEventListener('scroll', this$1.delegate);\n stale.removeEventListener('resize', this$1.delegate);\n delete this$1.store.containers[staleId];\n });\n /**\n * Destroy stale sequences.\n */\n\n each(this.store.sequences, function (sequence) {\n if (sequenceIds.active.indexOf(sequence.id) === -1) {\n sequenceIds.stale.push(sequence.id);\n }\n });\n each(sequenceIds.stale, function (staleId) {\n return delete this$1.store.sequences[staleId];\n });\n}\n\nvar getPrefixedCssProp = function () {\n var properties = {};\n var style = document.documentElement.style;\n\n function getPrefixedCssProperty(name, source) {\n if (source === void 0) source = style;\n\n if (name && typeof name === 'string') {\n if (properties[name]) {\n return properties[name];\n }\n\n if (typeof source[name] === 'string') {\n return properties[name] = name;\n }\n\n if (typeof source[\"-webkit-\" + name] === 'string') {\n return properties[name] = \"-webkit-\" + name;\n }\n\n throw new RangeError(\"Unable to find \\\"\" + name + \"\\\" style property.\");\n }\n\n throw new TypeError('Expected a string.');\n }\n\n getPrefixedCssProperty.clearCache = function () {\n return properties = {};\n };\n\n return getPrefixedCssProperty;\n}();\n\nfunction style(element) {\n var computed = window.getComputedStyle(element.node);\n var position = computed.position;\n var config = element.config;\n /**\n * Generate inline styles\n */\n\n var inline = {};\n var inlineStyle = element.node.getAttribute('style') || '';\n var inlineMatch = inlineStyle.match(/[\\w-]+\\s*:\\s*[^;]+\\s*/gi) || [];\n inline.computed = inlineMatch ? inlineMatch.map(function (m) {\n return m.trim();\n }).join('; ') + ';' : '';\n inline.generated = inlineMatch.some(function (m) {\n return m.match(/visibility\\s?:\\s?visible/i);\n }) ? inline.computed : inlineMatch.concat(['visibility: visible']).map(function (m) {\n return m.trim();\n }).join('; ') + ';';\n /**\n * Generate opacity styles\n */\n\n var computedOpacity = parseFloat(computed.opacity);\n var configOpacity = !isNaN(parseFloat(config.opacity)) ? parseFloat(config.opacity) : parseFloat(computed.opacity);\n var opacity = {\n computed: computedOpacity !== configOpacity ? \"opacity: \" + computedOpacity + \";\" : '',\n generated: computedOpacity !== configOpacity ? \"opacity: \" + configOpacity + \";\" : ''\n };\n /**\n * Generate transformation styles\n */\n\n var transformations = [];\n\n if (parseFloat(config.distance)) {\n var axis = config.origin === 'top' || config.origin === 'bottom' ? 'Y' : 'X';\n /**\n * Let’s make sure our our pixel distances are negative for top and left.\n * e.g. { origin: 'top', distance: '25px' } starts at `top: -25px` in CSS.\n */\n\n var distance = config.distance;\n\n if (config.origin === 'top' || config.origin === 'left') {\n distance = /^-/.test(distance) ? distance.substr(1) : \"-\" + distance;\n }\n\n var ref = distance.match(/(^-?\\d+\\.?\\d?)|(em$|px$|%$)/g);\n var value = ref[0];\n var unit = ref[1];\n\n switch (unit) {\n case 'em':\n distance = parseInt(computed.fontSize) * value;\n break;\n\n case 'px':\n distance = value;\n break;\n\n case '%':\n /**\n * Here we use `getBoundingClientRect` instead of\n * the existing data attached to `element.geometry`\n * because only the former includes any transformations\n * current applied to the element.\n *\n * If that behavior ends up being unintuitive, this\n * logic could instead utilize `element.geometry.height`\n * and `element.geoemetry.width` for the distance calculation\n */\n distance = axis === 'Y' ? element.node.getBoundingClientRect().height * value / 100 : element.node.getBoundingClientRect().width * value / 100;\n break;\n\n default:\n throw new RangeError('Unrecognized or missing distance unit.');\n }\n\n if (axis === 'Y') {\n transformations.push(translateY(distance));\n } else {\n transformations.push(translateX(distance));\n }\n }\n\n if (config.rotate.x) {\n transformations.push(rotateX(config.rotate.x));\n }\n\n if (config.rotate.y) {\n transformations.push(rotateY(config.rotate.y));\n }\n\n if (config.rotate.z) {\n transformations.push(rotateZ(config.rotate.z));\n }\n\n if (config.scale !== 1) {\n if (config.scale === 0) {\n /**\n * The CSS Transforms matrix interpolation specification\n * basically disallows transitions of non-invertible\n * matrixes, which means browsers won't transition\n * elements with zero scale.\n *\n * That’s inconvenient for the API and developer\n * experience, so we simply nudge their value\n * slightly above zero; this allows browsers\n * to transition our element as expected.\n *\n * `0.0002` was the smallest number\n * that performed across browsers.\n */\n transformations.push(scale(0.0002));\n } else {\n transformations.push(scale(config.scale));\n }\n }\n\n var transform = {};\n\n if (transformations.length) {\n transform.property = getPrefixedCssProp('transform');\n /**\n * The default computed transform value should be one of:\n * undefined || 'none' || 'matrix()' || 'matrix3d()'\n */\n\n transform.computed = {\n raw: computed[transform.property],\n matrix: parse(computed[transform.property])\n };\n transformations.unshift(transform.computed.matrix);\n var product = transformations.reduce(multiply);\n transform.generated = {\n initial: transform.property + \": matrix3d(\" + product.join(', ') + \");\",\n final: transform.property + \": matrix3d(\" + transform.computed.matrix.join(', ') + \");\"\n };\n } else {\n transform.generated = {\n initial: '',\n final: ''\n };\n }\n /**\n * Generate transition styles\n */\n\n\n var transition = {};\n\n if (opacity.generated || transform.generated.initial) {\n transition.property = getPrefixedCssProp('transition');\n transition.computed = computed[transition.property];\n transition.fragments = [];\n var delay = config.delay;\n var duration = config.duration;\n var easing = config.easing;\n\n if (opacity.generated) {\n transition.fragments.push({\n delayed: \"opacity \" + duration / 1000 + \"s \" + easing + \" \" + delay / 1000 + \"s\",\n instant: \"opacity \" + duration / 1000 + \"s \" + easing + \" 0s\"\n });\n }\n\n if (transform.generated.initial) {\n transition.fragments.push({\n delayed: transform.property + \" \" + duration / 1000 + \"s \" + easing + \" \" + delay / 1000 + \"s\",\n instant: transform.property + \" \" + duration / 1000 + \"s \" + easing + \" 0s\"\n });\n }\n /**\n * The default computed transition property should be undefined, or one of:\n * '' || 'none 0s ease 0s' || 'all 0s ease 0s' || 'all 0s 0s cubic-bezier()'\n */\n\n\n var hasCustomTransition = transition.computed && !transition.computed.match(/all 0s|none 0s/);\n\n if (hasCustomTransition) {\n transition.fragments.unshift({\n delayed: transition.computed,\n instant: transition.computed\n });\n }\n\n var composed = transition.fragments.reduce(function (composition, fragment, i) {\n composition.delayed += i === 0 ? fragment.delayed : \", \" + fragment.delayed;\n composition.instant += i === 0 ? fragment.instant : \", \" + fragment.instant;\n return composition;\n }, {\n delayed: '',\n instant: ''\n });\n transition.generated = {\n delayed: transition.property + \": \" + composed.delayed + \";\",\n instant: transition.property + \": \" + composed.instant + \";\"\n };\n } else {\n transition.generated = {\n delayed: '',\n instant: ''\n };\n }\n\n return {\n inline: inline,\n opacity: opacity,\n position: position,\n transform: transform,\n transition: transition\n };\n}\n/**\n * apply a CSS string to an element using the CSSOM (element.style) rather\n * than setAttribute, which may violate the content security policy.\n *\n * @param {Node} [el] Element to receive styles.\n * @param {string} [declaration] Styles to apply.\n */\n\n\nfunction applyStyle(el, declaration) {\n declaration.split(';').forEach(function (pair) {\n var ref = pair.split(':');\n var property = ref[0];\n var value = ref.slice(1);\n\n if (property && value) {\n el.style[property.trim()] = value.join(':');\n }\n });\n}\n\nfunction clean(target) {\n var this$1 = this;\n var dirty;\n\n try {\n each($(target), function (node) {\n var id = node.getAttribute('data-sr-id');\n\n if (id !== null) {\n dirty = true;\n var element = this$1.store.elements[id];\n\n if (element.callbackTimer) {\n window.clearTimeout(element.callbackTimer.clock);\n }\n\n applyStyle(element.node, element.styles.inline.generated);\n node.removeAttribute('data-sr-id');\n delete this$1.store.elements[id];\n }\n });\n } catch (e) {\n return logger.call(this, 'Clean failed.', e.message);\n }\n\n if (dirty) {\n try {\n rinse.call(this);\n } catch (e) {\n return logger.call(this, 'Clean failed.', e.message);\n }\n }\n}\n\nfunction destroy() {\n var this$1 = this;\n /**\n * Remove all generated styles and element ids\n */\n\n each(this.store.elements, function (element) {\n applyStyle(element.node, element.styles.inline.generated);\n element.node.removeAttribute('data-sr-id');\n });\n /**\n * Remove all event listeners.\n */\n\n each(this.store.containers, function (container) {\n var target = container.node === document.documentElement ? window : container.node;\n target.removeEventListener('scroll', this$1.delegate);\n target.removeEventListener('resize', this$1.delegate);\n });\n /**\n * Clear all data from the store\n */\n\n this.store = {\n containers: {},\n elements: {},\n history: [],\n sequences: {}\n };\n}\n\nfunction deepAssign(target) {\n var sources = [],\n len = arguments.length - 1;\n\n while (len-- > 0) {\n sources[len] = arguments[len + 1];\n }\n\n if (isObject(target)) {\n each(sources, function (source) {\n each(source, function (data, key) {\n if (isObject(data)) {\n if (!target[key] || !isObject(target[key])) {\n target[key] = {};\n }\n\n deepAssign(target[key], data);\n } else {\n target[key] = data;\n }\n });\n });\n return target;\n } else {\n throw new TypeError('Target must be an object literal.');\n }\n}\n\nfunction isMobile(agent) {\n if (agent === void 0) agent = navigator.userAgent;\n return /Android|iPhone|iPad|iPod/i.test(agent);\n}\n\nvar nextUniqueId = function () {\n var uid = 0;\n return function () {\n return uid++;\n };\n}();\n\nfunction initialize() {\n var this$1 = this;\n rinse.call(this);\n each(this.store.elements, function (element) {\n var styles = [element.styles.inline.generated];\n\n if (element.visible) {\n styles.push(element.styles.opacity.computed);\n styles.push(element.styles.transform.generated.final);\n element.revealed = true;\n } else {\n styles.push(element.styles.opacity.generated);\n styles.push(element.styles.transform.generated.initial);\n element.revealed = false;\n }\n\n applyStyle(element.node, styles.filter(function (s) {\n return s !== '';\n }).join(' '));\n });\n each(this.store.containers, function (container) {\n var target = container.node === document.documentElement ? window : container.node;\n target.addEventListener('scroll', this$1.delegate);\n target.addEventListener('resize', this$1.delegate);\n });\n /**\n * Manually invoke delegate once to capture\n * element and container dimensions, container\n * scroll position, and trigger any valid reveals\n */\n\n this.delegate();\n /**\n * Wipe any existing `setTimeout` now\n * that initialization has completed.\n */\n\n this.initTimeout = null;\n}\n\nfunction animate(element, force) {\n if (force === void 0) force = {};\n var pristine = force.pristine || this.pristine;\n var delayed = element.config.useDelay === 'always' || element.config.useDelay === 'onload' && pristine || element.config.useDelay === 'once' && !element.seen;\n var shouldReveal = element.visible && !element.revealed;\n var shouldReset = !element.visible && element.revealed && element.config.reset;\n\n if (force.reveal || shouldReveal) {\n return triggerReveal.call(this, element, delayed);\n }\n\n if (force.reset || shouldReset) {\n return triggerReset.call(this, element);\n }\n}\n\nfunction triggerReveal(element, delayed) {\n var styles = [element.styles.inline.generated, element.styles.opacity.computed, element.styles.transform.generated.final];\n\n if (delayed) {\n styles.push(element.styles.transition.generated.delayed);\n } else {\n styles.push(element.styles.transition.generated.instant);\n }\n\n element.revealed = element.seen = true;\n applyStyle(element.node, styles.filter(function (s) {\n return s !== '';\n }).join(' '));\n registerCallbacks.call(this, element, delayed);\n}\n\nfunction triggerReset(element) {\n var styles = [element.styles.inline.generated, element.styles.opacity.generated, element.styles.transform.generated.initial, element.styles.transition.generated.instant];\n element.revealed = false;\n applyStyle(element.node, styles.filter(function (s) {\n return s !== '';\n }).join(' '));\n registerCallbacks.call(this, element);\n}\n\nfunction registerCallbacks(element, isDelayed) {\n var this$1 = this;\n var duration = isDelayed ? element.config.duration + element.config.delay : element.config.duration;\n var beforeCallback = element.revealed ? element.config.beforeReveal : element.config.beforeReset;\n var afterCallback = element.revealed ? element.config.afterReveal : element.config.afterReset;\n var elapsed = 0;\n\n if (element.callbackTimer) {\n elapsed = Date.now() - element.callbackTimer.start;\n window.clearTimeout(element.callbackTimer.clock);\n }\n\n beforeCallback(element.node);\n element.callbackTimer = {\n start: Date.now(),\n clock: window.setTimeout(function () {\n afterCallback(element.node);\n element.callbackTimer = null;\n\n if (element.revealed && !element.config.reset && element.config.cleanup) {\n clean.call(this$1, element.node);\n }\n }, duration - elapsed)\n };\n}\n\nfunction sequence(element, pristine) {\n if (pristine === void 0) pristine = this.pristine;\n /**\n * We first check if the element should reset.\n */\n\n if (!element.visible && element.revealed && element.config.reset) {\n return animate.call(this, element, {\n reset: true\n });\n }\n\n var seq = this.store.sequences[element.sequence.id];\n var i = element.sequence.index;\n\n if (seq) {\n var visible = new SequenceModel(seq, 'visible', this.store);\n var revealed = new SequenceModel(seq, 'revealed', this.store);\n seq.models = {\n visible: visible,\n revealed: revealed\n };\n /**\n * If the sequence has no revealed members,\n * then we reveal the first visible element\n * within that sequence.\n *\n * The sequence then cues a recursive call\n * in both directions.\n */\n\n if (!revealed.body.length) {\n var nextId = seq.members[visible.body[0]];\n var nextElement = this.store.elements[nextId];\n\n if (nextElement) {\n cue.call(this, seq, visible.body[0], -1, pristine);\n cue.call(this, seq, visible.body[0], +1, pristine);\n return animate.call(this, nextElement, {\n reveal: true,\n pristine: pristine\n });\n }\n }\n /**\n * If our element isn’t resetting, we check the\n * element sequence index against the head, and\n * then the foot of the sequence.\n */\n\n\n if (!seq.blocked.head && i === [].concat(revealed.head).pop() && i >= [].concat(visible.body).shift()) {\n cue.call(this, seq, i, -1, pristine);\n return animate.call(this, element, {\n reveal: true,\n pristine: pristine\n });\n }\n\n if (!seq.blocked.foot && i === [].concat(revealed.foot).shift() && i <= [].concat(visible.body).pop()) {\n cue.call(this, seq, i, +1, pristine);\n return animate.call(this, element, {\n reveal: true,\n pristine: pristine\n });\n }\n }\n}\n\nfunction Sequence(interval) {\n var i = Math.abs(interval);\n\n if (!isNaN(i)) {\n this.id = nextUniqueId();\n this.interval = Math.max(i, 16);\n this.members = [];\n this.models = {};\n this.blocked = {\n head: false,\n foot: false\n };\n } else {\n throw new RangeError('Invalid sequence interval.');\n }\n}\n\nfunction SequenceModel(seq, prop, store) {\n var this$1 = this;\n this.head = [];\n this.body = [];\n this.foot = [];\n each(seq.members, function (id, index) {\n var element = store.elements[id];\n\n if (element && element[prop]) {\n this$1.body.push(index);\n }\n });\n\n if (this.body.length) {\n each(seq.members, function (id, index) {\n var element = store.elements[id];\n\n if (element && !element[prop]) {\n if (index < this$1.body[0]) {\n this$1.head.push(index);\n } else {\n this$1.foot.push(index);\n }\n }\n });\n }\n}\n\nfunction cue(seq, i, direction, pristine) {\n var this$1 = this;\n var blocked = ['head', null, 'foot'][1 + direction];\n var nextId = seq.members[i + direction];\n var nextElement = this.store.elements[nextId];\n seq.blocked[blocked] = true;\n setTimeout(function () {\n seq.blocked[blocked] = false;\n\n if (nextElement) {\n sequence.call(this$1, nextElement, pristine);\n }\n }, seq.interval);\n}\n\nfunction reveal(target, options, syncing) {\n var this$1 = this;\n if (options === void 0) options = {};\n if (syncing === void 0) syncing = false;\n var containerBuffer = [];\n var sequence$$1;\n var interval = options.interval || defaults.interval;\n\n try {\n if (interval) {\n sequence$$1 = new Sequence(interval);\n }\n\n var nodes = $(target);\n\n if (!nodes.length) {\n throw new Error('Invalid reveal target.');\n }\n\n var elements = nodes.reduce(function (elementBuffer, elementNode) {\n var element = {};\n var existingId = elementNode.getAttribute('data-sr-id');\n\n if (existingId) {\n deepAssign(element, this$1.store.elements[existingId]);\n /**\n * In order to prevent previously generated styles\n * from throwing off the new styles, the style tag\n * has to be reverted to its pre-reveal state.\n */\n\n applyStyle(element.node, element.styles.inline.computed);\n } else {\n element.id = nextUniqueId();\n element.node = elementNode;\n element.seen = false;\n element.revealed = false;\n element.visible = false;\n }\n\n var config = deepAssign({}, element.config || this$1.defaults, options);\n\n if (!config.mobile && isMobile() || !config.desktop && !isMobile()) {\n if (existingId) {\n clean.call(this$1, element);\n }\n\n return elementBuffer; // skip elements that are disabled\n }\n\n var containerNode = $(config.container)[0];\n\n if (!containerNode) {\n throw new Error('Invalid container.');\n }\n\n if (!containerNode.contains(elementNode)) {\n return elementBuffer; // skip elements found outside the container\n }\n\n var containerId;\n {\n containerId = getContainerId(containerNode, containerBuffer, this$1.store.containers);\n\n if (containerId === null) {\n containerId = nextUniqueId();\n containerBuffer.push({\n id: containerId,\n node: containerNode\n });\n }\n }\n element.config = config;\n element.containerId = containerId;\n element.styles = style(element);\n\n if (sequence$$1) {\n element.sequence = {\n id: sequence$$1.id,\n index: sequence$$1.members.length\n };\n sequence$$1.members.push(element.id);\n }\n\n elementBuffer.push(element);\n return elementBuffer;\n }, []);\n /**\n * Modifying the DOM via setAttribute needs to be handled\n * separately from reading computed styles in the map above\n * for the browser to batch DOM changes (limiting reflows)\n */\n\n each(elements, function (element) {\n this$1.store.elements[element.id] = element;\n element.node.setAttribute('data-sr-id', element.id);\n });\n } catch (e) {\n return logger.call(this, 'Reveal failed.', e.message);\n }\n /**\n * Now that element set-up is complete...\n * Let’s commit any container and sequence data we have to the store.\n */\n\n\n each(containerBuffer, function (container) {\n this$1.store.containers[container.id] = {\n id: container.id,\n node: container.node\n };\n });\n\n if (sequence$$1) {\n this.store.sequences[sequence$$1.id] = sequence$$1;\n }\n /**\n * If reveal wasn't invoked by sync, we want to\n * make sure to add this call to the history.\n */\n\n\n if (syncing !== true) {\n this.store.history.push({\n target: target,\n options: options\n });\n /**\n * Push initialization to the event queue, giving\n * multiple reveal calls time to be interpreted.\n */\n\n if (this.initTimeout) {\n window.clearTimeout(this.initTimeout);\n }\n\n this.initTimeout = window.setTimeout(initialize.bind(this), 0);\n }\n}\n\nfunction getContainerId(node) {\n var collections = [],\n len = arguments.length - 1;\n\n while (len-- > 0) {\n collections[len] = arguments[len + 1];\n }\n\n var id = null;\n each(collections, function (collection) {\n each(collection, function (container) {\n if (id === null && container.node === node) {\n id = container.id;\n }\n });\n });\n return id;\n}\n/**\n * Re-runs the reveal method for each record stored in history,\n * for capturing new content asynchronously loaded into the DOM.\n */\n\n\nfunction sync() {\n var this$1 = this;\n each(this.store.history, function (record) {\n reveal.call(this$1, record.target, record.options, true);\n });\n initialize.call(this);\n}\n\nvar polyfill = function polyfill(x) {\n return (x > 0) - (x < 0) || +x;\n};\n\nvar mathSign = Math.sign || polyfill;\n\nfunction getGeometry(target, isContainer) {\n /**\n * We want to ignore padding and scrollbars for container elements.\n * More information here: https://goo.gl/vOZpbz\n */\n var height = isContainer ? target.node.clientHeight : target.node.offsetHeight;\n var width = isContainer ? target.node.clientWidth : target.node.offsetWidth;\n var offsetTop = 0;\n var offsetLeft = 0;\n var node = target.node;\n\n do {\n if (!isNaN(node.offsetTop)) {\n offsetTop += node.offsetTop;\n }\n\n if (!isNaN(node.offsetLeft)) {\n offsetLeft += node.offsetLeft;\n }\n\n node = node.offsetParent;\n } while (node);\n\n return {\n bounds: {\n top: offsetTop,\n right: offsetLeft + width,\n bottom: offsetTop + height,\n left: offsetLeft\n },\n height: height,\n width: width\n };\n}\n\nfunction getScrolled(container) {\n var top, left;\n\n if (container.node === document.documentElement) {\n top = window.pageYOffset;\n left = window.pageXOffset;\n } else {\n top = container.node.scrollTop;\n left = container.node.scrollLeft;\n }\n\n return {\n top: top,\n left: left\n };\n}\n\nfunction isElementVisible(element) {\n if (element === void 0) element = {};\n var container = this.store.containers[element.containerId];\n\n if (!container) {\n return;\n }\n\n var viewFactor = Math.max(0, Math.min(1, element.config.viewFactor));\n var viewOffset = element.config.viewOffset;\n var elementBounds = {\n top: element.geometry.bounds.top + element.geometry.height * viewFactor,\n right: element.geometry.bounds.right - element.geometry.width * viewFactor,\n bottom: element.geometry.bounds.bottom - element.geometry.height * viewFactor,\n left: element.geometry.bounds.left + element.geometry.width * viewFactor\n };\n var containerBounds = {\n top: container.geometry.bounds.top + container.scroll.top + viewOffset.top,\n right: container.geometry.bounds.right + container.scroll.left - viewOffset.right,\n bottom: container.geometry.bounds.bottom + container.scroll.top - viewOffset.bottom,\n left: container.geometry.bounds.left + container.scroll.left + viewOffset.left\n };\n return elementBounds.top < containerBounds.bottom && elementBounds.right > containerBounds.left && elementBounds.bottom > containerBounds.top && elementBounds.left < containerBounds.right || element.styles.position === 'fixed';\n}\n\nfunction delegate(event, elements) {\n var this$1 = this;\n if (event === void 0) event = {\n type: 'init'\n };\n if (elements === void 0) elements = this.store.elements;\n raf(function () {\n var stale = event.type === 'init' || event.type === 'resize';\n each(this$1.store.containers, function (container) {\n if (stale) {\n container.geometry = getGeometry.call(this$1, container, true);\n }\n\n var scroll = getScrolled.call(this$1, container);\n\n if (container.scroll) {\n container.direction = {\n x: mathSign(scroll.left - container.scroll.left),\n y: mathSign(scroll.top - container.scroll.top)\n };\n }\n\n container.scroll = scroll;\n });\n /**\n * Due to how the sequencer is implemented, it’s\n * important that we update the state of all\n * elements, before any animation logic is\n * evaluated (in the second loop below).\n */\n\n each(elements, function (element) {\n if (stale || element.geometry === undefined) {\n element.geometry = getGeometry.call(this$1, element);\n }\n\n element.visible = isElementVisible.call(this$1, element);\n });\n each(elements, function (element) {\n if (element.sequence) {\n sequence.call(this$1, element);\n } else {\n animate.call(this$1, element);\n }\n });\n this$1.pristine = false;\n });\n}\n\nfunction isTransformSupported() {\n var style = document.documentElement.style;\n return 'transform' in style || 'WebkitTransform' in style;\n}\n\nfunction isTransitionSupported() {\n var style = document.documentElement.style;\n return 'transition' in style || 'WebkitTransition' in style;\n}\n\nvar version = \"4.0.9\";\nvar boundDelegate;\nvar boundDestroy;\nvar boundReveal;\nvar boundClean;\nvar boundSync;\nvar config;\nvar debug;\nvar instance;\n\nfunction ScrollReveal(options) {\n if (options === void 0) options = {};\n var invokedWithoutNew = typeof this === 'undefined' || Object.getPrototypeOf(this) !== ScrollReveal.prototype;\n\n if (invokedWithoutNew) {\n return new ScrollReveal(options);\n }\n\n if (!ScrollReveal.isSupported()) {\n logger.call(this, 'Instantiation failed.', 'This browser is not supported.');\n return mount.failure();\n }\n\n var buffer;\n\n try {\n buffer = config ? deepAssign({}, config, options) : deepAssign({}, defaults, options);\n } catch (e) {\n logger.call(this, 'Invalid configuration.', e.message);\n return mount.failure();\n }\n\n try {\n var container = $(buffer.container)[0];\n\n if (!container) {\n throw new Error('Invalid container.');\n }\n } catch (e) {\n logger.call(this, e.message);\n return mount.failure();\n }\n\n config = buffer;\n\n if (!config.mobile && isMobile() || !config.desktop && !isMobile()) {\n logger.call(this, 'This device is disabled.', \"desktop: \" + config.desktop, \"mobile: \" + config.mobile);\n return mount.failure();\n }\n\n mount.success();\n this.store = {\n containers: {},\n elements: {},\n history: [],\n sequences: {}\n };\n this.pristine = true;\n boundDelegate = boundDelegate || delegate.bind(this);\n boundDestroy = boundDestroy || destroy.bind(this);\n boundReveal = boundReveal || reveal.bind(this);\n boundClean = boundClean || clean.bind(this);\n boundSync = boundSync || sync.bind(this);\n Object.defineProperty(this, 'delegate', {\n get: function get() {\n return boundDelegate;\n }\n });\n Object.defineProperty(this, 'destroy', {\n get: function get() {\n return boundDestroy;\n }\n });\n Object.defineProperty(this, 'reveal', {\n get: function get() {\n return boundReveal;\n }\n });\n Object.defineProperty(this, 'clean', {\n get: function get() {\n return boundClean;\n }\n });\n Object.defineProperty(this, 'sync', {\n get: function get() {\n return boundSync;\n }\n });\n Object.defineProperty(this, 'defaults', {\n get: function get() {\n return config;\n }\n });\n Object.defineProperty(this, 'version', {\n get: function get() {\n return version;\n }\n });\n Object.defineProperty(this, 'noop', {\n get: function get() {\n return false;\n }\n });\n return instance ? instance : instance = this;\n}\n\nScrollReveal.isSupported = function () {\n return isTransformSupported() && isTransitionSupported();\n};\n\nObject.defineProperty(ScrollReveal, 'debug', {\n get: function get() {\n return debug || false;\n },\n set: function set(value) {\n return debug = typeof value === 'boolean' ? value : debug;\n }\n});\nScrollReveal();\nexport default ScrollReveal;","import ScrollReveal from 'scrollreveal';\n\nconst isSSR = typeof window === 'undefined';\nconst sr = isSSR ? null : ScrollReveal();\n\nexport default sr;\n","module.exports = __webpack_public_path__ + \"static/Calibre-Regular-e08232148510aade507c2af9bb66acd0.woff\";","function replaceClassName(origClass, classToRemove) {\n return origClass.replace(new RegExp(\"(^|\\\\s)\" + classToRemove + \"(?:\\\\s|$)\", 'g'), '$1').replace(/\\s+/g, ' ').replace(/^\\s*|\\s*$/g, '');\n}\n/**\n * Removes a CSS class from a given element.\n * \n * @param element the element\n * @param className the CSS class name\n */\n\n\nexport default function removeClass(element, className) {\n if (element.classList) {\n element.classList.remove(className);\n } else if (typeof element.className === 'string') {\n element.className = replaceClassName(element.className, className);\n } else {\n element.setAttribute('class', replaceClassName(element.className && element.className.baseVal || '', className));\n }\n}","export default {\n disabled: false\n};","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport config from './config';\nimport { timeoutsShape } from './utils/PropTypes';\nimport TransitionGroupContext from './TransitionGroupContext';\nexport var UNMOUNTED = 'unmounted';\nexport var EXITED = 'exited';\nexport var ENTERING = 'entering';\nexport var ENTERED = 'entered';\nexport var EXITING = 'exiting';\n/**\n * The Transition component lets you describe a transition from one component\n * state to another _over time_ with a simple declarative API. Most commonly\n * it's used to animate the mounting and unmounting of a component, but can also\n * be used to describe in-place transition states as well.\n *\n * ---\n *\n * **Note**: `Transition` is a platform-agnostic base component. If you're using\n * transitions in CSS, you'll probably want to use\n * [`CSSTransition`](https://reactcommunity.org/react-transition-group/css-transition)\n * instead. It inherits all the features of `Transition`, but contains\n * additional features necessary to play nice with CSS transitions (hence the\n * name of the component).\n *\n * ---\n *\n * By default the `Transition` component does not alter the behavior of the\n * component it renders, it only tracks \"enter\" and \"exit\" states for the\n * components. It's up to you to give meaning and effect to those states. For\n * example we can add styles to a component when it enters or exits:\n *\n * ```jsx\n * import { Transition } from 'react-transition-group';\n *\n * const duration = 300;\n *\n * const defaultStyle = {\n * transition: `opacity ${duration}ms ease-in-out`,\n * opacity: 0,\n * }\n *\n * const transitionStyles = {\n * entering: { opacity: 1 },\n * entered: { opacity: 1 },\n * exiting: { opacity: 0 },\n * exited: { opacity: 0 },\n * };\n *\n * const Fade = ({ in: inProp }) => (\n * \n * {state => (\n *
\n * I'm a fade Transition!\n *
\n * )}\n * \n * );\n * ```\n *\n * There are 4 main states a Transition can be in:\n * - `'entering'`\n * - `'entered'`\n * - `'exiting'`\n * - `'exited'`\n *\n * Transition state is toggled via the `in` prop. When `true` the component\n * begins the \"Enter\" stage. During this stage, the component will shift from\n * its current transition state, to `'entering'` for the duration of the\n * transition and then to the `'entered'` stage once it's complete. Let's take\n * the following example (we'll use the\n * [useState](https://reactjs.org/docs/hooks-reference.html#usestate) hook):\n *\n * ```jsx\n * function App() {\n * const [inProp, setInProp] = useState(false);\n * return (\n *