-
Notifications
You must be signed in to change notification settings - Fork 0
/
9c7871fbc7d2578c6e1c8088a018b992988aef50-cb6225e2ea626aa3aed1.js.map
1 lines (1 loc) · 330 KB
/
9c7871fbc7d2578c6e1c8088a018b992988aef50-cb6225e2ea626aa3aed1.js.map
1
{"version":3,"sources":["webpack:///./src/tokens/colors.js","webpack:///./src/theme.js","webpack:///./src/tokens/index.js","webpack:///./src/tokens/media.js","webpack:///./src/tokens/typography.js","webpack:///./node_modules/react-side-effect/lib/index.js","webpack:///./node_modules/process/browser.js","webpack:///./src/components/Link.js","webpack:///./node_modules/@babel/runtime/helpers/esm/isNativeReflectConstruct.js","webpack:///./node_modules/@babel/runtime/helpers/esm/construct.js","webpack:///./node_modules/@babel/runtime/helpers/esm/wrapNativeSuper.js","webpack:///./node_modules/@babel/runtime/helpers/esm/isNativeFunction.js","webpack:///./node_modules/polished/dist/polished.esm.js","webpack:///./src/styles/helpers.js","webpack:///./src/components/Text.js","webpack:///./node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","webpack:///./src/components/MobileHeader.js","webpack:///./src/components/Header.js","webpack:///./src/components/Footer.js","webpack:///./src/components/layout.js","webpack:///./src/components/SEO.js","webpack:///./node_modules/gatsby-plugin-intl/link.js","webpack:///./node_modules/shallowequal/index.js","webpack:///./src/components/Commons.js","webpack:///./src/components/Wrapper.js","webpack:///./node_modules/react-fast-compare/index.js","webpack:///./node_modules/gatsby-plugin-intl/with-intl.js","webpack:///./node_modules/gatsby-plugin-intl/index.js","webpack:///./node_modules/react-helmet/es/Helmet.js","webpack:///./src/hooks/use-site-images.js","webpack:///./src/hooks/use-site-config.js","webpack:///./node_modules/styled-components/dist/styled-components.browser.esm.js","webpack:///(webpack)/buildin/global.js"],"names":["colors","grey100","grey200","grey300","grey400","grey500","grey600","grey700","grey800","grey900","white","yellow","lightYellow","lightBlue","textLightest","textLightestHover","textLight","primary","primaryLight","text","background","backgroundArticle","heartFooter","links","backgroundSelection","highlight_code_oneline","highlight_code_bg","highlight_code_marker","highlight_code_linebg","socialMediaCardFilter","postMetadata","theme","media","small","medium","large","typography","fonts","default","secondary","weights","regular","bold","ex","React","React__default","_defineProperty","obj","key","value","Object","defineProperty","enumerable","configurable","writable","canUseDOM","window","document","createElement","module","exports","reducePropsToState","handleStateChangeOnClient","mapStateOnServer","Error","WrappedComponent","state","mountedInstances","emitChange","map","instance","props","SideEffect","_PureComponent","subClass","superClass","apply","this","arguments","prototype","create","constructor","__proto__","peek","rewind","recordedState","undefined","_proto","UNSAFE_componentWillMount","push","componentDidUpdate","componentWillUnmount","index","indexOf","splice","render","PureComponent","displayName","name","getDisplayName","cachedSetTimeout","cachedClearTimeout","process","defaultSetTimout","defaultClearTimeout","runTimeout","fun","setTimeout","e","call","clearTimeout","currentQueue","queue","draining","queueIndex","cleanUpNextTick","length","concat","drainQueue","timeout","len","run","marker","runClearTimeout","Item","array","noop","nextTick","args","Array","i","title","browser","env","argv","version","versions","on","addListener","once","off","removeListener","removeAllListeners","emit","prependListener","prependOnceListener","listeners","binding","cwd","chdir","dir","umask","linkCSS","css","ExternalLink","styled","InternalLink","to","children","className","external","href","target","activeClassName","_isNativeReflectConstruct","Reflect","construct","sham","Proxy","Date","toString","Parent","Class","a","Function","bind","setPrototypeOf","_cache","Map","fn","TypeError","has","get","set","Wrapper","getPrototypeOf","_Error","PolishedError","code","_this","cssRegex$1","getValueAndUnit","matchedValue","match","parseFloat","ratioNames","minorSecond","majorSecond","minorThird","majorThird","perfectFourth","augFourth","perfectFifth","minorSixth","goldenSection","majorSixth","minorSeventh","majorSeventh","octave","majorTenth","majorEleventh","majorTwelfth","doubleOctave","modularScale","steps","base","ratio","_ref","realBase","unit","realRatio","Math","pow","ms","step","TextTag","TextStyle","TextAlign","styleFonts","defaults","StyledText","fontSizeStep","lineHeightRatio","fontWeight","fontFamily","spacing","getTextStyles","textTag","textStyle","restOfProps","source","excluded","sourceKeys","keys","as","MobilePanel","MobilePanelWrapper","MobileNav","BurgerButton","BurgerContent","HeaderLink","HeaderLinkText","injectIntl","headerLinks","intl","useState","isToggledOn","setToggle","onClick","aria-label","headerLink","color","id","label","HeaderWrapper","HeaderNav","HeaderLinksContainer","LinkItem","HeaderSetting","LogoWrapper","LogoImage","StyledMobileHeader","useSiteMetadata","siteTitle","headerLinksIcon","iconSrc","useSiteImages","src","alt","FooterWrapper","footerLinks","footerLinksIcon","FooterItem","item","url","rel","FooterColumn","column","sectionName","FooterEnd","fluid","SiteContent","Template","Component","isBlogPost","path","lang","siteUrl","siteCover","siteDescription","twitterUsername","formatedSiteUrl","imagePath","withPrefix","image","description","internalTranslations","t","content","translation","hreflang","property","_interopRequireDefault","require","__esModule","changeLocale","navigate","_extends2","_objectWithoutPropertiesLoose2","_react","_propTypes","_gatsby","_intlContext","Link","language","rest","IntlContextConsumer","languageLink","link","routed","localStorage","setItem","propTypes","node","isRequired","string","defaultProps","_default","options","_window$___gatsbyIntl","___gatsbyIntl","pathname","substring","removeLocalePart","location","search","objA","objB","compare","compareContext","ret","keysA","keysB","bHasOwnProperty","hasOwnProperty","idx","valueA","valueB","GlobalStyle","createGlobalStyle","StyledLink","Text","Bull","ReadingTime","ReadingTimeContainer","role","hasElementType","Element","hasMap","hasSet","Set","hasArrayBuffer","ArrayBuffer","isView","b","equal","it","isArray","size","entries","next","done","RegExp","flags","valueOf","$$typeof","error","message","console","warn","_reactIntl","_interopRequireWildcard","_exportNames","withIntl","IntlContextProvider","forEach","_link","_withIntl","clock","_class","_temp","ATTRIBUTE_NAMES","TAG_NAMES","BASE","BODY","HEAD","HTML","LINK","META","NOSCRIPT","SCRIPT","STYLE","TITLE","TAG_PROPERTIES","REACT_TAG_MAP","accesskey","charset","class","contenteditable","contextmenu","itemprop","tabindex","HELMET_PROPS","HTML_TAG_MAP","reduce","SELF_CLOSING_TAGS","_typeof","Symbol","iterator","classCallCheck","Constructor","createClass","defineProperties","descriptor","protoProps","staticProps","_extends","assign","objectWithoutProperties","possibleConstructorReturn","self","ReferenceError","encodeSpecialCharacters","str","encode","String","replace","getTitleFromPropsList","propsList","innermostTitle","getInnermostProperty","innermostTemplate","join","innermostDefaultTitle","getOnChangeClientState","getAttributesFromPropsList","tagType","filter","tagAttrs","current","getBaseTagFromPropsList","primaryAttributes","reverse","innermostBaseTag","tag","lowerCaseAttributeKey","toLowerCase","getTagsFromPropsList","tagName","approvedSeenTags","approvedTags","instanceTags","instanceSeenTags","primaryAttributeKey","attributeKey","tagUnion","rafPolyfill","now","callback","currentTime","cafPolyfill","requestAnimationFrame","webkitRequestAnimationFrame","mozRequestAnimationFrame","global","cancelAnimationFrame","webkitCancelAnimationFrame","mozCancelAnimationFrame","msg","_helmetCallback","commitTagChanges","newState","cb","baseTag","bodyAttributes","htmlAttributes","linkTags","metaTags","noscriptTags","onChangeClientState","scriptTags","styleTags","titleAttributes","updateAttributes","updateTitle","tagUpdates","updateTags","addedTags","removedTags","_tagUpdates$tagType","newTags","oldTags","flattenArray","possibleArray","attributes","elementTag","getElementsByTagName","helmetAttributeString","getAttribute","helmetAttributes","split","attributesToRemove","attributeKeys","attribute","setAttribute","indexToSave","_i","removeAttribute","type","tags","headElement","head","querySelector","tagNodes","querySelectorAll","slice","indexToDelete","newElement","innerHTML","styleSheet","cssText","appendChild","createTextNode","some","existingTag","isEqualNode","parentNode","removeChild","generateElementAttributesAsString","attr","convertElementAttributestoReactProps","initProps","getMethodsForTag","toComponent","_initProps","attributeString","flattenedTitle","generateTitleAsString","_mappedTag","mappedTag","mappedAttribute","dangerouslySetInnerHTML","__html","generateTagsAsReactComponent","attributeHtml","tagContent","isSelfClosing","generateTagsAsString","_ref$title","meta","noscript","script","style","HelmetSideEffects","defer","HelmetExport","_React$Component","HelmetWrapper","inherits","shouldComponentUpdate","nextProps","mapNestedChildrenToProps","child","nestedChildren","flattenArrayTypeChildren","_babelHelpers$extends","arrayTypeChildren","newChildProps","mapObjectTypeChildren","_ref2","_babelHelpers$extends2","_babelHelpers$extends3","newProps","mapArrayTypeChildrenToProps","newFlattenedProps","arrayChildName","_babelHelpers$extends4","warnOnInvalidChildren","mapChildrenToProps","_this2","Children","_child$props","initAttributes","convertReactPropstoHtmlAttributes","_props","object","oneOfType","arrayOf","defaultTitle","bool","func","titleTemplate","mappedState","renderStatic","imageName","result","edge","interleave","strings","interpolations","isPlainObject","x","EMPTY_ARRAY","freeze","EMPTY_OBJECT","isFunction","test","getComponentName","isStyledComponent","styledComponentId","SC_ATTR","REACT_APP_SC_ATTR","IS_BROWSER","DISABLE_SPEEDY","SC_DISABLE_SPEEDY","REACT_APP_SC_DISABLE_SPEEDY","STATIC_EXECUTION_CONTEXT","getNonce","throwStyledComponentsError","_len","_key","makeStyleTag","parent","prevStyle","childNodes","nodeType","hasAttribute","findLastStyleTag","nextSibling","nonce","insertBefore","CSSOMTag","element","sheet","styleSheets","l","ownerNode","getSheet","insertRule","rule","_error","deleteRule","getRule","cssRules","nodes","_proto2","refNode","textContent","VirtualTag","_target","rules","_proto3","DefaultGroupedTag","groupSizes","Uint32Array","indexOfGroup","group","insertRules","oldBuffer","oldSize","newSize","ruleIndex","clearGroup","startIndex","endIndex","getGroup","groupIDRegister","reverseRegister","nextFreeGroup","getGroupForId","getIdForGroup","setGroupForId","SELECTOR","MARKER_RE","rehydrateNamesFromContent","names","registerName","rehydrateSheetFromTag","parts","part","trim","parseInt","getTag","SHOULD_REHYDRATE","defaultOptions","isServer","useCSSOMInjection","StyleSheet","globalStyles","gs","rehydrateSheet","registerId","reconstructWithOptions","allocateGSInstance","hasNameForId","add","groupNames","clearNames","clear","clearRules","clearTag","selector","outputSheet","phash","h","charCodeAt","hash","COMMENT_REGEX","createStylisInstance","_componentId","_selector","_selectorRegexp","_ref$options","_ref$plugins","plugins","stylis","parsingRules","parseRulesPlugin","toSheet","block","context","selectors","parents","line","ns","depth","at","delimiter","insertRulePlugin","selfReferenceReplacer","offset","stringifyRules","prefix","componentId","flatCSS","cssStr","use","_","lastIndexOf","parsedRules","acc","plugin","StyleSheetContext","createContext","StylisContext","Consumer","masterSheet","masterStylis","useStyleSheet","useStylis","Keyframes","stringifyArgs","inject","getName","uppercasePattern","msPattern","hyphenateStyleName","isFalsish","chunk","objToCssArray","prevKey","flatten","executionContext","ruleSet","isReactComponent","styles","isObject","val","isValidKey","mixin","mixinDeep","_rest","AD_REPLACER_R","getAlphabeticChar","fromCharCode","generateAlphabeticName","abs","isStaticRules","ComponentStyle","staticRulesId","isStatic","baseHash","generateAndInjectStyles","cssStatic","cssStaticFormatted","dynamicHash","partRule","partChunk","partString","_name","cssFormatted","determineTheme","providedTheme","escapeRegex","dashesAtEnds","escape","isTag","generateComponentId","ThemeContext","identifiers","useStyledComponentImpl","forwardedComponent","forwardedRef","componentAttrs","attrs","componentStyle","foldedComponentIds","shouldForwardProp","_useResolvedAttrs","resolvedAttrs","attrDef","resolvedAttrDef","useResolvedAttrs","generatedClassName","hasAttrs","warnTooManyClasses","useInjectedStyle","refToForward","elementToBeCreated","$as","isTargetTag","computedProps","propFilterFn","propsForElement","Boolean","ref","createStyledComponent","isTargetStyledComp","isCompositeComponent","_options$displayName","generateDisplayName","_options$componentId","parentComponentId","generateId","_options$attrs","finalAttrs","prop","filterFn","WrappedStyledComponent","forwardRef","withComponent","previousComponentId","optionsToCopy","_objectWithoutPropertiesLoose","newComponentId","_foldedDefaultProps","constructWithOptions","componentConstructor","templateFunction","withConfig","config","domElement","createStyles","removeStyles","renderStyles","JSON","stringify","globalStyle","GlobalStyleComponent","instanceRef","memo","g"],"mappings":"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","file":"9c7871fbc7d2578c6e1c8088a018b992988aef50-cb6225e2ea626aa3aed1.js","sourcesContent":["// 50 shades of grey generator\n// https://javisperez.github.io/tailwindcolorshades/#/?%233E4047=3E4047&tv=1\nconst colors = {\n grey100: '#ECECED',\n grey200: '#CFCFD1',\n grey300: '#B2B3B5',\n grey400: '#78797E',\n grey500: '#3E4047',\n grey600: '#383A40',\n grey700: '#25262B',\n grey800: '#1C1D20',\n grey900: '#131315',\n\n white: '#ffffff',\n yellow: '#ffdc4e',\n lightYellow: '#f9e892',\n lightBlue: '#697980',\n}\n\nexport default {\n ...colors,\n textLightest: colors.white,\n textLightestHover: colors.grey200,\n textLight: '#57595d',\n primary: '#243e50',\n primaryLight: `#eff5fa`,\n text: \"#243e50\",\n background: '#ffffff',\n backgroundArticle: colors.white,\n heartFooter: 'red',\n links: colors.yellow,\n backgroundSelection: colors.yellow,\n highlight_code_oneline: '#fff9d9',\n highlight_code_bg: colors.yellow,\n highlight_code_marker: colors.yellow,\n highlight_code_linebg: '#022a4b',\n socialMediaCardFilter: '#437abf', // #8f43bf\n postMetadata: colors.lightBlue,\n}\n","/*\n * To override any of this theme’s tokens in your site, create a new file in\n * your site at `theme.js` and export an object from\n * it. Tokens are nested under the file name.\n *\n * For example, to override the primary color, your `theme.js` would look\n * something like this:\n *\n * export default {\n * colors: {\n * primary: `#6556B3`,\n * primaryAlpha: `#6556B3cc`,\n * }\n * };\n *\n * All tokens are optional. When a token is not present in `theme.js`, the\n * default value from the `tokens/*.js` files will be used.\n *\n * For a full list of tokens, see the `src/tokens/` directory in this theme.\n */\nexport default {}\n","import colorDefaults from './colors'\nimport mediaDefaults from './media'\nimport typographyDefaults from './typography'\nimport theme from '../theme'\n\nexport const colors = { ...colorDefaults, ...(theme.colors || {}) }\nexport const media = { ...mediaDefaults, ...(theme.media || {}) }\nexport const typography = { ...typographyDefaults, ...(theme.typography || {}) }\nexport default { colors, media, typography }\n","export default {\n small: '(min-width: 480px)',\n medium: '(min-width: 700px)',\n large: '(min-width: 960px)',\n}\n","export default {\n fonts: {\n default: \"Lato, sans-serif\",\n secondary: \"Nunito, sans-serif\",\n },\n weights: {\n regular: 400,\n bold: 700,\n },\n}\n","'use strict';\n\nfunction _interopDefault(ex) {\n return ex && typeof ex === 'object' && 'default' in ex ? ex['default'] : ex;\n}\n\nvar React = require('react');\n\nvar React__default = _interopDefault(React);\n\nfunction _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}\n\nfunction _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n subClass.__proto__ = superClass;\n}\n\nvar canUseDOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\n\nfunction withSideEffect(reducePropsToState, handleStateChangeOnClient, mapStateOnServer) {\n if (typeof reducePropsToState !== 'function') {\n throw new Error('Expected reducePropsToState to be a function.');\n }\n\n if (typeof handleStateChangeOnClient !== 'function') {\n throw new Error('Expected handleStateChangeOnClient to be a function.');\n }\n\n if (typeof mapStateOnServer !== 'undefined' && typeof mapStateOnServer !== 'function') {\n throw new Error('Expected mapStateOnServer to either be undefined or a function.');\n }\n\n function getDisplayName(WrappedComponent) {\n return WrappedComponent.displayName || WrappedComponent.name || 'Component';\n }\n\n return function wrap(WrappedComponent) {\n if (typeof WrappedComponent !== 'function') {\n throw new Error('Expected WrappedComponent to be a React component.');\n }\n\n var mountedInstances = [];\n var state;\n\n function emitChange() {\n state = reducePropsToState(mountedInstances.map(function (instance) {\n return instance.props;\n }));\n\n if (SideEffect.canUseDOM) {\n handleStateChangeOnClient(state);\n } else if (mapStateOnServer) {\n state = mapStateOnServer(state);\n }\n }\n\n var SideEffect = /*#__PURE__*/function (_PureComponent) {\n _inheritsLoose(SideEffect, _PureComponent);\n\n function SideEffect() {\n return _PureComponent.apply(this, arguments) || this;\n } // Try to use displayName of wrapped component\n // Expose canUseDOM so tests can monkeypatch it\n\n\n SideEffect.peek = function peek() {\n return state;\n };\n\n SideEffect.rewind = function rewind() {\n if (SideEffect.canUseDOM) {\n throw new Error('You may only call rewind() on the server. Call peek() to read the current state.');\n }\n\n var recordedState = state;\n state = undefined;\n mountedInstances = [];\n return recordedState;\n };\n\n var _proto = SideEffect.prototype;\n\n _proto.UNSAFE_componentWillMount = function UNSAFE_componentWillMount() {\n mountedInstances.push(this);\n emitChange();\n };\n\n _proto.componentDidUpdate = function componentDidUpdate() {\n emitChange();\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n var index = mountedInstances.indexOf(this);\n mountedInstances.splice(index, 1);\n emitChange();\n };\n\n _proto.render = function render() {\n return React__default.createElement(WrappedComponent, this.props);\n };\n\n return SideEffect;\n }(React.PureComponent);\n\n _defineProperty(SideEffect, \"displayName\", \"SideEffect(\" + getDisplayName(WrappedComponent) + \")\");\n\n _defineProperty(SideEffect, \"canUseDOM\", canUseDOM);\n\n return SideEffect;\n };\n}\n\nmodule.exports = withSideEffect;","// shim for using process in browser\nvar process = module.exports = {}; // cached from whatever global is present so that test runners that stub it\n// don't break things. But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals. It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n throw new Error('setTimeout has not been defined');\n}\n\nfunction defaultClearTimeout() {\n throw new Error('clearTimeout has not been defined');\n}\n\n(function () {\n try {\n if (typeof setTimeout === 'function') {\n cachedSetTimeout = setTimeout;\n } else {\n cachedSetTimeout = defaultSetTimout;\n }\n } catch (e) {\n cachedSetTimeout = defaultSetTimout;\n }\n\n try {\n if (typeof clearTimeout === 'function') {\n cachedClearTimeout = clearTimeout;\n } else {\n cachedClearTimeout = defaultClearTimeout;\n }\n } catch (e) {\n cachedClearTimeout = defaultClearTimeout;\n }\n})();\n\nfunction runTimeout(fun) {\n if (cachedSetTimeout === setTimeout) {\n //normal enviroments in sane situations\n return setTimeout(fun, 0);\n } // if setTimeout wasn't available but was latter defined\n\n\n if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n cachedSetTimeout = setTimeout;\n return setTimeout(fun, 0);\n }\n\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedSetTimeout(fun, 0);\n } catch (e) {\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedSetTimeout.call(null, fun, 0);\n } catch (e) {\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n return cachedSetTimeout.call(this, fun, 0);\n }\n }\n}\n\nfunction runClearTimeout(marker) {\n if (cachedClearTimeout === clearTimeout) {\n //normal enviroments in sane situations\n return clearTimeout(marker);\n } // if clearTimeout wasn't available but was latter defined\n\n\n if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n cachedClearTimeout = clearTimeout;\n return clearTimeout(marker);\n }\n\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedClearTimeout(marker);\n } catch (e) {\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedClearTimeout.call(null, marker);\n } catch (e) {\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n return cachedClearTimeout.call(this, marker);\n }\n }\n}\n\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n\n draining = false;\n\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n\n var timeout = runTimeout(cleanUpNextTick);\n draining = true;\n var len = queue.length;\n\n while (len) {\n currentQueue = queue;\n queue = [];\n\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n\n queueIndex = -1;\n len = queue.length;\n }\n\n currentQueue = null;\n draining = false;\n runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n\n queue.push(new Item(fun, args));\n\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n}; // v8 likes predictible objects\n\n\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\n\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\n\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\n\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) {\n return [];\n};\n\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () {\n return '/';\n};\n\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\n\nprocess.umask = function () {\n return 0;\n};","import React from 'react'\nimport { Link as GatsbyLink } from \"gatsby-plugin-intl\"\nimport styled, { css } from 'styled-components'\n\nconst linkCSS = css`\n text-decoration: none;\n color: inherit;\n`\n\nconst ExternalLink = styled.a`\n ${linkCSS}\n`\n\nconst InternalLink = styled(GatsbyLink)`\n ${linkCSS}\n`\n\nconst Link = ({ to, children, className, external }) => {\n return external ? (\n <ExternalLink href={to} target={'_blank'} className={className}>\n {children}\n </ExternalLink>\n ) : (\n <InternalLink to={to} className={className} activeClassName={'active'}>\n {children}\n </InternalLink>\n )\n}\n\nexport default Link\n","export default function _isNativeReflectConstruct() {\n if (typeof Reflect === \"undefined\" || !Reflect.construct) return false;\n if (Reflect.construct.sham) return false;\n if (typeof Proxy === \"function\") return true;\n\n try {\n Date.prototype.toString.call(Reflect.construct(Date, [], function () {}));\n return true;\n } catch (e) {\n return false;\n }\n}","import setPrototypeOf from \"./setPrototypeOf\";\nimport isNativeReflectConstruct from \"./isNativeReflectConstruct\";\nexport default function _construct(Parent, args, Class) {\n if (isNativeReflectConstruct()) {\n _construct = Reflect.construct;\n } else {\n _construct = function _construct(Parent, args, Class) {\n var a = [null];\n a.push.apply(a, args);\n var Constructor = Function.bind.apply(Parent, a);\n var instance = new Constructor();\n if (Class) setPrototypeOf(instance, Class.prototype);\n return instance;\n };\n }\n\n return _construct.apply(null, arguments);\n}","import getPrototypeOf from \"./getPrototypeOf\";\nimport setPrototypeOf from \"./setPrototypeOf\";\nimport isNativeFunction from \"./isNativeFunction\";\nimport construct from \"./construct\";\nexport default function _wrapNativeSuper(Class) {\n var _cache = typeof Map === \"function\" ? new Map() : undefined;\n\n _wrapNativeSuper = function _wrapNativeSuper(Class) {\n if (Class === null || !isNativeFunction(Class)) return Class;\n\n if (typeof Class !== \"function\") {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n\n if (typeof _cache !== \"undefined\") {\n if (_cache.has(Class)) return _cache.get(Class);\n\n _cache.set(Class, Wrapper);\n }\n\n function Wrapper() {\n return construct(Class, arguments, getPrototypeOf(this).constructor);\n }\n\n Wrapper.prototype = Object.create(Class.prototype, {\n constructor: {\n value: Wrapper,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n return setPrototypeOf(Wrapper, Class);\n };\n\n return _wrapNativeSuper(Class);\n}","export default function _isNativeFunction(fn) {\n return Function.toString.call(fn).indexOf(\"[native code]\") !== -1;\n}","import _extends from '@babel/runtime/helpers/esm/extends';\nimport _assertThisInitialized from '@babel/runtime/helpers/esm/assertThisInitialized';\nimport _inheritsLoose from '@babel/runtime/helpers/esm/inheritsLoose';\nimport _wrapNativeSuper from '@babel/runtime/helpers/esm/wrapNativeSuper';\nimport _taggedTemplateLiteralLoose from '@babel/runtime/helpers/esm/taggedTemplateLiteralLoose';\n\nfunction last() {\n var _ref;\n\n return _ref = arguments.length - 1, _ref < 0 || arguments.length <= _ref ? undefined : arguments[_ref];\n}\n\nfunction negation(a) {\n return -a;\n}\n\nfunction addition(a, b) {\n return a + b;\n}\n\nfunction subtraction(a, b) {\n return a - b;\n}\n\nfunction multiplication(a, b) {\n return a * b;\n}\n\nfunction division(a, b) {\n return a / b;\n}\n\nfunction factorial(a) {\n if (a % 1 || !(+a >= 0)) return NaN;\n if (a > 170) return Infinity;else if (a === 0) return 1;else {\n return a * factorial(a - 1);\n }\n}\n\nfunction power(a, b) {\n return Math.pow(a, b);\n}\n\nfunction sqrt(a) {\n return Math.sqrt(a);\n}\n\nfunction max() {\n return Math.max.apply(Math, arguments);\n}\n\nfunction min() {\n return Math.min.apply(Math, arguments);\n}\n\nfunction comma() {\n return Array.of.apply(Array, arguments);\n}\n\nvar defaultMathSymbols = {\n symbols: {\n '!': {\n postfix: {\n symbol: '!',\n f: factorial,\n notation: 'postfix',\n precedence: 6,\n rightToLeft: 0,\n argCount: 1\n },\n symbol: '!',\n regSymbol: '!'\n },\n '^': {\n infix: {\n symbol: '^',\n f: power,\n notation: 'infix',\n precedence: 5,\n rightToLeft: 1,\n argCount: 2\n },\n symbol: '^',\n regSymbol: '\\\\^'\n },\n '*': {\n infix: {\n symbol: '*',\n f: multiplication,\n notation: 'infix',\n precedence: 4,\n rightToLeft: 0,\n argCount: 2\n },\n symbol: '*',\n regSymbol: '\\\\*'\n },\n '/': {\n infix: {\n symbol: '/',\n f: division,\n notation: 'infix',\n precedence: 4,\n rightToLeft: 0,\n argCount: 2\n },\n symbol: '/',\n regSymbol: '/'\n },\n '+': {\n infix: {\n symbol: '+',\n f: addition,\n notation: 'infix',\n precedence: 2,\n rightToLeft: 0,\n argCount: 2\n },\n prefix: {\n symbol: '+',\n f: last,\n notation: 'prefix',\n precedence: 3,\n rightToLeft: 0,\n argCount: 1\n },\n symbol: '+',\n regSymbol: '\\\\+'\n },\n '-': {\n infix: {\n symbol: '-',\n f: subtraction,\n notation: 'infix',\n precedence: 2,\n rightToLeft: 0,\n argCount: 2\n },\n prefix: {\n symbol: '-',\n f: negation,\n notation: 'prefix',\n precedence: 3,\n rightToLeft: 0,\n argCount: 1\n },\n symbol: '-',\n regSymbol: '-'\n },\n ',': {\n infix: {\n symbol: ',',\n f: comma,\n notation: 'infix',\n precedence: 1,\n rightToLeft: 0,\n argCount: 2\n },\n symbol: ',',\n regSymbol: ','\n },\n '(': {\n prefix: {\n symbol: '(',\n f: last,\n notation: 'prefix',\n precedence: 0,\n rightToLeft: 0,\n argCount: 1\n },\n symbol: '(',\n regSymbol: '\\\\('\n },\n ')': {\n postfix: {\n symbol: ')',\n f: undefined,\n notation: 'postfix',\n precedence: 0,\n rightToLeft: 0,\n argCount: 1\n },\n symbol: ')',\n regSymbol: '\\\\)'\n },\n min: {\n func: {\n symbol: 'min',\n f: min,\n notation: 'func',\n precedence: 0,\n rightToLeft: 0,\n argCount: 1\n },\n symbol: 'min',\n regSymbol: 'min\\\\b'\n },\n max: {\n func: {\n symbol: 'max',\n f: max,\n notation: 'func',\n precedence: 0,\n rightToLeft: 0,\n argCount: 1\n },\n symbol: 'max',\n regSymbol: 'max\\\\b'\n },\n sqrt: {\n func: {\n symbol: 'sqrt',\n f: sqrt,\n notation: 'func',\n precedence: 0,\n rightToLeft: 0,\n argCount: 1\n },\n symbol: 'sqrt',\n regSymbol: 'sqrt\\\\b'\n }\n }\n}; // based on https://github.com/styled-components/styled-components/blob/fcf6f3804c57a14dd7984dfab7bc06ee2edca044/src/utils/error.js\n\n/**\n * Parse errors.md and turn it into a simple hash of code: message\n * @private\n */\n\nvar ERRORS = {\n \"1\": \"Passed invalid arguments to hsl, please pass multiple numbers e.g. hsl(360, 0.75, 0.4) or an object e.g. rgb({ hue: 255, saturation: 0.4, lightness: 0.75 }).\\n\\n\",\n \"2\": \"Passed invalid arguments to hsla, please pass multiple numbers e.g. hsla(360, 0.75, 0.4, 0.7) or an object e.g. rgb({ hue: 255, saturation: 0.4, lightness: 0.75, alpha: 0.7 }).\\n\\n\",\n \"3\": \"Passed an incorrect argument to a color function, please pass a string representation of a color.\\n\\n\",\n \"4\": \"Couldn't generate valid rgb string from %s, it returned %s.\\n\\n\",\n \"5\": \"Couldn't parse the color string. Please provide the color as a string in hex, rgb, rgba, hsl or hsla notation.\\n\\n\",\n \"6\": \"Passed invalid arguments to rgb, please pass multiple numbers e.g. rgb(255, 205, 100) or an object e.g. rgb({ red: 255, green: 205, blue: 100 }).\\n\\n\",\n \"7\": \"Passed invalid arguments to rgba, please pass multiple numbers e.g. rgb(255, 205, 100, 0.75) or an object e.g. rgb({ red: 255, green: 205, blue: 100, alpha: 0.75 }).\\n\\n\",\n \"8\": \"Passed invalid argument to toColorString, please pass a RgbColor, RgbaColor, HslColor or HslaColor object.\\n\\n\",\n \"9\": \"Please provide a number of steps to the modularScale helper.\\n\\n\",\n \"10\": \"Please pass a number or one of the predefined scales to the modularScale helper as the ratio.\\n\\n\",\n \"11\": \"Invalid value passed as base to modularScale, expected number or em string but got \\\"%s\\\"\\n\\n\",\n \"12\": \"Expected a string ending in \\\"px\\\" or a number passed as the first argument to %s(), got \\\"%s\\\" instead.\\n\\n\",\n \"13\": \"Expected a string ending in \\\"px\\\" or a number passed as the second argument to %s(), got \\\"%s\\\" instead.\\n\\n\",\n \"14\": \"Passed invalid pixel value (\\\"%s\\\") to %s(), please pass a value like \\\"12px\\\" or 12.\\n\\n\",\n \"15\": \"Passed invalid base value (\\\"%s\\\") to %s(), please pass a value like \\\"12px\\\" or 12.\\n\\n\",\n \"16\": \"You must provide a template to this method.\\n\\n\",\n \"17\": \"You passed an unsupported selector state to this method.\\n\\n\",\n \"18\": \"minScreen and maxScreen must be provided as stringified numbers with the same units.\\n\\n\",\n \"19\": \"fromSize and toSize must be provided as stringified numbers with the same units.\\n\\n\",\n \"20\": \"expects either an array of objects or a single object with the properties prop, fromSize, and toSize.\\n\\n\",\n \"21\": \"expects the objects in the first argument array to have the properties `prop`, `fromSize`, and `toSize`.\\n\\n\",\n \"22\": \"expects the first argument object to have the properties `prop`, `fromSize`, and `toSize`.\\n\\n\",\n \"23\": \"fontFace expects a name of a font-family.\\n\\n\",\n \"24\": \"fontFace expects either the path to the font file(s) or a name of a local copy.\\n\\n\",\n \"25\": \"fontFace expects localFonts to be an array.\\n\\n\",\n \"26\": \"fontFace expects fileFormats to be an array.\\n\\n\",\n \"27\": \"radialGradient requries at least 2 color-stops to properly render.\\n\\n\",\n \"28\": \"Please supply a filename to retinaImage() as the first argument.\\n\\n\",\n \"29\": \"Passed invalid argument to triangle, please pass correct pointingDirection e.g. 'right'.\\n\\n\",\n \"30\": \"Passed an invalid value to `height` or `width`. Please provide a pixel based unit.\\n\\n\",\n \"31\": \"The animation shorthand only takes 8 arguments. See the specification for more information: http://mdn.io/animation\\n\\n\",\n \"32\": \"To pass multiple animations please supply them in arrays, e.g. animation(['rotate', '2s'], ['move', '1s'])\\nTo pass a single animation please supply them in simple values, e.g. animation('rotate', '2s')\\n\\n\",\n \"33\": \"The animation shorthand arrays can only have 8 elements. See the specification for more information: http://mdn.io/animation\\n\\n\",\n \"34\": \"borderRadius expects a radius value as a string or number as the second argument.\\n\\n\",\n \"35\": \"borderRadius expects one of \\\"top\\\", \\\"bottom\\\", \\\"left\\\" or \\\"right\\\" as the first argument.\\n\\n\",\n \"36\": \"Property must be a string value.\\n\\n\",\n \"37\": \"Syntax Error at %s.\\n\\n\",\n \"38\": \"Formula contains a function that needs parentheses at %s.\\n\\n\",\n \"39\": \"Formula is missing closing parenthesis at %s.\\n\\n\",\n \"40\": \"Formula has too many closing parentheses at %s.\\n\\n\",\n \"41\": \"All values in a formula must have the same unit or be unitless.\\n\\n\",\n \"42\": \"Please provide a number of steps to the modularScale helper.\\n\\n\",\n \"43\": \"Please pass a number or one of the predefined scales to the modularScale helper as the ratio.\\n\\n\",\n \"44\": \"Invalid value passed as base to modularScale, expected number or em/rem string but got %s.\\n\\n\",\n \"45\": \"Passed invalid argument to hslToColorString, please pass a HslColor or HslaColor object.\\n\\n\",\n \"46\": \"Passed invalid argument to rgbToColorString, please pass a RgbColor or RgbaColor object.\\n\\n\",\n \"47\": \"minScreen and maxScreen must be provided as stringified numbers with the same units.\\n\\n\",\n \"48\": \"fromSize and toSize must be provided as stringified numbers with the same units.\\n\\n\",\n \"49\": \"Expects either an array of objects or a single object with the properties prop, fromSize, and toSize.\\n\\n\",\n \"50\": \"Expects the objects in the first argument array to have the properties prop, fromSize, and toSize.\\n\\n\",\n \"51\": \"Expects the first argument object to have the properties prop, fromSize, and toSize.\\n\\n\",\n \"52\": \"fontFace expects either the path to the font file(s) or a name of a local copy.\\n\\n\",\n \"53\": \"fontFace expects localFonts to be an array.\\n\\n\",\n \"54\": \"fontFace expects fileFormats to be an array.\\n\\n\",\n \"55\": \"fontFace expects a name of a font-family.\\n\\n\",\n \"56\": \"linearGradient requries at least 2 color-stops to properly render.\\n\\n\",\n \"57\": \"radialGradient requries at least 2 color-stops to properly render.\\n\\n\",\n \"58\": \"Please supply a filename to retinaImage() as the first argument.\\n\\n\",\n \"59\": \"Passed invalid argument to triangle, please pass correct pointingDirection e.g. 'right'.\\n\\n\",\n \"60\": \"Passed an invalid value to `height` or `width`. Please provide a pixel based unit.\\n\\n\",\n \"61\": \"Property must be a string value.\\n\\n\",\n \"62\": \"borderRadius expects a radius value as a string or number as the second argument.\\n\\n\",\n \"63\": \"borderRadius expects one of \\\"top\\\", \\\"bottom\\\", \\\"left\\\" or \\\"right\\\" as the first argument.\\n\\n\",\n \"64\": \"The animation shorthand only takes 8 arguments. See the specification for more information: http://mdn.io/animation.\\n\\n\",\n \"65\": \"To pass multiple animations please supply them in arrays, e.g. animation(['rotate', '2s'], ['move', '1s'])\\\\nTo pass a single animation please supply them in simple values, e.g. animation('rotate', '2s').\\n\\n\",\n \"66\": \"The animation shorthand arrays can only have 8 elements. See the specification for more information: http://mdn.io/animation.\\n\\n\",\n \"67\": \"You must provide a template to this method.\\n\\n\",\n \"68\": \"You passed an unsupported selector state to this method.\\n\\n\",\n \"69\": \"Expected a string ending in \\\"px\\\" or a number passed as the first argument to %s(), got %s instead.\\n\\n\",\n \"70\": \"Expected a string ending in \\\"px\\\" or a number passed as the second argument to %s(), got %s instead.\\n\\n\",\n \"71\": \"Passed invalid pixel value %s to %s(), please pass a value like \\\"12px\\\" or 12.\\n\\n\",\n \"72\": \"Passed invalid base value %s to %s(), please pass a value like \\\"12px\\\" or 12.\\n\\n\",\n \"73\": \"Please provide a valid CSS variable.\\n\\n\",\n \"74\": \"CSS variable not found.\\n\"\n};\n/**\n * super basic version of sprintf\n * @private\n */\n\nfunction format() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n var a = args[0];\n var b = [];\n var c;\n\n for (c = 1; c < args.length; c += 1) {\n b.push(args[c]);\n }\n\n b.forEach(function (d) {\n a = a.replace(/%[a-z]/, d);\n });\n return a;\n}\n/**\n * Create an error file out of errors.md for development and a simple web link to the full errors\n * in production mode.\n * @private\n */\n\n\nvar PolishedError = /*#__PURE__*/function (_Error) {\n _inheritsLoose(PolishedError, _Error);\n\n function PolishedError(code) {\n var _this;\n\n if (process.env.NODE_ENV === 'production') {\n _this = _Error.call(this, \"An error occurred. See https://github.com/styled-components/polished/blob/master/src/internalHelpers/errors.md#\" + code + \" for more information.\") || this;\n } else {\n for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n args[_key2 - 1] = arguments[_key2];\n }\n\n _this = _Error.call(this, format.apply(void 0, [ERRORS[code]].concat(args))) || this;\n }\n\n return _assertThisInitialized(_this);\n }\n\n return PolishedError;\n}( /*#__PURE__*/_wrapNativeSuper(Error));\n\nvar unitRegExp = /((?!\\w)a|na|hc|mc|dg|me[r]?|xe|ni(?![a-zA-Z])|mm|cp|tp|xp|q(?!s)|hv|xamv|nimv|wv|sm|s(?!\\D|$)|ged|darg?|nrut)/g; // Merges additional math functionality into the defaults.\n\nfunction mergeSymbolMaps(additionalSymbols) {\n var symbolMap = {};\n symbolMap.symbols = additionalSymbols ? _extends({}, defaultMathSymbols.symbols, {}, additionalSymbols.symbols) : _extends({}, defaultMathSymbols.symbols);\n return symbolMap;\n}\n\nfunction exec(operators, values) {\n var _ref;\n\n var op = operators.pop();\n values.push(op.f.apply(op, (_ref = []).concat.apply(_ref, values.splice(-op.argCount))));\n return op.precedence;\n}\n\nfunction calculate(expression, additionalSymbols) {\n var symbolMap = mergeSymbolMaps(additionalSymbols);\n var match;\n var operators = [symbolMap.symbols['('].prefix];\n var values = [];\n var pattern = new RegExp( // Pattern for numbers\n \"\\\\d+(?:\\\\.\\\\d+)?|\" + // ...and patterns for individual operators/function names\n Object.keys(symbolMap.symbols).map(function (key) {\n return symbolMap.symbols[key];\n }) // longer symbols should be listed first\n // $FlowFixMe\n .sort(function (a, b) {\n return b.symbol.length - a.symbol.length;\n }) // $FlowFixMe\n .map(function (val) {\n return val.regSymbol;\n }).join('|') + \"|(\\\\S)\", 'g');\n pattern.lastIndex = 0; // Reset regular expression object\n\n var afterValue = false;\n\n do {\n match = pattern.exec(expression);\n\n var _ref2 = match || [')', undefined],\n token = _ref2[0],\n bad = _ref2[1];\n\n var notNumber = symbolMap.symbols[token];\n var notNewValue = notNumber && !notNumber.prefix && !notNumber.func;\n var notAfterValue = !notNumber || !notNumber.postfix && !notNumber.infix; // Check for syntax errors:\n\n if (bad || (afterValue ? notAfterValue : notNewValue)) {\n throw new PolishedError(37, match ? match.index : expression.length, expression);\n }\n\n if (afterValue) {\n // We either have an infix or postfix operator (they should be mutually exclusive)\n var curr = notNumber.postfix || notNumber.infix;\n\n do {\n var prev = operators[operators.length - 1];\n if ((curr.precedence - prev.precedence || prev.rightToLeft) > 0) break; // Apply previous operator, since it has precedence over current one\n } while (exec(operators, values)); // Exit loop after executing an opening parenthesis or function\n\n\n afterValue = curr.notation === 'postfix';\n\n if (curr.symbol !== ')') {\n operators.push(curr); // Postfix always has precedence over any operator that follows after it\n\n if (afterValue) exec(operators, values);\n }\n } else if (notNumber) {\n // prefix operator or function\n operators.push(notNumber.prefix || notNumber.func);\n\n if (notNumber.func) {\n // Require an opening parenthesis\n match = pattern.exec(expression);\n\n if (!match || match[0] !== '(') {\n throw new PolishedError(38, match ? match.index : expression.length, expression);\n }\n }\n } else {\n // number\n values.push(+token);\n afterValue = true;\n }\n } while (match && operators.length);\n\n if (operators.length) {\n throw new PolishedError(39, match ? match.index : expression.length, expression);\n } else if (match) {\n throw new PolishedError(40, match ? match.index : expression.length, expression);\n } else {\n return values.pop();\n }\n}\n\nfunction reverseString(str) {\n return str.split('').reverse().join('');\n}\n/**\n * Helper for doing math with CSS Units. Accepts a formula as a string. All values in the formula must have the same unit (or be unitless). Supports complex formulas utliziing addition, subtraction, multiplication, division, square root, powers, factorial, min, max, as well as parentheses for order of operation.\n *\n *In cases where you need to do calculations with mixed units where one unit is a [relative length unit](https://developer.mozilla.org/en-US/docs/Web/CSS/length#Relative_length_units), you will want to use [CSS Calc](https://developer.mozilla.org/en-US/docs/Web/CSS/calc).\n *\n * *warning* While we've done everything possible to ensure math safely evalutes formulas expressed as strings, you should always use extreme caution when passing `math` user provided values.\n * @example\n * // Styles as object usage\n * const styles = {\n * fontSize: math('12rem + 8rem'),\n * fontSize: math('(12px + 2px) * 3'),\n * fontSize: math('3px^2 + sqrt(4)'),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * fontSize: ${math('12rem + 8rem')};\n * fontSize: ${math('(12px + 2px) * 3')};\n * fontSize: ${math('3px^2 + sqrt(4)')};\n * `\n *\n * // CSS as JS Output\n *\n * div: {\n * fontSize: '20rem',\n * fontSize: '42px',\n * fontSize: '11px',\n * }\n */\n\n\nfunction math(formula, additionalSymbols) {\n var reversedFormula = reverseString(formula);\n var formulaMatch = reversedFormula.match(unitRegExp); // Check that all units are the same\n\n if (formulaMatch && !formulaMatch.every(function (unit) {\n return unit === formulaMatch[0];\n })) {\n throw new PolishedError(41);\n }\n\n var cleanFormula = reverseString(reversedFormula.replace(unitRegExp, ''));\n return \"\" + calculate(cleanFormula, additionalSymbols) + (formulaMatch ? reverseString(formulaMatch[0]) : '');\n}\n\nvar cssVariableRegex = /--[\\S]*/g;\n/**\n * Fetches the value of a passed CSS Variable.\n *\n * Passthrough can be enabled (off by default) for when you are unsure of the input and want non-variable values to be returned instead of an error.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * 'background': cssVar('--background-color'),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${cssVar('--background-color')};\n * `\n *\n * // CSS in JS Output\n *\n * element {\n * 'background': 'red'\n * }\n */\n\nfunction cssVar(cssVariable, passThrough) {\n if (!cssVariable || !cssVariable.match(cssVariableRegex)) {\n if (passThrough) return cssVariable;\n throw new PolishedError(73);\n }\n\n var variableValue;\n /* eslint-disable */\n\n /* istanbul ignore next */\n\n if (typeof document !== 'undefined' && document.documentElement !== null) {\n variableValue = getComputedStyle(document.documentElement).getPropertyValue(cssVariable);\n }\n /* eslint-enable */\n\n\n if (variableValue) {\n return variableValue.trim();\n } else {\n throw new PolishedError(74);\n }\n} // @private\n\n\nfunction capitalizeString(string) {\n return string.charAt(0).toUpperCase() + string.slice(1);\n}\n\nvar positionMap = ['Top', 'Right', 'Bottom', 'Left'];\n\nfunction generateProperty(property, position) {\n if (!property) return position.toLowerCase();\n var splitProperty = property.split('-');\n\n if (splitProperty.length > 1) {\n splitProperty.splice(1, 0, position);\n return splitProperty.reduce(function (acc, val) {\n return \"\" + acc + capitalizeString(val);\n });\n }\n\n var joinedProperty = property.replace(/([a-z])([A-Z])/g, \"$1\" + position + \"$2\");\n return property === joinedProperty ? \"\" + property + position : joinedProperty;\n}\n\nfunction generateStyles(property, valuesWithDefaults) {\n var styles = {};\n\n for (var i = 0; i < valuesWithDefaults.length; i += 1) {\n if (valuesWithDefaults[i] || valuesWithDefaults[i] === 0) {\n styles[generateProperty(property, positionMap[i])] = valuesWithDefaults[i];\n }\n }\n\n return styles;\n}\n/**\n * Enables shorthand for direction-based properties. It accepts a property (hyphenated or camelCased) and up to four values that map to top, right, bottom, and left, respectively. You can optionally pass an empty string to get only the directional values as properties. You can also optionally pass a null argument for a directional value to ignore it.\n * @example\n * // Styles as object usage\n * const styles = {\n * ...directionalProperty('padding', '12px', '24px', '36px', '48px')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${directionalProperty('padding', '12px', '24px', '36px', '48px')}\n * `\n *\n * // CSS as JS Output\n *\n * div {\n * 'paddingTop': '12px',\n * 'paddingRight': '24px',\n * 'paddingBottom': '36px',\n * 'paddingLeft': '48px'\n * }\n */\n\n\nfunction directionalProperty(property) {\n for (var _len = arguments.length, values = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n values[_key - 1] = arguments[_key];\n } // prettier-ignore\n\n\n var firstValue = values[0],\n _values$ = values[1],\n secondValue = _values$ === void 0 ? firstValue : _values$,\n _values$2 = values[2],\n thirdValue = _values$2 === void 0 ? firstValue : _values$2,\n _values$3 = values[3],\n fourthValue = _values$3 === void 0 ? secondValue : _values$3;\n var valuesWithDefaults = [firstValue, secondValue, thirdValue, fourthValue];\n return generateStyles(property, valuesWithDefaults);\n}\n/**\n * Check if a string ends with something\n * @private\n */\n\n\nfunction endsWith(string, suffix) {\n return string.substr(-suffix.length) === suffix;\n}\n\nvar cssRegex = /^([+-]?(?:\\d+|\\d*\\.\\d+))([a-z]*|%)$/;\n/**\n * Returns a given CSS value minus its unit of measure.\n *\n * @deprecated - stripUnit's unitReturn functionality has been marked for deprecation in polished 4.0. It's functionality has been been moved to getValueAndUnit.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * '--dimension': stripUnit('100px')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * --dimension: ${stripUnit('100px')};\n * `\n *\n * // CSS in JS Output\n *\n * element {\n * '--dimension': 100\n * }\n */\n\nfunction stripUnit(value, unitReturn) {\n if (typeof value !== 'string') return unitReturn ? [value, undefined] : value;\n var matchedValue = value.match(cssRegex);\n\n if (unitReturn) {\n // eslint-disable-next-line no-console\n console.warn(\"stripUnit's unitReturn functionality has been marked for deprecation in polished 4.0. It's functionality has been been moved to getValueAndUnit.\");\n if (matchedValue) return [parseFloat(value), matchedValue[2]];\n return [value, undefined];\n }\n\n if (matchedValue) return parseFloat(value);\n return value;\n}\n/**\n * Factory function that creates pixel-to-x converters\n * @private\n */\n\n\nvar pxtoFactory = function pxtoFactory(to) {\n return function (pxval, base) {\n if (base === void 0) {\n base = '16px';\n }\n\n var newPxval = pxval;\n var newBase = base;\n\n if (typeof pxval === 'string') {\n if (!endsWith(pxval, 'px')) {\n throw new PolishedError(69, to, pxval);\n }\n\n newPxval = stripUnit(pxval);\n }\n\n if (typeof base === 'string') {\n if (!endsWith(base, 'px')) {\n throw new PolishedError(70, to, base);\n }\n\n newBase = stripUnit(base);\n }\n\n if (typeof newPxval === 'string') {\n throw new PolishedError(71, pxval, to);\n }\n\n if (typeof newBase === 'string') {\n throw new PolishedError(72, base, to);\n }\n\n return \"\" + newPxval / newBase + to;\n };\n};\n/**\n * Convert pixel value to ems. The default base value is 16px, but can be changed by passing a\n * second argument to the function.\n * @function\n * @param {string|number} pxval\n * @param {string|number} [base='16px']\n * @example\n * // Styles as object usage\n * const styles = {\n * 'height': em('16px')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * height: ${em('16px')}\n * `\n *\n * // CSS in JS Output\n *\n * element {\n * 'height': '1em'\n * }\n */\n\n\nvar em = /*#__PURE__*/pxtoFactory('em');\nvar cssRegex$1 = /^([+-]?(?:\\d+|\\d*\\.\\d+))([a-z]*|%)$/;\n/**\n * Returns a given CSS value and its unit as elements of an array.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * '--dimension': getValueAndUnit('100px')[0],\n * '--unit': getValueAndUnit('100px')[1],\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * --dimension: ${getValueAndUnit('100px')[0]};\n * --unit: ${getValueAndUnit('100px')[1]};\n * `\n *\n * // CSS in JS Output\n *\n * element {\n * '--dimension': 100,\n * '--unit': 'px',\n * }\n */\n\nfunction getValueAndUnit(value) {\n if (typeof value !== 'string') return [value, ''];\n var matchedValue = value.match(cssRegex$1);\n if (matchedValue) return [parseFloat(value), matchedValue[2]];\n return [value, undefined];\n}\n\nvar ratioNames = {\n minorSecond: 1.067,\n majorSecond: 1.125,\n minorThird: 1.2,\n majorThird: 1.25,\n perfectFourth: 1.333,\n augFourth: 1.414,\n perfectFifth: 1.5,\n minorSixth: 1.6,\n goldenSection: 1.618,\n majorSixth: 1.667,\n minorSeventh: 1.778,\n majorSeventh: 1.875,\n octave: 2,\n majorTenth: 2.5,\n majorEleventh: 2.667,\n majorTwelfth: 3,\n doubleOctave: 4\n};\n\nfunction getRatio(ratioName) {\n return ratioNames[ratioName];\n}\n/**\n * Establish consistent measurements and spacial relationships throughout your projects by incrementing an em or rem value up or down a defined scale. We provide a list of commonly used scales as pre-defined variables.\n * @example\n * // Styles as object usage\n * const styles = {\n * // Increment two steps up the default scale\n * 'fontSize': modularScale(2)\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * // Increment two steps up the default scale\n * fontSize: ${modularScale(2)}\n * `\n *\n * // CSS in JS Output\n *\n * element {\n * 'fontSize': '1.77689em'\n * }\n */\n\n\nfunction modularScale(steps, base, ratio) {\n if (base === void 0) {\n base = '1em';\n }\n\n if (ratio === void 0) {\n ratio = 1.333;\n }\n\n if (typeof steps !== 'number') {\n throw new PolishedError(42);\n }\n\n if (typeof ratio === 'string' && !ratioNames[ratio]) {\n throw new PolishedError(43);\n }\n\n var _ref = typeof base === 'string' ? getValueAndUnit(base) : [base, ''],\n realBase = _ref[0],\n unit = _ref[1];\n\n var realRatio = typeof ratio === 'string' ? getRatio(ratio) : ratio;\n\n if (typeof realBase === 'string') {\n throw new PolishedError(44, base);\n }\n\n return \"\" + realBase * Math.pow(realRatio, steps) + (unit || '');\n}\n/**\n * Convert pixel value to rems. The default base value is 16px, but can be changed by passing a\n * second argument to the function.\n * @function\n * @param {string|number} pxval\n * @param {string|number} [base='16px']\n * @example\n * // Styles as object usage\n * const styles = {\n * 'height': rem('16px')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * height: ${rem('16px')}\n * `\n *\n * // CSS in JS Output\n *\n * element {\n * 'height': '1rem'\n * }\n */\n\n\nvar rem = /*#__PURE__*/pxtoFactory('rem');\n/**\n * Returns a CSS calc formula for linear interpolation of a property between two values. Accepts optional minScreen (defaults to '320px') and maxScreen (defaults to '1200px').\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * fontSize: between('20px', '100px', '400px', '1000px'),\n * fontSize: between('20px', '100px')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * fontSize: ${between('20px', '100px', '400px', '1000px')};\n * fontSize: ${between('20px', '100px')}\n * `\n *\n * // CSS as JS Output\n *\n * h1: {\n * 'fontSize': 'calc(-33.33333333333334px + 13.333333333333334vw)',\n * 'fontSize': 'calc(-9.090909090909093px + 9.090909090909092vw)'\n * }\n */\n\nfunction between(fromSize, toSize, minScreen, maxScreen) {\n if (minScreen === void 0) {\n minScreen = '320px';\n }\n\n if (maxScreen === void 0) {\n maxScreen = '1200px';\n }\n\n var _getValueAndUnit = getValueAndUnit(fromSize),\n unitlessFromSize = _getValueAndUnit[0],\n fromSizeUnit = _getValueAndUnit[1];\n\n var _getValueAndUnit2 = getValueAndUnit(toSize),\n unitlessToSize = _getValueAndUnit2[0],\n toSizeUnit = _getValueAndUnit2[1];\n\n var _getValueAndUnit3 = getValueAndUnit(minScreen),\n unitlessMinScreen = _getValueAndUnit3[0],\n minScreenUnit = _getValueAndUnit3[1];\n\n var _getValueAndUnit4 = getValueAndUnit(maxScreen),\n unitlessMaxScreen = _getValueAndUnit4[0],\n maxScreenUnit = _getValueAndUnit4[1];\n\n if (typeof unitlessMinScreen !== 'number' || typeof unitlessMaxScreen !== 'number' || !minScreenUnit || !maxScreenUnit || minScreenUnit !== maxScreenUnit) {\n throw new PolishedError(47);\n }\n\n if (typeof unitlessFromSize !== 'number' || typeof unitlessToSize !== 'number' || fromSizeUnit !== toSizeUnit) {\n throw new PolishedError(48);\n }\n\n var slope = (unitlessFromSize - unitlessToSize) / (unitlessMinScreen - unitlessMaxScreen);\n var base = unitlessToSize - slope * unitlessMaxScreen;\n return \"calc(\" + base.toFixed(2) + (fromSizeUnit || '') + \" + \" + (100 * slope).toFixed(2) + \"vw)\";\n}\n/**\n * CSS to contain a float (credit to CSSMojo).\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * ...clearFix(),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${clearFix()}\n * `\n *\n * // CSS as JS Output\n *\n * '&::after': {\n * 'clear': 'both',\n * 'content': '\"\"',\n * 'display': 'table'\n * }\n */\n\n\nfunction clearFix(parent) {\n var _ref;\n\n if (parent === void 0) {\n parent = '&';\n }\n\n var pseudoSelector = parent + \"::after\";\n return _ref = {}, _ref[pseudoSelector] = {\n clear: 'both',\n content: '\"\"',\n display: 'table'\n }, _ref;\n}\n/**\n * CSS to fully cover an area. Can optionally be passed an offset to act as a \"padding\".\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * ...cover()\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${cover()}\n * `\n *\n * // CSS as JS Output\n *\n * div: {\n * 'position': 'absolute',\n * 'top': '0',\n * 'right: '0',\n * 'bottom': '0',\n * 'left: '0'\n * }\n */\n\n\nfunction cover(offset) {\n if (offset === void 0) {\n offset = 0;\n }\n\n return {\n position: 'absolute',\n top: offset,\n right: offset,\n bottom: offset,\n left: offset\n };\n}\n/**\n * CSS to represent truncated text with an ellipsis.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * ...ellipsis('250px')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${ellipsis('250px')}\n * `\n *\n * // CSS as JS Output\n *\n * div: {\n * 'display': 'inline-block',\n * 'maxWidth': '250px',\n * 'overflow': 'hidden',\n * 'textOverflow': 'ellipsis',\n * 'whiteSpace': 'nowrap',\n * 'wordWrap': 'normal'\n * }\n */\n\n\nfunction ellipsis(width) {\n if (width === void 0) {\n width = '100%';\n }\n\n return {\n display: 'inline-block',\n maxWidth: width,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n wordWrap: 'normal'\n };\n}\n\nfunction _createForOfIteratorHelperLoose(o) {\n var i = 0;\n\n if (typeof Symbol === \"undefined\" || o[Symbol.iterator] == null) {\n if (Array.isArray(o) || (o = _unsupportedIterableToArray(o))) return function () {\n if (i >= o.length) return {\n done: true\n };\n return {\n done: false,\n value: o[i++]\n };\n };\n throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n }\n\n i = o[Symbol.iterator]();\n return i.next.bind(i);\n}\n\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(n);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);\n}\n\nfunction _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n\n return arr2;\n}\n/**\n * Returns a set of media queries that resizes a property (or set of properties) between a provided fromSize and toSize. Accepts optional minScreen (defaults to '320px') and maxScreen (defaults to '1200px') to constrain the interpolation.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * ...fluidRange(\n * {\n * prop: 'padding',\n * fromSize: '20px',\n * toSize: '100px',\n * },\n * '400px',\n * '1000px',\n * )\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${fluidRange(\n * {\n * prop: 'padding',\n * fromSize: '20px',\n * toSize: '100px',\n * },\n * '400px',\n * '1000px',\n * )}\n * `\n *\n * // CSS as JS Output\n *\n * div: {\n * \"@media (min-width: 1000px)\": Object {\n * \"padding\": \"100px\",\n * },\n * \"@media (min-width: 400px)\": Object {\n * \"padding\": \"calc(-33.33333333333334px + 13.333333333333334vw)\",\n * },\n * \"padding\": \"20px\",\n * }\n */\n\n\nfunction fluidRange(cssProp, minScreen, maxScreen) {\n if (minScreen === void 0) {\n minScreen = '320px';\n }\n\n if (maxScreen === void 0) {\n maxScreen = '1200px';\n }\n\n if (!Array.isArray(cssProp) && typeof cssProp !== 'object' || cssProp === null) {\n throw new PolishedError(49);\n }\n\n if (Array.isArray(cssProp)) {\n var mediaQueries = {};\n var fallbacks = {};\n\n for (var _iterator = _createForOfIteratorHelperLoose(cssProp), _step; !(_step = _iterator()).done;) {\n var _extends2, _extends3;\n\n var obj = _step.value;\n\n if (!obj.prop || !obj.fromSize || !obj.toSize) {\n throw new PolishedError(50);\n }\n\n fallbacks[obj.prop] = obj.fromSize;\n mediaQueries[\"@media (min-width: \" + minScreen + \")\"] = _extends({}, mediaQueries[\"@media (min-width: \" + minScreen + \")\"], (_extends2 = {}, _extends2[obj.prop] = between(obj.fromSize, obj.toSize, minScreen, maxScreen), _extends2));\n mediaQueries[\"@media (min-width: \" + maxScreen + \")\"] = _extends({}, mediaQueries[\"@media (min-width: \" + maxScreen + \")\"], (_extends3 = {}, _extends3[obj.prop] = obj.toSize, _extends3));\n }\n\n return _extends({}, fallbacks, {}, mediaQueries);\n } else {\n var _ref, _ref2, _ref3;\n\n if (!cssProp.prop || !cssProp.fromSize || !cssProp.toSize) {\n throw new PolishedError(51);\n }\n\n return _ref3 = {}, _ref3[cssProp.prop] = cssProp.fromSize, _ref3[\"@media (min-width: \" + minScreen + \")\"] = (_ref = {}, _ref[cssProp.prop] = between(cssProp.fromSize, cssProp.toSize, minScreen, maxScreen), _ref), _ref3[\"@media (min-width: \" + maxScreen + \")\"] = (_ref2 = {}, _ref2[cssProp.prop] = cssProp.toSize, _ref2), _ref3;\n }\n}\n\nvar dataURIRegex = /^\\s*data:([a-z]+\\/[a-z-]+(;[a-z-]+=[a-z-]+)?)?(;charset=[a-z0-9-]+)?(;base64)?,[a-z0-9!$&',()*+,;=\\-._~:@/?%\\s]*\\s*$/i;\nvar formatHintMap = {\n woff: 'woff',\n woff2: 'woff2',\n ttf: 'truetype',\n otf: 'opentype',\n eot: 'embedded-opentype',\n svg: 'svg',\n svgz: 'svg'\n};\n\nfunction generateFormatHint(format, formatHint) {\n if (!formatHint) return '';\n return \" format(\\\"\" + formatHintMap[format] + \"\\\")\";\n}\n\nfunction isDataURI(fontFilePath) {\n return !!fontFilePath.match(dataURIRegex);\n}\n\nfunction generateFileReferences(fontFilePath, fileFormats, formatHint) {\n if (isDataURI(fontFilePath)) {\n return \"url(\\\"\" + fontFilePath + \"\\\")\" + generateFormatHint(fileFormats[0], formatHint);\n }\n\n var fileFontReferences = fileFormats.map(function (format) {\n return \"url(\\\"\" + fontFilePath + \".\" + format + \"\\\")\" + generateFormatHint(format, formatHint);\n });\n return fileFontReferences.join(', ');\n}\n\nfunction generateLocalReferences(localFonts) {\n var localFontReferences = localFonts.map(function (font) {\n return \"local(\\\"\" + font + \"\\\")\";\n });\n return localFontReferences.join(', ');\n}\n\nfunction generateSources(fontFilePath, localFonts, fileFormats, formatHint) {\n var fontReferences = [];\n if (localFonts) fontReferences.push(generateLocalReferences(localFonts));\n\n if (fontFilePath) {\n fontReferences.push(generateFileReferences(fontFilePath, fileFormats, formatHint));\n }\n\n return fontReferences.join(', ');\n}\n/**\n * CSS for a @font-face declaration.\n *\n * @example\n * // Styles as object basic usage\n * const styles = {\n * ...fontFace({\n * 'fontFamily': 'Sans-Pro',\n * 'fontFilePath': 'path/to/file'\n * })\n * }\n *\n * // styled-components basic usage\n * const GlobalStyle = createGlobalStyle`${\n * fontFace({\n * 'fontFamily': 'Sans-Pro',\n * 'fontFilePath': 'path/to/file'\n * }\n * )}`\n *\n * // CSS as JS Output\n *\n * '@font-face': {\n * 'fontFamily': 'Sans-Pro',\n * 'src': 'url(\"path/to/file.eot\"), url(\"path/to/file.woff2\"), url(\"path/to/file.woff\"), url(\"path/to/file.ttf\"), url(\"path/to/file.svg\")',\n * }\n */\n\n\nfunction fontFace(_ref) {\n var fontFamily = _ref.fontFamily,\n fontFilePath = _ref.fontFilePath,\n fontStretch = _ref.fontStretch,\n fontStyle = _ref.fontStyle,\n fontVariant = _ref.fontVariant,\n fontWeight = _ref.fontWeight,\n _ref$fileFormats = _ref.fileFormats,\n fileFormats = _ref$fileFormats === void 0 ? ['eot', 'woff2', 'woff', 'ttf', 'svg'] : _ref$fileFormats,\n _ref$formatHint = _ref.formatHint,\n formatHint = _ref$formatHint === void 0 ? false : _ref$formatHint,\n localFonts = _ref.localFonts,\n unicodeRange = _ref.unicodeRange,\n fontDisplay = _ref.fontDisplay,\n fontVariationSettings = _ref.fontVariationSettings,\n fontFeatureSettings = _ref.fontFeatureSettings; // Error Handling\n\n if (!fontFamily) throw new PolishedError(55);\n\n if (!fontFilePath && !localFonts) {\n throw new PolishedError(52);\n }\n\n if (localFonts && !Array.isArray(localFonts)) {\n throw new PolishedError(53);\n }\n\n if (!Array.isArray(fileFormats)) {\n throw new PolishedError(54);\n }\n\n var fontFaceDeclaration = {\n '@font-face': {\n fontFamily: fontFamily,\n src: generateSources(fontFilePath, localFonts, fileFormats, formatHint),\n unicodeRange: unicodeRange,\n fontStretch: fontStretch,\n fontStyle: fontStyle,\n fontVariant: fontVariant,\n fontWeight: fontWeight,\n fontDisplay: fontDisplay,\n fontVariationSettings: fontVariationSettings,\n fontFeatureSettings: fontFeatureSettings\n }\n }; // Removes undefined fields for cleaner css object.\n\n return JSON.parse(JSON.stringify(fontFaceDeclaration));\n}\n/**\n * CSS to hide text to show a background image in a SEO-friendly way.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * 'backgroundImage': 'url(logo.png)',\n * ...hideText(),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * backgroundImage: url(logo.png);\n * ${hideText()};\n * `\n *\n * // CSS as JS Output\n *\n * 'div': {\n * 'backgroundImage': 'url(logo.png)',\n * 'textIndent': '101%',\n * 'overflow': 'hidden',\n * 'whiteSpace': 'nowrap',\n * }\n */\n\n\nfunction hideText() {\n return {\n textIndent: '101%',\n overflow: 'hidden',\n whiteSpace: 'nowrap'\n };\n}\n/**\n * CSS to hide content visually but remain accessible to screen readers.\n * from [HTML5 Boilerplate](https://github.com/h5bp/html5-boilerplate/blob/9a176f57af1cfe8ec70300da4621fb9b07e5fa31/src/css/main.css#L121)\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * ...hideVisually(),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${hideVisually()};\n * `\n *\n * // CSS as JS Output\n *\n * 'div': {\n * 'border': '0',\n * 'clip': 'rect(0 0 0 0)',\n * 'height': '1px',\n * 'margin': '-1px',\n * 'overflow': 'hidden',\n * 'padding': '0',\n * 'position': 'absolute',\n * 'whiteSpace': 'nowrap',\n * 'width': '1px',\n * }\n */\n\n\nfunction hideVisually() {\n return {\n border: '0',\n clip: 'rect(0 0 0 0)',\n height: '1px',\n margin: '-1px',\n overflow: 'hidden',\n padding: '0',\n position: 'absolute',\n whiteSpace: 'nowrap',\n width: '1px'\n };\n}\n/**\n * Generates a media query to target HiDPI devices.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * [hiDPI(1.5)]: {\n * width: 200px;\n * }\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${hiDPI(1.5)} {\n * width: 200px;\n * }\n * `\n *\n * // CSS as JS Output\n *\n * '@media only screen and (-webkit-min-device-pixel-ratio: 1.5),\n * only screen and (min--moz-device-pixel-ratio: 1.5),\n * only screen and (-o-min-device-pixel-ratio: 1.5/1),\n * only screen and (min-resolution: 144dpi),\n * only screen and (min-resolution: 1.5dppx)': {\n * 'width': '200px',\n * }\n */\n\n\nfunction hiDPI(ratio) {\n if (ratio === void 0) {\n ratio = 1.3;\n }\n\n return \"\\n @media only screen and (-webkit-min-device-pixel-ratio: \" + ratio + \"),\\n only screen and (min--moz-device-pixel-ratio: \" + ratio + \"),\\n only screen and (-o-min-device-pixel-ratio: \" + ratio + \"/1),\\n only screen and (min-resolution: \" + Math.round(ratio * 96) + \"dpi),\\n only screen and (min-resolution: \" + ratio + \"dppx)\\n \";\n}\n\nfunction constructGradientValue(literals) {\n var template = '';\n\n for (var _len = arguments.length, substitutions = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n substitutions[_key - 1] = arguments[_key];\n }\n\n for (var i = 0; i < literals.length; i += 1) {\n template += literals[i];\n\n if (i === substitutions.length - 1 && substitutions[i]) {\n var definedValues = substitutions.filter(function (substitute) {\n return !!substitute;\n }); // Adds leading coma if properties preceed color-stops\n\n if (definedValues.length > 1) {\n template = template.slice(0, -1);\n template += \", \" + substitutions[i]; // No trailing space if color-stops is the only param provided\n } else if (definedValues.length === 1) {\n template += \"\" + substitutions[i];\n }\n } else if (substitutions[i]) {\n template += substitutions[i] + \" \";\n }\n }\n\n return template.trim();\n}\n\nfunction _templateObject() {\n var data = _taggedTemplateLiteralLoose([\"linear-gradient(\", \"\", \")\"]);\n\n _templateObject = function _templateObject() {\n return data;\n };\n\n return data;\n}\n/**\n * CSS for declaring a linear gradient, including a fallback background-color. The fallback is either the first color-stop or an explicitly passed fallback color.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * ...linearGradient({\n colorStops: ['#00FFFF 0%', 'rgba(0, 0, 255, 0) 50%', '#0000FF 95%'],\n toDirection: 'to top right',\n fallback: '#FFF',\n })\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${linearGradient({\n colorStops: ['#00FFFF 0%', 'rgba(0, 0, 255, 0) 50%', '#0000FF 95%'],\n toDirection: 'to top right',\n fallback: '#FFF',\n })}\n *`\n *\n * // CSS as JS Output\n *\n * div: {\n * 'backgroundColor': '#FFF',\n * 'backgroundImage': 'linear-gradient(to top right, #00FFFF 0%, rgba(0, 0, 255, 0) 50%, #0000FF 95%)',\n * }\n */\n\n\nfunction linearGradient(_ref) {\n var colorStops = _ref.colorStops,\n fallback = _ref.fallback,\n _ref$toDirection = _ref.toDirection,\n toDirection = _ref$toDirection === void 0 ? '' : _ref$toDirection;\n\n if (!colorStops || colorStops.length < 2) {\n throw new PolishedError(56);\n }\n\n return {\n backgroundColor: fallback || colorStops[0].split(' ')[0],\n backgroundImage: constructGradientValue(_templateObject(), toDirection, colorStops.join(', '))\n };\n}\n/**\n * CSS to normalize abnormalities across browsers (normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css)\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * ...normalize(),\n * }\n *\n * // styled-components usage\n * const GlobalStyle = createGlobalStyle`${normalize()}`\n *\n * // CSS as JS Output\n *\n * html {\n * lineHeight: 1.15,\n * textSizeAdjust: 100%,\n * } ...\n */\n\n\nfunction normalize() {\n var _ref;\n\n return [(_ref = {\n html: {\n lineHeight: '1.15',\n textSizeAdjust: '100%'\n },\n body: {\n margin: '0'\n },\n main: {\n display: 'block'\n },\n h1: {\n fontSize: '2em',\n margin: '0.67em 0'\n },\n hr: {\n boxSizing: 'content-box',\n height: '0',\n overflow: 'visible'\n },\n pre: {\n fontFamily: 'monospace, monospace',\n fontSize: '1em'\n },\n a: {\n backgroundColor: 'transparent'\n },\n 'abbr[title]': {\n borderBottom: 'none',\n textDecoration: 'underline'\n }\n }, _ref[\"b,\\n strong\"] = {\n fontWeight: 'bolder'\n }, _ref[\"code,\\n kbd,\\n samp\"] = {\n fontFamily: 'monospace, monospace',\n fontSize: '1em'\n }, _ref.small = {\n fontSize: '80%'\n }, _ref[\"sub,\\n sup\"] = {\n fontSize: '75%',\n lineHeight: '0',\n position: 'relative',\n verticalAlign: 'baseline'\n }, _ref.sub = {\n bottom: '-0.25em'\n }, _ref.sup = {\n top: '-0.5em'\n }, _ref.img = {\n borderStyle: 'none'\n }, _ref[\"button,\\n input,\\n optgroup,\\n select,\\n textarea\"] = {\n fontFamily: 'inherit',\n fontSize: '100%',\n lineHeight: '1.15',\n margin: '0'\n }, _ref[\"button,\\n input\"] = {\n overflow: 'visible'\n }, _ref[\"button,\\n select\"] = {\n textTransform: 'none'\n }, _ref[\"button,\\n html [type=\\\"button\\\"],\\n [type=\\\"reset\\\"],\\n [type=\\\"submit\\\"]\"] = {\n WebkitAppearance: 'button'\n }, _ref[\"button::-moz-focus-inner,\\n [type=\\\"button\\\"]::-moz-focus-inner,\\n [type=\\\"reset\\\"]::-moz-focus-inner,\\n [type=\\\"submit\\\"]::-moz-focus-inner\"] = {\n borderStyle: 'none',\n padding: '0'\n }, _ref[\"button:-moz-focusring,\\n [type=\\\"button\\\"]:-moz-focusring,\\n [type=\\\"reset\\\"]:-moz-focusring,\\n [type=\\\"submit\\\"]:-moz-focusring\"] = {\n outline: '1px dotted ButtonText'\n }, _ref.fieldset = {\n padding: '0.35em 0.625em 0.75em'\n }, _ref.legend = {\n boxSizing: 'border-box',\n color: 'inherit',\n display: 'table',\n maxWidth: '100%',\n padding: '0',\n whiteSpace: 'normal'\n }, _ref.progress = {\n verticalAlign: 'baseline'\n }, _ref.textarea = {\n overflow: 'auto'\n }, _ref[\"[type=\\\"checkbox\\\"],\\n [type=\\\"radio\\\"]\"] = {\n boxSizing: 'border-box',\n padding: '0'\n }, _ref[\"[type=\\\"number\\\"]::-webkit-inner-spin-button,\\n [type=\\\"number\\\"]::-webkit-outer-spin-button\"] = {\n height: 'auto'\n }, _ref['[type=\"search\"]'] = {\n WebkitAppearance: 'textfield',\n outlineOffset: '-2px'\n }, _ref['[type=\"search\"]::-webkit-search-decoration'] = {\n WebkitAppearance: 'none'\n }, _ref['::-webkit-file-upload-button'] = {\n WebkitAppearance: 'button',\n font: 'inherit'\n }, _ref.details = {\n display: 'block'\n }, _ref.summary = {\n display: 'list-item'\n }, _ref.template = {\n display: 'none'\n }, _ref['[hidden]'] = {\n display: 'none'\n }, _ref), {\n 'abbr[title]': {\n textDecoration: 'underline dotted'\n }\n }];\n}\n\nfunction _templateObject$1() {\n var data = _taggedTemplateLiteralLoose([\"radial-gradient(\", \"\", \"\", \"\", \")\"]);\n\n _templateObject$1 = function _templateObject() {\n return data;\n };\n\n return data;\n}\n/**\n * CSS for declaring a radial gradient, including a fallback background-color. The fallback is either the first color-stop or an explicitly passed fallback color.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * ...radialGradient({\n * colorStops: ['#00FFFF 0%', 'rgba(0, 0, 255, 0) 50%', '#0000FF 95%'],\n * extent: 'farthest-corner at 45px 45px',\n * position: 'center',\n * shape: 'ellipse',\n * })\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${radialGradient({\n * colorStops: ['#00FFFF 0%', 'rgba(0, 0, 255, 0) 50%', '#0000FF 95%'],\n * extent: 'farthest-corner at 45px 45px',\n * position: 'center',\n * shape: 'ellipse',\n * })}\n *`\n *\n * // CSS as JS Output\n *\n * div: {\n * 'backgroundColor': '#00FFFF',\n * 'backgroundImage': 'radial-gradient(center ellipse farthest-corner at 45px 45px, #00FFFF 0%, rgba(0, 0, 255, 0) 50%, #0000FF 95%)',\n * }\n */\n\n\nfunction radialGradient(_ref) {\n var colorStops = _ref.colorStops,\n _ref$extent = _ref.extent,\n extent = _ref$extent === void 0 ? '' : _ref$extent,\n fallback = _ref.fallback,\n _ref$position = _ref.position,\n position = _ref$position === void 0 ? '' : _ref$position,\n _ref$shape = _ref.shape,\n shape = _ref$shape === void 0 ? '' : _ref$shape;\n\n if (!colorStops || colorStops.length < 2) {\n throw new PolishedError(57);\n }\n\n return {\n backgroundColor: fallback || colorStops[0].split(' ')[0],\n backgroundImage: constructGradientValue(_templateObject$1(), position, shape, extent, colorStops.join(', '))\n };\n}\n/**\n * A helper to generate a retina background image and non-retina\n * background image. The retina background image will output to a HiDPI media query. The mixin uses\n * a _2x.png filename suffix by default.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * ...retinaImage('my-img')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${retinaImage('my-img')}\n * `\n *\n * // CSS as JS Output\n * div {\n * backgroundImage: 'url(my-img.png)',\n * '@media only screen and (-webkit-min-device-pixel-ratio: 1.3),\n * only screen and (min--moz-device-pixel-ratio: 1.3),\n * only screen and (-o-min-device-pixel-ratio: 1.3/1),\n * only screen and (min-resolution: 144dpi),\n * only screen and (min-resolution: 1.5dppx)': {\n * backgroundImage: 'url(my-img_2x.png)',\n * }\n * }\n */\n\n\nfunction retinaImage(filename, backgroundSize, extension, retinaFilename, retinaSuffix) {\n var _ref;\n\n if (extension === void 0) {\n extension = 'png';\n }\n\n if (retinaSuffix === void 0) {\n retinaSuffix = '_2x';\n }\n\n if (!filename) {\n throw new PolishedError(58);\n } // Replace the dot at the beginning of the passed extension if one exists\n\n\n var ext = extension.replace(/^\\./, '');\n var rFilename = retinaFilename ? retinaFilename + \".\" + ext : \"\" + filename + retinaSuffix + \".\" + ext;\n return _ref = {\n backgroundImage: \"url(\" + filename + \".\" + ext + \")\"\n }, _ref[hiDPI()] = _extends({\n backgroundImage: \"url(\" + rFilename + \")\"\n }, backgroundSize ? {\n backgroundSize: backgroundSize\n } : {}), _ref;\n}\n/* eslint-disable key-spacing */\n\n\nvar functionsMap = {\n easeInBack: 'cubic-bezier(0.600, -0.280, 0.735, 0.045)',\n easeInCirc: 'cubic-bezier(0.600, 0.040, 0.980, 0.335)',\n easeInCubic: 'cubic-bezier(0.550, 0.055, 0.675, 0.190)',\n easeInExpo: 'cubic-bezier(0.950, 0.050, 0.795, 0.035)',\n easeInQuad: 'cubic-bezier(0.550, 0.085, 0.680, 0.530)',\n easeInQuart: 'cubic-bezier(0.895, 0.030, 0.685, 0.220)',\n easeInQuint: 'cubic-bezier(0.755, 0.050, 0.855, 0.060)',\n easeInSine: 'cubic-bezier(0.470, 0.000, 0.745, 0.715)',\n easeOutBack: 'cubic-bezier(0.175, 0.885, 0.320, 1.275)',\n easeOutCubic: 'cubic-bezier(0.215, 0.610, 0.355, 1.000)',\n easeOutCirc: 'cubic-bezier(0.075, 0.820, 0.165, 1.000)',\n easeOutExpo: 'cubic-bezier(0.190, 1.000, 0.220, 1.000)',\n easeOutQuad: 'cubic-bezier(0.250, 0.460, 0.450, 0.940)',\n easeOutQuart: 'cubic-bezier(0.165, 0.840, 0.440, 1.000)',\n easeOutQuint: 'cubic-bezier(0.230, 1.000, 0.320, 1.000)',\n easeOutSine: 'cubic-bezier(0.390, 0.575, 0.565, 1.000)',\n easeInOutBack: 'cubic-bezier(0.680, -0.550, 0.265, 1.550)',\n easeInOutCirc: 'cubic-bezier(0.785, 0.135, 0.150, 0.860)',\n easeInOutCubic: 'cubic-bezier(0.645, 0.045, 0.355, 1.000)',\n easeInOutExpo: 'cubic-bezier(1.000, 0.000, 0.000, 1.000)',\n easeInOutQuad: 'cubic-bezier(0.455, 0.030, 0.515, 0.955)',\n easeInOutQuart: 'cubic-bezier(0.770, 0.000, 0.175, 1.000)',\n easeInOutQuint: 'cubic-bezier(0.860, 0.000, 0.070, 1.000)',\n easeInOutSine: 'cubic-bezier(0.445, 0.050, 0.550, 0.950)'\n};\n/* eslint-enable key-spacing */\n\nfunction getTimingFunction(functionName) {\n return functionsMap[functionName];\n}\n/**\n * String to represent common easing functions as demonstrated here: (github.com/jaukia/easie).\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * 'transitionTimingFunction': timingFunctions('easeInQuad')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * transitionTimingFunction: ${timingFunctions('easeInQuad')};\n * `\n *\n * // CSS as JS Output\n *\n * 'div': {\n * 'transitionTimingFunction': 'cubic-bezier(0.550, 0.085, 0.680, 0.530)',\n * }\n */\n\n\nfunction timingFunctions(timingFunction) {\n return getTimingFunction(timingFunction);\n}\n\nvar getBorderWidth = function getBorderWidth(pointingDirection, height, width) {\n var fullWidth = \"\" + width[0] + (width[1] || '');\n var halfWidth = \"\" + width[0] / 2 + (width[1] || '');\n var fullHeight = \"\" + height[0] + (height[1] || '');\n var halfHeight = \"\" + height[0] / 2 + (height[1] || '');\n\n switch (pointingDirection) {\n case 'top':\n return \"0 \" + halfWidth + \" \" + fullHeight + \" \" + halfWidth;\n\n case 'topLeft':\n return fullWidth + \" \" + fullHeight + \" 0 0\";\n\n case 'left':\n return halfHeight + \" \" + fullWidth + \" \" + halfHeight + \" 0\";\n\n case 'bottomLeft':\n return fullWidth + \" 0 0 \" + fullHeight;\n\n case 'bottom':\n return fullHeight + \" \" + halfWidth + \" 0 \" + halfWidth;\n\n case 'bottomRight':\n return \"0 0 \" + fullWidth + \" \" + fullHeight;\n\n case 'right':\n return halfHeight + \" 0 \" + halfHeight + \" \" + fullWidth;\n\n case 'topRight':\n default:\n return \"0 \" + fullWidth + \" \" + fullHeight + \" 0\";\n }\n};\n\nvar getBorderColor = function getBorderColor(pointingDirection, foregroundColor, backgroundColor) {\n switch (pointingDirection) {\n case 'top':\n case 'bottomRight':\n return backgroundColor + \" \" + backgroundColor + \" \" + foregroundColor + \" \" + backgroundColor;\n\n case 'right':\n case 'bottomLeft':\n return backgroundColor + \" \" + backgroundColor + \" \" + backgroundColor + \" \" + foregroundColor;\n\n case 'bottom':\n case 'topLeft':\n return foregroundColor + \" \" + backgroundColor + \" \" + backgroundColor + \" \" + backgroundColor;\n\n case 'left':\n case 'topRight':\n return backgroundColor + \" \" + foregroundColor + \" \" + backgroundColor + \" \" + backgroundColor;\n\n default:\n throw new PolishedError(59);\n }\n};\n/**\n * CSS to represent triangle with any pointing direction with an optional background color.\n *\n * @example\n * // Styles as object usage\n *\n * const styles = {\n * ...triangle({ pointingDirection: 'right', width: '100px', height: '100px', foregroundColor: 'red' })\n * }\n *\n *\n * // styled-components usage\n * const div = styled.div`\n * ${triangle({ pointingDirection: 'right', width: '100px', height: '100px', foregroundColor: 'red' })}\n *\n *\n * // CSS as JS Output\n *\n * div: {\n * 'borderColor': 'transparent transparent transparent red',\n * 'borderStyle': 'solid',\n * 'borderWidth': '50px 0 50px 100px',\n * 'height': '0',\n * 'width': '0',\n * }\n */\n\n\nfunction triangle(_ref) {\n var pointingDirection = _ref.pointingDirection,\n height = _ref.height,\n width = _ref.width,\n foregroundColor = _ref.foregroundColor,\n _ref$backgroundColor = _ref.backgroundColor,\n backgroundColor = _ref$backgroundColor === void 0 ? 'transparent' : _ref$backgroundColor;\n var widthAndUnit = getValueAndUnit(width);\n var heightAndUnit = getValueAndUnit(height);\n\n if (isNaN(heightAndUnit[0]) || isNaN(widthAndUnit[0])) {\n throw new PolishedError(60);\n }\n\n return {\n width: '0',\n height: '0',\n borderColor: getBorderColor(pointingDirection, foregroundColor, backgroundColor),\n borderStyle: 'solid',\n borderWidth: getBorderWidth(pointingDirection, heightAndUnit, widthAndUnit)\n };\n}\n/**\n * Provides an easy way to change the `wordWrap` property.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * ...wordWrap('break-word')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${wordWrap('break-word')}\n * `\n *\n * // CSS as JS Output\n *\n * const styles = {\n * overflowWrap: 'break-word',\n * wordWrap: 'break-word',\n * wordBreak: 'break-all',\n * }\n */\n\n\nfunction wordWrap(wrap) {\n if (wrap === void 0) {\n wrap = 'break-word';\n }\n\n var wordBreak = wrap === 'break-word' ? 'break-all' : wrap;\n return {\n overflowWrap: wrap,\n wordWrap: wrap,\n wordBreak: wordBreak\n };\n}\n\nfunction colorToInt(color) {\n return Math.round(color * 255);\n}\n\nfunction convertToInt(red, green, blue) {\n return colorToInt(red) + \",\" + colorToInt(green) + \",\" + colorToInt(blue);\n}\n\nfunction hslToRgb(hue, saturation, lightness, convert) {\n if (convert === void 0) {\n convert = convertToInt;\n }\n\n if (saturation === 0) {\n // achromatic\n return convert(lightness, lightness, lightness);\n } // formulae from https://en.wikipedia.org/wiki/HSL_and_HSV\n\n\n var huePrime = (hue % 360 + 360) % 360 / 60;\n var chroma = (1 - Math.abs(2 * lightness - 1)) * saturation;\n var secondComponent = chroma * (1 - Math.abs(huePrime % 2 - 1));\n var red = 0;\n var green = 0;\n var blue = 0;\n\n if (huePrime >= 0 && huePrime < 1) {\n red = chroma;\n green = secondComponent;\n } else if (huePrime >= 1 && huePrime < 2) {\n red = secondComponent;\n green = chroma;\n } else if (huePrime >= 2 && huePrime < 3) {\n green = chroma;\n blue = secondComponent;\n } else if (huePrime >= 3 && huePrime < 4) {\n green = secondComponent;\n blue = chroma;\n } else if (huePrime >= 4 && huePrime < 5) {\n red = secondComponent;\n blue = chroma;\n } else if (huePrime >= 5 && huePrime < 6) {\n red = chroma;\n blue = secondComponent;\n }\n\n var lightnessModification = lightness - chroma / 2;\n var finalRed = red + lightnessModification;\n var finalGreen = green + lightnessModification;\n var finalBlue = blue + lightnessModification;\n return convert(finalRed, finalGreen, finalBlue);\n}\n\nvar namedColorMap = {\n aliceblue: 'f0f8ff',\n antiquewhite: 'faebd7',\n aqua: '00ffff',\n aquamarine: '7fffd4',\n azure: 'f0ffff',\n beige: 'f5f5dc',\n bisque: 'ffe4c4',\n black: '000',\n blanchedalmond: 'ffebcd',\n blue: '0000ff',\n blueviolet: '8a2be2',\n brown: 'a52a2a',\n burlywood: 'deb887',\n cadetblue: '5f9ea0',\n chartreuse: '7fff00',\n chocolate: 'd2691e',\n coral: 'ff7f50',\n cornflowerblue: '6495ed',\n cornsilk: 'fff8dc',\n crimson: 'dc143c',\n cyan: '00ffff',\n darkblue: '00008b',\n darkcyan: '008b8b',\n darkgoldenrod: 'b8860b',\n darkgray: 'a9a9a9',\n darkgreen: '006400',\n darkgrey: 'a9a9a9',\n darkkhaki: 'bdb76b',\n darkmagenta: '8b008b',\n darkolivegreen: '556b2f',\n darkorange: 'ff8c00',\n darkorchid: '9932cc',\n darkred: '8b0000',\n darksalmon: 'e9967a',\n darkseagreen: '8fbc8f',\n darkslateblue: '483d8b',\n darkslategray: '2f4f4f',\n darkslategrey: '2f4f4f',\n darkturquoise: '00ced1',\n darkviolet: '9400d3',\n deeppink: 'ff1493',\n deepskyblue: '00bfff',\n dimgray: '696969',\n dimgrey: '696969',\n dodgerblue: '1e90ff',\n firebrick: 'b22222',\n floralwhite: 'fffaf0',\n forestgreen: '228b22',\n fuchsia: 'ff00ff',\n gainsboro: 'dcdcdc',\n ghostwhite: 'f8f8ff',\n gold: 'ffd700',\n goldenrod: 'daa520',\n gray: '808080',\n green: '008000',\n greenyellow: 'adff2f',\n grey: '808080',\n honeydew: 'f0fff0',\n hotpink: 'ff69b4',\n indianred: 'cd5c5c',\n indigo: '4b0082',\n ivory: 'fffff0',\n khaki: 'f0e68c',\n lavender: 'e6e6fa',\n lavenderblush: 'fff0f5',\n lawngreen: '7cfc00',\n lemonchiffon: 'fffacd',\n lightblue: 'add8e6',\n lightcoral: 'f08080',\n lightcyan: 'e0ffff',\n lightgoldenrodyellow: 'fafad2',\n lightgray: 'd3d3d3',\n lightgreen: '90ee90',\n lightgrey: 'd3d3d3',\n lightpink: 'ffb6c1',\n lightsalmon: 'ffa07a',\n lightseagreen: '20b2aa',\n lightskyblue: '87cefa',\n lightslategray: '789',\n lightslategrey: '789',\n lightsteelblue: 'b0c4de',\n lightyellow: 'ffffe0',\n lime: '0f0',\n limegreen: '32cd32',\n linen: 'faf0e6',\n magenta: 'f0f',\n maroon: '800000',\n mediumaquamarine: '66cdaa',\n mediumblue: '0000cd',\n mediumorchid: 'ba55d3',\n mediumpurple: '9370db',\n mediumseagreen: '3cb371',\n mediumslateblue: '7b68ee',\n mediumspringgreen: '00fa9a',\n mediumturquoise: '48d1cc',\n mediumvioletred: 'c71585',\n midnightblue: '191970',\n mintcream: 'f5fffa',\n mistyrose: 'ffe4e1',\n moccasin: 'ffe4b5',\n navajowhite: 'ffdead',\n navy: '000080',\n oldlace: 'fdf5e6',\n olive: '808000',\n olivedrab: '6b8e23',\n orange: 'ffa500',\n orangered: 'ff4500',\n orchid: 'da70d6',\n palegoldenrod: 'eee8aa',\n palegreen: '98fb98',\n paleturquoise: 'afeeee',\n palevioletred: 'db7093',\n papayawhip: 'ffefd5',\n peachpuff: 'ffdab9',\n peru: 'cd853f',\n pink: 'ffc0cb',\n plum: 'dda0dd',\n powderblue: 'b0e0e6',\n purple: '800080',\n rebeccapurple: '639',\n red: 'f00',\n rosybrown: 'bc8f8f',\n royalblue: '4169e1',\n saddlebrown: '8b4513',\n salmon: 'fa8072',\n sandybrown: 'f4a460',\n seagreen: '2e8b57',\n seashell: 'fff5ee',\n sienna: 'a0522d',\n silver: 'c0c0c0',\n skyblue: '87ceeb',\n slateblue: '6a5acd',\n slategray: '708090',\n slategrey: '708090',\n snow: 'fffafa',\n springgreen: '00ff7f',\n steelblue: '4682b4',\n tan: 'd2b48c',\n teal: '008080',\n thistle: 'd8bfd8',\n tomato: 'ff6347',\n turquoise: '40e0d0',\n violet: 'ee82ee',\n wheat: 'f5deb3',\n white: 'fff',\n whitesmoke: 'f5f5f5',\n yellow: 'ff0',\n yellowgreen: '9acd32'\n};\n/**\n * Checks if a string is a CSS named color and returns its equivalent hex value, otherwise returns the original color.\n * @private\n */\n\nfunction nameToHex(color) {\n if (typeof color !== 'string') return color;\n var normalizedColorName = color.toLowerCase();\n return namedColorMap[normalizedColorName] ? \"#\" + namedColorMap[normalizedColorName] : color;\n}\n\nvar hexRegex = /^#[a-fA-F0-9]{6}$/;\nvar hexRgbaRegex = /^#[a-fA-F0-9]{8}$/;\nvar reducedHexRegex = /^#[a-fA-F0-9]{3}$/;\nvar reducedRgbaHexRegex = /^#[a-fA-F0-9]{4}$/;\nvar rgbRegex = /^rgb\\(\\s*(\\d{1,3})\\s*,\\s*(\\d{1,3})\\s*,\\s*(\\d{1,3})\\s*\\)$/i;\nvar rgbaRegex = /^rgba\\(\\s*(\\d{1,3})\\s*,\\s*(\\d{1,3})\\s*,\\s*(\\d{1,3})\\s*,\\s*([-+]?[0-9]*[.]?[0-9]+)\\s*\\)$/i;\nvar hslRegex = /^hsl\\(\\s*(\\d{0,3}[.]?[0-9]+)\\s*,\\s*(\\d{1,3}[.]?[0-9]?)%\\s*,\\s*(\\d{1,3}[.]?[0-9]?)%\\s*\\)$/i;\nvar hslaRegex = /^hsla\\(\\s*(\\d{0,3}[.]?[0-9]+)\\s*,\\s*(\\d{1,3}[.]?[0-9]?)%\\s*,\\s*(\\d{1,3}[.]?[0-9]?)%\\s*,\\s*([-+]?[0-9]*[.]?[0-9]+)\\s*\\)$/i;\n/**\n * Returns an RgbColor or RgbaColor object. This utility function is only useful\n * if want to extract a color component. With the color util `toColorString` you\n * can convert a RgbColor or RgbaColor object back to a string.\n *\n * @example\n * // Assigns `{ red: 255, green: 0, blue: 0 }` to color1\n * const color1 = parseToRgb('rgb(255, 0, 0)');\n * // Assigns `{ red: 92, green: 102, blue: 112, alpha: 0.75 }` to color2\n * const color2 = parseToRgb('hsla(210, 10%, 40%, 0.75)');\n */\n\nfunction parseToRgb(color) {\n if (typeof color !== 'string') {\n throw new PolishedError(3);\n }\n\n var normalizedColor = nameToHex(color);\n\n if (normalizedColor.match(hexRegex)) {\n return {\n red: parseInt(\"\" + normalizedColor[1] + normalizedColor[2], 16),\n green: parseInt(\"\" + normalizedColor[3] + normalizedColor[4], 16),\n blue: parseInt(\"\" + normalizedColor[5] + normalizedColor[6], 16)\n };\n }\n\n if (normalizedColor.match(hexRgbaRegex)) {\n var alpha = parseFloat((parseInt(\"\" + normalizedColor[7] + normalizedColor[8], 16) / 255).toFixed(2));\n return {\n red: parseInt(\"\" + normalizedColor[1] + normalizedColor[2], 16),\n green: parseInt(\"\" + normalizedColor[3] + normalizedColor[4], 16),\n blue: parseInt(\"\" + normalizedColor[5] + normalizedColor[6], 16),\n alpha: alpha\n };\n }\n\n if (normalizedColor.match(reducedHexRegex)) {\n return {\n red: parseInt(\"\" + normalizedColor[1] + normalizedColor[1], 16),\n green: parseInt(\"\" + normalizedColor[2] + normalizedColor[2], 16),\n blue: parseInt(\"\" + normalizedColor[3] + normalizedColor[3], 16)\n };\n }\n\n if (normalizedColor.match(reducedRgbaHexRegex)) {\n var _alpha = parseFloat((parseInt(\"\" + normalizedColor[4] + normalizedColor[4], 16) / 255).toFixed(2));\n\n return {\n red: parseInt(\"\" + normalizedColor[1] + normalizedColor[1], 16),\n green: parseInt(\"\" + normalizedColor[2] + normalizedColor[2], 16),\n blue: parseInt(\"\" + normalizedColor[3] + normalizedColor[3], 16),\n alpha: _alpha\n };\n }\n\n var rgbMatched = rgbRegex.exec(normalizedColor);\n\n if (rgbMatched) {\n return {\n red: parseInt(\"\" + rgbMatched[1], 10),\n green: parseInt(\"\" + rgbMatched[2], 10),\n blue: parseInt(\"\" + rgbMatched[3], 10)\n };\n }\n\n var rgbaMatched = rgbaRegex.exec(normalizedColor);\n\n if (rgbaMatched) {\n return {\n red: parseInt(\"\" + rgbaMatched[1], 10),\n green: parseInt(\"\" + rgbaMatched[2], 10),\n blue: parseInt(\"\" + rgbaMatched[3], 10),\n alpha: parseFloat(\"\" + rgbaMatched[4])\n };\n }\n\n var hslMatched = hslRegex.exec(normalizedColor);\n\n if (hslMatched) {\n var hue = parseInt(\"\" + hslMatched[1], 10);\n var saturation = parseInt(\"\" + hslMatched[2], 10) / 100;\n var lightness = parseInt(\"\" + hslMatched[3], 10) / 100;\n var rgbColorString = \"rgb(\" + hslToRgb(hue, saturation, lightness) + \")\";\n var hslRgbMatched = rgbRegex.exec(rgbColorString);\n\n if (!hslRgbMatched) {\n throw new PolishedError(4, normalizedColor, rgbColorString);\n }\n\n return {\n red: parseInt(\"\" + hslRgbMatched[1], 10),\n green: parseInt(\"\" + hslRgbMatched[2], 10),\n blue: parseInt(\"\" + hslRgbMatched[3], 10)\n };\n }\n\n var hslaMatched = hslaRegex.exec(normalizedColor);\n\n if (hslaMatched) {\n var _hue = parseInt(\"\" + hslaMatched[1], 10);\n\n var _saturation = parseInt(\"\" + hslaMatched[2], 10) / 100;\n\n var _lightness = parseInt(\"\" + hslaMatched[3], 10) / 100;\n\n var _rgbColorString = \"rgb(\" + hslToRgb(_hue, _saturation, _lightness) + \")\";\n\n var _hslRgbMatched = rgbRegex.exec(_rgbColorString);\n\n if (!_hslRgbMatched) {\n throw new PolishedError(4, normalizedColor, _rgbColorString);\n }\n\n return {\n red: parseInt(\"\" + _hslRgbMatched[1], 10),\n green: parseInt(\"\" + _hslRgbMatched[2], 10),\n blue: parseInt(\"\" + _hslRgbMatched[3], 10),\n alpha: parseFloat(\"\" + hslaMatched[4])\n };\n }\n\n throw new PolishedError(5);\n}\n\nfunction rgbToHsl(color) {\n // make sure rgb are contained in a set of [0, 255]\n var red = color.red / 255;\n var green = color.green / 255;\n var blue = color.blue / 255;\n var max = Math.max(red, green, blue);\n var min = Math.min(red, green, blue);\n var lightness = (max + min) / 2;\n\n if (max === min) {\n // achromatic\n if (color.alpha !== undefined) {\n return {\n hue: 0,\n saturation: 0,\n lightness: lightness,\n alpha: color.alpha\n };\n } else {\n return {\n hue: 0,\n saturation: 0,\n lightness: lightness\n };\n }\n }\n\n var hue;\n var delta = max - min;\n var saturation = lightness > 0.5 ? delta / (2 - max - min) : delta / (max + min);\n\n switch (max) {\n case red:\n hue = (green - blue) / delta + (green < blue ? 6 : 0);\n break;\n\n case green:\n hue = (blue - red) / delta + 2;\n break;\n\n default:\n // blue case\n hue = (red - green) / delta + 4;\n break;\n }\n\n hue *= 60;\n\n if (color.alpha !== undefined) {\n return {\n hue: hue,\n saturation: saturation,\n lightness: lightness,\n alpha: color.alpha\n };\n }\n\n return {\n hue: hue,\n saturation: saturation,\n lightness: lightness\n };\n}\n/**\n * Returns an HslColor or HslaColor object. This utility function is only useful\n * if want to extract a color component. With the color util `toColorString` you\n * can convert a HslColor or HslaColor object back to a string.\n *\n * @example\n * // Assigns `{ hue: 0, saturation: 1, lightness: 0.5 }` to color1\n * const color1 = parseToHsl('rgb(255, 0, 0)');\n * // Assigns `{ hue: 128, saturation: 1, lightness: 0.5, alpha: 0.75 }` to color2\n * const color2 = parseToHsl('hsla(128, 100%, 50%, 0.75)');\n */\n\n\nfunction parseToHsl(color) {\n // Note: At a later stage we can optimize this function as right now a hsl\n // color would be parsed converted to rgb values and converted back to hsl.\n return rgbToHsl(parseToRgb(color));\n}\n/**\n * Reduces hex values if possible e.g. #ff8866 to #f86\n * @private\n */\n\n\nvar reduceHexValue = function reduceHexValue(value) {\n if (value.length === 7 && value[1] === value[2] && value[3] === value[4] && value[5] === value[6]) {\n return \"#\" + value[1] + value[3] + value[5];\n }\n\n return value;\n};\n\nfunction numberToHex(value) {\n var hex = value.toString(16);\n return hex.length === 1 ? \"0\" + hex : hex;\n}\n\nfunction colorToHex(color) {\n return numberToHex(Math.round(color * 255));\n}\n\nfunction convertToHex(red, green, blue) {\n return reduceHexValue(\"#\" + colorToHex(red) + colorToHex(green) + colorToHex(blue));\n}\n\nfunction hslToHex(hue, saturation, lightness) {\n return hslToRgb(hue, saturation, lightness, convertToHex);\n}\n/**\n * Returns a string value for the color. The returned result is the smallest possible hex notation.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: hsl(359, 0.75, 0.4),\n * background: hsl({ hue: 360, saturation: 0.75, lightness: 0.4 }),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${hsl(359, 0.75, 0.4)};\n * background: ${hsl({ hue: 360, saturation: 0.75, lightness: 0.4 })};\n * `\n *\n * // CSS in JS Output\n *\n * element {\n * background: \"#b3191c\";\n * background: \"#b3191c\";\n * }\n */\n\n\nfunction hsl(value, saturation, lightness) {\n if (typeof value === 'number' && typeof saturation === 'number' && typeof lightness === 'number') {\n return hslToHex(value, saturation, lightness);\n } else if (typeof value === 'object' && saturation === undefined && lightness === undefined) {\n return hslToHex(value.hue, value.saturation, value.lightness);\n }\n\n throw new PolishedError(1);\n}\n/**\n * Returns a string value for the color. The returned result is the smallest possible rgba or hex notation.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: hsla(359, 0.75, 0.4, 0.7),\n * background: hsla({ hue: 360, saturation: 0.75, lightness: 0.4, alpha: 0,7 }),\n * background: hsla(359, 0.75, 0.4, 1),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${hsla(359, 0.75, 0.4, 0.7)};\n * background: ${hsla({ hue: 360, saturation: 0.75, lightness: 0.4, alpha: 0,7 })};\n * background: ${hsla(359, 0.75, 0.4, 1)};\n * `\n *\n * // CSS in JS Output\n *\n * element {\n * background: \"rgba(179,25,28,0.7)\";\n * background: \"rgba(179,25,28,0.7)\";\n * background: \"#b3191c\";\n * }\n */\n\n\nfunction hsla(value, saturation, lightness, alpha) {\n if (typeof value === 'number' && typeof saturation === 'number' && typeof lightness === 'number' && typeof alpha === 'number') {\n return alpha >= 1 ? hslToHex(value, saturation, lightness) : \"rgba(\" + hslToRgb(value, saturation, lightness) + \",\" + alpha + \")\";\n } else if (typeof value === 'object' && saturation === undefined && lightness === undefined && alpha === undefined) {\n return value.alpha >= 1 ? hslToHex(value.hue, value.saturation, value.lightness) : \"rgba(\" + hslToRgb(value.hue, value.saturation, value.lightness) + \",\" + value.alpha + \")\";\n }\n\n throw new PolishedError(2);\n}\n/**\n * Returns a string value for the color. The returned result is the smallest possible hex notation.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: rgb(255, 205, 100),\n * background: rgb({ red: 255, green: 205, blue: 100 }),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${rgb(255, 205, 100)};\n * background: ${rgb({ red: 255, green: 205, blue: 100 })};\n * `\n *\n * // CSS in JS Output\n *\n * element {\n * background: \"#ffcd64\";\n * background: \"#ffcd64\";\n * }\n */\n\n\nfunction rgb(value, green, blue) {\n if (typeof value === 'number' && typeof green === 'number' && typeof blue === 'number') {\n return reduceHexValue(\"#\" + numberToHex(value) + numberToHex(green) + numberToHex(blue));\n } else if (typeof value === 'object' && green === undefined && blue === undefined) {\n return reduceHexValue(\"#\" + numberToHex(value.red) + numberToHex(value.green) + numberToHex(value.blue));\n }\n\n throw new PolishedError(6);\n}\n/**\n * Returns a string value for the color. The returned result is the smallest possible rgba or hex notation.\n *\n * Can also be used to fade a color by passing a hex value or named CSS color along with an alpha value.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: rgba(255, 205, 100, 0.7),\n * background: rgba({ red: 255, green: 205, blue: 100, alpha: 0.7 }),\n * background: rgba(255, 205, 100, 1),\n * background: rgba('#ffffff', 0.4),\n * background: rgba('black', 0.7),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${rgba(255, 205, 100, 0.7)};\n * background: ${rgba({ red: 255, green: 205, blue: 100, alpha: 0.7 })};\n * background: ${rgba(255, 205, 100, 1)};\n * background: ${rgba('#ffffff', 0.4)};\n * background: ${rgba('black', 0.7)};\n * `\n *\n * // CSS in JS Output\n *\n * element {\n * background: \"rgba(255,205,100,0.7)\";\n * background: \"rgba(255,205,100,0.7)\";\n * background: \"#ffcd64\";\n * background: \"rgba(255,255,255,0.4)\";\n * background: \"rgba(0,0,0,0.7)\";\n * }\n */\n\n\nfunction rgba(firstValue, secondValue, thirdValue, fourthValue) {\n if (typeof firstValue === 'string' && typeof secondValue === 'number') {\n var rgbValue = parseToRgb(firstValue);\n return \"rgba(\" + rgbValue.red + \",\" + rgbValue.green + \",\" + rgbValue.blue + \",\" + secondValue + \")\";\n } else if (typeof firstValue === 'number' && typeof secondValue === 'number' && typeof thirdValue === 'number' && typeof fourthValue === 'number') {\n return fourthValue >= 1 ? rgb(firstValue, secondValue, thirdValue) : \"rgba(\" + firstValue + \",\" + secondValue + \",\" + thirdValue + \",\" + fourthValue + \")\";\n } else if (typeof firstValue === 'object' && secondValue === undefined && thirdValue === undefined && fourthValue === undefined) {\n return firstValue.alpha >= 1 ? rgb(firstValue.red, firstValue.green, firstValue.blue) : \"rgba(\" + firstValue.red + \",\" + firstValue.green + \",\" + firstValue.blue + \",\" + firstValue.alpha + \")\";\n }\n\n throw new PolishedError(7);\n}\n\nvar isRgb = function isRgb(color) {\n return typeof color.red === 'number' && typeof color.green === 'number' && typeof color.blue === 'number' && (typeof color.alpha !== 'number' || typeof color.alpha === 'undefined');\n};\n\nvar isRgba = function isRgba(color) {\n return typeof color.red === 'number' && typeof color.green === 'number' && typeof color.blue === 'number' && typeof color.alpha === 'number';\n};\n\nvar isHsl = function isHsl(color) {\n return typeof color.hue === 'number' && typeof color.saturation === 'number' && typeof color.lightness === 'number' && (typeof color.alpha !== 'number' || typeof color.alpha === 'undefined');\n};\n\nvar isHsla = function isHsla(color) {\n return typeof color.hue === 'number' && typeof color.saturation === 'number' && typeof color.lightness === 'number' && typeof color.alpha === 'number';\n};\n/**\n * Converts a RgbColor, RgbaColor, HslColor or HslaColor object to a color string.\n * This util is useful in case you only know on runtime which color object is\n * used. Otherwise we recommend to rely on `rgb`, `rgba`, `hsl` or `hsla`.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: toColorString({ red: 255, green: 205, blue: 100 }),\n * background: toColorString({ red: 255, green: 205, blue: 100, alpha: 0.72 }),\n * background: toColorString({ hue: 240, saturation: 1, lightness: 0.5 }),\n * background: toColorString({ hue: 360, saturation: 0.75, lightness: 0.4, alpha: 0.72 }),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${toColorString({ red: 255, green: 205, blue: 100 })};\n * background: ${toColorString({ red: 255, green: 205, blue: 100, alpha: 0.72 })};\n * background: ${toColorString({ hue: 240, saturation: 1, lightness: 0.5 })};\n * background: ${toColorString({ hue: 360, saturation: 0.75, lightness: 0.4, alpha: 0.72 })};\n * `\n *\n * // CSS in JS Output\n * element {\n * background: \"#ffcd64\";\n * background: \"rgba(255,205,100,0.72)\";\n * background: \"#00f\";\n * background: \"rgba(179,25,25,0.72)\";\n * }\n */\n\n\nfunction toColorString(color) {\n if (typeof color !== 'object') throw new PolishedError(8);\n if (isRgba(color)) return rgba(color);\n if (isRgb(color)) return rgb(color);\n if (isHsla(color)) return hsla(color);\n if (isHsl(color)) return hsl(color);\n throw new PolishedError(8);\n} // Type definitions taken from https://github.com/gcanti/flow-static-land/blob/master/src/Fun.js\n// eslint-disable-next-line no-unused-vars\n// eslint-disable-next-line no-unused-vars\n// eslint-disable-next-line no-redeclare\n\n\nfunction curried(f, length, acc) {\n return function fn() {\n // eslint-disable-next-line prefer-rest-params\n var combined = acc.concat(Array.prototype.slice.call(arguments));\n return combined.length >= length ? f.apply(this, combined) : curried(f, length, combined);\n };\n} // eslint-disable-next-line no-redeclare\n\n\nfunction curry(f) {\n // eslint-disable-line no-redeclare\n return curried(f, f.length, []);\n}\n/**\n * Changes the hue of the color. Hue is a number between 0 to 360. The first\n * argument for adjustHue is the amount of degrees the color is rotated around\n * the color wheel, always producing a positive hue value.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: adjustHue(180, '#448'),\n * background: adjustHue('180', 'rgba(101,100,205,0.7)'),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${adjustHue(180, '#448')};\n * background: ${adjustHue('180', 'rgba(101,100,205,0.7)')};\n * `\n *\n * // CSS in JS Output\n * element {\n * background: \"#888844\";\n * background: \"rgba(136,136,68,0.7)\";\n * }\n */\n\n\nfunction adjustHue(degree, color) {\n if (color === 'transparent') return color;\n var hslColor = parseToHsl(color);\n return toColorString(_extends({}, hslColor, {\n hue: hslColor.hue + parseFloat(degree)\n }));\n} // prettier-ignore\n\n\nvar curriedAdjustHue = /*#__PURE__*/curry\n/* ::<number | string, string, string> */\n(adjustHue);\n/**\n * Returns the complement of the provided color. This is identical to adjustHue(180, <color>).\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: complement('#448'),\n * background: complement('rgba(204,205,100,0.7)'),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${complement('#448')};\n * background: ${complement('rgba(204,205,100,0.7)')};\n * `\n *\n * // CSS in JS Output\n * element {\n * background: \"#884\";\n * background: \"rgba(153,153,153,0.7)\";\n * }\n */\n\nfunction complement(color) {\n if (color === 'transparent') return color;\n var hslColor = parseToHsl(color);\n return toColorString(_extends({}, hslColor, {\n hue: (hslColor.hue + 180) % 360\n }));\n}\n\nfunction guard(lowerBoundary, upperBoundary, value) {\n return Math.max(lowerBoundary, Math.min(upperBoundary, value));\n}\n/**\n * Returns a string value for the darkened color.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: darken(0.2, '#FFCD64'),\n * background: darken('0.2', 'rgba(255,205,100,0.7)'),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${darken(0.2, '#FFCD64')};\n * background: ${darken('0.2', 'rgba(255,205,100,0.7)')};\n * `\n *\n * // CSS in JS Output\n *\n * element {\n * background: \"#ffbd31\";\n * background: \"rgba(255,189,49,0.7)\";\n * }\n */\n\n\nfunction darken(amount, color) {\n if (color === 'transparent') return color;\n var hslColor = parseToHsl(color);\n return toColorString(_extends({}, hslColor, {\n lightness: guard(0, 1, hslColor.lightness - parseFloat(amount))\n }));\n} // prettier-ignore\n\n\nvar curriedDarken = /*#__PURE__*/curry\n/* ::<number | string, string, string> */\n(darken);\n/**\n * Decreases the intensity of a color. Its range is between 0 to 1. The first\n * argument of the desaturate function is the amount by how much the color\n * intensity should be decreased.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: desaturate(0.2, '#CCCD64'),\n * background: desaturate('0.2', 'rgba(204,205,100,0.7)'),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${desaturate(0.2, '#CCCD64')};\n * background: ${desaturate('0.2', 'rgba(204,205,100,0.7)')};\n * `\n *\n * // CSS in JS Output\n * element {\n * background: \"#b8b979\";\n * background: \"rgba(184,185,121,0.7)\";\n * }\n */\n\nfunction desaturate(amount, color) {\n if (color === 'transparent') return color;\n var hslColor = parseToHsl(color);\n return toColorString(_extends({}, hslColor, {\n saturation: guard(0, 1, hslColor.saturation - parseFloat(amount))\n }));\n} // prettier-ignore\n\n\nvar curriedDesaturate = /*#__PURE__*/curry\n/* ::<number | string, string, string> */\n(desaturate);\n/**\n * Returns a number (float) representing the luminance of a color.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: getLuminance('#CCCD64') >= getLuminance('#0000ff') ? '#CCCD64' : '#0000ff',\n * background: getLuminance('rgba(58, 133, 255, 1)') >= getLuminance('rgba(255, 57, 149, 1)') ?\n * 'rgba(58, 133, 255, 1)' :\n * 'rgba(255, 57, 149, 1)',\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${getLuminance('#CCCD64') >= getLuminance('#0000ff') ? '#CCCD64' : '#0000ff'};\n * background: ${getLuminance('rgba(58, 133, 255, 1)') >= getLuminance('rgba(255, 57, 149, 1)') ?\n * 'rgba(58, 133, 255, 1)' :\n * 'rgba(255, 57, 149, 1)'};\n *\n * // CSS in JS Output\n *\n * div {\n * background: \"#CCCD64\";\n * background: \"rgba(58, 133, 255, 1)\";\n * }\n */\n\nfunction getLuminance(color) {\n if (color === 'transparent') return 0;\n var rgbColor = parseToRgb(color);\n\n var _Object$keys$map = Object.keys(rgbColor).map(function (key) {\n var channel = rgbColor[key] / 255;\n return channel <= 0.03928 ? channel / 12.92 : Math.pow((channel + 0.055) / 1.055, 2.4);\n }),\n r = _Object$keys$map[0],\n g = _Object$keys$map[1],\n b = _Object$keys$map[2];\n\n return parseFloat((0.2126 * r + 0.7152 * g + 0.0722 * b).toFixed(3));\n}\n/**\n * Returns the contrast ratio between two colors based on\n * [W3's recommended equation for calculating contrast](http://www.w3.org/TR/WCAG20/#contrast-ratiodef).\n *\n * @example\n * const contrastRatio = getContrast('#444', '#fff');\n */\n\n\nfunction getContrast(color1, color2) {\n var luminance1 = getLuminance(color1);\n var luminance2 = getLuminance(color2);\n return parseFloat((luminance1 > luminance2 ? (luminance1 + 0.05) / (luminance2 + 0.05) : (luminance2 + 0.05) / (luminance1 + 0.05)).toFixed(2));\n}\n/**\n * Converts the color to a grayscale, by reducing its saturation to 0.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: grayscale('#CCCD64'),\n * background: grayscale('rgba(204,205,100,0.7)'),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${grayscale('#CCCD64')};\n * background: ${grayscale('rgba(204,205,100,0.7)')};\n * `\n *\n * // CSS in JS Output\n * element {\n * background: \"#999\";\n * background: \"rgba(153,153,153,0.7)\";\n * }\n */\n\n\nfunction grayscale(color) {\n if (color === 'transparent') return color;\n return toColorString(_extends({}, parseToHsl(color), {\n saturation: 0\n }));\n}\n/**\n * Converts a HslColor or HslaColor object to a color string.\n * This util is useful in case you only know on runtime which color object is\n * used. Otherwise we recommend to rely on `hsl` or `hsla`.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: hslToColorString({ hue: 240, saturation: 1, lightness: 0.5 }),\n * background: hslToColorString({ hue: 360, saturation: 0.75, lightness: 0.4, alpha: 0.72 }),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${hslToColorString({ hue: 240, saturation: 1, lightness: 0.5 })};\n * background: ${hslToColorString({ hue: 360, saturation: 0.75, lightness: 0.4, alpha: 0.72 })};\n * `\n *\n * // CSS in JS Output\n * element {\n * background: \"#00f\";\n * background: \"rgba(179,25,25,0.72)\";\n * }\n */\n\n\nfunction hslToColorString(color) {\n if (typeof color === 'object' && typeof color.hue === 'number' && typeof color.saturation === 'number' && typeof color.lightness === 'number') {\n if (color.alpha && typeof color.alpha === 'number') {\n return hsla({\n hue: color.hue,\n saturation: color.saturation,\n lightness: color.lightness,\n alpha: color.alpha\n });\n }\n\n return hsl({\n hue: color.hue,\n saturation: color.saturation,\n lightness: color.lightness\n });\n }\n\n throw new PolishedError(45);\n}\n/**\n * Inverts the red, green and blue values of a color.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: invert('#CCCD64'),\n * background: invert('rgba(101,100,205,0.7)'),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${invert('#CCCD64')};\n * background: ${invert('rgba(101,100,205,0.7)')};\n * `\n *\n * // CSS in JS Output\n *\n * element {\n * background: \"#33329b\";\n * background: \"rgba(154,155,50,0.7)\";\n * }\n */\n\n\nfunction invert(color) {\n if (color === 'transparent') return color; // parse color string to rgb\n\n var value = parseToRgb(color);\n return toColorString(_extends({}, value, {\n red: 255 - value.red,\n green: 255 - value.green,\n blue: 255 - value.blue\n }));\n}\n/**\n * Returns a string value for the lightened color.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: lighten(0.2, '#CCCD64'),\n * background: lighten('0.2', 'rgba(204,205,100,0.7)'),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${lighten(0.2, '#FFCD64')};\n * background: ${lighten('0.2', 'rgba(204,205,100,0.7)')};\n * `\n *\n * // CSS in JS Output\n *\n * element {\n * background: \"#e5e6b1\";\n * background: \"rgba(229,230,177,0.7)\";\n * }\n */\n\n\nfunction lighten(amount, color) {\n if (color === 'transparent') return color;\n var hslColor = parseToHsl(color);\n return toColorString(_extends({}, hslColor, {\n lightness: guard(0, 1, hslColor.lightness + parseFloat(amount))\n }));\n} // prettier-ignore\n\n\nvar curriedLighten = /*#__PURE__*/curry\n/* ::<number | string, string, string> */\n(lighten);\n/**\n * Determines which contrast guidelines have been met for two colors.\n * Based on the [contrast calculations recommended by W3](https://www.w3.org/WAI/WCAG21/Understanding/contrast-enhanced.html).\n *\n * @example\n * const scores = meetsContrastGuidelines('#444', '#fff');\n */\n\nfunction meetsContrastGuidelines(color1, color2) {\n var contrastRatio = getContrast(color1, color2);\n return {\n AA: contrastRatio >= 4.5,\n AALarge: contrastRatio >= 3,\n AAA: contrastRatio >= 7,\n AAALarge: contrastRatio >= 4.5\n };\n}\n/**\n * Mixes the two provided colors together by calculating the average of each of the RGB components weighted to the first color by the provided weight.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: mix(0.5, '#f00', '#00f')\n * background: mix(0.25, '#f00', '#00f')\n * background: mix('0.5', 'rgba(255, 0, 0, 0.5)', '#00f')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${mix(0.5, '#f00', '#00f')};\n * background: ${mix(0.25, '#f00', '#00f')};\n * background: ${mix('0.5', 'rgba(255, 0, 0, 0.5)', '#00f')};\n * `\n *\n * // CSS in JS Output\n *\n * element {\n * background: \"#7f007f\";\n * background: \"#3f00bf\";\n * background: \"rgba(63, 0, 191, 0.75)\";\n * }\n */\n\n\nfunction mix(weight, color, otherColor) {\n if (color === 'transparent') return otherColor;\n if (otherColor === 'transparent') return color;\n if (weight === 0) return otherColor;\n var parsedColor1 = parseToRgb(color);\n\n var color1 = _extends({}, parsedColor1, {\n alpha: typeof parsedColor1.alpha === 'number' ? parsedColor1.alpha : 1\n });\n\n var parsedColor2 = parseToRgb(otherColor);\n\n var color2 = _extends({}, parsedColor2, {\n alpha: typeof parsedColor2.alpha === 'number' ? parsedColor2.alpha : 1\n }); // The formula is copied from the original Sass implementation:\n // http://sass-lang.com/documentation/Sass/Script/Functions.html#mix-instance_method\n\n\n var alphaDelta = color1.alpha - color2.alpha;\n var x = parseFloat(weight) * 2 - 1;\n var y = x * alphaDelta === -1 ? x : x + alphaDelta;\n var z = 1 + x * alphaDelta;\n var weight1 = (y / z + 1) / 2.0;\n var weight2 = 1 - weight1;\n var mixedColor = {\n red: Math.floor(color1.red * weight1 + color2.red * weight2),\n green: Math.floor(color1.green * weight1 + color2.green * weight2),\n blue: Math.floor(color1.blue * weight1 + color2.blue * weight2),\n alpha: color1.alpha * (parseFloat(weight) / 1.0) + color2.alpha * (1 - parseFloat(weight) / 1.0)\n };\n return rgba(mixedColor);\n} // prettier-ignore\n\n\nvar curriedMix = /*#__PURE__*/curry\n/* ::<number | string, string, string, string> */\n(mix);\n/**\n * Increases the opacity of a color. Its range for the amount is between 0 to 1.\n *\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: opacify(0.1, 'rgba(255, 255, 255, 0.9)');\n * background: opacify(0.2, 'hsla(0, 0%, 100%, 0.5)'),\n * background: opacify('0.5', 'rgba(255, 0, 0, 0.2)'),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${opacify(0.1, 'rgba(255, 255, 255, 0.9)')};\n * background: ${opacify(0.2, 'hsla(0, 0%, 100%, 0.5)')},\n * background: ${opacify('0.5', 'rgba(255, 0, 0, 0.2)')},\n * `\n *\n * // CSS in JS Output\n *\n * element {\n * background: \"#fff\";\n * background: \"rgba(255,255,255,0.7)\";\n * background: \"rgba(255,0,0,0.7)\";\n * }\n */\n\nfunction opacify(amount, color) {\n if (color === 'transparent') return color;\n var parsedColor = parseToRgb(color);\n var alpha = typeof parsedColor.alpha === 'number' ? parsedColor.alpha : 1;\n\n var colorWithAlpha = _extends({}, parsedColor, {\n alpha: guard(0, 1, (alpha * 100 + parseFloat(amount) * 100) / 100)\n });\n\n return rgba(colorWithAlpha);\n} // prettier-ignore\n\n\nvar curriedOpacify = /*#__PURE__*/curry\n/* ::<number | string, string, string> */\n(opacify);\nvar defaultLightReturnColor = '#000';\nvar defaultDarkReturnColor = '#fff';\n/**\n * Returns black or white (or optional light and dark return colors) for best\n * contrast depending on the luminosity of the given color.\n * When passing custom return colors, set `strict` to `true` to ensure that the\n * return color always meets or exceeds WCAG level AA or greater. If this test\n * fails, the default return color (black or white) is returned in place of the\n * custom return color.\n *\n * Follows [W3C specs for readability](https://www.w3.org/TR/WCAG20-TECHS/G18.html).\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * color: readableColor('#000'),\n * color: readableColor('black', '#001', '#ff8'),\n * color: readableColor('white', '#001', '#ff8'),\n * color: readableColor('red', '#333', '#ddd', true)\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * color: ${readableColor('#000')};\n * color: ${readableColor('black', '#001', '#ff8')};\n * color: ${readableColor('white', '#001', '#ff8')};\n * color: ${readableColor('red', '#333', '#ddd', true)};\n * `\n *\n * // CSS in JS Output\n * element {\n * color: \"#fff\";\n * color: \"#ff8\";\n * color: \"#001\";\n * color: \"#000\";\n * }\n */\n\nfunction readableColor(color, lightReturnColor, darkReturnColor, strict) {\n if (lightReturnColor === void 0) {\n lightReturnColor = defaultLightReturnColor;\n }\n\n if (darkReturnColor === void 0) {\n darkReturnColor = defaultDarkReturnColor;\n }\n\n if (strict === void 0) {\n strict = false;\n }\n\n var isLightColor = getLuminance(color) > 0.179;\n var preferredReturnColor = isLightColor ? lightReturnColor : darkReturnColor; // TODO: Make `strict` the default behaviour in the next major release.\n // Without `strict`, this may return a color that does not meet WCAG AA.\n\n if (!strict || getContrast(color, preferredReturnColor) >= 4.5) {\n return preferredReturnColor;\n }\n\n return isLightColor ? defaultLightReturnColor : defaultDarkReturnColor;\n}\n/**\n * Converts a RgbColor or RgbaColor object to a color string.\n * This util is useful in case you only know on runtime which color object is\n * used. Otherwise we recommend to rely on `rgb` or `rgba`.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: rgbToColorString({ red: 255, green: 205, blue: 100 }),\n * background: rgbToColorString({ red: 255, green: 205, blue: 100, alpha: 0.72 }),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${rgbToColorString({ red: 255, green: 205, blue: 100 })};\n * background: ${rgbToColorString({ red: 255, green: 205, blue: 100, alpha: 0.72 })};\n * `\n *\n * // CSS in JS Output\n * element {\n * background: \"#ffcd64\";\n * background: \"rgba(255,205,100,0.72)\";\n * }\n */\n\n\nfunction rgbToColorString(color) {\n if (typeof color === 'object' && typeof color.red === 'number' && typeof color.green === 'number' && typeof color.blue === 'number') {\n if (typeof color.alpha === 'number') {\n return rgba({\n red: color.red,\n green: color.green,\n blue: color.blue,\n alpha: color.alpha\n });\n }\n\n return rgb({\n red: color.red,\n green: color.green,\n blue: color.blue\n });\n }\n\n throw new PolishedError(46);\n}\n/**\n * Increases the intensity of a color. Its range is between 0 to 1. The first\n * argument of the saturate function is the amount by how much the color\n * intensity should be increased.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: saturate(0.2, '#CCCD64'),\n * background: saturate('0.2', 'rgba(204,205,100,0.7)'),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${saturate(0.2, '#FFCD64')};\n * background: ${saturate('0.2', 'rgba(204,205,100,0.7)')};\n * `\n *\n * // CSS in JS Output\n *\n * element {\n * background: \"#e0e250\";\n * background: \"rgba(224,226,80,0.7)\";\n * }\n */\n\n\nfunction saturate(amount, color) {\n if (color === 'transparent') return color;\n var hslColor = parseToHsl(color);\n return toColorString(_extends({}, hslColor, {\n saturation: guard(0, 1, hslColor.saturation + parseFloat(amount))\n }));\n} // prettier-ignore\n\n\nvar curriedSaturate = /*#__PURE__*/curry\n/* ::<number | string, string, string> */\n(saturate);\n/**\n * Sets the hue of a color to the provided value. The hue range can be\n * from 0 and 359.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: setHue(42, '#CCCD64'),\n * background: setHue('244', 'rgba(204,205,100,0.7)'),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${setHue(42, '#CCCD64')};\n * background: ${setHue('244', 'rgba(204,205,100,0.7)')};\n * `\n *\n * // CSS in JS Output\n * element {\n * background: \"#cdae64\";\n * background: \"rgba(107,100,205,0.7)\";\n * }\n */\n\nfunction setHue(hue, color) {\n if (color === 'transparent') return color;\n return toColorString(_extends({}, parseToHsl(color), {\n hue: parseFloat(hue)\n }));\n} // prettier-ignore\n\n\nvar curriedSetHue = /*#__PURE__*/curry\n/* ::<number | string, string, string> */\n(setHue);\n/**\n * Sets the lightness of a color to the provided value. The lightness range can be\n * from 0 and 1.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: setLightness(0.2, '#CCCD64'),\n * background: setLightness('0.75', 'rgba(204,205,100,0.7)'),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${setLightness(0.2, '#CCCD64')};\n * background: ${setLightness('0.75', 'rgba(204,205,100,0.7)')};\n * `\n *\n * // CSS in JS Output\n * element {\n * background: \"#4d4d19\";\n * background: \"rgba(223,224,159,0.7)\";\n * }\n */\n\nfunction setLightness(lightness, color) {\n if (color === 'transparent') return color;\n return toColorString(_extends({}, parseToHsl(color), {\n lightness: parseFloat(lightness)\n }));\n} // prettier-ignore\n\n\nvar curriedSetLightness = /*#__PURE__*/curry\n/* ::<number | string, string, string> */\n(setLightness);\n/**\n * Sets the saturation of a color to the provided value. The saturation range can be\n * from 0 and 1.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: setSaturation(0.2, '#CCCD64'),\n * background: setSaturation('0.75', 'rgba(204,205,100,0.7)'),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${setSaturation(0.2, '#CCCD64')};\n * background: ${setSaturation('0.75', 'rgba(204,205,100,0.7)')};\n * `\n *\n * // CSS in JS Output\n * element {\n * background: \"#adad84\";\n * background: \"rgba(228,229,76,0.7)\";\n * }\n */\n\nfunction setSaturation(saturation, color) {\n if (color === 'transparent') return color;\n return toColorString(_extends({}, parseToHsl(color), {\n saturation: parseFloat(saturation)\n }));\n} // prettier-ignore\n\n\nvar curriedSetSaturation = /*#__PURE__*/curry\n/* ::<number | string, string, string> */\n(setSaturation);\n/**\n * Shades a color by mixing it with black. `shade` can produce\n * hue shifts, where as `darken` manipulates the luminance channel and therefore\n * doesn't produce hue shifts.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: shade(0.25, '#00f')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${shade(0.25, '#00f')};\n * `\n *\n * // CSS in JS Output\n *\n * element {\n * background: \"#00003f\";\n * }\n */\n\nfunction shade(percentage, color) {\n if (color === 'transparent') return color;\n return curriedMix(parseFloat(percentage), 'rgb(0, 0, 0)', color);\n} // prettier-ignore\n\n\nvar curriedShade = /*#__PURE__*/curry\n/* ::<number | string, string, string> */\n(shade);\n/**\n * Tints a color by mixing it with white. `tint` can produce\n * hue shifts, where as `lighten` manipulates the luminance channel and therefore\n * doesn't produce hue shifts.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: tint(0.25, '#00f')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${tint(0.25, '#00f')};\n * `\n *\n * // CSS in JS Output\n *\n * element {\n * background: \"#bfbfff\";\n * }\n */\n\nfunction tint(percentage, color) {\n if (color === 'transparent') return color;\n return curriedMix(parseFloat(percentage), 'rgb(255, 255, 255)', color);\n} // prettier-ignore\n\n\nvar curriedTint = /*#__PURE__*/curry\n/* ::<number | string, string, string> */\n(tint);\n/**\n * Decreases the opacity of a color. Its range for the amount is between 0 to 1.\n *\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * background: transparentize(0.1, '#fff');\n * background: transparentize(0.2, 'hsl(0, 0%, 100%)'),\n * background: transparentize('0.5', 'rgba(255, 0, 0, 0.8)'),\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * background: ${transparentize(0.1, '#fff')};\n * background: ${transparentize(0.2, 'hsl(0, 0%, 100%)')},\n * background: ${transparentize('0.5', 'rgba(255, 0, 0, 0.8)')},\n * `\n *\n * // CSS in JS Output\n *\n * element {\n * background: \"rgba(255,255,255,0.9)\";\n * background: \"rgba(255,255,255,0.8)\";\n * background: \"rgba(255,0,0,0.3)\";\n * }\n */\n\nfunction transparentize(amount, color) {\n if (color === 'transparent') return color;\n var parsedColor = parseToRgb(color);\n var alpha = typeof parsedColor.alpha === 'number' ? parsedColor.alpha : 1;\n\n var colorWithAlpha = _extends({}, parsedColor, {\n alpha: guard(0, 1, (alpha * 100 - parseFloat(amount) * 100) / 100)\n });\n\n return rgba(colorWithAlpha);\n} // prettier-ignore\n\n\nvar curriedTransparentize = /*#__PURE__*/curry\n/* ::<number | string, string, string> */\n(transparentize);\n/**\n * Shorthand for easily setting the animation property. Allows either multiple arrays with animations\n * or a single animation spread over the arguments.\n * @example\n * // Styles as object usage\n * const styles = {\n * ...animation(['rotate', '1s', 'ease-in-out'], ['colorchange', '2s'])\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${animation(['rotate', '1s', 'ease-in-out'], ['colorchange', '2s'])}\n * `\n *\n * // CSS as JS Output\n *\n * div {\n * 'animation': 'rotate 1s ease-in-out, colorchange 2s'\n * }\n * @example\n * // Styles as object usage\n * const styles = {\n * ...animation('rotate', '1s', 'ease-in-out')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${animation('rotate', '1s', 'ease-in-out')}\n * `\n *\n * // CSS as JS Output\n *\n * div {\n * 'animation': 'rotate 1s ease-in-out'\n * }\n */\n\nfunction animation() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n } // Allow single or multiple animations passed\n\n\n var multiMode = Array.isArray(args[0]);\n\n if (!multiMode && args.length > 8) {\n throw new PolishedError(64);\n }\n\n var code = args.map(function (arg) {\n if (multiMode && !Array.isArray(arg) || !multiMode && Array.isArray(arg)) {\n throw new PolishedError(65);\n }\n\n if (Array.isArray(arg) && arg.length > 8) {\n throw new PolishedError(66);\n }\n\n return Array.isArray(arg) ? arg.join(' ') : arg;\n }).join(', ');\n return {\n animation: code\n };\n}\n/**\n * Shorthand that accepts any number of backgroundImage values as parameters for creating a single background statement.\n * @example\n * // Styles as object usage\n * const styles = {\n * ...backgroundImages('url(\"/image/background.jpg\")', 'linear-gradient(red, green)')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${backgroundImages('url(\"/image/background.jpg\")', 'linear-gradient(red, green)')}\n * `\n *\n * // CSS as JS Output\n *\n * div {\n * 'backgroundImage': 'url(\"/image/background.jpg\"), linear-gradient(red, green)'\n * }\n */\n\n\nfunction backgroundImages() {\n for (var _len = arguments.length, properties = new Array(_len), _key = 0; _key < _len; _key++) {\n properties[_key] = arguments[_key];\n }\n\n return {\n backgroundImage: properties.join(', ')\n };\n}\n/**\n * Shorthand that accepts any number of background values as parameters for creating a single background statement.\n * @example\n * // Styles as object usage\n * const styles = {\n * ...backgrounds('url(\"/image/background.jpg\")', 'linear-gradient(red, green)', 'center no-repeat')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${backgrounds('url(\"/image/background.jpg\")', 'linear-gradient(red, green)', 'center no-repeat')}\n * `\n *\n * // CSS as JS Output\n *\n * div {\n * 'background': 'url(\"/image/background.jpg\"), linear-gradient(red, green), center no-repeat'\n * }\n */\n\n\nfunction backgrounds() {\n for (var _len = arguments.length, properties = new Array(_len), _key = 0; _key < _len; _key++) {\n properties[_key] = arguments[_key];\n }\n\n return {\n background: properties.join(', ')\n };\n}\n\nvar sideMap = ['top', 'right', 'bottom', 'left'];\n/**\n * Shorthand for the border property that splits out individual properties for use with tools like Fela and Styletron. A side keyword can optionally be passed to target only one side's border properties.\n *\n * @example\n * // Styles as object usage\n * const styles = {\n * ...border('1px', 'solid', 'red')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${border('1px', 'solid', 'red')}\n * `\n *\n * // CSS as JS Output\n *\n * div {\n * 'borderColor': 'red',\n * 'borderStyle': 'solid',\n * 'borderWidth': `1px`,\n * }\n *\n * // Styles as object usage\n * const styles = {\n * ...border('top', '1px', 'solid', 'red')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${border('top', '1px', 'solid', 'red')}\n * `\n *\n * // CSS as JS Output\n *\n * div {\n * 'borderTopColor': 'red',\n * 'borderTopStyle': 'solid',\n * 'borderTopWidth': `1px`,\n * }\n */\n\nfunction border(sideKeyword) {\n for (var _len = arguments.length, values = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n values[_key - 1] = arguments[_key];\n }\n\n if (typeof sideKeyword === 'string' && sideMap.indexOf(sideKeyword) >= 0) {\n var _ref;\n\n return _ref = {}, _ref[\"border\" + capitalizeString(sideKeyword) + \"Width\"] = values[0], _ref[\"border\" + capitalizeString(sideKeyword) + \"Style\"] = values[1], _ref[\"border\" + capitalizeString(sideKeyword) + \"Color\"] = values[2], _ref;\n } else {\n values.unshift(sideKeyword);\n return {\n borderWidth: values[0],\n borderStyle: values[1],\n borderColor: values[2]\n };\n }\n}\n/**\n * Shorthand that accepts up to four values, including null to skip a value, and maps them to their respective directions.\n * @example\n * // Styles as object usage\n * const styles = {\n * ...borderColor('red', 'green', 'blue', 'yellow')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${borderColor('red', 'green', 'blue', 'yellow')}\n * `\n *\n * // CSS as JS Output\n *\n * div {\n * 'borderTopColor': 'red',\n * 'borderRightColor': 'green',\n * 'borderBottomColor': 'blue',\n * 'borderLeftColor': 'yellow'\n * }\n */\n\n\nfunction borderColor() {\n for (var _len = arguments.length, values = new Array(_len), _key = 0; _key < _len; _key++) {\n values[_key] = arguments[_key];\n }\n\n return directionalProperty.apply(void 0, ['borderColor'].concat(values));\n}\n/**\n * Shorthand that accepts a value for side and a value for radius and applies the radius value to both corners of the side.\n * @example\n * // Styles as object usage\n * const styles = {\n * ...borderRadius('top', '5px')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${borderRadius('top', '5px')}\n * `\n *\n * // CSS as JS Output\n *\n * div {\n * 'borderTopRightRadius': '5px',\n * 'borderTopLeftRadius': '5px',\n * }\n */\n\n\nfunction borderRadius(side, radius) {\n var uppercaseSide = capitalizeString(side);\n\n if (!radius && radius !== 0) {\n throw new PolishedError(62);\n }\n\n if (uppercaseSide === 'Top' || uppercaseSide === 'Bottom') {\n var _ref;\n\n return _ref = {}, _ref[\"border\" + uppercaseSide + \"RightRadius\"] = radius, _ref[\"border\" + uppercaseSide + \"LeftRadius\"] = radius, _ref;\n }\n\n if (uppercaseSide === 'Left' || uppercaseSide === 'Right') {\n var _ref2;\n\n return _ref2 = {}, _ref2[\"borderTop\" + uppercaseSide + \"Radius\"] = radius, _ref2[\"borderBottom\" + uppercaseSide + \"Radius\"] = radius, _ref2;\n }\n\n throw new PolishedError(63);\n}\n/**\n * Shorthand that accepts up to four values, including null to skip a value, and maps them to their respective directions.\n * @example\n * // Styles as object usage\n * const styles = {\n * ...borderStyle('solid', 'dashed', 'dotted', 'double')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${borderStyle('solid', 'dashed', 'dotted', 'double')}\n * `\n *\n * // CSS as JS Output\n *\n * div {\n * 'borderTopStyle': 'solid',\n * 'borderRightStyle': 'dashed',\n * 'borderBottomStyle': 'dotted',\n * 'borderLeftStyle': 'double'\n * }\n */\n\n\nfunction borderStyle() {\n for (var _len = arguments.length, values = new Array(_len), _key = 0; _key < _len; _key++) {\n values[_key] = arguments[_key];\n }\n\n return directionalProperty.apply(void 0, ['borderStyle'].concat(values));\n}\n/**\n * Shorthand that accepts up to four values, including null to skip a value, and maps them to their respective directions.\n * @example\n * // Styles as object usage\n * const styles = {\n * ...borderWidth('12px', '24px', '36px', '48px')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${borderWidth('12px', '24px', '36px', '48px')}\n * `\n *\n * // CSS as JS Output\n *\n * div {\n * 'borderTopWidth': '12px',\n * 'borderRightWidth': '24px',\n * 'borderBottomWidth': '36px',\n * 'borderLeftWidth': '48px'\n * }\n */\n\n\nfunction borderWidth() {\n for (var _len = arguments.length, values = new Array(_len), _key = 0; _key < _len; _key++) {\n values[_key] = arguments[_key];\n }\n\n return directionalProperty.apply(void 0, ['borderWidth'].concat(values));\n}\n\nfunction generateSelectors(template, state) {\n var stateSuffix = state ? \":\" + state : '';\n return template(stateSuffix);\n}\n/**\n * Function helper that adds an array of states to a template of selectors. Used in textInputs and buttons.\n * @private\n */\n\n\nfunction statefulSelectors(states, template, stateMap) {\n if (!template) throw new PolishedError(67);\n if (states.length === 0) return generateSelectors(template, null);\n var selectors = [];\n\n for (var i = 0; i < states.length; i += 1) {\n if (stateMap && stateMap.indexOf(states[i]) < 0) {\n throw new PolishedError(68);\n }\n\n selectors.push(generateSelectors(template, states[i]));\n }\n\n selectors = selectors.join(',');\n return selectors;\n}\n\nvar stateMap = [undefined, null, 'active', 'focus', 'hover'];\n\nfunction template(state) {\n return \"button\" + state + \",\\n input[type=\\\"button\\\"]\" + state + \",\\n input[type=\\\"reset\\\"]\" + state + \",\\n input[type=\\\"submit\\\"]\" + state;\n}\n/**\n * Populates selectors that target all buttons. You can pass optional states to append to the selectors.\n * @example\n * // Styles as object usage\n * const styles = {\n * [buttons('active')]: {\n * 'border': 'none'\n * }\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * > ${buttons('active')} {\n * border: none;\n * }\n * `\n *\n * // CSS in JS Output\n *\n * 'button:active,\n * 'input[type=\"button\"]:active,\n * 'input[type=\\\"reset\\\"]:active,\n * 'input[type=\\\"submit\\\"]:active: {\n * 'border': 'none'\n * }\n */\n\n\nfunction buttons() {\n for (var _len = arguments.length, states = new Array(_len), _key = 0; _key < _len; _key++) {\n states[_key] = arguments[_key];\n }\n\n return statefulSelectors(states, template, stateMap);\n}\n/**\n * Shorthand that accepts up to four values, including null to skip a value, and maps them to their respective directions.\n * @example\n * // Styles as object usage\n * const styles = {\n * ...margin('12px', '24px', '36px', '48px')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${margin('12px', '24px', '36px', '48px')}\n * `\n *\n * // CSS as JS Output\n *\n * div {\n * 'marginTop': '12px',\n * 'marginRight': '24px',\n * 'marginBottom': '36px',\n * 'marginLeft': '48px'\n * }\n */\n\n\nfunction margin() {\n for (var _len = arguments.length, values = new Array(_len), _key = 0; _key < _len; _key++) {\n values[_key] = arguments[_key];\n }\n\n return directionalProperty.apply(void 0, ['margin'].concat(values));\n}\n/**\n * Shorthand that accepts up to four values, including null to skip a value, and maps them to their respective directions.\n * @example\n * // Styles as object usage\n * const styles = {\n * ...padding('12px', '24px', '36px', '48px')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${padding('12px', '24px', '36px', '48px')}\n * `\n *\n * // CSS as JS Output\n *\n * div {\n * 'paddingTop': '12px',\n * 'paddingRight': '24px',\n * 'paddingBottom': '36px',\n * 'paddingLeft': '48px'\n * }\n */\n\n\nfunction padding() {\n for (var _len = arguments.length, values = new Array(_len), _key = 0; _key < _len; _key++) {\n values[_key] = arguments[_key];\n }\n\n return directionalProperty.apply(void 0, ['padding'].concat(values));\n}\n\nvar positionMap$1 = ['absolute', 'fixed', 'relative', 'static', 'sticky'];\n/**\n * Shorthand accepts up to five values, including null to skip a value, and maps them to their respective directions. The first value can optionally be a position keyword.\n * @example\n * // Styles as object usage\n * const styles = {\n * ...position('12px', '24px', '36px', '48px')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${position('12px', '24px', '36px', '48px')}\n * `\n *\n * // CSS as JS Output\n *\n * div {\n * 'top': '12px',\n * 'right': '24px',\n * 'bottom': '36px',\n * 'left': '48px'\n * }\n *\n * // Styles as object usage\n * const styles = {\n * ...position('absolute', '12px', '24px', '36px', '48px')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${position('absolute', '12px', '24px', '36px', '48px')}\n * `\n *\n * // CSS as JS Output\n *\n * div {\n * 'position': 'absolute',\n * 'top': '12px',\n * 'right': '24px',\n * 'bottom': '36px',\n * 'left': '48px'\n * }\n */\n\nfunction position(firstValue) {\n for (var _len = arguments.length, values = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n values[_key - 1] = arguments[_key];\n }\n\n if (positionMap$1.indexOf(firstValue) >= 0 && firstValue) {\n return _extends({}, directionalProperty.apply(void 0, [''].concat(values)), {\n position: firstValue\n });\n } else {\n return directionalProperty.apply(void 0, ['', firstValue].concat(values));\n }\n}\n/**\n * Shorthand to set the height and width properties in a single statement.\n * @example\n * // Styles as object usage\n * const styles = {\n * ...size('300px', '250px')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${size('300px', '250px')}\n * `\n *\n * // CSS as JS Output\n *\n * div {\n * 'height': '300px',\n * 'width': '250px',\n * }\n */\n\n\nfunction size(height, width) {\n if (width === void 0) {\n width = height;\n }\n\n return {\n height: height,\n width: width\n };\n}\n\nvar stateMap$1 = [undefined, null, 'active', 'focus', 'hover'];\n\nfunction template$1(state) {\n return \"input[type=\\\"color\\\"]\" + state + \",\\n input[type=\\\"date\\\"]\" + state + \",\\n input[type=\\\"datetime\\\"]\" + state + \",\\n input[type=\\\"datetime-local\\\"]\" + state + \",\\n input[type=\\\"email\\\"]\" + state + \",\\n input[type=\\\"month\\\"]\" + state + \",\\n input[type=\\\"number\\\"]\" + state + \",\\n input[type=\\\"password\\\"]\" + state + \",\\n input[type=\\\"search\\\"]\" + state + \",\\n input[type=\\\"tel\\\"]\" + state + \",\\n input[type=\\\"text\\\"]\" + state + \",\\n input[type=\\\"time\\\"]\" + state + \",\\n input[type=\\\"url\\\"]\" + state + \",\\n input[type=\\\"week\\\"]\" + state + \",\\n input:not([type])\" + state + \",\\n textarea\" + state;\n}\n/**\n * Populates selectors that target all text inputs. You can pass optional states to append to the selectors.\n * @example\n * // Styles as object usage\n * const styles = {\n * [textInputs('active')]: {\n * 'border': 'none'\n * }\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * > ${textInputs('active')} {\n * border: none;\n * }\n * `\n *\n * // CSS in JS Output\n *\n * 'input[type=\"color\"]:active,\n * input[type=\"date\"]:active,\n * input[type=\"datetime\"]:active,\n * input[type=\"datetime-local\"]:active,\n * input[type=\"email\"]:active,\n * input[type=\"month\"]:active,\n * input[type=\"number\"]:active,\n * input[type=\"password\"]:active,\n * input[type=\"search\"]:active,\n * input[type=\"tel\"]:active,\n * input[type=\"text\"]:active,\n * input[type=\"time\"]:active,\n * input[type=\"url\"]:active,\n * input[type=\"week\"]:active,\n * input:not([type]):active,\n * textarea:active': {\n * 'border': 'none'\n * }\n */\n\n\nfunction textInputs() {\n for (var _len = arguments.length, states = new Array(_len), _key = 0; _key < _len; _key++) {\n states[_key] = arguments[_key];\n }\n\n return statefulSelectors(states, template$1, stateMap$1);\n}\n/**\n * Accepts any number of transition values as parameters for creating a single transition statement. You may also pass an array of properties as the first parameter that you would like to apply the same transition values to (second parameter).\n * @example\n * // Styles as object usage\n * const styles = {\n * ...transitions('opacity 1.0s ease-in 0s', 'width 2.0s ease-in 2s'),\n * ...transitions(['color', 'background-color'], '2.0s ease-in 2s')\n * }\n *\n * // styled-components usage\n * const div = styled.div`\n * ${transitions('opacity 1.0s ease-in 0s', 'width 2.0s ease-in 2s')};\n * ${transitions(['color', 'background-color'], '2.0s ease-in 2s'),};\n * `\n *\n * // CSS as JS Output\n *\n * div {\n * 'transition': 'opacity 1.0s ease-in 0s, width 2.0s ease-in 2s'\n * 'transition': 'color 2.0s ease-in 2s, background-color 2.0s ease-in 2s',\n * }\n */\n\n\nfunction transitions() {\n for (var _len = arguments.length, properties = new Array(_len), _key = 0; _key < _len; _key++) {\n properties[_key] = arguments[_key];\n }\n\n if (Array.isArray(properties[0]) && properties.length === 2) {\n var value = properties[1];\n\n if (typeof value !== 'string') {\n throw new PolishedError(61);\n }\n\n var transitionsString = properties[0].map(function (property) {\n return property + \" \" + value;\n }).join(', ');\n return {\n transition: transitionsString\n };\n } else {\n return {\n transition: properties.join(', ')\n };\n }\n}\n\nexport { curriedAdjustHue as adjustHue, animation, backgroundImages, backgrounds, between, border, borderColor, borderRadius, borderStyle, borderWidth, buttons, clearFix, complement, cover, cssVar, curriedDarken as darken, curriedDesaturate as desaturate, directionalProperty, ellipsis, em, fluidRange, fontFace, getContrast, getLuminance, getValueAndUnit, grayscale, hiDPI, hideText, hideVisually, hsl, hslToColorString, hsla, invert, curriedLighten as lighten, linearGradient, margin, math, meetsContrastGuidelines, curriedMix as mix, modularScale, normalize, curriedOpacify as opacify, padding, parseToHsl, parseToRgb, position, radialGradient, readableColor, rem, retinaImage, rgb, rgbToColorString, rgba, curriedSaturate as saturate, curriedSetHue as setHue, curriedSetLightness as setLightness, curriedSetSaturation as setSaturation, curriedShade as shade, size, stripUnit, textInputs, timingFunctions, curriedTint as tint, toColorString, transitions, curriedTransparentize as transparentize, triangle, wordWrap };","import { modularScale } from 'polished'\n\nexport function ms(step) {\n return modularScale(step, '1rem', 'majorSecond')\n}\n","import React from \"react\"\nimport styled, { css } from \"styled-components\"\nimport { colors, typography } from \"../tokens\"\nimport { ms } from \"../styles/helpers\"\n\nconst DEFAULT_SPACING = '0.2px'\n\nexport const TextTag = {\n h1: \"h1\",\n h2: \"h2\",\n h3: \"h3\",\n h4: \"h4\",\n h5: \"h5\",\n h6: \"h6\",\n span: \"span\",\n label: \"label\",\n p: \"p\",\n li: \"li\",\n a: \"a\",\n}\n\nexport const TextStyle = {\n Heading1: \"Heading1\",\n Heading2: \"Heading2\",\n Body: \"Body\",\n LabelDefault: \"LabelDefault\",\n}\n\nexport const TextAlign = {\n Left: \"left\",\n Center: \"center\",\n Right: \"right\",\n Justify: \"justify\",\n}\n\nconst styleFonts = (props, defaults) => {\n return css`\n text-align: ${props.textAlign || TextAlign.Left};\n font-family: ${defaults.fontFamily || typography.fonts.default};\n font-size: ${ms(defaults.fontSizeStep)};\n line-height: ${defaults.lineHeightRatio};\n letter-spacing: ${defaults.spacing || DEFAULT_SPACING};\n font-weight: ${props.weight ||\n defaults.fontWeight ||\n typography.weights.regular};\n `\n}\n\nconst getTextStyles = props => {\n const { textStyle } = props\n\n switch (textStyle) {\n case TextStyle.Heading1:\n return styleFonts(props, {\n fontSizeStep: 2,\n lineHeightRatio: 1.39,\n fontWeight: typography.weights.bold,\n fontFamily: typography.fonts.secondary\n })\n case TextStyle.Heading2:\n return styleFonts(props, {\n fontSizeStep: 1.125,\n lineHeightRatio: 1.39,\n fontWeight: typography.weights.bold,\n fontFamily: typography.fonts.secondary\n })\n\n case TextStyle.LabelDefault:\n return styleFonts(props, {\n fontSizeStep: -1,\n lineHeightRatio: 1.214,\n spacing: \"1.5px\",\n fontWeight: typography.weights.bold,\n fontFamily: typography.fonts.secondary\n })\n default:\n case TextStyle.Body:\n return styleFonts(props, {\n fontSizeStep: 0,\n lineHeightRatio: 1.75,\n })\n\n }\n}\n\nexport const StyledText = styled.p`\n margin: 0;\n display: inline-block;\n color: ${props => props.color || colors.text};\n ${({ textStyle }) =>\n (textStyle === TextStyle.LabelDefault) &&\n \"text-transform: uppercase\"};\n ${props => getTextStyles(props)}\n`\n\nconst Text = ({\n textTag = TextTag.span,\n textStyle = TextStyle.Body,\n className,\n children,\n ...restOfProps\n}) => {\n return (\n <StyledText\n className={className}\n {...restOfProps}\n as={textTag}\n textTag={textTag}\n textStyle={textStyle}\n >\n {children}\n </StyledText>\n )\n}\n\nexport default Text\n","export default function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n\n return target;\n}","import React, { useState } from \"react\"\nimport { colors, media, typography } from \"../tokens\"\nimport styled from \"styled-components\"\nimport { ms } from \"../styles/helpers\"\nimport Text, { StyledText, TextStyle } from \"./Text\"\nimport Link from \"./Link\"\nimport { injectIntl } from \"gatsby-plugin-intl\"\n\nconst MobilePanel = styled.div`\n position: absolute;\n z-index: 20;\n left: 0;\n top: 0;\n width: 100vw;\n height: 100vh;\n display: flex;\n background-color: ${colors.primary};\n @media ${media.medium} {\n display: none;\n }\n`\n\nconst MobilePanelWrapper = styled.div`\n width: 100%;\n height: 100%;\n display: flex;\n align-items: center;\n flex-direction: column;\n justify-content: center;\n`\n\nconst MobileNav = styled.nav`\n max-width: 800px;\n display: grid;\n grid-template-columns: 1fr;\n grid-auto-rows: auto;\n grid-gap: ${ms(2)};\n align-items: center;\n`\n\nconst BurgerButton = styled.button`\n color: ${colors.textLightest};\n display: flex;\n background: transparent;\n border: none;\n cursor: pointer;\n padding: 8px 12px;\n outline: none;\n -webkit-tap-highlight-color: transparent;\n`\n\nconst BurgerContent = styled.div`\n width: 24px;\n top: 30px;\n height: 2px;\n background: ${colors.text};\n position: absolute;\n left: 0;\n ${props =>\n props.isToggledOn\n ? \"background: transparent\"\n : `background: ${colors.text}`};\n transition: all 250ms cubic-bezier(0.86, 0, 0.07, 1);\n ::before {\n content: \"\";\n top: -8px;\n width: 24px;\n height: 2px;\n background: ${props =>\n props.isToggledOn ? colors.textLightest : colors.text};\n position: absolute;\n left: 0;\n ${props =>\n props.isToggledOn\n ? \"transform: rotate(45deg); top: 0;\"\n : \"transform: rotate(0)\"};\n transition: all 250ms cubic-bezier(0.86, 0, 0.07, 1);\n }\n ::after {\n top: 8px;\n content: \"\";\n width: 24px;\n height: 2px;\n background: ${props =>\n props.isToggledOn ? colors.textLightest : colors.text};\n position: absolute;\n left: 0;\n ${props =>\n props.isToggledOn\n ? \"transform: rotate(-45deg); top: 0;\"\n : \"transform: rotate(0)\"};\n transition: all 250ms cubic-bezier(0.86, 0, 0.07, 1);\n }\n`\n\nconst HeaderLink = styled(Link)`\n &.active {\n ${StyledText} {\n font-weight: ${typography.weights.bold};\n }\n }\n`\n\nconst HeaderLinkText = styled(Text)`\n font-weight: ${typography.weights.regular};\n`\n\nconst MobileHeader = ({ headerLinks, className, intl }) => {\n const [isToggledOn, setToggle] = useState(false)\n const toggle = () => setToggle(!isToggledOn)\n\n return (\n <>\n <BurgerButton\n className={className}\n onClick={toggle}\n aria-label={`${isToggledOn ? \"close menu\" : \"open menu\"}`}\n >\n <BurgerContent isToggledOn={isToggledOn} />\n </BurgerButton>\n {isToggledOn && (\n <MobilePanel>\n <MobilePanelWrapper>\n <MobileNav>\n {headerLinks.map((headerLink, i) => (\n <HeaderLink\n to={headerLink.url}\n key={`header-link-${i}`}\n aria-label={`View ${headerLink.label} page`}\n >\n <HeaderLinkText\n textStyle={TextStyle.Heading2}\n color={colors.textLightest}\n >\n {intl.formatMessage({ id: headerLink.label })}\n\n </HeaderLinkText>\n </HeaderLink>\n ))}\n }\n </MobileNav>\n </MobilePanelWrapper>\n </MobilePanel>\n )}\n </>\n )\n}\n\nexport default injectIntl(MobileHeader)\n","/* eslint-disable react-hooks/rules-of-hooks */\n\nimport React from \"react\"\nimport Link from \"../components/Link\"\nimport styled from \"styled-components\"\nimport { injectIntl } from \"gatsby-plugin-intl\"\n\nimport useSiteMetadata from \"../hooks/use-site-config\"\nimport { colors, media, typography } from \"../tokens\"\nimport useSiteImages from \"../hooks/use-site-images\"\nimport { ms } from \"../styles/helpers\"\n\nimport Text, { TextStyle, StyledText } from \"./Text\"\nimport MobileHeader from \"./MobileHeader\"\n\nconst HeaderWrapper = styled.header`\n top: 0;\n left: 0;\n margin: 0 auto;\n display: block;\n width: 100%;\n z-index: 1000;\n background-color: ${colors.primaryLight};\n\n @media ${media.medium} {\n position: sticky;\n }\n`\n\nconst HeaderNav = styled.nav`\n display: grid;\n grid-template-areas: \"logo settings\";\n grid-template-columns: 1fr auto;\n max-width: 1440px;\n margin: 0 auto;\n padding: 0 ${ms(0)};\n\n @media ${media.medium} {\n padding: 0 ${ms(8)};\n grid-template-areas:\n \"logo settings\"\n \"logo navigation\";\n }\n`\n\nconst HeaderLinksContainer = styled.ul`\n display: none;\n\n @media ${media.medium} {\n padding: 0;\n margin: 0;\n list-style: none;\n display: flex;\n grid-area: navigation;\n justify-content: flex-end;\n align-items: center;\n }\n`\n\nconst LinkItem = styled.li`\n margin: 0 ${ms(2)} 0 0;\n &:last-of-type {\n margin: 0;\n }\n`\n\nconst HeaderLink = styled(Link)`\n &.active {\n ${StyledText} {\n font-weight: ${typography.weights.bold};\n }\n }\n`\n\nconst HeaderLinkText = styled(Text)`\n font-weight: ${typography.weights.regular};\n`\n\nconst HeaderSetting = styled.div`\n display: none;\n @media ${media.medium} {\n display: block;\n grid-area: settings;\n justify-self: flex-end;\n align-self: center;\n }\n`\n\nconst LogoWrapper = styled.div`\n grid-area: logo;\n margin: 0 0 0 -${ms(0)};\n\n @media ${media.medium} {\n margin: 0 0 0 -${ms(6)};\n }\n`\n\nconst LogoImage = styled.img`\n height: 80px;\n width: 80px;\n @media ${media.medium} {\n height: 140px;\n width: 140px;\n }\n`\n\nconst StyledMobileHeader = styled(MobileHeader)`\n z-index: 30;\n top: 0px;\n position: relative;\n color: ${colors.textLightest};\n grid-area: settings;\n\n @media ${media.medium} {\n display: none;\n }\n`\n\nconst Header = ({ intl }) => {\n const { headerLinks, siteTitle, headerLinksIcon } = useSiteMetadata()\n const iconSrc = headerLinksIcon\n ? useSiteImages(headerLinksIcon).fluid.src\n : null\n\n return (\n <HeaderWrapper>\n <HeaderNav>\n <LogoWrapper>\n <Link to={`/`} aria-label={`View home page`}>\n {iconSrc && <LogoImage src={iconSrc} alt={siteTitle} />}\n </Link>\n </LogoWrapper>\n <HeaderSetting/>\n <HeaderLinksContainer>\n {headerLinks.map((headerLink, i) => (\n <LinkItem key={`header-link-${i}`}>\n <HeaderLink\n to={headerLink.url}\n aria-label={`View ${headerLink.label} page`}\n >\n <HeaderLinkText textStyle={TextStyle.Heading2}>\n {intl.formatMessage({ id: headerLink.label })}\n </HeaderLinkText>\n </HeaderLink>\n </LinkItem>\n ))}\n </HeaderLinksContainer>\n <StyledMobileHeader headerLinks={headerLinks} />\n </HeaderNav>\n </HeaderWrapper>\n )\n}\n\nexport default injectIntl(Header)\n","import React from 'react'\nimport { Link } from 'gatsby'\nimport Image from 'gatsby-image'\nimport styled from 'styled-components'\nimport useSiteMetadata from '../hooks/use-site-config'\nimport { colors, media } from '../tokens'\nimport useSiteImages from \"../hooks/use-site-images\"\n\nconst FooterWrapper = styled.footer`\n text-align: left;\n padding-top: 8px;\n background-color: ${colors.primary};\n color: ${colors.textLightest};\n margin: 0 auto;\n\n & nav {\n display: flex;\n flex-flow: row wrap;\n align-items: flex-start;\n max-width: 1100px;\n margin: 0 auto;\n padding-bottom: 8px;\n\n .footer-col {\n flex: 1 auto;\n display: inline-flex;\n flex-direction: column;\n padding-left: 5em;\n padding-bottom: 2em;\n }\n }\n\n & a {\n color: ${colors.textLightest};\n font-weight: bold;\n\n &:hover {\n color: ${colors.textLightestHover};\n }\n }\n\n .footer-col > p {\n margin: 0;\n }\n\n .footer-title {\n font-size: 18sp;\n margin: 1.5rem 0 1rem;\n }\n\n .footer-item {\n color: ${colors.textLightest};\n\n & a {\n padding: 0.25rem 0;\n display: block;\n }\n }\n\n .footer-heart {\n color: ${colors.heartFooter};\n }\n\n .footer-item-text {\n padding: 0.1rem 0;\n color: ${colors.textLightest};\n }\n\n .footer-header {\n order: 1;\n margin: 0 0.25rem;\n margin-right: 0.25rem;\n padding: 0.25rem;\n }\n\n .footer-column-items {\n grid-template-columns: 1fr;\n display: grid;\n }\n\n .footer-bottom {\n background-color: #f6b3cd;\n padding: 19px;\n }\n\n .footer-bottom-title {\n max-width: 1100px;\n margin: 0 auto;\n font-size: 0.83em;\n }\n\n @media (max-width: 564px) {\n .footer-col:first-child {\n width: 100%;\n }\n }\n`\nconst LogoImage = styled(Image)`\n height: 0px;\n width: 0px;\n @media ${media.medium} {\n height: 200px;\n width: 200px;\n }\n`\n\nconst Footer = () => {\n const { footerLinks, footerLinksIcon } = useSiteMetadata()\n const iconSrc = useSiteImages(footerLinksIcon).fluid\n\n const FooterItem = ({ item }) => {\n if (item.url.startsWith('/')) {\n return (\n <span className=\"footer-item\">\n <Link className=\"footer-link\" to={item.url}>\n {item.label}\n </Link>\n </span>\n )\n }\n return (\n <span className=\"footer-item\">\n <a className=\"footer-link\" href={item.url} target=\"_blank\" rel=\"noreferrer\">\n {item.label}\n </a>\n </span>\n )\n }\n\n const FooterColumn = ({ column }) => {\n return (\n <div className=\"footer-col\">\n <h3 className=\"footer-title\" key={column.sectionName}>\n {column.sectionName}\n </h3>\n <div className=\"footer-column-items\">\n {column.links.map((item, i) => {\n return <FooterItem item={item} key={`footer-column-item-${i}`} />\n })}\n </div>\n </div>\n )\n }\n\n const FooterEnd = () => {\n return (\n <div className=\"footer-bottom\">\n <h3 className=\"footer-bottom-title\">\n © SREBRNYDOM.PL {new Date().getFullYear()} - WSZELKIE PRAWA ZASTRZEŻONE.\n </h3>\n </div>\n )\n }\n\n return (\n <FooterWrapper>\n <nav>\n <LogoImage fluid={iconSrc}/>\n\n {footerLinks.map((column, i) => {\n return <FooterColumn column={column} key={`footer-column-${i}`} />\n })}\n </nav>\n <FooterEnd/>\n </FooterWrapper> \n )\n}\n\nexport default Footer\n","import React from 'react'\nimport { Helmet } from 'react-helmet'\nimport styled from 'styled-components'\nimport Header from './Header'\nimport Footer from './Footer'\nimport 'prismjs/themes/prism-tomorrow.css'\nimport { GlobalStyle } from './Commons'\nimport { media } from '../tokens'\nimport './cookie-though-layout.css'\n\nconst SiteContent = styled.div`\n margin: 0 0;\n\n @media ${media.medium} {\n margin: 0 0 60px 0;\n }\n`\n\nclass Template extends React.Component {\n render() {\n const { children } = this.props\n\n return (\n <>\n <Helmet>\n <link\n href=\"https://fonts.googleapis.com/css?family=Lato:400,700|Nunito:400,700&display=swap\"\n rel=\"stylesheet\"\n />\n </Helmet>\n <GlobalStyle />\n <Header />\n <SiteContent>{children}</SiteContent>\n <Footer />\n </>\n )\n }\n}\n\nexport default Template\n","import React from 'react'\nimport { Helmet } from 'react-helmet'\nimport { withPrefix } from 'gatsby'\nimport useSiteMetadata from '../hooks/use-site-config'\n\nconst SEO = props => {\n const { isBlogPost, path = '', lang = 'pl' } = props\n const {\n siteTitle,\n siteUrl,\n siteCover,\n siteDescription,\n twitterUsername,\n } = useSiteMetadata()\n\n const title = props.title\n ? `${props.title}`\n : `${siteTitle}`\n const formatedSiteUrl = siteUrl.endsWith('/')\n ? siteUrl.substring(0, siteUrl.length - 1)\n : siteUrl\n const imagePath = props.imageShare || props.cover || withPrefix(siteCover)\n const image = `${formatedSiteUrl}${imagePath}`\n const description = props.description || siteDescription\n const internalTranslations = (props.translations || []).filter(\n t => !t.link.startsWith('http')\n )\n\n return (\n <Helmet title={title}>\n {/* General tags */}\n <html lang={lang} />\n <meta name=\"description\" content={description} />\n <link rel=\"canonical\" href={formatedSiteUrl + withPrefix(path)} />\n\n {internalTranslations.map(translation => (\n <link\n rel=\"alternate\"\n hreflang={translation.hreflang}\n href={formatedSiteUrl + withPrefix(translation.link)}\n />\n ))}\n\n {/* OpenGraph tags */}\n <meta property=\"og:url\" content={formatedSiteUrl + withPrefix(path)} />\n <meta property=\"og:type\" content={isBlogPost ? 'article' : 'website'} />\n <meta property=\"og:title\" content={title} />\n <meta property=\"og:description\" content={description} />\n <meta property=\"og:image\" content={image} />\n\n {/* Twitter Card tags */}\n <meta name=\"twitter:card\" content=\"summary_large_image\" />\n <meta name=\"twitter:creator\" content={twitterUsername} />\n <meta name=\"twitter:title\" content={title} />\n <meta name=\"twitter:description\" content={description} />\n <meta name=\"twitter:image\" content={image} />\n </Helmet>\n )\n}\n\nexport default SEO\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nexports.__esModule = true;\nexports.changeLocale = exports.navigate = exports.default = void 0;\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _objectWithoutPropertiesLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/objectWithoutPropertiesLoose\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _gatsby = require(\"gatsby\");\n\nvar _intlContext = require(\"./intl-context\");\n\nvar Link = function Link(_ref) {\n var to = _ref.to,\n language = _ref.language,\n children = _ref.children,\n onClick = _ref.onClick,\n rest = (0, _objectWithoutPropertiesLoose2.default)(_ref, [\"to\", \"language\", \"children\", \"onClick\"]);\n return _react.default.createElement(_intlContext.IntlContextConsumer, null, function (intl) {\n var languageLink = language || intl.language;\n var link = intl.routed || language ? \"/\" + languageLink + to : \"\" + to;\n\n var handleClick = function handleClick(e) {\n if (language) {\n localStorage.setItem(\"gatsby-intl-language\", language);\n }\n\n if (onClick) {\n onClick(e);\n }\n };\n\n return _react.default.createElement(_gatsby.Link, (0, _extends2.default)({}, rest, {\n to: link,\n onClick: handleClick\n }), children);\n });\n};\n\nLink.propTypes = {\n children: _propTypes.default.node.isRequired,\n to: _propTypes.default.string,\n language: _propTypes.default.string\n};\nLink.defaultProps = {\n to: \"\"\n};\nvar _default = Link;\nexports.default = _default;\n\nvar navigate = function navigate(to, options) {\n if (typeof window === \"undefined\") {\n return;\n }\n\n var _window$___gatsbyIntl = window.___gatsbyIntl,\n language = _window$___gatsbyIntl.language,\n routed = _window$___gatsbyIntl.routed;\n var link = routed ? \"/\" + language + to : \"\" + to;\n (0, _gatsby.navigate)(link, options);\n};\n\nexports.navigate = navigate;\n\nvar changeLocale = function changeLocale(language, to) {\n if (typeof window === \"undefined\") {\n return;\n }\n\n var routed = window.___gatsbyIntl.routed;\n\n var removePrefix = function removePrefix(pathname) {\n var base = typeof __BASE_PATH__ !== \"undefined\" ? __BASE_PATH__ : __PATH_PREFIX__;\n\n if (base && pathname.indexOf(base) === 0) {\n pathname = pathname.slice(base.length);\n }\n\n return pathname;\n };\n\n var removeLocalePart = function removeLocalePart(pathname) {\n if (!routed) {\n return pathname;\n }\n\n var i = pathname.indexOf(\"/\", 1);\n return pathname.substring(i);\n };\n\n var pathname = to || removeLocalePart(removePrefix(window.location.pathname)); // TODO: check slash\n\n var link = \"/\" + language + pathname + window.location.search;\n localStorage.setItem(\"gatsby-intl-language\", language);\n (0, _gatsby.navigate)(link);\n};\n\nexports.changeLocale = changeLocale;","//\nmodule.exports = function shallowEqual(objA, objB, compare, compareContext) {\n var ret = compare ? compare.call(compareContext, objA, objB) : void 0;\n\n if (ret !== void 0) {\n return !!ret;\n }\n\n if (objA === objB) {\n return true;\n }\n\n if (typeof objA !== \"object\" || !objA || typeof objB !== \"object\" || !objB) {\n return false;\n }\n\n var keysA = Object.keys(objA);\n var keysB = Object.keys(objB);\n\n if (keysA.length !== keysB.length) {\n return false;\n }\n\n var bHasOwnProperty = Object.prototype.hasOwnProperty.bind(objB); // Test for A's keys different from B.\n\n for (var idx = 0; idx < keysA.length; idx++) {\n var key = keysA[idx];\n\n if (!bHasOwnProperty(key)) {\n return false;\n }\n\n var valueA = objA[key];\n var valueB = objB[key];\n ret = compare ? compare.call(compareContext, valueA, valueB, key) : void 0;\n\n if (ret === false || ret === void 0 && valueA !== valueB) {\n return false;\n }\n }\n\n return true;\n};","import React from 'react'\nimport styled from 'styled-components'\nimport { createGlobalStyle } from 'styled-components'\nimport { Link } from 'gatsby'\nimport { colors } from '../tokens'\n\nexport const GlobalStyle = createGlobalStyle`\n* {\n box-sizing: border-box;\n margin: 0;\n padding: 0;\n}\n\nbody {\n font-family: \"Lato\", sans-serif;\n color: ${colors.text};\n background-color: ${colors.background};\n}\n\nimg {\n max-width: 100%;\n height: auto;\n vertical-align: middle;\n border: 0;\n}\n\na {\n text-decoration: none;\n color: ${colors.primary};\n}\n\nhr {\n border: 0;\n border-top: 1px solid ${colors.grey100};\n margin: 50px 0 5px 0;\n}\n\nul,\nol {\n padding-left: 2em;\n margin: 1em 0 0 0;\n}\n\n*::selection {\n background-color: ${colors.backgroundSelection};\n}\n`\nexport const StyledLink = styled(Link)`\n box-shadow: 0 2px 0 0 ${colors.links};\n\n &:hover {\n filter: brightness(150%);\n box-shadow: none;\n }\n`\n\nexport const Text = styled.p`\n line-height: 1.6;\n margin: 1em 0 0 0;\n`\n\nexport const Bull = styled.span`\n display: inline-block;\n color: ${colors.postMetadata};\n margin: 0 4px;\n &::before {\n content: '•';\n }\n`\n\nexport const ReadingTime = props => {\n const ReadingTimeContainer = styled.span`\n text-transform: uppercase;\n color: ${colors.postMetadata};\n `\n return <ReadingTimeContainer>{props.min} min read</ReadingTimeContainer>\n}\n","import styled from 'styled-components'\nimport { colors } from '../tokens'\n\nconst Wrapper = styled.main.attrs({\n role: 'main',\n})`\n position: relative;\n border-radius: 5px;\n max-width: 720px;\n word-wrap: break-word;\n background-color: ${colors.backgroundArticle};\n margin: 0px auto 0px auto;\n top: 8px;\n padding: 60px 0px 80px 0px;\n\n @media (max-width: 780px) {\n width: 100%;\n padding: 25px;\n }\n`\n\nexport default Wrapper\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<Type> &&` 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};","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nexports.__esModule = true;\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _reactIntl = require(\"react-intl\");\n\nvar _default = function _default(Component) {\n return function (props) {\n console.warn(\"withIntl is deprecated. Please use injectIntl instead.\");\n return _react.default.createElement((0, _reactIntl.injectIntl)(Component), props);\n };\n};\n\nexports.default = _default;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nvar _interopRequireWildcard = require(\"@babel/runtime/helpers/interopRequireWildcard\");\n\nexports.__esModule = true;\nvar _exportNames = {\n Link: true,\n withIntl: true,\n navigate: true,\n changeLocale: true,\n IntlContextProvider: true,\n IntlContextConsumer: true\n};\nexports.IntlContextConsumer = exports.IntlContextProvider = exports.changeLocale = exports.navigate = exports.withIntl = exports.Link = void 0;\n\nvar _reactIntl = require(\"react-intl\");\n\nObject.keys(_reactIntl).forEach(function (key) {\n if (key === \"default\" || key === \"__esModule\") return;\n if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;\n exports[key] = _reactIntl[key];\n});\n\nvar _link = _interopRequireWildcard(require(\"./link\"));\n\nexports.Link = _link.default;\nexports.navigate = _link.navigate;\nexports.changeLocale = _link.changeLocale;\n\nvar _withIntl = _interopRequireDefault(require(\"./with-intl\"));\n\nexports.withIntl = _withIntl.default;\n\nvar _intlContext = require(\"./intl-context\");\n\nexports.IntlContextProvider = _intlContext.IntlContextProvider;\nexports.IntlContextConsumer = _intlContext.IntlContextConsumer;","import PropTypes from 'prop-types';\nimport withSideEffect from 'react-side-effect';\nimport isEqual from 'react-fast-compare';\nimport React from 'react';\nimport objectAssign from 'object-assign';\nvar ATTRIBUTE_NAMES = {\n BODY: \"bodyAttributes\",\n HTML: \"htmlAttributes\",\n TITLE: \"titleAttributes\"\n};\nvar TAG_NAMES = {\n BASE: \"base\",\n BODY: \"body\",\n HEAD: \"head\",\n HTML: \"html\",\n LINK: \"link\",\n META: \"meta\",\n NOSCRIPT: \"noscript\",\n SCRIPT: \"script\",\n STYLE: \"style\",\n TITLE: \"title\"\n};\nvar VALID_TAG_NAMES = Object.keys(TAG_NAMES).map(function (name) {\n return TAG_NAMES[name];\n});\nvar TAG_PROPERTIES = {\n CHARSET: \"charset\",\n CSS_TEXT: \"cssText\",\n HREF: \"href\",\n HTTPEQUIV: \"http-equiv\",\n INNER_HTML: \"innerHTML\",\n ITEM_PROP: \"itemprop\",\n NAME: \"name\",\n PROPERTY: \"property\",\n REL: \"rel\",\n SRC: \"src\",\n TARGET: \"target\"\n};\nvar REACT_TAG_MAP = {\n accesskey: \"accessKey\",\n charset: \"charSet\",\n class: \"className\",\n contenteditable: \"contentEditable\",\n contextmenu: \"contextMenu\",\n \"http-equiv\": \"httpEquiv\",\n itemprop: \"itemProp\",\n tabindex: \"tabIndex\"\n};\nvar HELMET_PROPS = {\n DEFAULT_TITLE: \"defaultTitle\",\n DEFER: \"defer\",\n ENCODE_SPECIAL_CHARACTERS: \"encodeSpecialCharacters\",\n ON_CHANGE_CLIENT_STATE: \"onChangeClientState\",\n TITLE_TEMPLATE: \"titleTemplate\"\n};\nvar HTML_TAG_MAP = Object.keys(REACT_TAG_MAP).reduce(function (obj, key) {\n obj[REACT_TAG_MAP[key]] = key;\n return obj;\n}, {});\nvar SELF_CLOSING_TAGS = [TAG_NAMES.NOSCRIPT, TAG_NAMES.SCRIPT, TAG_NAMES.STYLE];\nvar HELMET_ATTRIBUTE = \"data-react-helmet\";\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) {\n return typeof obj;\n} : function (obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n};\n\nvar classCallCheck = function classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n};\n\nvar createClass = function () {\n function defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n }\n\n return function (Constructor, protoProps, staticProps) {\n if (protoProps) defineProperties(Constructor.prototype, protoProps);\n if (staticProps) defineProperties(Constructor, staticProps);\n return Constructor;\n };\n}();\n\nvar _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n};\n\nvar inherits = function inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass);\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;\n};\n\nvar objectWithoutProperties = function objectWithoutProperties(obj, keys) {\n var target = {};\n\n for (var i in obj) {\n if (keys.indexOf(i) >= 0) continue;\n if (!Object.prototype.hasOwnProperty.call(obj, i)) continue;\n target[i] = obj[i];\n }\n\n return target;\n};\n\nvar possibleConstructorReturn = function possibleConstructorReturn(self, call) {\n if (!self) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self;\n};\n\nvar encodeSpecialCharacters = function encodeSpecialCharacters(str) {\n var encode = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n\n if (encode === false) {\n return String(str);\n }\n\n return String(str).replace(/&/g, \"&\").replace(/</g, \"<\").replace(/>/g, \">\").replace(/\"/g, \""\").replace(/'/g, \"'\");\n};\n\nvar getTitleFromPropsList = function getTitleFromPropsList(propsList) {\n var innermostTitle = getInnermostProperty(propsList, TAG_NAMES.TITLE);\n var innermostTemplate = getInnermostProperty(propsList, HELMET_PROPS.TITLE_TEMPLATE);\n\n if (innermostTemplate && innermostTitle) {\n // use function arg to avoid need to escape $ characters\n return innermostTemplate.replace(/%s/g, function () {\n return Array.isArray(innermostTitle) ? innermostTitle.join(\"\") : innermostTitle;\n });\n }\n\n var innermostDefaultTitle = getInnermostProperty(propsList, HELMET_PROPS.DEFAULT_TITLE);\n return innermostTitle || innermostDefaultTitle || undefined;\n};\n\nvar getOnChangeClientState = function getOnChangeClientState(propsList) {\n return getInnermostProperty(propsList, HELMET_PROPS.ON_CHANGE_CLIENT_STATE) || function () {};\n};\n\nvar getAttributesFromPropsList = function getAttributesFromPropsList(tagType, propsList) {\n return propsList.filter(function (props) {\n return typeof props[tagType] !== \"undefined\";\n }).map(function (props) {\n return props[tagType];\n }).reduce(function (tagAttrs, current) {\n return _extends({}, tagAttrs, current);\n }, {});\n};\n\nvar getBaseTagFromPropsList = function getBaseTagFromPropsList(primaryAttributes, propsList) {\n return propsList.filter(function (props) {\n return typeof props[TAG_NAMES.BASE] !== \"undefined\";\n }).map(function (props) {\n return props[TAG_NAMES.BASE];\n }).reverse().reduce(function (innermostBaseTag, tag) {\n if (!innermostBaseTag.length) {\n var keys = Object.keys(tag);\n\n for (var i = 0; i < keys.length; i++) {\n var attributeKey = keys[i];\n var lowerCaseAttributeKey = attributeKey.toLowerCase();\n\n if (primaryAttributes.indexOf(lowerCaseAttributeKey) !== -1 && tag[lowerCaseAttributeKey]) {\n return innermostBaseTag.concat(tag);\n }\n }\n }\n\n return innermostBaseTag;\n }, []);\n};\n\nvar getTagsFromPropsList = function getTagsFromPropsList(tagName, primaryAttributes, propsList) {\n // Calculate list of tags, giving priority innermost component (end of the propslist)\n var approvedSeenTags = {};\n return propsList.filter(function (props) {\n if (Array.isArray(props[tagName])) {\n return true;\n }\n\n if (typeof props[tagName] !== \"undefined\") {\n warn(\"Helmet: \" + tagName + \" should be of type \\\"Array\\\". Instead found type \\\"\" + _typeof(props[tagName]) + \"\\\"\");\n }\n\n return false;\n }).map(function (props) {\n return props[tagName];\n }).reverse().reduce(function (approvedTags, instanceTags) {\n var instanceSeenTags = {};\n instanceTags.filter(function (tag) {\n var primaryAttributeKey = void 0;\n var keys = Object.keys(tag);\n\n for (var i = 0; i < keys.length; i++) {\n var attributeKey = keys[i];\n var lowerCaseAttributeKey = attributeKey.toLowerCase(); // Special rule with link tags, since rel and href are both primary tags, rel takes priority\n\n if (primaryAttributes.indexOf(lowerCaseAttributeKey) !== -1 && !(primaryAttributeKey === TAG_PROPERTIES.REL && tag[primaryAttributeKey].toLowerCase() === \"canonical\") && !(lowerCaseAttributeKey === TAG_PROPERTIES.REL && tag[lowerCaseAttributeKey].toLowerCase() === \"stylesheet\")) {\n primaryAttributeKey = lowerCaseAttributeKey;\n } // Special case for innerHTML which doesn't work lowercased\n\n\n if (primaryAttributes.indexOf(attributeKey) !== -1 && (attributeKey === TAG_PROPERTIES.INNER_HTML || attributeKey === TAG_PROPERTIES.CSS_TEXT || attributeKey === TAG_PROPERTIES.ITEM_PROP)) {\n primaryAttributeKey = attributeKey;\n }\n }\n\n if (!primaryAttributeKey || !tag[primaryAttributeKey]) {\n return false;\n }\n\n var value = tag[primaryAttributeKey].toLowerCase();\n\n if (!approvedSeenTags[primaryAttributeKey]) {\n approvedSeenTags[primaryAttributeKey] = {};\n }\n\n if (!instanceSeenTags[primaryAttributeKey]) {\n instanceSeenTags[primaryAttributeKey] = {};\n }\n\n if (!approvedSeenTags[primaryAttributeKey][value]) {\n instanceSeenTags[primaryAttributeKey][value] = true;\n return true;\n }\n\n return false;\n }).reverse().forEach(function (tag) {\n return approvedTags.push(tag);\n }); // Update seen tags with tags from this instance\n\n var keys = Object.keys(instanceSeenTags);\n\n for (var i = 0; i < keys.length; i++) {\n var attributeKey = keys[i];\n var tagUnion = objectAssign({}, approvedSeenTags[attributeKey], instanceSeenTags[attributeKey]);\n approvedSeenTags[attributeKey] = tagUnion;\n }\n\n return approvedTags;\n }, []).reverse();\n};\n\nvar getInnermostProperty = function getInnermostProperty(propsList, property) {\n for (var i = propsList.length - 1; i >= 0; i--) {\n var props = propsList[i];\n\n if (props.hasOwnProperty(property)) {\n return props[property];\n }\n }\n\n return null;\n};\n\nvar reducePropsToState = function reducePropsToState(propsList) {\n return {\n baseTag: getBaseTagFromPropsList([TAG_PROPERTIES.HREF, TAG_PROPERTIES.TARGET], propsList),\n bodyAttributes: getAttributesFromPropsList(ATTRIBUTE_NAMES.BODY, propsList),\n defer: getInnermostProperty(propsList, HELMET_PROPS.DEFER),\n encode: getInnermostProperty(propsList, HELMET_PROPS.ENCODE_SPECIAL_CHARACTERS),\n htmlAttributes: getAttributesFromPropsList(ATTRIBUTE_NAMES.HTML, propsList),\n linkTags: getTagsFromPropsList(TAG_NAMES.LINK, [TAG_PROPERTIES.REL, TAG_PROPERTIES.HREF], propsList),\n metaTags: getTagsFromPropsList(TAG_NAMES.META, [TAG_PROPERTIES.NAME, TAG_PROPERTIES.CHARSET, TAG_PROPERTIES.HTTPEQUIV, TAG_PROPERTIES.PROPERTY, TAG_PROPERTIES.ITEM_PROP], propsList),\n noscriptTags: getTagsFromPropsList(TAG_NAMES.NOSCRIPT, [TAG_PROPERTIES.INNER_HTML], propsList),\n onChangeClientState: getOnChangeClientState(propsList),\n scriptTags: getTagsFromPropsList(TAG_NAMES.SCRIPT, [TAG_PROPERTIES.SRC, TAG_PROPERTIES.INNER_HTML], propsList),\n styleTags: getTagsFromPropsList(TAG_NAMES.STYLE, [TAG_PROPERTIES.CSS_TEXT], propsList),\n title: getTitleFromPropsList(propsList),\n titleAttributes: getAttributesFromPropsList(ATTRIBUTE_NAMES.TITLE, propsList)\n };\n};\n\nvar rafPolyfill = 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 rafPolyfill(callback);\n }, 0);\n }\n };\n}();\n\nvar cafPolyfill = function cafPolyfill(id) {\n return clearTimeout(id);\n};\n\nvar requestAnimationFrame = typeof window !== \"undefined\" ? window.requestAnimationFrame && window.requestAnimationFrame.bind(window) || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || rafPolyfill : global.requestAnimationFrame || rafPolyfill;\nvar cancelAnimationFrame = typeof window !== \"undefined\" ? window.cancelAnimationFrame || window.webkitCancelAnimationFrame || window.mozCancelAnimationFrame || cafPolyfill : global.cancelAnimationFrame || cafPolyfill;\n\nvar warn = function warn(msg) {\n return console && typeof console.warn === \"function\" && console.warn(msg);\n};\n\nvar _helmetCallback = null;\n\nvar handleClientStateChange = function handleClientStateChange(newState) {\n if (_helmetCallback) {\n cancelAnimationFrame(_helmetCallback);\n }\n\n if (newState.defer) {\n _helmetCallback = requestAnimationFrame(function () {\n commitTagChanges(newState, function () {\n _helmetCallback = null;\n });\n });\n } else {\n commitTagChanges(newState);\n _helmetCallback = null;\n }\n};\n\nvar commitTagChanges = function commitTagChanges(newState, cb) {\n var baseTag = newState.baseTag,\n bodyAttributes = newState.bodyAttributes,\n htmlAttributes = newState.htmlAttributes,\n linkTags = newState.linkTags,\n metaTags = newState.metaTags,\n noscriptTags = newState.noscriptTags,\n onChangeClientState = newState.onChangeClientState,\n scriptTags = newState.scriptTags,\n styleTags = newState.styleTags,\n title = newState.title,\n titleAttributes = newState.titleAttributes;\n updateAttributes(TAG_NAMES.BODY, bodyAttributes);\n updateAttributes(TAG_NAMES.HTML, htmlAttributes);\n updateTitle(title, titleAttributes);\n var tagUpdates = {\n baseTag: updateTags(TAG_NAMES.BASE, baseTag),\n linkTags: updateTags(TAG_NAMES.LINK, linkTags),\n metaTags: updateTags(TAG_NAMES.META, metaTags),\n noscriptTags: updateTags(TAG_NAMES.NOSCRIPT, noscriptTags),\n scriptTags: updateTags(TAG_NAMES.SCRIPT, scriptTags),\n styleTags: updateTags(TAG_NAMES.STYLE, styleTags)\n };\n var addedTags = {};\n var removedTags = {};\n Object.keys(tagUpdates).forEach(function (tagType) {\n var _tagUpdates$tagType = tagUpdates[tagType],\n newTags = _tagUpdates$tagType.newTags,\n oldTags = _tagUpdates$tagType.oldTags;\n\n if (newTags.length) {\n addedTags[tagType] = newTags;\n }\n\n if (oldTags.length) {\n removedTags[tagType] = tagUpdates[tagType].oldTags;\n }\n });\n cb && cb();\n onChangeClientState(newState, addedTags, removedTags);\n};\n\nvar flattenArray = function flattenArray(possibleArray) {\n return Array.isArray(possibleArray) ? possibleArray.join(\"\") : possibleArray;\n};\n\nvar updateTitle = function updateTitle(title, attributes) {\n if (typeof title !== \"undefined\" && document.title !== title) {\n document.title = flattenArray(title);\n }\n\n updateAttributes(TAG_NAMES.TITLE, attributes);\n};\n\nvar updateAttributes = function updateAttributes(tagName, attributes) {\n var elementTag = document.getElementsByTagName(tagName)[0];\n\n if (!elementTag) {\n return;\n }\n\n var helmetAttributeString = elementTag.getAttribute(HELMET_ATTRIBUTE);\n var helmetAttributes = helmetAttributeString ? helmetAttributeString.split(\",\") : [];\n var attributesToRemove = [].concat(helmetAttributes);\n var attributeKeys = Object.keys(attributes);\n\n for (var i = 0; i < attributeKeys.length; i++) {\n var attribute = attributeKeys[i];\n var value = attributes[attribute] || \"\";\n\n if (elementTag.getAttribute(attribute) !== value) {\n elementTag.setAttribute(attribute, value);\n }\n\n if (helmetAttributes.indexOf(attribute) === -1) {\n helmetAttributes.push(attribute);\n }\n\n var indexToSave = attributesToRemove.indexOf(attribute);\n\n if (indexToSave !== -1) {\n attributesToRemove.splice(indexToSave, 1);\n }\n }\n\n for (var _i = attributesToRemove.length - 1; _i >= 0; _i--) {\n elementTag.removeAttribute(attributesToRemove[_i]);\n }\n\n if (helmetAttributes.length === attributesToRemove.length) {\n elementTag.removeAttribute(HELMET_ATTRIBUTE);\n } else if (elementTag.getAttribute(HELMET_ATTRIBUTE) !== attributeKeys.join(\",\")) {\n elementTag.setAttribute(HELMET_ATTRIBUTE, attributeKeys.join(\",\"));\n }\n};\n\nvar updateTags = function updateTags(type, tags) {\n var headElement = document.head || document.querySelector(TAG_NAMES.HEAD);\n var tagNodes = headElement.querySelectorAll(type + \"[\" + HELMET_ATTRIBUTE + \"]\");\n var oldTags = Array.prototype.slice.call(tagNodes);\n var newTags = [];\n var indexToDelete = void 0;\n\n if (tags && tags.length) {\n tags.forEach(function (tag) {\n var newElement = document.createElement(type);\n\n for (var attribute in tag) {\n if (tag.hasOwnProperty(attribute)) {\n if (attribute === TAG_PROPERTIES.INNER_HTML) {\n newElement.innerHTML = tag.innerHTML;\n } else if (attribute === TAG_PROPERTIES.CSS_TEXT) {\n if (newElement.styleSheet) {\n newElement.styleSheet.cssText = tag.cssText;\n } else {\n newElement.appendChild(document.createTextNode(tag.cssText));\n }\n } else {\n var value = typeof tag[attribute] === \"undefined\" ? \"\" : tag[attribute];\n newElement.setAttribute(attribute, value);\n }\n }\n }\n\n newElement.setAttribute(HELMET_ATTRIBUTE, \"true\"); // Remove a duplicate tag from domTagstoRemove, so it isn't cleared.\n\n if (oldTags.some(function (existingTag, index) {\n indexToDelete = index;\n return newElement.isEqualNode(existingTag);\n })) {\n oldTags.splice(indexToDelete, 1);\n } else {\n newTags.push(newElement);\n }\n });\n }\n\n oldTags.forEach(function (tag) {\n return tag.parentNode.removeChild(tag);\n });\n newTags.forEach(function (tag) {\n return headElement.appendChild(tag);\n });\n return {\n oldTags: oldTags,\n newTags: newTags\n };\n};\n\nvar generateElementAttributesAsString = function generateElementAttributesAsString(attributes) {\n return Object.keys(attributes).reduce(function (str, key) {\n var attr = typeof attributes[key] !== \"undefined\" ? key + \"=\\\"\" + attributes[key] + \"\\\"\" : \"\" + key;\n return str ? str + \" \" + attr : attr;\n }, \"\");\n};\n\nvar generateTitleAsString = function generateTitleAsString(type, title, attributes, encode) {\n var attributeString = generateElementAttributesAsString(attributes);\n var flattenedTitle = flattenArray(title);\n return attributeString ? \"<\" + type + \" \" + HELMET_ATTRIBUTE + \"=\\\"true\\\" \" + attributeString + \">\" + encodeSpecialCharacters(flattenedTitle, encode) + \"</\" + type + \">\" : \"<\" + type + \" \" + HELMET_ATTRIBUTE + \"=\\\"true\\\">\" + encodeSpecialCharacters(flattenedTitle, encode) + \"</\" + type + \">\";\n};\n\nvar generateTagsAsString = function generateTagsAsString(type, tags, encode) {\n return tags.reduce(function (str, tag) {\n var attributeHtml = Object.keys(tag).filter(function (attribute) {\n return !(attribute === TAG_PROPERTIES.INNER_HTML || attribute === TAG_PROPERTIES.CSS_TEXT);\n }).reduce(function (string, attribute) {\n var attr = typeof tag[attribute] === \"undefined\" ? attribute : attribute + \"=\\\"\" + encodeSpecialCharacters(tag[attribute], encode) + \"\\\"\";\n return string ? string + \" \" + attr : attr;\n }, \"\");\n var tagContent = tag.innerHTML || tag.cssText || \"\";\n var isSelfClosing = SELF_CLOSING_TAGS.indexOf(type) === -1;\n return str + \"<\" + type + \" \" + HELMET_ATTRIBUTE + \"=\\\"true\\\" \" + attributeHtml + (isSelfClosing ? \"/>\" : \">\" + tagContent + \"</\" + type + \">\");\n }, \"\");\n};\n\nvar convertElementAttributestoReactProps = function convertElementAttributestoReactProps(attributes) {\n var initProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n return Object.keys(attributes).reduce(function (obj, key) {\n obj[REACT_TAG_MAP[key] || key] = attributes[key];\n return obj;\n }, initProps);\n};\n\nvar convertReactPropstoHtmlAttributes = function convertReactPropstoHtmlAttributes(props) {\n var initAttributes = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n return Object.keys(props).reduce(function (obj, key) {\n obj[HTML_TAG_MAP[key] || key] = props[key];\n return obj;\n }, initAttributes);\n};\n\nvar generateTitleAsReactComponent = function generateTitleAsReactComponent(type, title, attributes) {\n var _initProps; // assigning into an array to define toString function on it\n\n\n var initProps = (_initProps = {\n key: title\n }, _initProps[HELMET_ATTRIBUTE] = true, _initProps);\n var props = convertElementAttributestoReactProps(attributes, initProps);\n return [React.createElement(TAG_NAMES.TITLE, props, title)];\n};\n\nvar generateTagsAsReactComponent = function generateTagsAsReactComponent(type, tags) {\n return tags.map(function (tag, i) {\n var _mappedTag;\n\n var mappedTag = (_mappedTag = {\n key: i\n }, _mappedTag[HELMET_ATTRIBUTE] = true, _mappedTag);\n Object.keys(tag).forEach(function (attribute) {\n var mappedAttribute = REACT_TAG_MAP[attribute] || attribute;\n\n if (mappedAttribute === TAG_PROPERTIES.INNER_HTML || mappedAttribute === TAG_PROPERTIES.CSS_TEXT) {\n var content = tag.innerHTML || tag.cssText;\n mappedTag.dangerouslySetInnerHTML = {\n __html: content\n };\n } else {\n mappedTag[mappedAttribute] = tag[attribute];\n }\n });\n return React.createElement(type, mappedTag);\n });\n};\n\nvar getMethodsForTag = function getMethodsForTag(type, tags, encode) {\n switch (type) {\n case TAG_NAMES.TITLE:\n return {\n toComponent: function toComponent() {\n return generateTitleAsReactComponent(type, tags.title, tags.titleAttributes, encode);\n },\n toString: function toString() {\n return generateTitleAsString(type, tags.title, tags.titleAttributes, encode);\n }\n };\n\n case ATTRIBUTE_NAMES.BODY:\n case ATTRIBUTE_NAMES.HTML:\n return {\n toComponent: function toComponent() {\n return convertElementAttributestoReactProps(tags);\n },\n toString: function toString() {\n return generateElementAttributesAsString(tags);\n }\n };\n\n default:\n return {\n toComponent: function toComponent() {\n return generateTagsAsReactComponent(type, tags);\n },\n toString: function toString() {\n return generateTagsAsString(type, tags, encode);\n }\n };\n }\n};\n\nvar mapStateOnServer = function mapStateOnServer(_ref) {\n var baseTag = _ref.baseTag,\n bodyAttributes = _ref.bodyAttributes,\n encode = _ref.encode,\n htmlAttributes = _ref.htmlAttributes,\n linkTags = _ref.linkTags,\n metaTags = _ref.metaTags,\n noscriptTags = _ref.noscriptTags,\n scriptTags = _ref.scriptTags,\n styleTags = _ref.styleTags,\n _ref$title = _ref.title,\n title = _ref$title === undefined ? \"\" : _ref$title,\n titleAttributes = _ref.titleAttributes;\n return {\n base: getMethodsForTag(TAG_NAMES.BASE, baseTag, encode),\n bodyAttributes: getMethodsForTag(ATTRIBUTE_NAMES.BODY, bodyAttributes, encode),\n htmlAttributes: getMethodsForTag(ATTRIBUTE_NAMES.HTML, htmlAttributes, encode),\n link: getMethodsForTag(TAG_NAMES.LINK, linkTags, encode),\n meta: getMethodsForTag(TAG_NAMES.META, metaTags, encode),\n noscript: getMethodsForTag(TAG_NAMES.NOSCRIPT, noscriptTags, encode),\n script: getMethodsForTag(TAG_NAMES.SCRIPT, scriptTags, encode),\n style: getMethodsForTag(TAG_NAMES.STYLE, styleTags, encode),\n title: getMethodsForTag(TAG_NAMES.TITLE, {\n title: title,\n titleAttributes: titleAttributes\n }, encode)\n };\n};\n\nvar Helmet = function Helmet(Component) {\n var _class, _temp;\n\n return _temp = _class = function (_React$Component) {\n inherits(HelmetWrapper, _React$Component);\n\n function HelmetWrapper() {\n classCallCheck(this, HelmetWrapper);\n return possibleConstructorReturn(this, _React$Component.apply(this, arguments));\n }\n\n HelmetWrapper.prototype.shouldComponentUpdate = function shouldComponentUpdate(nextProps) {\n return !isEqual(this.props, nextProps);\n };\n\n HelmetWrapper.prototype.mapNestedChildrenToProps = function mapNestedChildrenToProps(child, nestedChildren) {\n if (!nestedChildren) {\n return null;\n }\n\n switch (child.type) {\n case TAG_NAMES.SCRIPT:\n case TAG_NAMES.NOSCRIPT:\n return {\n innerHTML: nestedChildren\n };\n\n case TAG_NAMES.STYLE:\n return {\n cssText: nestedChildren\n };\n }\n\n throw new Error(\"<\" + child.type + \" /> elements are self-closing and can not contain children. Refer to our API for more information.\");\n };\n\n HelmetWrapper.prototype.flattenArrayTypeChildren = function flattenArrayTypeChildren(_ref) {\n var _babelHelpers$extends;\n\n var child = _ref.child,\n arrayTypeChildren = _ref.arrayTypeChildren,\n newChildProps = _ref.newChildProps,\n nestedChildren = _ref.nestedChildren;\n return _extends({}, arrayTypeChildren, (_babelHelpers$extends = {}, _babelHelpers$extends[child.type] = [].concat(arrayTypeChildren[child.type] || [], [_extends({}, newChildProps, this.mapNestedChildrenToProps(child, nestedChildren))]), _babelHelpers$extends));\n };\n\n HelmetWrapper.prototype.mapObjectTypeChildren = function mapObjectTypeChildren(_ref2) {\n var _babelHelpers$extends2, _babelHelpers$extends3;\n\n var child = _ref2.child,\n newProps = _ref2.newProps,\n newChildProps = _ref2.newChildProps,\n nestedChildren = _ref2.nestedChildren;\n\n switch (child.type) {\n case TAG_NAMES.TITLE:\n return _extends({}, newProps, (_babelHelpers$extends2 = {}, _babelHelpers$extends2[child.type] = nestedChildren, _babelHelpers$extends2.titleAttributes = _extends({}, newChildProps), _babelHelpers$extends2));\n\n case TAG_NAMES.BODY:\n return _extends({}, newProps, {\n bodyAttributes: _extends({}, newChildProps)\n });\n\n case TAG_NAMES.HTML:\n return _extends({}, newProps, {\n htmlAttributes: _extends({}, newChildProps)\n });\n }\n\n return _extends({}, newProps, (_babelHelpers$extends3 = {}, _babelHelpers$extends3[child.type] = _extends({}, newChildProps), _babelHelpers$extends3));\n };\n\n HelmetWrapper.prototype.mapArrayTypeChildrenToProps = function mapArrayTypeChildrenToProps(arrayTypeChildren, newProps) {\n var newFlattenedProps = _extends({}, newProps);\n\n Object.keys(arrayTypeChildren).forEach(function (arrayChildName) {\n var _babelHelpers$extends4;\n\n newFlattenedProps = _extends({}, newFlattenedProps, (_babelHelpers$extends4 = {}, _babelHelpers$extends4[arrayChildName] = arrayTypeChildren[arrayChildName], _babelHelpers$extends4));\n });\n return newFlattenedProps;\n };\n\n HelmetWrapper.prototype.warnOnInvalidChildren = function warnOnInvalidChildren(child, nestedChildren) {\n if (process.env.NODE_ENV !== \"production\") {\n if (!VALID_TAG_NAMES.some(function (name) {\n return child.type === name;\n })) {\n if (typeof child.type === \"function\") {\n return warn(\"You may be attempting to nest <Helmet> components within each other, which is not allowed. Refer to our API for more information.\");\n }\n\n return warn(\"Only elements types \" + VALID_TAG_NAMES.join(\", \") + \" are allowed. Helmet does not support rendering <\" + child.type + \"> elements. Refer to our API for more information.\");\n }\n\n if (nestedChildren && typeof nestedChildren !== \"string\" && (!Array.isArray(nestedChildren) || nestedChildren.some(function (nestedChild) {\n return typeof nestedChild !== \"string\";\n }))) {\n throw new Error(\"Helmet expects a string as a child of <\" + child.type + \">. Did you forget to wrap your children in braces? ( <\" + child.type + \">{``}</\" + child.type + \"> ) Refer to our API for more information.\");\n }\n }\n\n return true;\n };\n\n HelmetWrapper.prototype.mapChildrenToProps = function mapChildrenToProps(children, newProps) {\n var _this2 = this;\n\n var arrayTypeChildren = {};\n React.Children.forEach(children, function (child) {\n if (!child || !child.props) {\n return;\n }\n\n var _child$props = child.props,\n nestedChildren = _child$props.children,\n childProps = objectWithoutProperties(_child$props, [\"children\"]);\n var newChildProps = convertReactPropstoHtmlAttributes(childProps);\n\n _this2.warnOnInvalidChildren(child, nestedChildren);\n\n switch (child.type) {\n case TAG_NAMES.LINK:\n case TAG_NAMES.META:\n case TAG_NAMES.NOSCRIPT:\n case TAG_NAMES.SCRIPT:\n case TAG_NAMES.STYLE:\n arrayTypeChildren = _this2.flattenArrayTypeChildren({\n child: child,\n arrayTypeChildren: arrayTypeChildren,\n newChildProps: newChildProps,\n nestedChildren: nestedChildren\n });\n break;\n\n default:\n newProps = _this2.mapObjectTypeChildren({\n child: child,\n newProps: newProps,\n newChildProps: newChildProps,\n nestedChildren: nestedChildren\n });\n break;\n }\n });\n newProps = this.mapArrayTypeChildrenToProps(arrayTypeChildren, newProps);\n return newProps;\n };\n\n HelmetWrapper.prototype.render = function render() {\n var _props = this.props,\n children = _props.children,\n props = objectWithoutProperties(_props, [\"children\"]);\n\n var newProps = _extends({}, props);\n\n if (children) {\n newProps = this.mapChildrenToProps(children, newProps);\n }\n\n return React.createElement(Component, newProps);\n };\n\n createClass(HelmetWrapper, null, [{\n key: \"canUseDOM\",\n // Component.peek comes from react-side-effect:\n // For testing, you may use a static peek() method available on the returned component.\n // It lets you get the current state without resetting the mounted instance stack.\n // Don’t use it for anything other than testing.\n\n /**\n * @param {Object} base: {\"target\": \"_blank\", \"href\": \"http://mysite.com/\"}\n * @param {Object} bodyAttributes: {\"className\": \"root\"}\n * @param {String} defaultTitle: \"Default Title\"\n * @param {Boolean} defer: true\n * @param {Boolean} encodeSpecialCharacters: true\n * @param {Object} htmlAttributes: {\"lang\": \"en\", \"amp\": undefined}\n * @param {Array} link: [{\"rel\": \"canonical\", \"href\": \"http://mysite.com/example\"}]\n * @param {Array} meta: [{\"name\": \"description\", \"content\": \"Test description\"}]\n * @param {Array} noscript: [{\"innerHTML\": \"<img src='http://mysite.com/js/test.js'\"}]\n * @param {Function} onChangeClientState: \"(newState) => console.log(newState)\"\n * @param {Array} script: [{\"type\": \"text/javascript\", \"src\": \"http://mysite.com/js/test.js\"}]\n * @param {Array} style: [{\"type\": \"text/css\", \"cssText\": \"div { display: block; color: blue; }\"}]\n * @param {String} title: \"Title\"\n * @param {Object} titleAttributes: {\"itemprop\": \"name\"}\n * @param {String} titleTemplate: \"MySite.com - %s\"\n */\n set: function set$$1(canUseDOM) {\n Component.canUseDOM = canUseDOM;\n }\n }]);\n return HelmetWrapper;\n }(React.Component), _class.propTypes = {\n base: PropTypes.object,\n bodyAttributes: PropTypes.object,\n children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]),\n defaultTitle: PropTypes.string,\n defer: PropTypes.bool,\n encodeSpecialCharacters: PropTypes.bool,\n htmlAttributes: PropTypes.object,\n link: PropTypes.arrayOf(PropTypes.object),\n meta: PropTypes.arrayOf(PropTypes.object),\n noscript: PropTypes.arrayOf(PropTypes.object),\n onChangeClientState: PropTypes.func,\n script: PropTypes.arrayOf(PropTypes.object),\n style: PropTypes.arrayOf(PropTypes.object),\n title: PropTypes.string,\n titleAttributes: PropTypes.object,\n titleTemplate: PropTypes.string\n }, _class.defaultProps = {\n defer: true,\n encodeSpecialCharacters: true\n }, _class.peek = Component.peek, _class.rewind = function () {\n var mappedState = Component.rewind();\n\n if (!mappedState) {\n // provide fallback if mappedState is undefined\n mappedState = mapStateOnServer({\n baseTag: [],\n bodyAttributes: {},\n encodeSpecialCharacters: true,\n htmlAttributes: {},\n linkTags: [],\n metaTags: [],\n noscriptTags: [],\n scriptTags: [],\n styleTags: [],\n title: \"\",\n titleAttributes: {}\n });\n }\n\n return mappedState;\n }, _temp;\n};\n\nvar NullComponent = function NullComponent() {\n return null;\n};\n\nvar HelmetSideEffects = withSideEffect(reducePropsToState, handleClientStateChange, mapStateOnServer)(NullComponent);\nvar HelmetExport = Helmet(HelmetSideEffects);\nHelmetExport.renderStatic = HelmetExport.rewind;\nexport default HelmetExport;\nexport { HelmetExport as Helmet };","import { useStaticQuery, graphql } from 'gatsby'\n\nconst useSiteImages = imageName => {\n const result = useStaticQuery(graphql`\n {\n allFile(filter: { sourceInstanceName: { eq: \"images\" } }) {\n edges {\n node {\n relativePath\n childImageSharp {\n fixed {\n base64\n tracedSVG\n aspectRatio\n width\n height\n src\n srcSet\n srcWebp\n srcSetWebp\n originalName\n }\n fluid(maxWidth: 3080, quality: 100) {\n base64\n tracedSVG\n aspectRatio\n src\n srcSet\n srcWebp\n srcSetWebp\n sizes\n originalImg\n originalName\n presentationWidth\n presentationHeight\n }\n }\n }\n }\n }\n }\n `)\n const items = result.allFile.edges\n const image = items.find(edge => edge.node.relativePath === imageName)\n if (image === undefined) {\n throw new Error(`Unable to find image: ${imageName} (in content/images)`)\n }\n\n return image.node.childImageSharp\n}\n\nexport default useSiteImages\n","import { useStaticQuery, graphql } from 'gatsby'\n\nconst useSiteMetadata = () => {\n const result = useStaticQuery(graphql`\n {\n site {\n siteMetadata {\n siteTitle\n siteUrl\n siteCover\n trees\n comfort\n doctor\n health24\n nature\n physio\n authorName\n authorAvatar\n homepageImage\n authorDescription\n siteDescription\n twitterUsername\n disqusShortname\n disqusSiteUrl\n defaultLang\n headerTitle\n headerLinksIcon\n footerLinksIcon\n headerLinks {\n label\n url\n }\n websiteHost {\n name\n url\n }\n footerLinks {\n sectionName\n links {\n label\n url\n }\n }\n }\n }\n }\n `)\n return result.site.siteMetadata\n}\n\nexport default useSiteMetadata\n","import { typeOf, isElement, isValidElementType } from 'react-is';\nimport React, { useState, useContext, useMemo, useEffect, useRef, createElement, useDebugValue } from 'react';\nimport shallowequal from 'shallowequal';\nimport Stylis from '@emotion/stylis';\nimport unitless from '@emotion/unitless';\nimport validAttr from '@emotion/is-prop-valid';\nimport hoist from 'hoist-non-react-statics';\n\nfunction _extends() {\n _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n };\n\n return _extends.apply(this, arguments);\n}\n\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n\n return target;\n} // \n\n\nvar interleave = function interleave(strings, interpolations) {\n var result = [strings[0]];\n\n for (var i = 0, len = interpolations.length; i < len; i += 1) {\n result.push(interpolations[i], strings[i + 1]);\n }\n\n return result;\n}; // \n\n\nvar isPlainObject = function isPlainObject(x) {\n return x !== null && typeof x === 'object' && (x.toString ? x.toString() : Object.prototype.toString.call(x)) === '[object Object]' && !typeOf(x);\n}; // \n\n\nvar EMPTY_ARRAY = Object.freeze([]);\nvar EMPTY_OBJECT = Object.freeze({}); // \n\nfunction isFunction(test) {\n return typeof test === 'function';\n} // \n\n\nfunction getComponentName(target) {\n return (process.env.NODE_ENV !== 'production' ? typeof target === 'string' && target : false) || // $FlowFixMe\n target.displayName || // $FlowFixMe\n target.name || 'Component';\n} // \n\n\nfunction isStatelessFunction(test) {\n return typeof test === 'function' && !(test.prototype && test.prototype.isReactComponent);\n} // \n\n\nfunction isStyledComponent(target) {\n return target && typeof target.styledComponentId === 'string';\n} // \n\n\nvar SC_ATTR = typeof process !== 'undefined' && (process.env.REACT_APP_SC_ATTR || process.env.SC_ATTR) || 'data-styled';\nvar SC_ATTR_ACTIVE = 'active';\nvar SC_ATTR_VERSION = 'data-styled-version';\nvar SC_VERSION = \"5.1.1\";\nvar SPLITTER = '/*!sc*/\\n';\nvar IS_BROWSER = typeof window !== 'undefined' && 'HTMLElement' in window;\nvar DISABLE_SPEEDY = typeof SC_DISABLE_SPEEDY === 'boolean' && SC_DISABLE_SPEEDY || typeof process !== 'undefined' && (process.env.REACT_APP_SC_DISABLE_SPEEDY || process.env.SC_DISABLE_SPEEDY) || process.env.NODE_ENV !== 'production'; // Shared empty execution context when generating static styles\n\nvar STATIC_EXECUTION_CONTEXT = {}; // \n\n/* eslint-disable camelcase, no-undef */\n\nvar getNonce = function getNonce() {\n return typeof __webpack_nonce__ !== 'undefined' ? __webpack_nonce__ : null;\n};\n\nvar errorMap = {\n \"1\": \"Cannot create styled-component for component: %s.\\n\\n\",\n \"2\": \"Can't collect styles once you've consumed a `ServerStyleSheet`'s styles! `ServerStyleSheet` is a one off instance for each server-side render cycle.\\n\\n- Are you trying to reuse it across renders?\\n- Are you accidentally calling collectStyles twice?\\n\\n\",\n \"3\": \"Streaming SSR is only supported in a Node.js environment; Please do not try to call this method in the browser.\\n\\n\",\n \"4\": \"The `StyleSheetManager` expects a valid target or sheet prop!\\n\\n- Does this error occur on the client and is your target falsy?\\n- Does this error occur on the server and is the sheet falsy?\\n\\n\",\n \"5\": \"The clone method cannot be used on the client!\\n\\n- Are you running in a client-like environment on the server?\\n- Are you trying to run SSR on the client?\\n\\n\",\n \"6\": \"Trying to insert a new style tag, but the given Node is unmounted!\\n\\n- Are you using a custom target that isn't mounted?\\n- Does your document not have a valid head element?\\n- Have you accidentally removed a style tag manually?\\n\\n\",\n \"7\": \"ThemeProvider: Please return an object from your \\\"theme\\\" prop function, e.g.\\n\\n```js\\ntheme={() => ({})}\\n```\\n\\n\",\n \"8\": \"ThemeProvider: Please make your \\\"theme\\\" prop an object.\\n\\n\",\n \"9\": \"Missing document `<head>`\\n\\n\",\n \"10\": \"Cannot find a StyleSheet instance. Usually this happens if there are multiple copies of styled-components loaded at once. Check out this issue for how to troubleshoot and fix the common cases where this situation can happen: https://github.com/styled-components/styled-components/issues/1941#issuecomment-417862021\\n\\n\",\n \"11\": \"_This error was replaced with a dev-time warning, it will be deleted for v4 final._ [createGlobalStyle] received children which will not be rendered. Please use the component without passing children elements.\\n\\n\",\n \"12\": \"It seems you are interpolating a keyframe declaration (%s) into an untagged string. This was supported in styled-components v3, but is not longer supported in v4 as keyframes are now injected on-demand. Please wrap your string in the css\\\\`\\\\` helper which ensures the styles are injected correctly. See https://www.styled-components.com/docs/api#css\\n\\n\",\n \"13\": \"%s is not a styled component and cannot be referred to via component selector. See https://www.styled-components.com/docs/advanced#referring-to-other-components for more details.\\n\\n\",\n \"14\": \"ThemeProvider: \\\"theme\\\" prop is required.\\n\\n\",\n \"15\": \"A stylis plugin has been supplied that is not named. We need a name for each plugin to be able to prevent styling collisions between different stylis configurations within the same app. Before you pass your plugin to `<StyleSheetManager stylisPlugins={[]}>`, please make sure each plugin is uniquely-named, e.g.\\n\\n```js\\nObject.defineProperty(importedPlugin, 'name', { value: 'some-unique-name' });\\n```\\n\\n\",\n \"16\": \"Reached the limit of how many styled components may be created at group %s.\\nYou may only create up to 1,073,741,824 components. If you're creating components dynamically,\\nas for instance in your render method then you may be running into this limitation.\\n\\n\",\n \"17\": \"CSSStyleSheet could not be found on HTMLStyleElement.\\nHas styled-components' style tag been unmounted or altered by another script?\\n\"\n}; // \n\nvar ERRORS = process.env.NODE_ENV !== 'production' ? errorMap : {};\n/**\n * super basic version of sprintf\n */\n\nfunction format() {\n var a = arguments.length <= 0 ? undefined : arguments[0];\n var b = [];\n\n for (var c = 1, len = arguments.length; c < len; c += 1) {\n b.push(c < 0 || arguments.length <= c ? undefined : arguments[c]);\n }\n\n b.forEach(function (d) {\n a = a.replace(/%[a-z]/, d);\n });\n return a;\n}\n/**\n * Create an error file out of errors.md for development and a simple web link to the full errors\n * in production mode.\n */\n\n\nfunction throwStyledComponentsError(code) {\n for (var _len = arguments.length, interpolations = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n interpolations[_key - 1] = arguments[_key];\n }\n\n if (process.env.NODE_ENV === 'production') {\n throw new Error(\"An error occurred. See https://github.com/styled-components/styled-components/blob/master/packages/styled-components/src/utils/errors.md#\" + code + \" for more information.\" + (interpolations.length > 0 ? \" Additional arguments: \" + interpolations.join(', ') : ''));\n } else {\n throw new Error(format.apply(void 0, [ERRORS[code]].concat(interpolations)).trim());\n }\n} // \n\n\nvar ELEMENT_TYPE = 1;\n/* Node.ELEMENT_TYPE */\n\n/** Find last style element if any inside target */\n\nvar findLastStyleTag = function findLastStyleTag(target) {\n var childNodes = target.childNodes;\n\n for (var i = childNodes.length; i >= 0; i--) {\n var child = childNodes[i];\n\n if (child && child.nodeType === ELEMENT_TYPE && child.hasAttribute(SC_ATTR)) {\n return child;\n }\n }\n\n return undefined;\n};\n/** Create a style element inside `target` or <head> after the last */\n\n\nvar makeStyleTag = function makeStyleTag(target) {\n var head = document.head;\n var parent = target || head;\n var style = document.createElement('style');\n var prevStyle = findLastStyleTag(parent);\n var nextSibling = prevStyle !== undefined ? prevStyle.nextSibling : null;\n style.setAttribute(SC_ATTR, SC_ATTR_ACTIVE);\n style.setAttribute(SC_ATTR_VERSION, SC_VERSION);\n var nonce = getNonce();\n if (nonce) style.setAttribute('nonce', nonce);\n parent.insertBefore(style, nextSibling);\n return style;\n};\n/** Get the CSSStyleSheet instance for a given style element */\n\n\nvar getSheet = function getSheet(tag) {\n if (tag.sheet) {\n return tag.sheet;\n } // Avoid Firefox quirk where the style element might not have a sheet property\n\n\n var _document = document,\n styleSheets = _document.styleSheets;\n\n for (var i = 0, l = styleSheets.length; i < l; i++) {\n var sheet = styleSheets[i];\n\n if (sheet.ownerNode === tag) {\n return sheet;\n }\n }\n\n throwStyledComponentsError(17);\n return undefined;\n}; // \n\n/** Create a CSSStyleSheet-like tag depending on the environment */\n\n\nvar makeTag = function makeTag(_ref) {\n var isServer = _ref.isServer,\n useCSSOMInjection = _ref.useCSSOMInjection,\n target = _ref.target;\n\n if (isServer) {\n return new VirtualTag(target);\n } else if (useCSSOMInjection) {\n return new CSSOMTag(target);\n } else {\n return new TextTag(target);\n }\n};\n\nvar CSSOMTag = /*#__PURE__*/function () {\n function CSSOMTag(target) {\n var element = this.element = makeStyleTag(target); // Avoid Edge bug where empty style elements don't create sheets\n\n element.appendChild(document.createTextNode(''));\n this.sheet = getSheet(element);\n this.length = 0;\n }\n\n var _proto = CSSOMTag.prototype;\n\n _proto.insertRule = function insertRule(index, rule) {\n try {\n this.sheet.insertRule(rule, index);\n this.length++;\n return true;\n } catch (_error) {\n return false;\n }\n };\n\n _proto.deleteRule = function deleteRule(index) {\n this.sheet.deleteRule(index);\n this.length--;\n };\n\n _proto.getRule = function getRule(index) {\n var rule = this.sheet.cssRules[index]; // Avoid IE11 quirk where cssText is inaccessible on some invalid rules\n\n if (rule !== undefined && typeof rule.cssText === 'string') {\n return rule.cssText;\n } else {\n return '';\n }\n };\n\n return CSSOMTag;\n}();\n/** A Tag that emulates the CSSStyleSheet API but uses text nodes */\n\n\nvar TextTag = /*#__PURE__*/function () {\n function TextTag(target) {\n var element = this.element = makeStyleTag(target);\n this.nodes = element.childNodes;\n this.length = 0;\n }\n\n var _proto2 = TextTag.prototype;\n\n _proto2.insertRule = function insertRule(index, rule) {\n if (index <= this.length && index >= 0) {\n var node = document.createTextNode(rule);\n var refNode = this.nodes[index];\n this.element.insertBefore(node, refNode || null);\n this.length++;\n return true;\n } else {\n return false;\n }\n };\n\n _proto2.deleteRule = function deleteRule(index) {\n this.element.removeChild(this.nodes[index]);\n this.length--;\n };\n\n _proto2.getRule = function getRule(index) {\n if (index < this.length) {\n return this.nodes[index].textContent;\n } else {\n return '';\n }\n };\n\n return TextTag;\n}();\n/** A completely virtual (server-side) Tag that doesn't manipulate the DOM */\n\n\nvar VirtualTag = /*#__PURE__*/function () {\n function VirtualTag(_target) {\n this.rules = [];\n this.length = 0;\n }\n\n var _proto3 = VirtualTag.prototype;\n\n _proto3.insertRule = function insertRule(index, rule) {\n if (index <= this.length) {\n this.rules.splice(index, 0, rule);\n this.length++;\n return true;\n } else {\n return false;\n }\n };\n\n _proto3.deleteRule = function deleteRule(index) {\n this.rules.splice(index, 1);\n this.length--;\n };\n\n _proto3.getRule = function getRule(index) {\n if (index < this.length) {\n return this.rules[index];\n } else {\n return '';\n }\n };\n\n return VirtualTag;\n}(); // \n\n/** Create a GroupedTag with an underlying Tag implementation */\n\n\nvar makeGroupedTag = function makeGroupedTag(tag) {\n return new DefaultGroupedTag(tag);\n};\n\nvar BASE_SIZE = 1 << 9;\n\nvar DefaultGroupedTag = /*#__PURE__*/function () {\n function DefaultGroupedTag(tag) {\n this.groupSizes = new Uint32Array(BASE_SIZE);\n this.length = BASE_SIZE;\n this.tag = tag;\n }\n\n var _proto = DefaultGroupedTag.prototype;\n\n _proto.indexOfGroup = function indexOfGroup(group) {\n var index = 0;\n\n for (var i = 0; i < group; i++) {\n index += this.groupSizes[i];\n }\n\n return index;\n };\n\n _proto.insertRules = function insertRules(group, rules) {\n if (group >= this.groupSizes.length) {\n var oldBuffer = this.groupSizes;\n var oldSize = oldBuffer.length;\n var newSize = oldSize;\n\n while (group >= newSize) {\n newSize <<= 1;\n\n if (newSize < 0) {\n throwStyledComponentsError(16, \"\" + group);\n }\n }\n\n this.groupSizes = new Uint32Array(newSize);\n this.groupSizes.set(oldBuffer);\n this.length = newSize;\n\n for (var i = oldSize; i < newSize; i++) {\n this.groupSizes[i] = 0;\n }\n }\n\n var ruleIndex = this.indexOfGroup(group + 1);\n\n for (var _i = 0, l = rules.length; _i < l; _i++) {\n if (this.tag.insertRule(ruleIndex, rules[_i])) {\n this.groupSizes[group]++;\n ruleIndex++;\n }\n }\n };\n\n _proto.clearGroup = function clearGroup(group) {\n if (group < this.length) {\n var length = this.groupSizes[group];\n var startIndex = this.indexOfGroup(group);\n var endIndex = startIndex + length;\n this.groupSizes[group] = 0;\n\n for (var i = startIndex; i < endIndex; i++) {\n this.tag.deleteRule(startIndex);\n }\n }\n };\n\n _proto.getGroup = function getGroup(group) {\n var css = '';\n\n if (group >= this.length || this.groupSizes[group] === 0) {\n return css;\n }\n\n var length = this.groupSizes[group];\n var startIndex = this.indexOfGroup(group);\n var endIndex = startIndex + length;\n\n for (var i = startIndex; i < endIndex; i++) {\n css += \"\" + this.tag.getRule(i) + SPLITTER;\n }\n\n return css;\n };\n\n return DefaultGroupedTag;\n}(); // \n\n\nvar MAX_SMI = 1 << 31 - 1;\nvar groupIDRegister = new Map();\nvar reverseRegister = new Map();\nvar nextFreeGroup = 1;\n\nvar getGroupForId = function getGroupForId(id) {\n if (groupIDRegister.has(id)) {\n return groupIDRegister.get(id);\n }\n\n var group = nextFreeGroup++;\n\n if (process.env.NODE_ENV !== 'production' && ((group | 0) < 0 || group > MAX_SMI)) {\n throwStyledComponentsError(16, \"\" + group);\n }\n\n groupIDRegister.set(id, group);\n reverseRegister.set(group, id);\n return group;\n};\n\nvar getIdForGroup = function getIdForGroup(group) {\n return reverseRegister.get(group);\n};\n\nvar setGroupForId = function setGroupForId(id, group) {\n if (group >= nextFreeGroup) {\n nextFreeGroup = group + 1;\n }\n\n groupIDRegister.set(id, group);\n reverseRegister.set(group, id);\n}; // \n\n\nvar SELECTOR = \"style[\" + SC_ATTR + \"][\" + SC_ATTR_VERSION + \"=\\\"\" + SC_VERSION + \"\\\"]\";\nvar MARKER_RE = new RegExp(\"^\" + SC_ATTR + \"\\\\.g(\\\\d+)\\\\[id=\\\"([\\\\w\\\\d-]+)\\\"\\\\].*?\\\"([^\\\"]*)\");\n\nvar outputSheet = function outputSheet(sheet) {\n var tag = sheet.getTag();\n var length = tag.length;\n var css = '';\n\n for (var group = 0; group < length; group++) {\n var id = getIdForGroup(group);\n if (id === undefined) continue;\n var names = sheet.names.get(id);\n var rules = tag.getGroup(group);\n if (names === undefined || rules.length === 0) continue;\n var selector = SC_ATTR + \".g\" + group + \"[id=\\\"\" + id + \"\\\"]\";\n var content = '';\n\n if (names !== undefined) {\n names.forEach(function (name) {\n if (name.length > 0) {\n content += name + \",\";\n }\n });\n } // NOTE: It's easier to collect rules and have the marker\n // after the actual rules to simplify the rehydration\n\n\n css += \"\" + rules + selector + \"{content:\\\"\" + content + \"\\\"}\" + SPLITTER;\n }\n\n return css;\n};\n\nvar rehydrateNamesFromContent = function rehydrateNamesFromContent(sheet, id, content) {\n var names = content.split(',');\n var name;\n\n for (var i = 0, l = names.length; i < l; i++) {\n // eslint-disable-next-line\n if (name = names[i]) {\n sheet.registerName(id, name);\n }\n }\n};\n\nvar rehydrateSheetFromTag = function rehydrateSheetFromTag(sheet, style) {\n var parts = style.innerHTML.split(SPLITTER);\n var rules = [];\n\n for (var i = 0, l = parts.length; i < l; i++) {\n var part = parts[i].trim();\n if (!part) continue;\n var marker = part.match(MARKER_RE);\n\n if (marker) {\n var group = parseInt(marker[1], 10) | 0;\n var id = marker[2];\n\n if (group !== 0) {\n // Rehydrate componentId to group index mapping\n setGroupForId(id, group); // Rehydrate names and rules\n // looks like: data-styled.g11[id=\"idA\"]{content:\"nameA,\"}\n\n rehydrateNamesFromContent(sheet, id, marker[3]);\n sheet.getTag().insertRules(group, rules);\n }\n\n rules.length = 0;\n } else {\n rules.push(part);\n }\n }\n};\n\nvar rehydrateSheet = function rehydrateSheet(sheet) {\n var nodes = document.querySelectorAll(SELECTOR);\n\n for (var i = 0, l = nodes.length; i < l; i++) {\n var node = nodes[i];\n\n if (node && node.getAttribute(SC_ATTR) !== SC_ATTR_ACTIVE) {\n rehydrateSheetFromTag(sheet, node);\n\n if (node.parentNode) {\n node.parentNode.removeChild(node);\n }\n }\n }\n};\n\nvar SHOULD_REHYDRATE = IS_BROWSER;\nvar defaultOptions = {\n isServer: !IS_BROWSER,\n useCSSOMInjection: !DISABLE_SPEEDY\n};\n/** Contains the main stylesheet logic for stringification and caching */\n\nvar StyleSheet = /*#__PURE__*/function () {\n /** Register a group ID to give it an index */\n StyleSheet.registerId = function registerId(id) {\n return getGroupForId(id);\n };\n\n function StyleSheet(options, globalStyles, names) {\n if (options === void 0) {\n options = defaultOptions;\n }\n\n if (globalStyles === void 0) {\n globalStyles = {};\n }\n\n this.options = _extends({}, defaultOptions, {}, options);\n this.gs = globalStyles;\n this.names = new Map(names); // We rehydrate only once and use the sheet that is created first\n\n if (!this.options.isServer && IS_BROWSER && SHOULD_REHYDRATE) {\n SHOULD_REHYDRATE = false;\n rehydrateSheet(this);\n }\n }\n\n var _proto = StyleSheet.prototype;\n\n _proto.reconstructWithOptions = function reconstructWithOptions(options) {\n return new StyleSheet(_extends({}, this.options, {}, options), this.gs, this.names);\n };\n\n _proto.allocateGSInstance = function allocateGSInstance(id) {\n return this.gs[id] = (this.gs[id] || 0) + 1;\n }\n /** Lazily initialises a GroupedTag for when it's actually needed */\n ;\n\n _proto.getTag = function getTag() {\n return this.tag || (this.tag = makeGroupedTag(makeTag(this.options)));\n }\n /** Check whether a name is known for caching */\n ;\n\n _proto.hasNameForId = function hasNameForId(id, name) {\n return this.names.has(id) && this.names.get(id).has(name);\n }\n /** Mark a group's name as known for caching */\n ;\n\n _proto.registerName = function registerName(id, name) {\n getGroupForId(id);\n\n if (!this.names.has(id)) {\n var groupNames = new Set();\n groupNames.add(name);\n this.names.set(id, groupNames);\n } else {\n this.names.get(id).add(name);\n }\n }\n /** Insert new rules which also marks the name as known */\n ;\n\n _proto.insertRules = function insertRules(id, name, rules) {\n this.registerName(id, name);\n this.getTag().insertRules(getGroupForId(id), rules);\n }\n /** Clears all cached names for a given group ID */\n ;\n\n _proto.clearNames = function clearNames(id) {\n if (this.names.has(id)) {\n this.names.get(id).clear();\n }\n }\n /** Clears all rules for a given group ID */\n ;\n\n _proto.clearRules = function clearRules(id) {\n this.getTag().clearGroup(getGroupForId(id));\n this.clearNames(id);\n }\n /** Clears the entire tag which deletes all rules but not its names */\n ;\n\n _proto.clearTag = function clearTag() {\n // NOTE: This does not clear the names, since it's only used during SSR\n // so that we can continuously output only new rules\n this.tag = undefined;\n }\n /** Outputs the current sheet as a CSS string with markers for SSR */\n ;\n\n _proto.toString = function toString() {\n return outputSheet(this);\n };\n\n return StyleSheet;\n}(); // \n\n/* eslint-disable */\n\n\nvar SEED = 5381; // When we have separate strings it's useful to run a progressive\n// version of djb2 where we pretend that we're still looping over\n// the same string\n\nvar phash = function phash(h, x) {\n var i = x.length;\n\n while (i) {\n h = h * 33 ^ x.charCodeAt(--i);\n }\n\n return h;\n}; // This is a djb2 hashing function\n\n\nvar hash = function hash(x) {\n return phash(SEED, x);\n};\n/**\n * MIT License\n *\n * Copyright (c) 2016 Sultan Tarimo\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy of\n * this software and associated documentation files (the \"Software\"),\n * to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n * sell copies of the Software and to permit persons to whom the Software is furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n * OR IMPLIED INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,\n * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR\n * IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n */\n\n/* eslint-disable */\n\n\nfunction insertRulePlugin(insertRule) {\n var delimiter = '/*|*/';\n var needle = delimiter + \"}\";\n\n function toSheet(block) {\n if (block) {\n try {\n insertRule(block + \"}\");\n } catch (e) {}\n }\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\nvar COMMENT_REGEX = /^\\s*\\/\\/.*$/gm;\n\nfunction createStylisInstance(_temp) {\n var _ref = _temp === void 0 ? EMPTY_OBJECT : _temp,\n _ref$options = _ref.options,\n options = _ref$options === void 0 ? EMPTY_OBJECT : _ref$options,\n _ref$plugins = _ref.plugins,\n plugins = _ref$plugins === void 0 ? EMPTY_ARRAY : _ref$plugins;\n\n var stylis = new Stylis(options); // Wrap `insertRulePlugin to build a list of rules,\n // and then make our own plugin to return the rules. This\n // makes it easier to hook into the existing SSR architecture\n\n var parsingRules = []; // eslint-disable-next-line consistent-return\n\n var returnRulesPlugin = function returnRulesPlugin(context) {\n if (context === -2) {\n var parsedRules = parsingRules;\n parsingRules = [];\n return parsedRules;\n }\n };\n\n var parseRulesPlugin = insertRulePlugin(function (rule) {\n parsingRules.push(rule);\n });\n\n var _componentId;\n\n var _selector;\n\n var _selectorRegexp;\n\n var selfReferenceReplacer = function selfReferenceReplacer(match, offset, string) {\n if ( // the first self-ref is always untouched\n offset > 0 && // there should be at least two self-refs to do a replacement (.b > .b)\n string.slice(0, offset).indexOf(_selector) !== -1 && // no consecutive self refs (.b.b); that is a precedence boost and treated differently\n string.slice(offset - _selector.length, offset) !== _selector) {\n return \".\" + _componentId;\n }\n\n return match;\n };\n /**\n * When writing a style like\n *\n * & + & {\n * color: red;\n * }\n *\n * The second ampersand should be a reference to the static component class. stylis\n * has no knowledge of static class so we have to intelligently replace the base selector.\n *\n * https://github.com/thysultan/stylis.js#plugins <- more info about the context phase values\n * \"2\" means this plugin is taking effect at the very end after all other processing is complete\n */\n\n\n var selfReferenceReplacementPlugin = function selfReferenceReplacementPlugin(context, _, selectors) {\n if (context === 2 && selectors.length && selectors[0].lastIndexOf(_selector) > 0) {\n // eslint-disable-next-line no-param-reassign\n selectors[0] = selectors[0].replace(_selectorRegexp, selfReferenceReplacer);\n }\n };\n\n stylis.use([].concat(plugins, [selfReferenceReplacementPlugin, parseRulesPlugin, returnRulesPlugin]));\n\n function stringifyRules(css, selector, prefix, componentId) {\n if (componentId === void 0) {\n componentId = '&';\n }\n\n var flatCSS = css.replace(COMMENT_REGEX, '');\n var cssStr = selector && prefix ? prefix + \" \" + selector + \" { \" + flatCSS + \" }\" : flatCSS; // stylis has no concept of state to be passed to plugins\n // but since JS is single=threaded, we can rely on that to ensure\n // these properties stay in sync with the current stylis run\n\n _componentId = componentId;\n _selector = selector;\n _selectorRegexp = new RegExp(\"\\\\\" + _selector + \"\\\\b\", 'g');\n return stylis(prefix || !selector ? '' : selector, cssStr);\n }\n\n stringifyRules.hash = plugins.length ? plugins.reduce(function (acc, plugin) {\n if (!plugin.name) {\n throwStyledComponentsError(15);\n }\n\n return phash(acc, plugin.name);\n }, SEED).toString() : '';\n return stringifyRules;\n} // \n\n\nvar StyleSheetContext = React.createContext();\nvar StyleSheetConsumer = StyleSheetContext.Consumer;\nvar StylisContext = React.createContext();\nvar StylisConsumer = StylisContext.Consumer;\nvar masterSheet = new StyleSheet();\nvar masterStylis = createStylisInstance();\n\nfunction useStyleSheet() {\n return useContext(StyleSheetContext) || masterSheet;\n}\n\nfunction useStylis() {\n return useContext(StylisContext) || masterStylis;\n}\n\nfunction StyleSheetManager(props) {\n var _useState = useState(props.stylisPlugins),\n plugins = _useState[0],\n setPlugins = _useState[1];\n\n var contextStyleSheet = useStyleSheet();\n var styleSheet = useMemo(function () {\n var sheet = contextStyleSheet;\n\n if (props.sheet) {\n // eslint-disable-next-line prefer-destructuring\n sheet = props.sheet;\n } else if (props.target) {\n sheet = sheet.reconstructWithOptions({\n target: props.target\n });\n }\n\n if (props.disableCSSOMInjection) {\n sheet = sheet.reconstructWithOptions({\n useCSSOMInjection: false\n });\n }\n\n return sheet;\n }, [props.disableCSSOMInjection, props.sheet, props.target]);\n var stylis = useMemo(function () {\n return createStylisInstance({\n options: {\n prefix: !props.disableVendorPrefixes\n },\n plugins: plugins\n });\n }, [props.disableVendorPrefixes, plugins]);\n useEffect(function () {\n if (!shallowequal(plugins, props.stylisPlugins)) setPlugins(props.stylisPlugins);\n }, [props.stylisPlugins]);\n return /*#__PURE__*/React.createElement(StyleSheetContext.Provider, {\n value: styleSheet\n }, /*#__PURE__*/React.createElement(StylisContext.Provider, {\n value: stylis\n }, process.env.NODE_ENV !== 'production' ? React.Children.only(props.children) : props.children));\n} // \n\n\nvar Keyframes = /*#__PURE__*/function () {\n function Keyframes(name, stringifyArgs) {\n var _this = this;\n\n this.inject = function (styleSheet) {\n if (!styleSheet.hasNameForId(_this.id, _this.name)) {\n styleSheet.insertRules(_this.id, _this.name, masterStylis.apply(void 0, _this.stringifyArgs));\n }\n };\n\n this.toString = function () {\n return throwStyledComponentsError(12, String(_this.name));\n };\n\n this.name = name;\n this.id = \"sc-keyframes-\" + name;\n this.stringifyArgs = stringifyArgs;\n }\n\n var _proto = Keyframes.prototype;\n\n _proto.getName = function getName() {\n return this.name;\n };\n\n return Keyframes;\n}(); // \n\n/**\n * inlined version of\n * https://github.com/facebook/fbjs/blob/master/packages/fbjs/src/core/hyphenateStyleName.js\n */\n\n\nvar uppercasePattern = /([A-Z])/g;\nvar msPattern = /^ms-/;\n/**\n * Hyphenates a camelcased CSS property name, for example:\n *\n * > hyphenateStyleName('backgroundColor')\n * < \"background-color\"\n * > hyphenateStyleName('MozTransition')\n * < \"-moz-transition\"\n * > hyphenateStyleName('msTransition')\n * < \"-ms-transition\"\n *\n * As Modernizr suggests (http://modernizr.com/docs/#prefixed), an `ms` prefix\n * is converted to `-ms-`.\n *\n * @param {string} string\n * @return {string}\n */\n\nfunction hyphenateStyleName(string) {\n return string.replace(uppercasePattern, '-$1').toLowerCase().replace(msPattern, '-ms-');\n} // \n\n\nfunction addUnitIfNeeded(name, value) {\n // https://github.com/amilajack/eslint-plugin-flowtype-errors/issues/133\n // $FlowFixMe\n if (value == null || typeof value === 'boolean' || value === '') {\n return '';\n }\n\n if (typeof value === 'number' && value !== 0 && !(name in unitless)) {\n return value + \"px\"; // Presumes implicit 'px' suffix for unitless numbers\n }\n\n return String(value).trim();\n} // \n\n/**\n * It's falsish not falsy because 0 is allowed.\n */\n\n\nvar isFalsish = function isFalsish(chunk) {\n return chunk === undefined || chunk === null || chunk === false || chunk === '';\n};\n\nvar objToCssArray = function objToCssArray(obj, prevKey) {\n var rules = [];\n var keys = Object.keys(obj);\n keys.forEach(function (key) {\n if (!isFalsish(obj[key])) {\n if (isPlainObject(obj[key])) {\n rules.push.apply(rules, objToCssArray(obj[key], key));\n return rules;\n } else if (isFunction(obj[key])) {\n rules.push(hyphenateStyleName(key) + \":\", obj[key], ';');\n return rules;\n }\n\n rules.push(hyphenateStyleName(key) + \": \" + addUnitIfNeeded(key, obj[key]) + \";\");\n }\n\n return rules;\n });\n return prevKey ? [prevKey + \" {\"].concat(rules, ['}']) : rules;\n};\n\nfunction flatten(chunk, executionContext, styleSheet) {\n if (Array.isArray(chunk)) {\n var ruleSet = [];\n\n for (var i = 0, len = chunk.length, result; i < len; i += 1) {\n result = flatten(chunk[i], executionContext, styleSheet);\n if (result === '') continue;else if (Array.isArray(result)) ruleSet.push.apply(ruleSet, result);else ruleSet.push(result);\n }\n\n return ruleSet;\n }\n\n if (isFalsish(chunk)) {\n return '';\n }\n /* Handle other components */\n\n\n if (isStyledComponent(chunk)) {\n return \".\" + chunk.styledComponentId;\n }\n /* Either execute or defer the function */\n\n\n if (isFunction(chunk)) {\n if (isStatelessFunction(chunk) && executionContext) {\n var _result = chunk(executionContext);\n\n if (process.env.NODE_ENV !== 'production' && isElement(_result)) {\n // eslint-disable-next-line no-console\n console.warn(getComponentName(chunk) + \" is not a styled component and cannot be referred to via component selector. See https://www.styled-components.com/docs/advanced#referring-to-other-components for more details.\");\n }\n\n return flatten(_result, executionContext, styleSheet);\n } else return chunk;\n }\n\n if (chunk instanceof Keyframes) {\n if (styleSheet) {\n chunk.inject(styleSheet);\n return chunk.getName();\n } else return chunk;\n }\n /* Handle objects */\n\n\n return isPlainObject(chunk) ? objToCssArray(chunk) : chunk.toString();\n} // \n\n\nfunction css(styles) {\n for (var _len = arguments.length, interpolations = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n interpolations[_key - 1] = arguments[_key];\n }\n\n if (isFunction(styles) || isPlainObject(styles)) {\n // $FlowFixMe\n return flatten(interleave(EMPTY_ARRAY, [styles].concat(interpolations)));\n }\n\n if (interpolations.length === 0 && styles.length === 1 && typeof styles[0] === \"string\") {\n // $FlowFixMe\n return styles;\n } // $FlowFixMe\n\n\n return flatten(interleave(styles, interpolations));\n}\n\nfunction constructWithOptions(componentConstructor, tag, options) {\n if (options === void 0) {\n options = EMPTY_OBJECT;\n }\n\n if (!isValidElementType(tag)) {\n return throwStyledComponentsError(1, String(tag));\n }\n /* This is callable directly as a template function */\n // $FlowFixMe: Not typed to avoid destructuring arguments\n\n\n var templateFunction = function templateFunction() {\n return componentConstructor(tag, options, css.apply(void 0, arguments));\n };\n /* If config methods are called, wrap up a new template function and merge options */\n\n\n templateFunction.withConfig = function (config) {\n return constructWithOptions(componentConstructor, tag, _extends({}, options, {}, config));\n };\n /* Modify/inject new props at runtime */\n\n\n templateFunction.attrs = function (attrs) {\n return constructWithOptions(componentConstructor, tag, _extends({}, options, {\n attrs: Array.prototype.concat(options.attrs, attrs).filter(Boolean)\n }));\n };\n\n return templateFunction;\n}\n/* eslint-disable */\n\n/**\n mixin-deep; https://github.com/jonschlinkert/mixin-deep\n Inlined such that it will be consistently transpiled to an IE-compatible syntax.\n\n The MIT License (MIT)\n\n Copyright (c) 2014-present, Jon Schlinkert.\n\n Permission is hereby granted, free of charge, to any person obtaining a copy\n of this software and associated documentation files (the \"Software\"), to deal\n in the Software without restriction, including without limitation the rights\n to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n copies of the Software, and to permit persons to whom the Software is\n furnished to do so, subject to the following conditions:\n\n The above copyright notice and this permission notice shall be included in\n all copies or substantial portions of the Software.\n\n THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n THE SOFTWARE.\n*/\n\n\nvar isObject = function isObject(val) {\n return typeof val === 'function' || typeof val === 'object' && val !== null && !Array.isArray(val);\n};\n\nvar isValidKey = function isValidKey(key) {\n return key !== '__proto__' && key !== 'constructor' && key !== 'prototype';\n};\n\nfunction mixin(target, val, key) {\n var obj = target[key];\n\n if (isObject(val) && isObject(obj)) {\n mixinDeep(obj, val);\n } else {\n target[key] = val;\n }\n}\n\nfunction mixinDeep(target) {\n for (var _len = arguments.length, rest = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n rest[_key - 1] = arguments[_key];\n }\n\n for (var _i = 0, _rest = rest; _i < _rest.length; _i++) {\n var obj = _rest[_i];\n\n if (isObject(obj)) {\n for (var key in obj) {\n if (isValidKey(key)) {\n mixin(target, obj[key], key);\n }\n }\n }\n }\n\n return target;\n} // \n\n/* eslint-disable no-bitwise */\n\n\nvar AD_REPLACER_R = /(a)(d)/gi;\n/* This is the \"capacity\" of our alphabet i.e. 2x26 for all letters plus their capitalised\n * counterparts */\n\nvar charsLength = 52;\n/* start at 75 for 'a' until 'z' (25) and then start at 65 for capitalised letters */\n\nvar getAlphabeticChar = function getAlphabeticChar(code) {\n return String.fromCharCode(code + (code > 25 ? 39 : 97));\n};\n/* input a number, usually a hash and convert it to base-52 */\n\n\nfunction generateAlphabeticName(code) {\n var name = '';\n var x;\n /* get a char and divide by alphabet-length */\n\n for (x = Math.abs(code); x > charsLength; x = x / charsLength | 0) {\n name = getAlphabeticChar(x % charsLength) + name;\n }\n\n return (getAlphabeticChar(x % charsLength) + name).replace(AD_REPLACER_R, '$1-$2');\n} // \n\n\nfunction isStaticRules(rules) {\n for (var i = 0; i < rules.length; i += 1) {\n var rule = rules[i];\n\n if (isFunction(rule) && !isStyledComponent(rule)) {\n // functions are allowed to be static if they're just being\n // used to get the classname of a nested styled component\n return false;\n }\n }\n\n return true;\n} // \n\n/*\n ComponentStyle is all the CSS-specific stuff, not\n the React-specific stuff.\n */\n\n\nvar ComponentStyle = /*#__PURE__*/function () {\n function ComponentStyle(rules, componentId) {\n this.rules = rules;\n this.staticRulesId = '';\n this.isStatic = process.env.NODE_ENV === 'production' && isStaticRules(rules);\n this.componentId = componentId;\n this.baseHash = hash(componentId); // NOTE: This registers the componentId, which ensures a consistent order\n // for this component's styles compared to others\n\n StyleSheet.registerId(componentId);\n }\n /*\n * Flattens a rule set into valid CSS\n * Hashes it, wraps the whole chunk in a .hash1234 {}\n * Returns the hash to be injected on render()\n * */\n\n\n var _proto = ComponentStyle.prototype;\n\n _proto.generateAndInjectStyles = function generateAndInjectStyles(executionContext, styleSheet, stylis) {\n var componentId = this.componentId; // force dynamic classnames if user-supplied stylis plugins are in use\n\n if (this.isStatic && !stylis.hash) {\n if (this.staticRulesId && styleSheet.hasNameForId(componentId, this.staticRulesId)) {\n return this.staticRulesId;\n }\n\n var cssStatic = flatten(this.rules, executionContext, styleSheet).join('');\n var name = generateAlphabeticName(phash(this.baseHash, cssStatic.length) >>> 0);\n\n if (!styleSheet.hasNameForId(componentId, name)) {\n var cssStaticFormatted = stylis(cssStatic, \".\" + name, undefined, componentId);\n styleSheet.insertRules(componentId, name, cssStaticFormatted);\n }\n\n this.staticRulesId = name;\n return name;\n } else {\n var length = this.rules.length;\n var dynamicHash = phash(this.baseHash, stylis.hash);\n var css = '';\n\n for (var i = 0; i < length; i++) {\n var partRule = this.rules[i];\n\n if (typeof partRule === 'string') {\n css += partRule;\n if (process.env.NODE_ENV !== 'production') dynamicHash = phash(dynamicHash, partRule + i);\n } else {\n var partChunk = flatten(partRule, executionContext, styleSheet);\n var partString = Array.isArray(partChunk) ? partChunk.join('') : partChunk;\n dynamicHash = phash(dynamicHash, partString + i);\n css += partString;\n }\n }\n\n var _name = generateAlphabeticName(dynamicHash >>> 0);\n\n if (!styleSheet.hasNameForId(componentId, _name)) {\n var cssFormatted = stylis(css, \".\" + _name, undefined, componentId);\n styleSheet.insertRules(componentId, _name, cssFormatted);\n }\n\n return _name;\n }\n };\n\n return ComponentStyle;\n}(); // \n\n\nvar LIMIT = 200;\n\nvar createWarnTooManyClasses = function createWarnTooManyClasses(displayName, componentId) {\n var generatedClasses = {};\n var warningSeen = false;\n return function (className) {\n if (!warningSeen) {\n generatedClasses[className] = true;\n\n if (Object.keys(generatedClasses).length >= LIMIT) {\n // Unable to find latestRule in test environment.\n\n /* eslint-disable no-console, prefer-template */\n var parsedIdString = componentId ? \" with the id of \\\"\" + componentId + \"\\\"\" : '';\n console.warn(\"Over \" + LIMIT + \" classes were generated for component \" + displayName + parsedIdString + \".\\n\" + 'Consider using the attrs method, together with a style object for frequently changed styles.\\n' + 'Example:\\n' + ' const Component = styled.div.attrs(props => ({\\n' + ' style: {\\n' + ' background: props.background,\\n' + ' },\\n' + ' }))`width: 100%;`\\n\\n' + ' <Component />');\n warningSeen = true;\n generatedClasses = {};\n }\n }\n };\n}; // \n\n\nvar invalidHookCallRe = /invalid hook call/i;\nvar seen = new Set();\n\nvar checkDynamicCreation = function checkDynamicCreation(displayName, componentId) {\n if (process.env.NODE_ENV !== 'production') {\n var parsedIdString = componentId ? \" with the id of \\\"\" + componentId + \"\\\"\" : '';\n var message = \"The component \" + displayName + parsedIdString + \" has been created dynamically.\\n\" + 'You may see this warning because you\\'ve called styled inside another component.\\n' + 'To resolve this only create new StyledComponents outside of any render method and function component.';\n\n try {\n // We purposefully call `useRef` outside of a component and expect it to throw\n // If it doesn't, then we're inside another component.\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useRef();\n\n if (!seen.has(message)) {\n // eslint-disable-next-line no-console\n console.warn(message);\n seen.add(message);\n }\n } catch (error) {\n // The error here is expected, since we're expecting anything that uses `checkDynamicCreation` to\n // be called outside of a React component.\n if (invalidHookCallRe.test(error.message)) {\n // This shouldn't happen, but resets `warningSeen` if we had this error happen intermittently\n seen[\"delete\"](message);\n }\n }\n }\n}; // \n\n\nvar determineTheme = function determineTheme(props, providedTheme, defaultProps) {\n if (defaultProps === void 0) {\n defaultProps = EMPTY_OBJECT;\n }\n\n return props.theme !== defaultProps.theme && props.theme || providedTheme || defaultProps.theme;\n}; // \n// Source: https://www.w3.org/TR/cssom-1/#serialize-an-identifier\n// Control characters and non-letter first symbols are not supported\n\n\nvar escapeRegex = /[!\"#$%&'()*+,./:;<=>?@[\\\\\\]^`{|}~-]+/g;\nvar dashesAtEnds = /(^-|-$)/g;\n/**\n * TODO: Explore using CSS.escape when it becomes more available\n * in evergreen browsers.\n */\n\nfunction escape(str) {\n return str // Replace all possible CSS selectors\n .replace(escapeRegex, '-') // Remove extraneous hyphens at the start and end\n .replace(dashesAtEnds, '');\n} // \n\n\nfunction isTag(target) {\n return typeof target === 'string' && (process.env.NODE_ENV !== 'production' ? target.charAt(0) === target.charAt(0).toLowerCase() : true);\n} // \n\n\nfunction generateDisplayName(target) {\n // $FlowFixMe\n return isTag(target) ? \"styled.\" + target : \"Styled(\" + getComponentName(target) + \")\";\n} // \n\n\nvar generateComponentId = function generateComponentId(str) {\n return generateAlphabeticName(hash(str) >>> 0);\n};\n/**\n * Convenience function for joining strings to form className chains\n */\n\n\nfunction joinStrings(a, b) {\n return a && b ? a + \" \" + b : a || b;\n}\n\nvar ThemeContext = React.createContext();\nvar ThemeConsumer = ThemeContext.Consumer;\n\nfunction mergeTheme(theme, outerTheme) {\n if (!theme) {\n return throwStyledComponentsError(14);\n }\n\n if (isFunction(theme)) {\n var mergedTheme = theme(outerTheme);\n\n if (process.env.NODE_ENV !== 'production' && (mergedTheme === null || Array.isArray(mergedTheme) || typeof mergedTheme !== 'object')) {\n return throwStyledComponentsError(7);\n }\n\n return mergedTheme;\n }\n\n if (Array.isArray(theme) || typeof theme !== 'object') {\n return throwStyledComponentsError(8);\n }\n\n return outerTheme ? _extends({}, outerTheme, {}, theme) : theme;\n}\n/**\n * Provide a theme to an entire react component tree via context\n */\n\n\nfunction ThemeProvider(props) {\n var outerTheme = useContext(ThemeContext);\n var themeContext = useMemo(function () {\n return mergeTheme(props.theme, outerTheme);\n }, [props.theme, outerTheme]);\n\n if (!props.children) {\n return null;\n }\n\n return /*#__PURE__*/React.createElement(ThemeContext.Provider, {\n value: themeContext\n }, props.children);\n}\n/* global $Call */\n\n\nvar identifiers = {};\n/* We depend on components having unique IDs */\n\nfunction generateId(displayName, parentComponentId) {\n var name = typeof displayName !== 'string' ? 'sc' : escape(displayName); // Ensure that no displayName can lead to duplicate componentIds\n\n identifiers[name] = (identifiers[name] || 0) + 1;\n var componentId = name + \"-\" + generateComponentId(name + identifiers[name]);\n return parentComponentId ? parentComponentId + \"-\" + componentId : componentId;\n}\n\nfunction useResolvedAttrs(theme, props, attrs) {\n if (theme === void 0) {\n theme = EMPTY_OBJECT;\n } // NOTE: can't memoize this\n // returns [context, resolvedAttrs]\n // where resolvedAttrs is only the things injected by the attrs themselves\n\n\n var context = _extends({}, props, {\n theme: theme\n });\n\n var resolvedAttrs = {};\n attrs.forEach(function (attrDef) {\n var resolvedAttrDef = attrDef;\n var key;\n\n if (isFunction(resolvedAttrDef)) {\n resolvedAttrDef = resolvedAttrDef(context);\n }\n /* eslint-disable guard-for-in */\n\n\n for (key in resolvedAttrDef) {\n context[key] = resolvedAttrs[key] = key === 'className' ? joinStrings(resolvedAttrs[key], resolvedAttrDef[key]) : resolvedAttrDef[key];\n }\n /* eslint-enable guard-for-in */\n\n });\n return [context, resolvedAttrs];\n}\n\nfunction useInjectedStyle(componentStyle, hasAttrs, resolvedAttrs, warnTooManyClasses) {\n var styleSheet = useStyleSheet();\n var stylis = useStylis(); // statically styled-components don't need to build an execution context object,\n // and shouldn't be increasing the number of class names\n\n var isStatic = componentStyle.isStatic && !hasAttrs;\n var className = isStatic ? componentStyle.generateAndInjectStyles(EMPTY_OBJECT, styleSheet, stylis) : componentStyle.generateAndInjectStyles(resolvedAttrs, styleSheet, stylis);\n useDebugValue(className);\n\n if (process.env.NODE_ENV !== 'production' && !isStatic && warnTooManyClasses) {\n warnTooManyClasses(className);\n }\n\n return className;\n}\n\nfunction useStyledComponentImpl(forwardedComponent, props, forwardedRef) {\n var componentAttrs = forwardedComponent.attrs,\n componentStyle = forwardedComponent.componentStyle,\n defaultProps = forwardedComponent.defaultProps,\n foldedComponentIds = forwardedComponent.foldedComponentIds,\n shouldForwardProp = forwardedComponent.shouldForwardProp,\n styledComponentId = forwardedComponent.styledComponentId,\n target = forwardedComponent.target;\n useDebugValue(styledComponentId); // NOTE: the non-hooks version only subscribes to this when !componentStyle.isStatic,\n // but that'd be against the rules-of-hooks. We could be naughty and do it anyway as it\n // should be an immutable value, but behave for now.\n\n var theme = determineTheme(props, useContext(ThemeContext), defaultProps);\n\n var _useResolvedAttrs = useResolvedAttrs(theme || EMPTY_OBJECT, props, componentAttrs),\n context = _useResolvedAttrs[0],\n attrs = _useResolvedAttrs[1];\n\n var generatedClassName = useInjectedStyle(componentStyle, componentAttrs.length > 0, context, process.env.NODE_ENV !== 'production' ? forwardedComponent.warnTooManyClasses : undefined);\n var refToForward = forwardedRef;\n var elementToBeCreated = attrs.$as || props.$as || attrs.as || props.as || target;\n var isTargetTag = isTag(elementToBeCreated);\n var computedProps = attrs !== props ? _extends({}, props, {}, attrs) : props;\n var propFilterFn = shouldForwardProp || isTargetTag && validAttr;\n var propsForElement = {}; // eslint-disable-next-line guard-for-in\n\n for (var key in computedProps) {\n if (key[0] === '$' || key === 'as') continue;else if (key === 'forwardedAs') {\n propsForElement.as = computedProps[key];\n } else if (!propFilterFn || propFilterFn(key, validAttr)) {\n // Don't pass through non HTML tags through to HTML elements\n propsForElement[key] = computedProps[key];\n }\n }\n\n if (props.style && attrs.style !== props.style) {\n propsForElement.style = _extends({}, props.style, {}, attrs.style);\n }\n\n propsForElement.className = Array.prototype.concat(foldedComponentIds, styledComponentId, generatedClassName !== styledComponentId ? generatedClassName : null, props.className, attrs.className).filter(Boolean).join(' ');\n propsForElement.ref = refToForward;\n return createElement(elementToBeCreated, propsForElement);\n}\n\nfunction createStyledComponent(target, options, rules) {\n var isTargetStyledComp = isStyledComponent(target);\n var isCompositeComponent = !isTag(target);\n var _options$displayName = options.displayName,\n displayName = _options$displayName === void 0 ? generateDisplayName(target) : _options$displayName,\n _options$componentId = options.componentId,\n componentId = _options$componentId === void 0 ? generateId(options.displayName, options.parentComponentId) : _options$componentId,\n _options$attrs = options.attrs,\n attrs = _options$attrs === void 0 ? EMPTY_ARRAY : _options$attrs;\n var styledComponentId = options.displayName && options.componentId ? escape(options.displayName) + \"-\" + options.componentId : options.componentId || componentId; // fold the underlying StyledComponent attrs up (implicit extend)\n\n var finalAttrs = // $FlowFixMe\n isTargetStyledComp && target.attrs ? Array.prototype.concat(target.attrs, attrs).filter(Boolean) : attrs; // eslint-disable-next-line prefer-destructuring\n\n var shouldForwardProp = options.shouldForwardProp; // $FlowFixMe\n\n if (isTargetStyledComp && target.shouldForwardProp) {\n if (shouldForwardProp) {\n // compose nested shouldForwardProp calls\n shouldForwardProp = function shouldForwardProp(prop, filterFn) {\n return (// $FlowFixMe\n target.shouldForwardProp(prop, filterFn) && options.shouldForwardProp(prop, filterFn)\n );\n };\n } else {\n // eslint-disable-next-line prefer-destructuring\n shouldForwardProp = target.shouldForwardProp;\n }\n }\n\n var componentStyle = new ComponentStyle(isTargetStyledComp ? // fold the underlying StyledComponent rules up (implicit extend)\n // $FlowFixMe\n target.componentStyle.rules.concat(rules) : rules, styledComponentId);\n /**\n * forwardRef creates a new interim component, which we'll take advantage of\n * instead of extending ParentComponent to create _another_ interim class\n */\n\n var WrappedStyledComponent; // eslint-disable-next-line react-hooks/rules-of-hooks\n\n var forwardRef = function forwardRef(props, ref) {\n return useStyledComponentImpl(WrappedStyledComponent, props, ref);\n };\n\n forwardRef.displayName = displayName; // $FlowFixMe this is a forced cast to merge it StyledComponentWrapperProperties\n\n WrappedStyledComponent = React.forwardRef(forwardRef);\n WrappedStyledComponent.attrs = finalAttrs;\n WrappedStyledComponent.componentStyle = componentStyle;\n WrappedStyledComponent.displayName = displayName;\n WrappedStyledComponent.shouldForwardProp = shouldForwardProp; // this static is used to preserve the cascade of static classes for component selector\n // purposes; this is especially important with usage of the css prop\n\n WrappedStyledComponent.foldedComponentIds = isTargetStyledComp ? // $FlowFixMe\n Array.prototype.concat(target.foldedComponentIds, target.styledComponentId) : EMPTY_ARRAY;\n WrappedStyledComponent.styledComponentId = styledComponentId; // fold the underlying StyledComponent target up since we folded the styles\n\n WrappedStyledComponent.target = isTargetStyledComp ? // $FlowFixMe\n target.target : target; // $FlowFixMe\n\n WrappedStyledComponent.withComponent = function withComponent(tag) {\n var previousComponentId = options.componentId,\n optionsToCopy = _objectWithoutPropertiesLoose(options, [\"componentId\"]);\n\n var newComponentId = previousComponentId && previousComponentId + \"-\" + (isTag(tag) ? tag : escape(getComponentName(tag)));\n\n var newOptions = _extends({}, optionsToCopy, {\n attrs: finalAttrs,\n componentId: newComponentId\n });\n\n return createStyledComponent(tag, newOptions, rules);\n }; // $FlowFixMe\n\n\n Object.defineProperty(WrappedStyledComponent, 'defaultProps', {\n get: function get() {\n return this._foldedDefaultProps;\n },\n set: function set(obj) {\n // $FlowFixMe\n this._foldedDefaultProps = isTargetStyledComp ? mixinDeep({}, target.defaultProps, obj) : obj;\n }\n });\n\n if (process.env.NODE_ENV !== 'production') {\n checkDynamicCreation(displayName, styledComponentId);\n WrappedStyledComponent.warnTooManyClasses = createWarnTooManyClasses(displayName, styledComponentId);\n } // $FlowFixMe\n\n\n WrappedStyledComponent.toString = function () {\n return \".\" + WrappedStyledComponent.styledComponentId;\n };\n\n if (isCompositeComponent) {\n hoist(WrappedStyledComponent, target, {\n // all SC-specific things should not be hoisted\n attrs: true,\n componentStyle: true,\n displayName: true,\n foldedComponentIds: true,\n shouldForwardProp: true,\n self: true,\n styledComponentId: true,\n target: true,\n withComponent: true\n });\n }\n\n return WrappedStyledComponent;\n} // \n// Thanks to ReactDOMFactories for this handy list!\n\n\nvar domElements = ['a', 'abbr', 'address', 'area', 'article', 'aside', 'audio', 'b', 'base', 'bdi', 'bdo', 'big', 'blockquote', 'body', 'br', 'button', 'canvas', 'caption', 'cite', 'code', 'col', 'colgroup', 'data', 'datalist', 'dd', 'del', 'details', 'dfn', 'dialog', 'div', 'dl', 'dt', 'em', 'embed', 'fieldset', 'figcaption', 'figure', 'footer', 'form', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'head', 'header', 'hgroup', 'hr', 'html', 'i', 'iframe', 'img', 'input', 'ins', 'kbd', 'keygen', 'label', 'legend', 'li', 'link', 'main', 'map', 'mark', 'marquee', 'menu', 'menuitem', 'meta', 'meter', 'nav', 'noscript', 'object', 'ol', 'optgroup', 'option', 'output', 'p', 'param', 'picture', 'pre', 'progress', 'q', 'rp', 'rt', 'ruby', 's', 'samp', 'script', 'section', 'select', 'small', 'source', 'span', 'strong', 'style', 'sub', 'summary', 'sup', 'table', 'tbody', 'td', 'textarea', 'tfoot', 'th', 'thead', 'time', 'title', 'tr', 'track', 'u', 'ul', 'var', 'video', 'wbr', // SVG\n'circle', 'clipPath', 'defs', 'ellipse', 'foreignObject', 'g', 'image', 'line', 'linearGradient', 'marker', 'mask', 'path', 'pattern', 'polygon', 'polyline', 'radialGradient', 'rect', 'stop', 'svg', 'text', 'tspan']; // \n\nvar styled = function styled(tag) {\n return constructWithOptions(createStyledComponent, tag);\n}; // Shorthands for all valid HTML Elements\n\n\ndomElements.forEach(function (domElement) {\n styled[domElement] = styled(domElement);\n}); // \n\nvar GlobalStyle = /*#__PURE__*/function () {\n function GlobalStyle(rules, componentId) {\n this.rules = rules;\n this.componentId = componentId;\n this.isStatic = isStaticRules(rules);\n }\n\n var _proto = GlobalStyle.prototype;\n\n _proto.createStyles = function createStyles(instance, executionContext, styleSheet, stylis) {\n var flatCSS = flatten(this.rules, executionContext, styleSheet);\n var css = stylis(flatCSS.join(''), '');\n var id = this.componentId + instance; // NOTE: We use the id as a name as well, since these rules never change\n\n styleSheet.insertRules(id, id, css);\n };\n\n _proto.removeStyles = function removeStyles(instance, styleSheet) {\n styleSheet.clearRules(this.componentId + instance);\n };\n\n _proto.renderStyles = function renderStyles(instance, executionContext, styleSheet, stylis) {\n StyleSheet.registerId(this.componentId + instance); // NOTE: Remove old styles, then inject the new ones\n\n this.removeStyles(instance, styleSheet);\n this.createStyles(instance, executionContext, styleSheet, stylis);\n };\n\n return GlobalStyle;\n}();\n\nfunction createGlobalStyle(strings) {\n for (var _len = arguments.length, interpolations = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n interpolations[_key - 1] = arguments[_key];\n }\n\n var rules = css.apply(void 0, [strings].concat(interpolations));\n var styledComponentId = \"sc-global-\" + generateComponentId(JSON.stringify(rules));\n var globalStyle = new GlobalStyle(rules, styledComponentId);\n\n if (process.env.NODE_ENV !== 'production') {\n checkDynamicCreation(styledComponentId);\n }\n\n function GlobalStyleComponent(props) {\n var styleSheet = useStyleSheet();\n var stylis = useStylis();\n var theme = useContext(ThemeContext);\n var instanceRef = useRef(null);\n\n if (instanceRef.current === null) {\n instanceRef.current = styleSheet.allocateGSInstance(styledComponentId);\n }\n\n var instance = instanceRef.current;\n\n if (process.env.NODE_ENV !== 'production' && React.Children.count(props.children)) {\n // eslint-disable-next-line no-console\n console.warn(\"The global style component \" + styledComponentId + \" was given child JSX. createGlobalStyle does not render children.\");\n }\n\n if (process.env.NODE_ENV !== 'production' && rules.some(function (rule) {\n return typeof rule === 'string' && rule.indexOf('@import') !== -1;\n })) {\n console.warn(\"Please do not use @import CSS syntax in createGlobalStyle at this time, as the CSSOM APIs we use in production do not handle it well. Instead, we recommend using a library such as react-helmet to inject a typical <link> meta tag to the stylesheet, or simply embedding it manually in your index.html <head> section for a simpler app.\");\n }\n\n if (globalStyle.isStatic) {\n globalStyle.renderStyles(instance, STATIC_EXECUTION_CONTEXT, styleSheet, stylis);\n } else {\n var context = _extends({}, props, {\n theme: determineTheme(props, theme, GlobalStyleComponent.defaultProps)\n });\n\n globalStyle.renderStyles(instance, context, styleSheet, stylis);\n }\n\n useEffect(function () {\n return function () {\n return globalStyle.removeStyles(instance, styleSheet);\n };\n }, EMPTY_ARRAY);\n return null;\n } // $FlowFixMe\n\n\n return React.memo(GlobalStyleComponent);\n} // \n\n\nfunction keyframes(strings) {\n /* Warning if you've used keyframes on React Native */\n if (process.env.NODE_ENV !== 'production' && typeof navigator !== 'undefined' && navigator.product === 'ReactNative') {\n // eslint-disable-next-line no-console\n console.warn('`keyframes` cannot be used on ReactNative, only on the web. To do animation in ReactNative please use Animated.');\n }\n\n for (var _len = arguments.length, interpolations = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n interpolations[_key - 1] = arguments[_key];\n }\n\n var rules = css.apply(void 0, [strings].concat(interpolations)).join('');\n var name = generateComponentId(rules);\n return new Keyframes(name, [rules, name, '@keyframes']);\n}\n\nvar ServerStyleSheet = /*#__PURE__*/function () {\n function ServerStyleSheet() {\n var _this = this;\n\n this._emitSheetCSS = function () {\n var css = _this.instance.toString();\n\n var nonce = getNonce();\n var attrs = [nonce && \"nonce=\\\"\" + nonce + \"\\\"\", SC_ATTR + \"=\\\"true\\\"\", SC_ATTR_VERSION + \"=\\\"\" + SC_VERSION + \"\\\"\"];\n var htmlAttr = attrs.filter(Boolean).join(' ');\n return \"<style \" + htmlAttr + \">\" + css + \"</style>\";\n };\n\n this.getStyleTags = function () {\n if (_this.sealed) {\n return throwStyledComponentsError(2);\n }\n\n return _this._emitSheetCSS();\n };\n\n this.getStyleElement = function () {\n var _props;\n\n if (_this.sealed) {\n return throwStyledComponentsError(2);\n }\n\n var props = (_props = {}, _props[SC_ATTR] = '', _props[SC_ATTR_VERSION] = SC_VERSION, _props.dangerouslySetInnerHTML = {\n __html: _this.instance.toString()\n }, _props);\n var nonce = getNonce();\n\n if (nonce) {\n props.nonce = nonce;\n } // v4 returned an array for this fn, so we'll do the same for v5 for backward compat\n\n\n return [/*#__PURE__*/React.createElement(\"style\", _extends({}, props, {\n key: \"sc-0-0\"\n }))];\n };\n\n this.seal = function () {\n _this.sealed = true;\n };\n\n this.instance = new StyleSheet({\n isServer: true\n });\n this.sealed = false;\n }\n\n var _proto = ServerStyleSheet.prototype;\n\n _proto.collectStyles = function collectStyles(children) {\n if (this.sealed) {\n return throwStyledComponentsError(2);\n }\n\n return /*#__PURE__*/React.createElement(StyleSheetManager, {\n sheet: this.instance\n }, children);\n }; // eslint-disable-next-line consistent-return\n\n\n _proto.interleaveWithNodeStream = function interleaveWithNodeStream(input) {\n {\n return throwStyledComponentsError(3);\n }\n };\n\n return ServerStyleSheet;\n}(); // export default <Config: { theme?: any }, Instance>(\n// Component: AbstractComponent<Config, Instance>\n// ): AbstractComponent<$Diff<Config, { theme?: any }> & { theme?: any }, Instance>\n//\n// but the old build system tooling doesn't support the syntax\n\n\nvar withTheme = function withTheme(Component) {\n // $FlowFixMe This should be React.forwardRef<Config, Instance>\n var WithTheme = React.forwardRef(function (props, ref) {\n var theme = useContext(ThemeContext); // $FlowFixMe defaultProps isn't declared so it can be inferrable\n\n var defaultProps = Component.defaultProps;\n var themeProp = determineTheme(props, theme, defaultProps);\n\n if (process.env.NODE_ENV !== 'production' && themeProp === undefined) {\n // eslint-disable-next-line no-console\n console.warn(\"[withTheme] You are not using a ThemeProvider nor passing a theme prop or a theme in defaultProps in component class \\\"\" + getComponentName(Component) + \"\\\"\");\n }\n\n return /*#__PURE__*/React.createElement(Component, _extends({}, props, {\n theme: themeProp,\n ref: ref\n }));\n });\n hoist(WithTheme, Component);\n WithTheme.displayName = \"WithTheme(\" + getComponentName(Component) + \")\";\n return WithTheme;\n}; // \n\n\nvar useTheme = function useTheme() {\n return useContext(ThemeContext);\n}; // \n\n\nvar __PRIVATE__ = {\n StyleSheet: StyleSheet,\n masterSheet: masterSheet\n}; // \n\n/* Define bundle version for export */\n\nvar version = \"5.1.1\";\n/* Warning if you've imported this file on React Native */\n\nif (process.env.NODE_ENV !== 'production' && typeof navigator !== 'undefined' && navigator.product === 'ReactNative') {\n // eslint-disable-next-line no-console\n console.warn(\"It looks like you've imported 'styled-components' on React Native.\\n\" + \"Perhaps you're looking to import 'styled-components/native'?\\n\" + 'Read more about this at https://www.styled-components.com/docs/basics#react-native');\n}\n/* Warning if there are several instances of styled-components */\n\n\nif (process.env.NODE_ENV !== 'production' && process.env.NODE_ENV !== 'test' && typeof window !== 'undefined') {\n window['__styled-components-init__'] = window['__styled-components-init__'] || 0;\n\n if (window['__styled-components-init__'] === 1) {\n // eslint-disable-next-line no-console\n console.warn(\"It looks like there are several instances of 'styled-components' initialized in this application. \" + 'This may cause dynamic styles not rendering properly, errors happening during rehydration process, ' + 'missing theme prop, and makes your application bigger without a good reason.\\n\\n' + 'See https://s-c.sh/2BAXzed for more info.');\n }\n\n window['__styled-components-init__'] += 1;\n}\n\nexport default styled;\nexport { ServerStyleSheet, StyleSheetConsumer, StyleSheetContext, StyleSheetManager, ThemeConsumer, ThemeContext, ThemeProvider, __PRIVATE__, createGlobalStyle, css, isStyledComponent, keyframes, useTheme, version, withTheme };","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n"],"sourceRoot":""}