{"version":3,"sources":["webpack:///./src/helpers/media.ts","webpack:///./src/hooks/useIntersectionObserver.ts","webpack:///./src/hooks/useInView.ts","webpack:///./src/stories/Components/SectionWrapper/SectionWrapper.tsx","webpack:///./src/stories/Components/Global/Typography/Heading.styles.ts","webpack:///./src/stories/Widgets/RichText/RichText.styles.ts","webpack:///./src/stories/Components/Global/SiteWide/SiteWide.tsx","webpack:///./src/stories/Components/Global/SiteWide/SiteWide.styles.ts","webpack:///./src/stories/Components/Global/Typography/Paragraph.styles.ts","webpack:///./src/helpers/fluid.ts","webpack:///./src/helpers/animation.ts","webpack:///./src/stories/Widgets/RichText/RichText.tsx","webpack:///./src/helpers/brand.ts","webpack:///./src/helpers/grey.ts","webpack:///./src/helpers/cssVar.ts","webpack:///./src/helpers/fonts.ts","webpack:///./src/stories/Components/SectionWrapper/SectionWrapper.styles.ts"],"names":["Device","from","size","until","between","start","end","useIntersectionObserver","callback","options","observerRef","useRef","rootRef","elementRef","useEffect","current","IntersectionObserver","root","observe","disconnect","JSON","stringify","useInView","reverse","isEditMode","inView","setInView","useState","entries","isIntersecting","SectionWrapper","React","children","className","flush","fullWidth","id","innerWidth","theme","otherProps","ref","S","Container","themeOption","SiteWide","width","displayName","H1Styles","css","fonts","brown","thin","fluid","H2Styles","H3Styles","light","H4Styles","H5Styles","bold","H6Styles","Heading","styled","h1","visual","linkStyles","cssVar","regular","tableStyles","ParagraphStyles","RegularStyles","contentStyles","HeadingStyles","verticalMargin","setCssVar","TabletLarge","isActive","fadeIn","animation","easeInOutCubic","MobileLarge","Content","div","imageStyles","createElement","DesktopLarge","LargeStyles","SmallStyles","Paragraph","p","DEFAULT_MIN_VALUE","Tablet","DEFAULT_MAX_VALUE","ActualDesktop","min","max","minWidth","maxWidth","minRem","maxRem","minWidthRem","slope","yAxisIntersection","round","fluidUnit","unit","num","Math","threshold","rootMargin","earlyRootMargin","globalThreshold","slideInUpInitial","slideInUp","animate","duration","delay","easingFunc","fadeInUp","amount","backgroundAnimation","textClip","multicolouredBackground","multicolouredAnimatedText","multicolouredBackgroundBright","multicolouredTextBright","choirInTheSpireBackground","choirInTheSpireText","transition","properties","timing","innerCss","RichText","content","refContainer","isInView","dangerouslySetInnerHTML","__html","brand","black","blue","blueGrey","blueTint","grey","reduce","previous","value","hsl","orange","white","validation","invalid","valid","lightTheme","grey90","grey96","darkTheme","grey10","themes","dark","name","thinItalic","lightItalic","regularItalic","boldItalic","section","StyledSiteWide"],"mappings":"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","file":"85-0005e8e52a2626e0c410.js","sourcesContent":["export var Device;\r\n(function (Device) {\r\n Device[Device[\"MobileSmall\"] = 320] = \"MobileSmall\";\r\n Device[Device[\"Mobile\"] = 375] = \"Mobile\";\r\n Device[Device[\"MobileLarge\"] = 480] = \"MobileLarge\";\r\n Device[Device[\"TabletSmall\"] = 568] = \"TabletSmall\";\r\n Device[Device[\"Tablet\"] = 768] = \"Tablet\";\r\n Device[Device[\"TabletLarge\"] = 1024] = \"TabletLarge\";\r\n Device[Device[\"DesktopSmall\"] = 1280] = \"DesktopSmall\";\r\n Device[Device[\"Desktop\"] = 1366] = \"Desktop\";\r\n Device[Device[\"DesktopLarge\"] = 1600] = \"DesktopLarge\";\r\n Device[Device[\"ActualDesktop\"] = 1920] = \"ActualDesktop\";\r\n Device[Device[\"DesktopXL\"] = 2560] = \"DesktopXL\";\r\n})(Device || (Device = {}));\r\nexport function from(size) {\r\n return `(min-width: ${size}px)`;\r\n}\r\nexport function until(size) {\r\n return `(max-width: ${size - 1}px)`;\r\n}\r\nexport function between(start, end) {\r\n return `${from(start)} and ${until(end)}`;\r\n}\r\n","import { useEffect, useRef } from 'react';\r\n/**\r\n * Use the IntersectionObserver to track visibility of an element in the viewport.\r\n * @param {IntersectionObserverCallback} callback\r\n * @param {IntersectionObserverInit} options\r\n * @returns {UseIntersectionObserverReturn}\r\n */\r\nfunction useIntersectionObserver(callback, options = {}) {\r\n const observerRef = useRef(null);\r\n const rootRef = useRef(null);\r\n const elementRef = useRef(null);\r\n useEffect(() => {\r\n if (!elementRef.current) {\r\n return undefined;\r\n }\r\n observerRef.current = new IntersectionObserver(callback, {\r\n root: rootRef.current,\r\n ...options,\r\n });\r\n observerRef.current.observe(elementRef.current);\r\n return () => {\r\n if (observerRef.current === null) {\r\n return;\r\n }\r\n observerRef.current.disconnect();\r\n };\r\n }, [JSON.stringify(options)]);\r\n return { elementRef, observerRef, rootRef };\r\n}\r\nexport default useIntersectionObserver;\r\n","import { useState } from 'react';\r\nimport useIntersectionObserver from './useIntersectionObserver';\r\nexport function useInView(options, reverse = false, isEditMode = false) {\r\n const [inView, setInView] = useState(false);\r\n const { elementRef } = useIntersectionObserver((entries) => {\r\n if (entries[0].isIntersecting) {\r\n setInView(true);\r\n }\r\n else if (reverse === true) {\r\n setInView(false);\r\n }\r\n }, options);\r\n return [elementRef, isEditMode ? true : inView];\r\n}\r\n","import * as React from 'react';\r\nimport S from './SectionWrapper.styles';\r\nconst SectionWrapper = React.forwardRef(({ children, className, flush, fullWidth = false, id, innerWidth = 'default', theme = 'light', ...otherProps }, ref) => {\r\n return (React.createElement(S.Container, { ref: ref, id: id, className: className, flush: flush, themeOption: theme, \"data-theme\": theme, ...otherProps }, fullWidth ? children : React.createElement(S.SiteWide, { width: innerWidth }, children)));\r\n});\r\nSectionWrapper.displayName = 'SectionWrapper';\r\nexport default SectionWrapper;\r\n","import { fluid } from '@helpers/fluid';\r\nimport fonts from '@helpers/fonts';\r\nimport styled, { css } from 'styled-components';\r\nconst H1Styles = css `\r\n ${fonts.brown.thin};\r\n font-size: ${fluid(32, 70)};\r\n line-height: ${fluid(32, 70)};\r\n letter-spacing: normal;\r\n margin: 0 0 16px;\r\n text-transform: uppercase;\r\n`;\r\nconst H2Styles = css `\r\n ${fonts.brown.thin};\r\n font-size: ${fluid(28, 60)};\r\n line-height: ${fluid(28, 64)};\r\n letter-spacing: normal;\r\n margin: 0 0 16px;\r\n text-transform: uppercase;\r\n`;\r\nconst H3Styles = css `\r\n ${fonts.brown.light};\r\n font-size: ${fluid(24, 50)};\r\n line-height: ${fluid(26, 54)};\r\n letter-spacing: normal;\r\n margin: 0 0 16px;\r\n text-transform: uppercase;\r\n`;\r\nconst H4Styles = css `\r\n ${fonts.brown.light};\r\n font-size: ${fluid(21, 24)};\r\n line-height: ${fluid(28, 32)};\r\n letter-spacing: normal;\r\n margin: 0 0 16px;\r\n text-transform: uppercase;\r\n`;\r\nconst H5Styles = css `\r\n ${fonts.brown.bold};\r\n font-size: ${fluid(16, 20)};\r\n line-height: ${fluid(18, 28)};\r\n letter-spacing: normal;\r\n margin: 0 0 16px;\r\n text-transform: uppercase;\r\n`;\r\nconst H6Styles = css `\r\n ${fonts.brown.bold};\r\n font-size: ${fluid(16, 20)};\r\n line-height: ${fluid(18, 28)};\r\n letter-spacing: normal;\r\n margin: 0 0 16px;\r\n text-transform: uppercase;\r\n`;\r\nconst Heading = styled.h1 `\r\n ${({ visual }) => {\r\n switch (visual) {\r\n case 'h1':\r\n return H1Styles;\r\n case 'h2':\r\n return H2Styles;\r\n case 'h3':\r\n return H3Styles;\r\n case 'h4':\r\n return H4Styles;\r\n case 'h5':\r\n return H5Styles;\r\n case 'h6':\r\n return H6Styles;\r\n default:\r\n break;\r\n }\r\n}}\r\n`;\r\nexport default {\r\n H1Styles,\r\n H2Styles,\r\n H3Styles,\r\n H4Styles,\r\n H5Styles,\r\n H6Styles,\r\n Heading,\r\n};\r\n","import animation, { fadeIn } from '@helpers/animation';\r\nimport { cssVar, setCssVar } from '@helpers/cssVar';\r\nimport fonts from '@helpers/fonts';\r\nimport { Device, from, until } from '@helpers/media';\r\nimport HeadingStyles from '@stories/Components/Global/Typography/Heading.styles';\r\nimport ParagraphStyles from '@stories/Components/Global/Typography/Paragraph.styles';\r\nimport SectionWrapper from '@stories/Components/SectionWrapper/SectionWrapper';\r\nimport styled, { css } from 'styled-components';\r\nconst linkStyles = css `\r\n background-color: transparent;\r\n background-image: linear-gradient(\r\n to right,\r\n ${cssVar('accentColor')} 0%,\r\n ${cssVar('accentColor')} 100%\r\n );\r\n background-repeat: no-repeat;\r\n background-size: 0% 100%;\r\n color: ${cssVar('fgColor')};\r\n ${fonts.brown.regular};\r\n margin: -3px;\r\n padding: 3px;\r\n text-decoration: underline;\r\n text-underline-position: under;\r\n transition: background-size 0.15s ease-out;\r\n\r\n &:focus {\r\n outline: none;\r\n }\r\n\r\n &:focus,\r\n &:hover {\r\n background-size: 100% 100%;\r\n }\r\n`;\r\nconst tableStyles = css `\r\n margin: 0 0 16px;\r\n\r\n th,\r\n td {\r\n border: 1px solid ${cssVar('fgColor')};\r\n color: ${cssVar('fgColor')};\r\n ${ParagraphStyles.RegularStyles};\r\n height: auto !important; // override inline height - no point this being content editable.\r\n margin: 0;\r\n padding: 8px 16px;\r\n }\r\n`;\r\nconst contentStyles = css `\r\n color: ${cssVar('fgColor')};\r\n ${fonts.brown.regular};\r\n\r\n h1 {\r\n ${HeadingStyles.H1Styles};\r\n }\r\n\r\n h2 {\r\n ${HeadingStyles.H2Styles};\r\n }\r\n\r\n h3 {\r\n ${HeadingStyles.H3Styles};\r\n }\r\n\r\n h4 {\r\n ${HeadingStyles.H4Styles};\r\n }\r\n\r\n h5 {\r\n ${HeadingStyles.H5Styles};\r\n }\r\n\r\n h6 {\r\n ${HeadingStyles.H6Styles};\r\n }\r\n\r\n p {\r\n ${ParagraphStyles.RegularStyles};\r\n }\r\n\r\n strong {\r\n ${fonts.brown.bold};\r\n }\r\n\r\n ol,\r\n ul {\r\n display: block;\r\n ${ParagraphStyles.RegularStyles};\r\n padding: 0 0 0 40px;\r\n }\r\n\r\n ol {\r\n list-style: decimal;\r\n\r\n li {\r\n display: list-item;\r\n }\r\n }\r\n\r\n ul {\r\n list-style: disc;\r\n\r\n /* Adjust padding if the browser supports custom markers, otherwise use default disc marker. */\r\n @supports (selector(ul li::marker)) {\r\n padding: 0 0 0 20px;\r\n\r\n li {\r\n display: list-item;\r\n padding: 0 0 0 20px;\r\n\r\n &::marker {\r\n content: '-';\r\n }\r\n }\r\n }\r\n }\r\n\r\n a {\r\n ${linkStyles};\r\n }\r\n\r\n > *:last-child {\r\n margin-bottom: 0;\r\n }\r\n\r\n table {\r\n ${tableStyles};\r\n }\r\n\r\n hr {\r\n margin: 16px 0;\r\n }\r\n\r\n sup {\r\n position: relative;\r\n top: -0.5em;\r\n font-size: 80%;\r\n }\r\n\r\n sub {\r\n position: relative;\r\n top: 0.5em;\r\n font-size: 80%;\r\n }\r\n`;\r\nconst Container = styled(SectionWrapper) `\r\n ${({ verticalMargin }) => verticalMargin &&\r\n css `\r\n ${setCssVar('sectionMargin', verticalMargin)};\r\n `}\r\n padding-top: 40px;\r\n @media ${from(Device.TabletLarge)} {\r\n scroll-margin-top: 128px;\r\n margin: ${cssVar('sectionMargin')} 0;\r\n opacity: 0;\r\n\r\n ${({ isActive }) => isActive &&\r\n css `\r\n ${fadeIn(isActive, 375, 0, animation.easeInOutCubic)};\r\n `}\r\n }\r\n\r\n @media ${until(Device.MobileLarge)} {\r\n scroll-margin-top: 60px;\r\n margin: calc(${cssVar('sectionMargin')} / 2) 0;\r\n }\r\n`;\r\nconst Content = styled.div `\r\n margin: 0 auto;\r\n width: 100%;\r\n\r\n ${contentStyles}\r\n`;\r\nconst imageStyles = css `\r\n img {\r\n object-fit: contain;\r\n height: fit-content;\r\n }\r\n`;\r\nexport default {\r\n Container,\r\n Content,\r\n contentStyles,\r\n linkStyles,\r\n imageStyles,\r\n};\r\n","import React from 'react';\r\nimport S from './SiteWide.styles';\r\nconst SiteWide = ({ children, className, width = 'default' }) => {\r\n return (React.createElement(S.Container, { className: className, width: width }, children));\r\n};\r\nexport default SiteWide;\r\n","import { cssVar, setCssVar } from '@helpers/cssVar';\r\nimport { Device, from } from '@helpers/media';\r\nimport styled, { css } from 'styled-components';\r\nconst Container = styled.div `\r\n ${setCssVar('sitePadding', '18px')};\r\n ${setCssVar('siteWidth', '100%')};\r\n\r\n --siteGutter: calc((1926px - (var(--siteWidth) + (var(--sitePadding) * 2))) / 2);\r\n\r\n margin-left: auto;\r\n margin-right: auto;\r\n max-width: calc(${cssVar('siteWidth')} + (${cssVar('sitePadding')} * 2));\r\n padding-left: ${cssVar('sitePadding')};\r\n padding-right: ${cssVar('sitePadding')};\r\n width: 100%;\r\n\r\n ${({ width }) => {\r\n switch (width) {\r\n case 'default':\r\n return css `\r\n @media ${from(Device.DesktopLarge)} {\r\n ${setCssVar('sitePadding', '18px')};\r\n ${setCssVar('siteWidth', '1312px')};\r\n }\r\n `;\r\n case 'narrow':\r\n return css `\r\n @media ${from(Device.TabletLarge)} {\r\n ${setCssVar('sitePadding', '18px')};\r\n ${setCssVar('siteWidth', '804px')};\r\n }\r\n `;\r\n case 'wide':\r\n return css `\r\n @media ${from(Device.TabletLarge)} {\r\n ${setCssVar('sitePadding', '18px')};\r\n ${setCssVar('siteWidth', '1640px')};\r\n }\r\n `;\r\n }\r\n}}\r\n`;\r\nexport default {\r\n Container,\r\n};\r\n","import { fluid } from '@helpers/fluid';\r\nimport fonts from '@helpers/fonts';\r\nimport styled, { css } from 'styled-components';\r\n/**\r\n * 20px / 28px\r\n */\r\nconst LargeStyles = css `\r\n ${fonts.brown.light};\r\n font-size: ${fluid(18, 24)};\r\n line-height: ${fluid(26, 36)};\r\n letter-spacing: normal;\r\n margin: 0 0 16px;\r\n`;\r\n/**\r\n * 18px / 28px\r\n */\r\nconst RegularStyles = css `\r\n ${fonts.brown.light};\r\n font-size: ${fluid(16, 20)};\r\n line-height: ${fluid(26, 32)};\r\n letter-spacing: normal;\r\n margin: 0 0 16px;\r\n`;\r\n/**\r\n * 16px / 26px\r\n */\r\nconst SmallStyles = css `\r\n ${fonts.brown.light};\r\n font-size: ${fluid(14, 16)};\r\n line-height: ${fluid(20, 22)};\r\n letter-spacing: normal;\r\n margin: 0 0 16px;\r\n`;\r\nconst Paragraph = styled.p `\r\n ${({ size }) => {\r\n switch (size) {\r\n case 'large':\r\n return LargeStyles;\r\n case 'regular':\r\n return RegularStyles;\r\n case 'small':\r\n return SmallStyles;\r\n default:\r\n break;\r\n }\r\n}}\r\n`;\r\nexport default {\r\n Paragraph,\r\n SmallStyles,\r\n RegularStyles,\r\n LargeStyles,\r\n};\r\n","import { Device } from './media';\r\n/**\r\n * Base pixel value for the \"rem\" unit.\r\n */\r\nexport const PIXELS_PER_REM = 16;\r\n/**\r\n * Default pixel value for the min width.\r\n */\r\nexport const DEFAULT_MIN_VALUE = Device.Tablet;\r\n/**\r\n * Default pixel value for the max width.\r\n */\r\nexport const DEFAULT_MAX_VALUE = Device.ActualDesktop;\r\n/**\r\n * Define a fluid value between the min/max values at the min/max widths.\r\n */\r\nexport function fluid(min, max, minWidth = DEFAULT_MIN_VALUE, maxWidth = DEFAULT_MAX_VALUE) {\r\n const minRem = min / PIXELS_PER_REM;\r\n const maxRem = max / PIXELS_PER_REM;\r\n const minWidthRem = minWidth / PIXELS_PER_REM;\r\n const maxWidthRem = maxWidth / PIXELS_PER_REM;\r\n const slope = (maxRem - minRem) / (maxWidthRem - minWidthRem);\r\n const yAxisIntersection = -minWidthRem * slope + minRem;\r\n const clampMin = `${round(minRem)}rem`;\r\n const clampVal = `${round(yAxisIntersection)}rem + ${round(slope * 100)}vw`;\r\n const clampMax = `${round(maxRem)}rem`;\r\n return `clamp(${clampMin}, ${clampVal}, ${clampMax})`;\r\n}\r\n/**\r\n * Define a fluid value between the min/max values at the min/max widths.\r\n */\r\nexport function fluidUnit(min, max, unit = '', minWidth = DEFAULT_MIN_VALUE, maxWidth = DEFAULT_MAX_VALUE) {\r\n const slope = (max - min) / (maxWidth - minWidth);\r\n const yAxisIntersection = -minWidth * slope + min;\r\n const clampMin = `${round(min)}`;\r\n const clampVal = `${round(yAxisIntersection)}${unit} + ${round(slope * 100)}vw`;\r\n const clampMax = `${round(max)}`;\r\n return `clamp(${clampMin}${unit}, ${clampVal}, ${clampMax}${unit})`;\r\n}\r\n/**\r\n * Round to nearest hundredth.\r\n */\r\nfunction round(num) {\r\n return Math.round(num * 100) / 100;\r\n}\r\n","import { css } from 'styled-components';\r\nimport fonts from './fonts';\r\nexport default {\r\n inView: {\r\n threshold: 0.25,\r\n rootMargin: '0px 0px -25% 0px',\r\n earlyRootMargin: '0px 0px -10% 0px',\r\n },\r\n globalThreshold: 0.25,\r\n easeInOutCubic: 'cubic-bezier(0.645, 0.045, 0.355, 1)',\r\n};\r\nexport const slideInUpInitial = css `\r\n > span {\r\n opacity: 0;\r\n transform: translateY(100%);\r\n }\r\n`;\r\nexport function slideInUp(animate, duration, delay, easingFunc) {\r\n return css `\r\n overflow: hidden;\r\n\r\n > span {\r\n display: inline-block;\r\n transition: transform ${duration}ms ${delay}ms ${easingFunc},\r\n opacity ${duration}ms ${delay}ms ${easingFunc};\r\n }\r\n\r\n ${animate\r\n ? css `\r\n > span {\r\n opacity: 1;\r\n transform: translateY(0px);\r\n }\r\n `\r\n : css `\r\n ${slideInUpInitial};\r\n `}\r\n `;\r\n}\r\nexport function fadeInUp(animate, amount, duration, delay, easingFunc) {\r\n return css `\r\n transition: transform ${duration}ms ${delay}ms ${easingFunc},\r\n opacity ${duration}ms ${delay}ms ${easingFunc};\r\n\r\n ${animate\r\n ? css `\r\n opacity: 1;\r\n transform: translateY(0px);\r\n `\r\n : css `\r\n opacity: 0;\r\n transform: translateY(${amount}px);\r\n `}\r\n `;\r\n}\r\nexport function fadeIn(animate, duration, delay, easingFunc) {\r\n return css `\r\n transition: opacity ${duration}ms ${delay}ms ${easingFunc};\r\n\r\n ${animate\r\n ? css `\r\n opacity: 1;\r\n `\r\n : css `\r\n opacity: 0;\r\n `}\r\n `;\r\n}\r\nconst backgroundAnimation = css `\r\n background-size: 200% auto;\r\n animation: multicoloured 5s linear infinite;\r\n\r\n @keyframes multicoloured {\r\n to {\r\n background-position: 200% center;\r\n }\r\n }\r\n`;\r\nconst textClip = css `\r\n background-clip: text;\r\n -webkit-text-fill-color: transparent;\r\n width: fit-content;\r\n`;\r\nexport const multicolouredBackground = css `\r\n background: linear-gradient(\r\n 90deg,\r\n rgba(213, 149, 91, 1) 0%,\r\n rgba(213, 118, 86, 1) 20%,\r\n rgba(100, 202, 185, 1) 40%,\r\n rgba(150, 145, 204, 1) 60%,\r\n rgba(182, 103, 202, 1) 80%,\r\n rgba(174, 90, 188, 1) 100%\r\n );\r\n\r\n ${backgroundAnimation}\r\n`;\r\nexport const multicolouredAnimatedText = css `\r\n ${fonts.brown.light}\r\n ${multicolouredBackground};\r\n ${textClip};\r\n`;\r\nexport const multicolouredBackgroundBright = css `\r\n background: linear-gradient(\r\n 90deg,\r\n #ed4141,\r\n #ef523d,\r\n #f0623a,\r\n #f17138,\r\n #f07e37,\r\n #f08b39,\r\n #ef983c,\r\n #eda441,\r\n #d8a936,\r\n #c2ae30,\r\n #aab231,\r\n #90b439,\r\n #73b645,\r\n #50b754,\r\n #08b766,\r\n #50b754,\r\n #73b645,\r\n #90b439,\r\n #aab231,\r\n #c2ae30,\r\n #d8a936,\r\n #eda441,\r\n #ef983c,\r\n #f08b39,\r\n #f07e37,\r\n #f17138,\r\n #f0623a,\r\n #ef523d,\r\n #ed4141\r\n );\r\n\r\n ${backgroundAnimation}\r\n`;\r\nexport const multicolouredTextBright = css `\r\n ${fonts.brown.light}\r\n ${multicolouredBackgroundBright};\r\n ${textClip};\r\n`;\r\nexport const choirInTheSpireBackground = css `\r\n background: linear-gradient(\r\n 90deg,\r\n #f1563c 9%,\r\n #e65352 10%,\r\n #d34e79 11%,\r\n #c74c92 12%,\r\n #c34b9b 13%,\r\n #00b3c1 40%,\r\n #c34b9b 45%,\r\n #f1563c 50%,\r\n #f1563c 59%,\r\n #e65352 60%,\r\n #d34e79 61%,\r\n #d34e79 62%,\r\n #c74c92 63%,\r\n #00b3c1 90%,\r\n #c34b9b 95%,\r\n #f1563c 100%\r\n );\r\n\r\n ${backgroundAnimation}\r\n`;\r\nexport const choirInTheSpireText = css `\r\n ${choirInTheSpireBackground};\r\n ${textClip};\r\n`;\r\nexport const cubicEaseOut = `cubic-bezier(0.33, 1, 0.68, 1)`;\r\nexport const shouldAnimate = (innerCss) => {\r\n return css `\r\n @media (prefers-reduced-motion: no-preference) {\r\n ${innerCss}\r\n }\r\n `;\r\n};\r\nexport const transition = (properties, duration = 0.35, timing = cubicEaseOut) => {\r\n return shouldAnimate(css `\r\n transition-duration: ${typeof duration === 'string' ? duration : `${duration}s`};\r\n transition-property: ${properties};\r\n transition-timing-function: ${timing};\r\n will-change: ${properties};\r\n `);\r\n};\r\n","import { useInView } from '@hooks/useInView';\r\nimport React from 'react';\r\nimport S from './RichText.styles';\r\nconst RichText = ({ id, content, verticalMargin = '80px' }) => {\r\n const [refContainer, isInView] = useInView({\r\n rootMargin: '0px 0px -8% 0px',\r\n });\r\n return (React.createElement(S.Container, { ref: refContainer, id: id, innerWidth: \"narrow\", isActive: isInView, verticalMargin: verticalMargin },\r\n React.createElement(S.Content, { dangerouslySetInnerHTML: { __html: content } })));\r\n};\r\nexport default RichText;\r\n","import { css } from 'styled-components';\r\nimport { setCssVar } from './cssVar';\r\nimport greyscale from './grey';\r\nconst brand = {\r\n black: '#000000',\r\n blue: '#b7cbeb',\r\n blueGrey: '#eff1f1',\r\n blueTint: '#eef1f8',\r\n grey: greyscale,\r\n orange: '#f96a1d',\r\n white: '#fff',\r\n validation: {\r\n invalid: '#da291c',\r\n valid: '#008c15',\r\n },\r\n};\r\nexport const lightTheme = css `\r\n ${setCssVar('fgColor', brand.black)};\r\n ${setCssVar('bgColor', brand.white)};\r\n ${setCssVar('bgColorAlt', brand.grey.grey90)};\r\n ${setCssVar('bgColorAlt2', brand.grey.grey96)};\r\n ${setCssVar('accentColor', brand.orange)};\r\n ${setCssVar('colorScheme', 'light')};\r\n`;\r\nexport const darkTheme = css `\r\n ${setCssVar('fgColor', brand.white)};\r\n ${setCssVar('bgColor', brand.black)};\r\n ${setCssVar('bgColorAlt', brand.grey.grey10)};\r\n ${setCssVar('bgColorAlt2', brand.black)};\r\n ${setCssVar('accentColor', brand.orange)};\r\n ${setCssVar('colorScheme', 'dark')};\r\n`;\r\nexport const themes = {\r\n dark: darkTheme,\r\n light: lightTheme,\r\n};\r\nexport default brand;\r\n","import { hsl } from 'polished';\r\nconst greyscaleValues = [10, 18, 46, 73, 90, 96];\r\nconst greyscale = greyscaleValues.reduce((previous, current) => ({\r\n ...previous,\r\n [`grey${current}`]: grey(current),\r\n}), {});\r\nfunction grey(value) {\r\n return hsl(0, 0, value / 100);\r\n}\r\nexport { greyscale as default, grey };\r\n","const variables = [\r\n 'fgColor',\r\n 'bgColor',\r\n 'bgColorAlt',\r\n 'bgColorAlt2',\r\n 'accentColor',\r\n 'siteWidth',\r\n 'sitePadding',\r\n 'sectionMargin',\r\n 'colorScheme',\r\n];\r\nfunction cssVar(name) {\r\n return `var(--${name})`;\r\n}\r\nfunction setCssVar(name, value) {\r\n return `--${name}: ${value}`;\r\n}\r\nexport { cssVar, setCssVar };\r\n","import { css } from 'styled-components';\r\nexport default {\r\n brown: {\r\n thin: css `\r\n font-family: 'Brown', sans-serif;\r\n font-style: normal;\r\n font-weight: 100;\r\n `,\r\n thinItalic: css `\r\n font-family: 'Brown', sans-serif;\r\n font-weight: 100;\r\n font-style: italic;\r\n `,\r\n light: css `\r\n font-family: 'Brown', sans-serif;\r\n font-style: normal;\r\n font-weight: 300;\r\n `,\r\n lightItalic: css `\r\n font-family: 'Brown', sans-serif;\r\n font-weight: 300;\r\n font-style: italic;\r\n `,\r\n regular: css `\r\n font-family: 'Brown', sans-serif;\r\n font-style: normal;\r\n font-weight: 400;\r\n `,\r\n regularItalic: css `\r\n font-family: 'Brown', sans-serif;\r\n font-weight: 400;\r\n font-style: italic;\r\n `,\r\n bold: css `\r\n font-family: 'Brown', sans-serif;\r\n font-style: normal;\r\n font-weight: 700;\r\n `,\r\n boldItalic: css `\r\n font-family: 'Brown', sans-serif;\r\n font-weight: 700;\r\n font-style: italic;\r\n `,\r\n },\r\n};\r\n","import { themes } from '@helpers/brand';\r\nimport { setCssVar } from '@helpers/cssVar';\r\nimport { fluid } from '@helpers/fluid';\r\nimport { Device, from } from '@helpers/media';\r\nimport styled, { css } from 'styled-components';\r\nimport SiteWide from '../Global/SiteWide/SiteWide';\r\nconst Container = styled.section `\r\n --sectionMargin: ${fluid(64, 102)};\r\n ${setCssVar('sitePadding', '18px')};\r\n ${setCssVar('siteWidth', '100%')};\r\n\r\n @media ${from(Device.DesktopLarge)} {\r\n ${setCssVar('sitePadding', '18px')};\r\n ${setCssVar('siteWidth', '1312px')};\r\n }\r\n\r\n ${({ flush, themeOption }) => themeOption === 'light' &&\r\n css `\r\n margin-top: ${flush === 'both' || flush === 'top' ? 0 : `calc(var(--sectionMargin) / 2)`};\r\n margin-bottom: ${flush === 'both' || flush === 'bottom' ? 0 : `calc(var(--sectionMargin) / 2)`};\r\n `}\r\n\r\n ${({ flush, themeOption }) => themeOption !== 'light' &&\r\n css `\r\n padding-top: ${flush === 'both' || flush === 'top' ? 0 : `calc(var(--sectionMargin) / 2)`};\r\n padding-bottom: ${flush === 'both' || flush === 'bottom' ? 0 : `calc(var(--sectionMargin) / 2)`};\r\n `}\r\n\r\n ${({ themeOption }) => themeOption &&\r\n css `\r\n ${themes[themeOption]}\r\n `}\r\n`;\r\nconst StyledSiteWide = styled(SiteWide) ``;\r\nexport default {\r\n Container,\r\n SiteWide: StyledSiteWide,\r\n};\r\n"],"sourceRoot":""}