{"version":3,"file":"9837-7f67850af147ec7e6b96.js","mappings":"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","sources":["webpack://royal-college-radiologists/./src/img/branding-graphics/curves-wheel.svg","webpack://royal-college-radiologists/./src/helpers/aspectRatio.ts","webpack://royal-college-radiologists/./src/helpers/global.ts","webpack://royal-college-radiologists/./src/helpers/image.ts","webpack://royal-college-radiologists/./src/hooks/useIntersectionObserver.ts","webpack://royal-college-radiologists/./src/hooks/useInView.ts","webpack://royal-college-radiologists/./src/stories/Components/Buttons/GeneralButton/Button.styles.tsx","webpack://royal-college-radiologists/./src/stories/Components/Buttons/GeneralButton/Button.tsx","webpack://royal-college-radiologists/./src/stories/Components/General/SkipLink/SkipLink.styles.ts","webpack://royal-college-radiologists/./src/stories/Components/General/SkipLink/SkipLink.tsx","webpack://royal-college-radiologists/./src/stories/Components/General/TitleIntroBlock/TitleIntroBlock.styles.ts","webpack://royal-college-radiologists/./src/stories/Components/General/TitleIntroBlock/TitleIntroBlock.tsx","webpack://royal-college-radiologists/./src/stories/Components/Global/SectionWrapper/SectionWrapper.styles.ts","webpack://royal-college-radiologists/./src/hoc/withBaseProps.tsx","webpack://royal-college-radiologists/./src/stories/Components/Global/SectionWrapper/SectionWrapper.tsx","webpack://royal-college-radiologists/./src/stories/Widgets/SignpostCards/SignpostCards.styles.ts","webpack://royal-college-radiologists/./src/img/branding-graphics/card-wave-oncology.svg","webpack://royal-college-radiologists/./src/img/branding-graphics/card-wave-radiology.svg","webpack://royal-college-radiologists/./src/stories/Components/Cards/SignpostCard/SignpostCard.styles.ts","webpack://royal-college-radiologists/./src/stories/Components/Cards/SignpostCard/SignpostCard.tsx","webpack://royal-college-radiologists/./src/stories/Widgets/SignpostCards/SignpostCards.tsx","webpack://royal-college-radiologists/./node_modules/decode-uri-component/index.js","webpack://royal-college-radiologists/./node_modules/filter-obj/index.js","webpack://royal-college-radiologists/./node_modules/query-string/index.js","webpack://royal-college-radiologists/./node_modules/split-on-first/index.js","webpack://royal-college-radiologists/./node_modules/strict-uri-encode/index.js"],"sourcesContent":["var _path, _path2;\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from \"react\";\nfunction SvgCurvesWheel(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 136.3 136.3\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n className: \"curves-wheel_svg__st3\",\n d: \"M115.2 115.2c6.3-6.3 7.2-16 2.7-23.3l-8.6-13.8c-1.8-2.9-2.8-6.3-2.8-9.9s1-7 2.8-9.9l8.6-13.8c4.5-7.3 3.6-17-2.7-23.3-6.3-6.3-16-7.2-23.3-2.7L78.1 27c-2.9 1.8-6.3 2.8-9.9 2.8-3.6 0-7-1-9.9-2.8l-13.8-8.6c-7.3-4.5-17-3.6-23.3 2.7-6.3 6.3-7.2 16-2.7 23.3L27 58.2c1.8 2.9 2.8 6.3 2.8 9.9s-1 7-2.8 9.9l-8.6 13.8c-4.5 7.3-3.6 17 2.7 23.3 6.3 6.3 16 7.2 23.3 2.7l13.8-8.6c2.9-1.8 6.3-2.8 9.9-2.8s7 1 9.9 2.8l13.8 8.6c7.4 4.6 17.1 3.7 23.4-2.6z\",\n fill: \"none\",\n stroke: \"currentColor\",\n strokeWidth: 0.25,\n strokeMiterlimit: 10,\n strokeDasharray: \"0.9992,0.9992\"\n })), _path2 || (_path2 = /*#__PURE__*/React.createElement(\"path\", {\n className: \"curves-wheel_svg__st0\",\n d: \"M68.2 134.6c8.9 0 16.4-6.2 18.4-14.5l3.7-15.8c.8-3.3 2.5-6.4 5-9 2.6-2.6 5.7-4.2 9-5l15.8-3.7c8.3-2 14.5-9.4 14.5-18.4s-6.2-16.4-14.5-18.4l-15.8-3.7c-3.3-.8-6.4-2.5-9-5-2.6-2.6-4.2-5.7-5-9l-3.7-15.8C84.6 8 77.2 1.8 68.2 1.8c-8.9 0-16.4 6.2-18.4 14.5L46.1 32c-.8 3.3-2.5 6.4-5 9-2.6 2.6-5.7 4.2-9 5l-15.8 3.7C8 51.7 1.8 59.1 1.8 68.1 1.8 77 8 84.5 16.3 86.5L32 90.3c3.3.8 6.4 2.5 9 5 2.6 2.6 4.2 5.7 5 9l3.7 15.8c2 8.3 9.5 14.5 18.5 14.5z\",\n fill: \"none\",\n stroke: \"currentColor\",\n strokeWidth: 0.25,\n strokeMiterlimit: 10\n })));\n}\nexport default SvgCurvesWheel;","import { css } from 'styled-components';\r\nimport { fluidUnit } from './fluid';\r\n/**\r\n * Returns the aspect ratio of the given width and height as a percentage.\r\n */\r\nexport function aspectRatio(width, height) {\r\n return (height / width) * 100;\r\n}\r\n/**\r\n * Re-usable styles for image container where the\r\n * image needs to maintain it's aspect ratio\r\n *\r\n * @param width\r\n * @param height\r\n * @returns\r\n */\r\nexport function imageWrapperPreserveRatio(width, height, \r\n/**\r\n * Additonal values to use if the ratio increases over time\r\n */\r\nmaxWidth, maxHeight) {\r\n if (!width && !height) {\r\n return null;\r\n }\r\n let padding;\r\n if (maxWidth && maxHeight) {\r\n padding = `${fluidUnit(aspectRatio(width, height), aspectRatio(maxWidth, maxHeight), '%')}`;\r\n }\r\n else {\r\n padding = `${aspectRatio(width, height)}%`;\r\n }\r\n return css `\r\n position: relative;\r\n height: 0;\r\n width: 100%;\r\n overflow: hidden;\r\n overflow: clip;\r\n padding-bottom: ${padding};\r\n `;\r\n}\r\n/**\r\n * Re-usable styles for an image placed within\r\n * a container maintaining aspect ratio\r\n */\r\nexport const imageCoverContainer = (relative) => css `\r\n display: block;\r\n width: 100%;\r\n height: 100%;\r\n object-fit: cover;\r\n object-position: center;\r\n ${!relative && 'position: absolute; top: 0;left: 0;'}\r\n`;\r\n","import { css } from 'styled-components';\r\nexport default {\r\n navHeight: 107,\r\n navHeightTablet: 80,\r\n navHeightMobile: 59,\r\n};\r\nexport const ButtonReset = css `\r\n border: none;\r\n outline: none;\r\n padding: 0px;\r\n background: none;\r\n border-radius: 0px;\r\n`;\r\n","import queryString from 'query-string';\r\n/**\r\n * Create an image URL for ImageProcessor\r\n * @param image The image model\r\n * @param imageParams The image parameters\r\n * @returns The image URL\r\n */\r\nexport function imageUrl(image, imageParams) {\r\n if (!image) {\r\n return '';\r\n }\r\n const params = {\r\n center: image.focalPoint ? `${image.focalPoint.top},${image.focalPoint.left}` : undefined,\r\n ...imageParams,\r\n };\r\n const paramsString = queryString.stringify(params);\r\n return `${image.src}${paramsString ? `?${queryString.stringify(params)}` : ''}`;\r\n}\r\nexport function getSrcs(image, upper, lower, steps, ratio, params) {\r\n const sizes = getRange(upper, lower, steps);\r\n return sizes.map((size) => `${imageUrl(image, {\r\n width: size,\r\n height: ratio ? size * ratio : undefined,\r\n ...params,\r\n })} ${size}w`);\r\n}\r\nfunction getRange(upper, lower, steps) {\r\n const difference = upper - lower;\r\n const increment = difference / (steps - 1);\r\n return [\r\n lower,\r\n ...Array(steps - 2)\r\n .fill('')\r\n .map((_, index) => Math.ceil(lower + increment * (index + 1))),\r\n upper,\r\n ];\r\n}\r\nexport function getRetinaSrcs(image, width, height) {\r\n const dprs = [1, 1.5, 2, 2.5, 3];\r\n return dprs.map((dpr) => `${imageUrl(image, {\r\n width: width * dpr,\r\n height: height ? height * dpr : undefined,\r\n })} ${dpr}x`);\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 }, [callback, 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 { transition } from '@helpers/animate';\r\nimport brand from '@helpers/brand';\r\nimport { fluid } from '@helpers/fluid';\r\nimport fonts from '@helpers/fonts';\r\nimport { Device, until } from '@helpers/media';\r\nimport styled, { css } from 'styled-components';\r\nconst Text = styled.div ``;\r\nconst PrimaryStyles = css `\r\n border: 0;\r\n background-color: ${brand.secondary.red};\r\n color: ${brand.primary.purple};\r\n border-radius: 1000000px;\r\n overflow: hidden;\r\n\r\n &:before {\r\n ${transition('transform')};\r\n\r\n content: '';\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n background-color: ${brand.primary.offWhite};\r\n border-radius: 1000000px;\r\n transform: translateX(calc(-100% - 2px));\r\n }\r\n\r\n [data-variant='light'] & {\r\n span& {\r\n button.focus-ring &,\r\n button:hover &,\r\n a.focus-ring & {\r\n background-color: ${brand.primary.purple};\r\n color: ${brand.primary.offWhite};\r\n }\r\n\r\n @media (hover: hover) {\r\n a:hover & { \r\n background-color: ${brand.primary.purple};\r\n color: ${brand.primary.offWhite};\r\n }\r\n }\r\n }\r\n\r\n &:not(span) {\r\n &.focus-ring,\r\n &:hover,\r\n &:active {\r\n background-color: ${brand.primary.purple};\r\n color: ${brand.primary.offWhite};\r\n }\r\n\r\n @media (hover: hover) {\r\n &:hover { \r\n background-color: ${brand.primary.purple};\r\n color: ${brand.primary.offWhite};\r\n }\r\n }\r\n }\r\n\r\n &.focus-ring {\r\n outline-color: ${brand.primary.purple};\r\n }\r\n\r\n &:before {\r\n background-color: ${brand.primary.purple};\r\n }\r\n }\r\n\r\n [data-variant='dark'] & {\r\n span& {\r\n button.focus-ring &,\r\n button:hover &,\r\n a.focus-ring & {\r\n background-color: ${brand.primary.offWhite};\r\n }\r\n\r\n @media (hover: hover) {\r\n a:hover & { \r\n background-color: ${brand.primary.offWhite};\r\n }\r\n }\r\n }\r\n\r\n &:not(span) {\r\n &.focus-ring,\r\n &:active {\r\n background-color: ${brand.primary.offWhite};\r\n }\r\n\r\n @media (hover: hover) {\r\n &:hover { \r\n background-color: ${brand.primary.offWhite};\r\n }\r\n }\r\n }\r\n\r\n &.focus-ring {\r\n outline-color: ${brand.primary.offWhite};\r\n }\r\n\r\n &:before {\r\n background-color: ${brand.primary.offWhite};\r\n }\r\n }\r\n\r\n @media (hover: hover) {\r\n &:hover { \r\n background-color: ${brand.primary.offWhite};\r\n\r\n &:before {\r\n transform: translateX(0);\r\n }\r\n }\r\n }\r\n\r\n &.focus-ring,\r\n &:active,\r\n &[data-toggle-on='true'] {\r\n background-color: ${brand.primary.offWhite};\r\n\r\n &:before {\r\n transform: translateX(0);\r\n }\r\n }\r\n`;\r\nconst OutlineStyles = css `\r\n background-color: transparent;\r\n border-radius: 1000000px;\r\n overflow: hidden;\r\n\r\n &:before {\r\n ${transition('transform')};\r\n\r\n content: '';\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n background-color: ${brand.primary.offWhite};\r\n border-radius: 1000000px;\r\n transform: translateX(calc(-100% - 2px));\r\n }\r\n\r\n [data-variant='light'] & {\r\n color: ${brand.primary.purple};\r\n border: 1px solid ${brand.primary.purple};\r\n\r\n span& {\r\n button.focus-ring &,\r\n button:hover &,\r\n a.focus-ring &,\r\n a[data-toggle-on='true'] & {\r\n border-color: ${brand.primary.purple};\r\n background-color: ${brand.primary.purple};\r\n color: ${brand.primary.offWhite};\r\n }\r\n\r\n @media (hover: hover) {\r\n a:hover & { \r\n border-color: ${brand.primary.purple};\r\n background-color: ${brand.primary.purple};\r\n color: ${brand.primary.offWhite};\r\n }\r\n }\r\n }\r\n\r\n &:not(span) {\r\n &.focus-ring,\r\n &:active,\r\n &[data-toggle-on='true'] {\r\n border-color: ${brand.primary.purple};\r\n background-color: ${brand.primary.purple};\r\n color: ${brand.primary.offWhite};\r\n }\r\n\r\n @media (hover: hover) {\r\n &:hover { \r\n border-color: ${brand.primary.purple};\r\n background-color: ${brand.primary.purple};\r\n color: ${brand.primary.offWhite};\r\n }\r\n }\r\n }\r\n\r\n &.focus-ring {\r\n outline-color: ${brand.primary.purple};\r\n }\r\n\r\n &:before {\r\n background-color: ${brand.primary.purple};\r\n }\r\n }\r\n\r\n [data-variant='dark'] & {\r\n color: ${brand.primary.offWhite};\r\n border: 1px solid ${brand.primary.offWhite};\r\n\r\n span& {\r\n button.focus-ring &,\r\n \r\n a.focus-ring &,\r\n a[data-toggle-on='true'] & {\r\n background-color: ${brand.primary.offWhite};\r\n color: ${brand.primary.purple};\r\n }\r\n\r\n @media (hover: hover) {\r\n button:hover &,\r\n a:hover & { \r\n background-color: ${brand.primary.offWhite};\r\n color: ${brand.primary.purple};\r\n }\r\n }\r\n }\r\n\r\n &:not(span) {\r\n &.focus-ring,\r\n &:hover,\r\n &:active,\r\n &[data-toggle-on='true'] {\r\n background-color: ${brand.primary.offWhite};\r\n color: ${brand.primary.purple};\r\n }\r\n\r\n @media (hover: hover) {\r\n &:hover { \r\n background-color: ${brand.primary.offWhite};\r\n color: ${brand.primary.purple};\r\n }\r\n }\r\n }\r\n\r\n &.focus-ring {\r\n outline-color: ${brand.primary.offWhite};\r\n }\r\n\r\n &:before {\r\n background-color: ${brand.primary.offWhite};\r\n }\r\n }\r\n\r\n &.focus-ring {\r\n outline: auto;\r\n outline-offset: 3px;\r\n outline-style: solid;\r\n outline-width: 2px;\r\n }\r\n\r\n span& {\r\n button.focus-ring &, \r\n a.focus-ring &,\r\n a[data-toggle-on='true'] & {\r\n &::before {\r\n transform: translateX(0);\r\n }\r\n }\r\n\r\n @media (hover: hover) {\r\n button:hover &,\r\n a:hover & { \r\n &::before {\r\n transform: translateX(0);\r\n }\r\n }\r\n }\r\n }\r\n\r\n &:not(span) {\r\n &.focus-ring,\r\n &:active,\r\n &[data-toggle-on='true'] {\r\n &::before {\r\n transform: translateX(0);\r\n }\r\n }\r\n\r\n @media (hover: hover) {\r\n &:hover { \r\n &::before {\r\n transform: translateX(0);\r\n }\r\n }\r\n }\r\n }\r\n`;\r\nconst OutlineAltStyles = css `\r\n background-color: transparent;\r\n border-radius: 1000000px;\r\n overflow: hidden;\r\n\r\n &:before {\r\n ${transition('transform')};\r\n\r\n content: '';\r\n position: absolute;\r\n top: 0;\r\n left: 0;\r\n width: 100%;\r\n height: 100%;\r\n background-color: ${brand.secondary.red};\r\n border-radius: 1000000px;\r\n transform: translateX(calc(-100% - 2px));\r\n }\r\n\r\n [data-variant='light'] & {\r\n color: ${brand.primary.purple};\r\n border: 1px solid ${brand.primary.purple};\r\n\r\n &.focus-ring {\r\n outline-color: ${brand.primary.purple};\r\n }\r\n }\r\n\r\n [data-variant='dark'] & {\r\n color: ${brand.primary.offWhite};\r\n border: 1px solid ${brand.primary.offWhite};\r\n\r\n span& {\r\n button.focus-ring &, \r\n a.focus-ring &,\r\n a[data-toggle-on='true'] & {\r\n color: ${brand.primary.purple};\r\n }\r\n\r\n @media (hover: hover) {\r\n button:hover &,\r\n a:hover & { \r\n color: ${brand.primary.purple};\r\n }\r\n }\r\n }\r\n\r\n &:not(span) {\r\n &.focus-ring,\r\n &:active,\r\n &[data-toggle-on='true'] {\r\n color: ${brand.primary.purple};\r\n }\r\n\r\n @media (hover: hover) {\r\n &:hover { \r\n color: ${brand.primary.purple};\r\n }\r\n }\r\n }\r\n\r\n &.focus-ring {\r\n outline-color: ${brand.primary.offWhite};\r\n }\r\n\r\n &:before {\r\n background-color: ${brand.secondary.red};\r\n }\r\n }\r\n\r\n &.focus-ring {\r\n outline: auto;\r\n outline-offset: 3px;\r\n outline-style: solid;\r\n outline-width: 2px;\r\n }\r\n\r\n span& {\r\n button.focus-ring &, \r\n a.focus-ring &,\r\n a[data-toggle-on='true'] & {\r\n background-color: ${brand.secondary.red};\r\n border-color: ${brand.secondary.red};\r\n\r\n &::before {\r\n transform: translateX(0);\r\n }\r\n }\r\n\r\n @media (hover: hover) {\r\n button:hover &,\r\n a:hover & { \r\n background-color: ${brand.secondary.red};\r\n border-color: ${brand.secondary.red};\r\n\r\n &::before {\r\n transform: translateX(0);\r\n }\r\n }\r\n }\r\n }\r\n\r\n &:not(span) {\r\n &.focus-ring,\r\n &:active,\r\n &[data-toggle-on='true'] {\r\n background-color: ${brand.secondary.red};\r\n border-color: ${brand.secondary.red};\r\n\r\n &::before {\r\n transform: translateX(0);\r\n }\r\n }\r\n\r\n @media (hover: hover) {\r\n &:hover { \r\n background-color: ${brand.secondary.red};\r\n border-color: ${brand.secondary.red};\r\n\r\n &::before {\r\n transform: translateX(0);\r\n }\r\n }\r\n }\r\n }\r\n`;\r\nconst Wave = styled.div `\r\n ${transition('max-width')};\r\n\r\n overflow: hidden;\r\n max-width: 0;\r\n color: ${brand.secondary.red};\r\n\r\n svg {\r\n display: block;\r\n margin-right: 5px;\r\n height: 30px;\r\n }\r\n`;\r\nconst Arrow = styled.div `\r\n ${transition('transform')};\r\n\r\n margin: 0 0 0 5px;\r\n\r\n svg {\r\n display: block;\r\n height: 12px;\r\n }\r\n`;\r\nconst TextOnlyStyles = css `\r\n display: inline-flex;\r\n align-items: center;\r\n border: 1px solid transparent;\r\n background: none;\r\n color: ${brand.primary.purple};\r\n padding: 0;\r\n\r\n [data-variant='dark'] & {\r\n color: ${brand.primary.offWhite};\r\n }\r\n\r\n ${Text} {\r\n margin-bottom: 2px;\r\n }\r\n\r\n &.focus-ring {\r\n outline: auto;\r\n outline-offset: 3px;\r\n outline-style: solid;\r\n outline-width: 2px;\r\n }\r\n\r\n span& {\r\n button.focus-ring &,\r\n a.focus-ring & {\r\n ${Wave} {\r\n max-width: 50px;\r\n }\r\n\r\n ${Arrow} {\r\n transform: translateX(15%);\r\n }\r\n }\r\n\r\n @media (hover: hover) {\r\n button:hover &,\r\n a:hover & { \r\n ${Wave} {\r\n max-width: 50px;\r\n }\r\n\r\n ${Arrow} {\r\n transform: translateX(15%);\r\n }\r\n }\r\n }\r\n }\r\n\r\n &:not(span) {\r\n &:hover,\r\n &:active,\r\n &.focus-ring {\r\n ${Wave} {\r\n max-width: 50px;\r\n }\r\n\r\n ${Arrow} {\r\n transform: translateX(15%);\r\n }\r\n }\r\n\r\n @media (hover: hover) {\r\n &:hover { \r\n ${Wave} {\r\n max-width: 50px;\r\n }\r\n\r\n ${Arrow} {\r\n transform: translateX(15%);\r\n }\r\n }\r\n }\r\n }\r\n`;\r\nconst Icon = styled.div `\r\n display: inline-flex;\r\n align-items: center;\r\n margin: 0 0 0 8px;\r\n\r\n svg {\r\n max-height: 24px;\r\n width: 20px;\r\n }\r\n\r\n &[data-position='left'] {\r\n order: -1;\r\n margin: 0 8px 0 0;\r\n }\r\n`;\r\nconst Button = styled.button `\r\n ${transition('color, background-color, border-color')};\r\n\r\n display: inline-flex;\r\n padding: 10px ${fluid(20, 25)} 12px;\r\n height: ${fluid(46, 48)};\r\n user-select: none;\r\n text-decoration: none;\r\n position: relative;\r\n align-items: center;\r\n\r\n ${Text} {\r\n ${fonts.graphikCompact.medium};\r\n\r\n font-size: ${fluid(18, 20)};\r\n line-height: ${fluid(24, 26)};\r\n display: inline-block;\r\n vertical-align: middle;\r\n position: relative;\r\n z-index: 2;\r\n }\r\n\r\n &:disabled {\r\n opacity: 0.66;\r\n pointer-events: none;\r\n\r\n &:hover {\r\n opacity: 0.66;\r\n }\r\n }\r\n\r\n /* Mobile click styles - button should mimic press */\r\n @media ${until(Device.TabletLarge)} {\r\n ${transition('color, background-color, border-color, transform')};\r\n\r\n span& {\r\n button:active &,\r\n a:active & {\r\n transform: translateY(1.5px);\r\n }\r\n }\r\n\r\n &:not(span) {\r\n &:active {\r\n transform: translateY(1.5px);\r\n }\r\n }\r\n }\r\n\r\n ${({ branding }) => {\r\n switch (branding) {\r\n case 'textOnly':\r\n return TextOnlyStyles;\r\n case 'solid':\r\n return PrimaryStyles;\r\n case 'outline':\r\n return OutlineStyles;\r\n case 'outline-alt':\r\n return OutlineAltStyles;\r\n default:\r\n break;\r\n }\r\n}}\r\n`;\r\nconst ArrowButton = styled.button `\r\n display: flex;\r\n align-items: center;\r\n justify-content: flex-start;\r\n background: transparent;\r\n border: none;\r\n width: ${fluid(58, 60)};\r\n height: ${fluid(48, 50)};\r\n padding: 0;\r\n color: var(--fgColour, ${brand.primary.purple});\r\n\r\n &:first-child {\r\n justify-content: flex-end;\r\n\r\n svg {\r\n transform: scaleX(-1);\r\n }\r\n }\r\n\r\n &:disabled {\r\n opacity: 0.66;\r\n pointer-events: none;\r\n\r\n &:hover {\r\n opacity: 0.66;\r\n }\r\n }\r\n\r\n svg {\r\n display: block;\r\n height: ${fluid(12, 15)};\r\n }\r\n\r\n /* Mobile click styles - button should mimic press */\r\n @media ${until(Device.TabletLarge)} {\r\n ${transition('transform', 0.15)};\r\n\r\n &:active {\r\n transform: translateY(1.5px);\r\n }\r\n }\r\n`;\r\nconst ButtonInner = styled.div `\r\n ${transition('max-width')};\r\n\r\n border: 2px solid var(--fgColour, ${brand.primary.purple});\r\n border-radius: 5000000px;\r\n max-width: ${fluid(46, 48)};\r\n width: ${fluid(56, 58)};\r\n height: ${fluid(46, 48)};\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n\r\n ${ArrowButton}.focus-ring & {\r\n outline: auto;\r\n outline-offset: 3px;\r\n outline-style: solid;\r\n outline-width: 2px;\r\n }\r\n\r\n ${ArrowButton}.focus-ring & {\r\n max-width: ${fluid(56, 58)};\r\n }\r\n\r\n @media (hover: hover) {\r\n ${ArrowButton}:hover & {\r\n max-width: ${fluid(56, 58)};\r\n }\r\n }\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n max-width: ${fluid(56, 58)};\r\n }\r\n`;\r\nconst ButtonIcon = styled.div `\r\n ${transition('transform')};\r\n position: relative;\r\n line-height: 0;\r\n transform: translateX(0);\r\n\r\n ${ArrowButton}:last-child.focus-ring &{\r\n transform: translateX(7px);\r\n }\r\n\r\n @media (hover: hover) {\r\n ${ArrowButton}:last-child:hover & {\r\n transform: translateX(7px);\r\n }\r\n }\r\n\r\n ${ArrowButton}.focus-ring & {\r\n transform: translateX(-7px);\r\n }\r\n\r\n @media (hover: hover) {\r\n ${ArrowButton}:hover & {\r\n transform: translateX(-7px);\r\n }\r\n }\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n transform: translateX(-7px);\r\n\r\n ${ArrowButton}:last-child & {\r\n transform: translateX(7px);\r\n }\r\n }\r\n`;\r\nconst HoverLine = styled.div `\r\n ${transition('transform')};\r\n\r\n position: absolute;\r\n left: 0;\r\n top: 50%;\r\n width: 22px;\r\n height: 3px;\r\n transform-origin: 0;\r\n transform: translate(2px, -50%) scaleX(0);\r\n background-color: var(--fgColour, ${brand.primary.purple});\r\n\r\n ${ArrowButton}:last-child & {\r\n transform-origin: 100%;\r\n left: auto;\r\n right: 0;\r\n transform: translate(-2px, -50%) scaleX(0);\r\n }\r\n\r\n ${ArrowButton}.focus-ring & {\r\n transform: translate(2px, -50%) scaleX(1);\r\n }\r\n\r\n @media (hover: hover) {\r\n ${ArrowButton}:hover & {\r\n transform: translate(2px, -50%) scaleX(1);\r\n }\r\n }\r\n\r\n ${ArrowButton}:last-child.focus-ring & {\r\n transform: translate(-2px, -50%) scaleX(1);\r\n }\r\n\r\n @media (hover: hover) {\r\n ${ArrowButton}:last-child:hover & {\r\n transform: translate(-2px, -50%) scaleX(1);\r\n }\r\n }\r\n\r\n @media ${until(Device.TabletLarge)} {\r\n transform: translate(2px, -50%) scaleX(1);\r\n\r\n ${ArrowButton}:last-child & {\r\n transform: translate(-2px, -50%) scaleX(1);\r\n }\r\n }\r\n`;\r\nexport const ButtonStyles = {\r\n Arrow,\r\n ArrowButton,\r\n Button,\r\n ButtonIcon,\r\n ButtonInner,\r\n HoverLine,\r\n Icon,\r\n Text,\r\n Wave,\r\n};\r\n","import { getSvgFromSystem, SystemIcon } from '@helpers/systemIcons';\r\nimport React from 'react';\r\nimport { FocusRing } from 'react-aria';\r\nimport { ButtonStyles } from './Button.styles';\r\nconst Button = ({ branding, className, disabled, title, toggleOn = false, type = 'button', onClick, icon, iconPosition = 'right', ...otherProps }) => {\r\n return (React.createElement(FocusRing, { focusRingClass: \"focus-ring\" },\r\n React.createElement(ButtonStyles.Button, { className: className, branding: branding, disabled: disabled, type: type, onClick: onClick, \"data-toggle-on\": toggleOn, \"data-branding\": branding, ...otherProps },\r\n branding === 'textOnly' && (React.createElement(ButtonStyles.Wave, null, getSvgFromSystem(SystemIcon.Wave1))),\r\n React.createElement(ButtonStyles.Text, null, title),\r\n icon ? (React.createElement(ButtonStyles.Icon, { \"data-position\": iconPosition }, icon)) : branding === 'textOnly' ? (React.createElement(ButtonStyles.Arrow, null, getSvgFromSystem(SystemIcon.ArrowRight))) : null)));\r\n};\r\nconst FakeButton = ({ branding, className, title, icon, iconPosition = 'right', ...otherProps }) => {\r\n return (React.createElement(ButtonStyles.Button, { className: className, branding: branding, as: \"span\", ...otherProps },\r\n branding === 'textOnly' && (React.createElement(ButtonStyles.Wave, null, getSvgFromSystem(SystemIcon.Wave1))),\r\n React.createElement(ButtonStyles.Text, null, title),\r\n icon ? (React.createElement(ButtonStyles.Icon, { \"data-position\": iconPosition }, icon)) : branding === 'textOnly' ? (React.createElement(ButtonStyles.Arrow, null, getSvgFromSystem(SystemIcon.ArrowRight))) : null));\r\n};\r\nconst LinkButton = ({ branding, className, href, target = '_self', title, icon, iconPosition = 'right', ...otherProps }) => {\r\n return (React.createElement(FocusRing, { focusRingClass: \"focus-ring\" },\r\n React.createElement(ButtonStyles.Button, { className: className, as: \"a\", branding: branding, href: href, target: target, ...otherProps },\r\n branding === 'textOnly' && (React.createElement(ButtonStyles.Wave, null, getSvgFromSystem(SystemIcon.Wave1))),\r\n React.createElement(ButtonStyles.Text, null, title),\r\n icon ? (React.createElement(ButtonStyles.Icon, { \"data-position\": iconPosition }, icon)) : branding === 'textOnly' ? (React.createElement(ButtonStyles.Arrow, null, getSvgFromSystem(SystemIcon.ArrowRight))) : null)));\r\n};\r\nconst ArrowButton = ({ labelText, disabled, onClick, ...otherProps }) => {\r\n return (React.createElement(FocusRing, { focusRingClass: \"focus-ring\" },\r\n React.createElement(ButtonStyles.ArrowButton, { \"aria-label\": labelText, disabled: disabled, onClick: onClick, ...otherProps },\r\n React.createElement(ButtonStyles.ButtonInner, null,\r\n React.createElement(ButtonStyles.ButtonIcon, null,\r\n getSvgFromSystem(SystemIcon.Chevron),\r\n React.createElement(ButtonStyles.HoverLine, null))))));\r\n};\r\nexport { Button as default, LinkButton, ArrowButton, FakeButton };\r\n","import { transition } from '@helpers/animate';\r\nimport brand from '@helpers/brand';\r\nimport { ButtonReset } from '@helpers/global';\r\nimport { siteWide } from '@helpers/grid';\r\nimport { Layers } from '@helpers/layers';\r\nimport { paragraphRegular } from '@helpers/typography';\r\nimport styled from 'styled-components';\r\nconst Container = styled.div `\r\n ${siteWide};\r\n\r\n position: relative;\r\n z-index: ${Layers.NavigationTray + 1};\r\n height: 0;\r\n`;\r\nconst Button = styled.button `\r\n ${ButtonReset};\r\n ${transition('opacity, transform')};\r\n ${paragraphRegular};\r\n\r\n position: absolute;\r\n left: 0;\r\n top: 0;\r\n margin: 0;\r\n opacity: 0;\r\n transform: translate(3px, -100%);\r\n background-color: var(--fgColour, ${brand.primary.offWhite});\r\n color: var(--bgColour, ${brand.primary.purple});\r\n padding: 8px 12px;\r\n\r\n &.focus-ring {\r\n outline: auto;\r\n outline-offset: 3px;\r\n outline-style: solid;\r\n outline-width: 2px;\r\n outline-color: var(--fgColour, ${brand.primary.offWhite});\r\n opacity: 1;\r\n transform: translate(3px, 3px);\r\n }\r\n`;\r\nconst SkipLinkStyles = {\r\n Container,\r\n Button,\r\n};\r\nexport default SkipLinkStyles;\r\n","import { scrollIntoView } from '@helpers/animate';\r\nimport * as React from 'react';\r\nimport { FocusRing } from 'react-aria';\r\nimport S from './SkipLink.styles';\r\nconst SkipLink = ({ type = 'inline' }) => {\r\n const ref = React.useRef(null);\r\n return (React.createElement(S.Container, null,\r\n React.createElement(FocusRing, { focusRingClass: \"focus-ring\" },\r\n React.createElement(S.Button, { ref: ref, onClick: () => {\r\n if (type === 'header') {\r\n skipToMain();\r\n }\r\n else {\r\n skipSection();\r\n }\r\n } }, type === 'header' ? React.createElement(React.Fragment, null, \"Skip to Main Content\") : React.createElement(React.Fragment, null, \"Skip to Next Section\")))));\r\n function skipToMain() {\r\n const targetEl = document.getElementById('main');\r\n if (!targetEl) {\r\n return;\r\n }\r\n scrollIntoView(targetEl);\r\n focusNext(targetEl);\r\n }\r\n function skipSection() {\r\n let wrapperEl = ref.current?.closest('div[class^=react_Components_]');\r\n // Should only ever occur in storybook\r\n if (!wrapperEl) {\r\n wrapperEl = ref.current?.closest('section');\r\n }\r\n let targetEl = wrapperEl?.nextElementSibling;\r\n // Last element in main wrapper, next element is footer\r\n if (!targetEl) {\r\n targetEl = wrapperEl?.parentElement?.nextElementSibling;\r\n }\r\n if (!targetEl) {\r\n return;\r\n }\r\n scrollIntoView(targetEl);\r\n focusNext(targetEl);\r\n }\r\n function focusNext(el) {\r\n const focusable = el.querySelectorAll('button');\r\n focusable[0]?.focus();\r\n }\r\n};\r\nexport default SkipLink;\r\n","import { transition } from '@helpers/animate';\r\nimport brand from '@helpers/brand';\r\nimport { fluid } from '@helpers/fluid';\r\nimport { baseGrid } from '@helpers/grid';\r\nimport { Device, from } from '@helpers/media';\r\nimport { contentStyles, h2 } from '@helpers/typography';\r\nimport { ButtonStyles } from '@stories/Components/Buttons/GeneralButton/Button.styles';\r\nimport styled, { css } from 'styled-components';\r\nconst Container = styled.div `\r\n ${baseGrid};\r\n\r\n row-gap: ${fluid(14, 20)};\r\n grid-template-rows: auto 1fr;\r\n margin: 0 0 ${fluid(32, 48)};\r\n overflow: hidden;\r\n`;\r\nconst Title = styled.h2 `\r\n ${h2};\r\n\r\n grid-column: 1 / span 12;\r\n line-height: 1;\r\n letter-spacing: 0.025em;\r\n margin: 0;\r\n\r\n [data-title-colour='true'] & {\r\n color: ${brand.secondary.red};\r\n }\r\n\r\n span[data-type='word'] {\r\n overflow: hidden;\r\n height: ${fluid(40, 70)};\r\n }\r\n\r\n span[data-type='highlight'] {\r\n color: ${brand.secondary.red};\r\n }\r\n\r\n span[data-type='letter'] {\r\n ${transition('transform, opacity', 0.5, 'cubic-bezier(.02,.11,.3,1.22)')}\r\n\r\n opacity: 0;\r\n transform: translateY(100%);\r\n transition-delay: calc(var(--index, 1) * 45ms);\r\n\r\n ${Container}[data-animate='true'] & {\r\n opacity: 1;\r\n transform: none;\r\n }\r\n }\r\n\r\n @media ${from(Device.Tablet)} {\r\n grid-column: 1 / span 6;\r\n\r\n ${Container}[data-has-content='false'][data-has-cta='false'] & {\r\n grid-column: 1 / span 12;\r\n }\r\n\r\n ${Container}[data-has-content='true'][data-has-cta='true'] & {\r\n grid-row: 1 / span 2;\r\n }\r\n }\r\n\r\n @media ${from(Device.DesktopSmall)} {\r\n grid-column: 2 / span 5;\r\n\r\n ${Container}[data-has-content='false'][data-has-cta='false'] & {\r\n grid-column: 2 / span 10;\r\n }\r\n }\r\n\r\n @media ${from(Device.Desktop)} {\r\n grid-column: 3 / span 4;\r\n\r\n ${Container}[data-has-content='false'][data-has-cta='false'] & {\r\n grid-column: 3 / span 8;\r\n }\r\n }\r\n`;\r\nconst rightSpans = css `\r\n grid-column: 1 / span 12;\r\n\r\n @media ${from(Device.Tablet)} {\r\n grid-column: 7 / span 6;\r\n }\r\n\r\n @media ${from(Device.DesktopSmall)} {\r\n grid-column: 7 / span 5;\r\n }\r\n\r\n @media ${from(Device.Desktop)} {\r\n grid-column: 7 / span 4;\r\n }\r\n`;\r\nconst Content = styled.div `\r\n ${transition('transform, opacity', 1)};\r\n\r\n ${contentStyles};\r\n ${rightSpans};\r\n\r\n opacity: 0;\r\n transform: translateX(66%);\r\n\r\n ${Container}[data-animate='true'] & {\r\n opacity: 1;\r\n transform: none;\r\n }\r\n`;\r\nconst ButtonWrapper = styled.div `\r\n ${transition('transform, opacity', 0.8)};\r\n ${rightSpans};\r\n\r\n margin: -6px 0 0;\r\n opacity: 0;\r\n transform: translatey(100%);\r\n\r\n ${Container}[data-animate='true'] & {\r\n opacity: 1;\r\n transform: none;\r\n }\r\n\r\n ${ButtonStyles.Text} {\r\n font-size: ${fluid(18, 24)};\r\n line-height: ${fluid(24, 32)};\r\n }\r\n\r\n @media ${from(Device.Tablet)} {\r\n display: flex;\r\n\r\n ${Container}[data-has-content='false'] & {\r\n margin: 0;\r\n\r\n ${ButtonStyles.Button} {\r\n ${transition('transform', 0.3)};\r\n\r\n margin-left: auto;\r\n\r\n /* Compensate for wave appearing */\r\n &.focus-ring,\r\n &:hover {\r\n transform: translateX(44px);\r\n }\r\n }\r\n }\r\n }\r\n`;\r\nconst TitleIntroBlockStyles = {\r\n Container,\r\n Title,\r\n Content,\r\n ButtonWrapper,\r\n};\r\nexport default TitleIntroBlockStyles;\r\n","import { rootMargin } from '@helpers/animate';\r\nimport { useInView } from '@hooks/useInView';\r\nimport { LinkButton } from '@stories/Components/Buttons/GeneralButton/Button';\r\nimport * as React from 'react';\r\nimport S from './TitleIntroBlock.styles';\r\nconst TitleIntroBlock = (props) => {\r\n const [elementRef, inView] = useInView({ rootMargin }, false);\r\n let index = 0;\r\n return (React.createElement(S.Container, { ref: elementRef, \"data-animate\": inView, \"data-has-title\": !!props.title, \"data-has-content\": !!props.intro, \"data-has-cta\": !!props.introCta, \"data-title-colour\": props.altTitleColour },\r\n splitTitleIntoWords(props.title),\r\n props.intro && React.createElement(S.Content, { dangerouslySetInnerHTML: { __html: props.intro } }),\r\n props.introCta && (React.createElement(S.ButtonWrapper, null,\r\n React.createElement(LinkButton, { branding: 'textOnly', href: props.introCta.url, target: props.introCta.target, title: props.introCta.text ?? `View ${props.title}` })))));\r\n /**\r\n * Wraps word groups based on position of asterisks for highlighting\r\n */\r\n function splitTitleIntoWords(title) {\r\n if (!title) {\r\n return null;\r\n }\r\n const sections = title.split('*');\r\n return (React.createElement(S.Title, null, sections.map((section, i) => {\r\n if (i % 2 !== 0) {\r\n return (React.createElement(\"span\", { key: `title-word-section-${section}-${i}`, \"data-type\": \"highlight\" }, wrapTitleWords(section)));\r\n }\r\n else {\r\n return wrapTitleWords(section);\r\n }\r\n })));\r\n }\r\n /**\r\n * Wraps each letter in a span, with a span around each word\r\n */\r\n function wrapTitleWords(title) {\r\n if (!title || title === '') {\r\n return null;\r\n }\r\n const words = title.split(' ');\r\n return (React.createElement(React.Fragment, null, words.map((word, i) => {\r\n const letters = word.split('');\r\n return (React.createElement(React.Fragment, { key: `title-word-${word}-${i}` },\r\n React.createElement(\"span\", { \"data-type\": \"word\" }, letters.map((letter) => {\r\n index = index + 1;\r\n return (React.createElement(\"span\", { key: `title-word-${word}-${i}-${index}`, \"data-type\": \"letter\", style: { '--index': index } }, letter));\r\n })),\r\n i === words.length - 1 ? '' : ' '));\r\n })));\r\n }\r\n};\r\nexport default TitleIntroBlock;\r\n","import brand from '@helpers/brand';\r\nimport { fluid } from '@helpers/fluid';\r\nimport { ButtonReset } from '@helpers/global';\r\nimport { siteWide } from '@helpers/grid';\r\nimport { Device, from } from '@helpers/media';\r\nimport styled from 'styled-components';\r\nconst Container = styled.section `\r\n --sectionSpacingTop: ${fluid(32, 80)};\r\n --sectionSpacingBottom: ${fluid(32, 80)};\r\n --bgColour: transparent;\r\n --bgColourTint: ${brand.tint.offWhite};\r\n --fgColour: ${brand.primary.purple};\r\n --fgColourTint: ${brand.tint.purple};\r\n\r\n position: relative;\r\n scroll-margin: var(--stickyHeaderHeight) 0 0;\r\n background-color: var(--bgColour);\r\n color: var(--fgColour);\r\n\r\n &[data-variant='light'] {\r\n --bgColour: ${brand.primary.offWhite};\r\n --bgColourTint: ${brand.tint.offWhite};\r\n --fgColour: ${brand.primary.purple};\r\n --fgColourTint: ${brand.tint.purple};\r\n }\r\n\r\n &[data-variant='dark'] {\r\n --bgColour: ${brand.primary.purple};\r\n --bgColourTint: ${brand.tint.purple};\r\n --fgColour: ${brand.primary.offWhite};\r\n --fgColourTint: ${brand.tint.offWhite};\r\n }\r\n\r\n &[data-allow-scroll-margin='true'],\r\n &[data-has-skip='true'] {\r\n overflow: clip;\r\n overflow: hidden;\r\n }\r\n\r\n &[data-flush='top'] {\r\n --sectionSpacingTop: 0;\r\n\r\n @media ${from(Device.Tablet)} {\r\n --sectionSpacingTop: 0;\r\n }\r\n }\r\n\r\n &[data-flush='bottom'] {\r\n --sectionSpacingBottom: 0;\r\n\r\n @media ${from(Device.Tablet)} {\r\n --sectionSpacingBottom: 0;\r\n }\r\n }\r\n\r\n &[data-flush='both'] {\r\n --sectionSpacingTop: 0;\r\n --sectionSpacingBottom: 0;\r\n\r\n @media ${from(Device.Tablet)} {\r\n --sectionSpacingTop: 0;\r\n --sectionSpacingBottom: 0;\r\n }\r\n }\r\n\r\n /* Negative margin bottom to force overlap */\r\n &[data-overlap-bottom='true'] {\r\n margin-bottom: calc(var(--sectionSpacingBottom) * -1);\r\n }\r\n\r\n .equally-ai___high-saturation & {\r\n filter: saturate(200%);\r\n }\r\n\r\n .equally-ai___reverse-contrast & {\r\n filter: invert(100%);\r\n }\r\n\r\n .equally-ai___monochrome-contrast & {\r\n filter: grayscale(100%);\r\n }\r\n\r\n .equally-ai___reverse-contrast.equally-ai___monochrome-contrast & {\r\n filter: grayscale(100%) invert(100%);\r\n }\r\n`;\r\nconst Inner = styled.div `\r\n color: var(--fgColor);\r\n padding-top: var(--sectionSpacingTop);\r\n padding-bottom: var(--sectionSpacingBottom);\r\n\r\n /* Don't apply background color for white backgrounds */\r\n ${Container} & {\r\n background: var(--bgColor);\r\n }\r\n`;\r\nconst SiteWide = styled.div `\r\n ${siteWide}\r\n`;\r\nconst FocusAnchor = styled.button `\r\n ${ButtonReset};\r\n\r\n height: 0;\r\n width: 0;\r\n`;\r\nconst SectionWrapperStyles = {\r\n Container,\r\n Inner,\r\n SiteWide,\r\n FocusAnchor,\r\n};\r\nexport default SectionWrapperStyles;\r\n","import * as React from 'react';\r\nconst BasePropsContext = React.createContext({});\r\nexport function withBaseProps(WrappedComponent) {\r\n const displayName = WrappedComponent.displayName || WrappedComponent.name || 'Component';\r\n const ComponentWithBaseProps = (props) => {\r\n return (React.createElement(BasePropsContext.Provider, { value: props },\r\n React.createElement(WrappedComponent, { ...props })));\r\n };\r\n ComponentWithBaseProps.displayName = `withBaseProps(${displayName})`;\r\n return ComponentWithBaseProps;\r\n}\r\nexport const useBaseProps = () => React.useContext(BasePropsContext);\r\n","import { useBaseProps } from '@hoc/withBaseProps';\r\nimport SkipLink from '@stories/Components/General/SkipLink/SkipLink';\r\nimport * as React from 'react';\r\nimport S from './SectionWrapper.styles';\r\nconst SectionWrapper = React.forwardRef((props, ref) => {\r\n const { children, layout = 'default', flush = 'none', variant = 'none', removeSkipLink, ...otherProps } = props;\r\n const baseProps = useBaseProps();\r\n return (React.createElement(S.Container, { ref: ref, id: baseProps.id, \"data-allow-scroll-margin\": !!baseProps.id, \"data-flush\": flush, \"data-variant\": variant, \"data-has-skip\": !removeSkipLink, ...otherProps },\r\n React.createElement(S.Inner, null,\r\n !removeSkipLink ? React.createElement(SkipLink, null) : React.createElement(S.FocusAnchor, { \"aria-label\": \"Skip to content anchor\" }),\r\n renderLayout())));\r\n function renderLayout() {\r\n if (layout === 'fullWidth') {\r\n return children;\r\n }\r\n return React.createElement(S.SiteWide, null, children);\r\n }\r\n});\r\nSectionWrapper.displayName = 'SectionWrapper';\r\nexport default SectionWrapper;\r\n","import { fluid } from '@helpers/fluid';\r\nimport { baseGrid } from '@helpers/grid';\r\nimport { Device, from } from '@helpers/media';\r\nimport { contentStyles } from '@helpers/typography';\r\nimport SectionWrapper from '@stories/Components/Global/SectionWrapper/SectionWrapper';\r\nimport styled from 'styled-components';\r\nconst Container = styled(SectionWrapper) `\r\n overflow: hidden;\r\n\r\n &[data-is-in-view='true'] {\r\n overflow: unset;\r\n }\r\n`;\r\nconst TopArea = styled.div ``;\r\nconst Content = styled.div `\r\n ${contentStyles};\r\n`;\r\nconst CardArea = styled.div `\r\n ${baseGrid};\r\n`;\r\nconst CardGrid = styled.div `\r\n grid-column: 1 / span 12;\r\n display: grid;\r\n grid-template-columns: 1fr;\r\n gap: ${fluid(16, 32)};\r\n\r\n @media ${from(Device.TabletLarge)} {\r\n grid-template-columns: repeat(2, 1fr);\r\n }\r\n\r\n @media ${from(Device.Desktop)} {\r\n grid-column: 2 / span 10;\r\n }\r\n`;\r\nconst Item = styled.div ``;\r\nconst SignpostCardsStyles = {\r\n CardArea,\r\n CardGrid,\r\n Container,\r\n Content,\r\n Item,\r\n TopArea,\r\n};\r\nexport default SignpostCardsStyles;\r\n","var _g;\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from \"react\";\nfunction SvgCardWaveOncology(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 717 500\"\n }, props), _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n \"data-name\": \"Mask Group 9\"\n }, /*#__PURE__*/React.createElement(\"g\", {\n \"data-name\": \"Group 67\",\n fill: \"none\",\n stroke: \"currentColor\",\n strokeMiterlimit: 10,\n strokeWidth: 4.725\n }, /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 170\",\n d: \"M418.957 93.19c27.8 0 50.993 20.361 56.576 47.507l53.971 224.19c5.084 23.964 25.615 41.906 50.209 41.9H1002\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 171\",\n d: \"M-41 406.812h299.157c24.595 0 45.13-17.946 50.216-41.91l54-224.2c5.586-27.146 28.786-47.512 56.583-47.514\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 172\",\n d: \"M282.515 230.855c15.8 0 28.993 11.423 32.168 26.653l30.686 125.779a29.421 29.421 0 0028.547 23.51H763.13\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n \"data-name\": \"Path 173\",\n d: \"M.996 406.812h190.093a29.434 29.434 0 0028.552-23.513l30.7-125.786c3.177-15.23 16.366-26.657 32.171-26.658\"\n })))));\n}\nexport default SvgCardWaveOncology;","var _g;\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from \"react\";\nfunction SvgCardWaveRadiology(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"0 0 717 500\"\n }, props), _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n fill: \"none\",\n stroke: \"currentColor\",\n strokeMiterlimit: 10,\n strokeWidth: 2\n }, /*#__PURE__*/React.createElement(\"path\", {\n d: \"M376.033 383.644c21.219 0 38.936-15.295 43.325-35.719l46.587-191.075c4.82-23.136 24.836-40.493 48.817-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.32 35.712v.019c21.218 0 38.936-15.295 43.324-35.719l46.589-191.075c4.819-23.136 24.835-40.492 48.815-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.32 35.712m-1109.692.019c21.219 0 38.936-15.295 43.325-35.719L-88.9 156.85c4.82-23.136 24.836-40.493 48.817-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.325-35.719l46.587-191.074c4.82-23.136 24.835-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712m15.894.019c21.219 0 38.936-15.295 43.323-35.719l46.589-191.074c4.819-23.136 24.836-40.493 48.814-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.324-35.719l46.589-191.075c4.82-23.136 24.836-40.492 48.817-40.494s44 17.352 48.813 40.487l46.563 191.07c4.385 20.424 22.1 35.715 43.318 35.712m-1109.691.019c21.219 0 38.936-15.295 43.324-35.719l46.59-191.074c4.819-23.136 24.836-40.493 48.817-40.494s44 17.352 48.811 40.487l46.564 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.324-35.719l46.589-191.074c4.819-23.136 24.836-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712m15.893.019c21.219 0 38.936-15.295 43.325-35.719l46.587-191.074c4.821-23.136 24.836-40.493 48.821-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.325-35.719l46.581-191.074c4.82-23.136 24.836-40.492 48.817-40.494s44 17.352 48.813 40.487l46.57 191.069c4.385 20.424 22.1 35.715 43.317 35.712m-1109.691.019c21.219 0 38.936-15.295 43.324-35.719l46.584-191.074c4.82-23.136 24.836-40.493 48.817-40.494s44 17.352 48.813 40.487L87.08 347.912c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.325-35.719L220.31 156.85c4.82-23.136 24.835-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712m15.894.019c21.219 0 38.936-15.295 43.324-35.719l46.589-191.074c4.819-23.136 24.835-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.324-35.719l46.592-191.074c4.819-23.136 24.836-40.492 48.817-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712m-1109.692.019c21.219 0 38.937-15.295 43.325-35.719l46.584-191.074c4.819-23.136 24.836-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.324-35.719l46.589-191.074c4.819-23.136 24.836-40.493 48.817-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712m15.893.019c21.219 0 38.936-15.295 43.325-35.719L529.52 156.85c4.82-23.136 24.833-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.325-35.719l46.587-191.075c4.82-23.136 24.836-40.492 48.817-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712m-1109.691.019c21.219 0 38.936-15.295 43.324-35.719l46.588-191.073c4.82-23.136 24.836-40.493 48.817-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.324-35.719l46.588-191.074c4.82-23.136 24.836-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712m15.894.019c21.219 0 38.936-15.295 43.324-35.719l46.589-191.074c4.819-23.136 24.839-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.324-35.719l46.589-191.075c4.816-23.135 24.835-40.492 48.816-40.493s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712m-1109.694.02c21.219 0 38.937-15.295 43.325-35.719l46.59-191.075c4.819-23.136 24.835-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.32 35.712v.019c21.218 0 38.936-15.295 43.324-35.719l46.587-191.074c4.819-23.136 24.835-40.493 48.815-40.494s44 17.352 48.813 40.487l46.564 191.069c4.385 20.424 22.1 35.715 43.318 35.712m-174 .019c21.219 0 38.936-15.295 43.323-35.719l46.587-191.074c4.82-23.136 24.835-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.323-35.719l46.589-191.074c4.82-23.136 24.836-40.493 48.82-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712m-1109.694.02c21.219 0 38.936-15.295 43.324-35.719l46.588-191.075c4.819-23.136 24.836-40.493 48.817-40.494s44 17.352 48.813 40.487l46.558 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.324-35.719L93.988 156.85c4.819-23.136 24.836-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712m0 .019c21.219 0 38.936-15.295 43.323-35.719l46.59-191.074c4.82-23.136 24.835-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.323-35.719l46.589-191.074c4.82-23.136 24.836-40.493 48.82-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712m-1109.694.02c21.219 0 38.936-15.295 43.324-35.719l46.588-191.075c4.819-23.136 24.836-40.493 48.817-40.494s44 17.352 48.813 40.487l46.558 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.324-35.719L93.988 156.85c4.819-23.136 24.836-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712m15.893.019c21.219 0 38.936-15.295 43.325-35.719l46.587-191.074c4.821-23.136 24.836-40.493 48.817-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.325-35.719l46.588-191.074c4.819-23.136 24.835-40.493 48.817-40.494s44 17.352 48.811 40.487l46.563 191.069c4.386 20.424 22.1 35.715 43.32 35.712m-1109.692.019c21.219 0 38.936-15.295 43.325-35.719l46.587-191.074c4.82-23.136 24.836-40.493 48.817-40.494s44 17.352 48.813 40.487l46.565 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.325-35.719l46.585-191.074c4.82-23.136 24.836-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712m15.894.019c21.219 0 38.936-15.295 43.323-35.719l46.59-191.074c4.82-23.136 24.835-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.324-35.719L680.62 156.85c4.821-23.136 24.833-40.493 48.817-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712m-1109.691.019c21.219 0 38.936-15.295 43.324-35.719l46.589-191.074c4.818-23.136 24.835-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.324-35.719l46.588-191.074c4.819-23.136 24.836-40.493 48.817-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712m15.893.019c21.219 0 38.936-15.295 43.325-35.719l46.587-191.074c4.82-23.136 24.835-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.325-35.719l46.587-191.074c4.82-23.136 24.84-40.493 48.817-40.494s44 17.352 48.813 40.487l46.563 191.069c4.386 20.424 22.1 35.715 43.32 35.712m-1109.693.02c21.219 0 38.936-15.295 43.324-35.719l46.588-191.075c4.82-23.136 24.836-40.493 48.817-40.494s44 17.352 48.813 40.487L8.438 347.912c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.325-35.719l46.587-191.074c4.82-23.136 24.836-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712m15.894.019c21.219 0 38.936-15.295 43.324-35.719l46.589-191.074c4.819-23.136 24.836-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.323-35.719l46.59-191.074c4.82-23.136 24.835-40.493 48.816-40.494s43.995 17.352 48.813 40.487L856.6 347.912c4.385 20.424 22.1 35.715 43.318 35.712m-1109.691.019c21.218 0 38.936-15.295 43.324-35.719l46.588-191.074c4.819-23.136 24.836-40.493 48.814-40.494s44 17.352 48.811 40.487l46.564 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.323-35.719l46.593-191.074c4.819-23.136 24.836-40.493 48.817-40.494s44 17.352 48.813 40.487l46.561 191.069c4.385 20.424 22.1 35.715 43.318 35.712m15.893.019c21.219 0 38.936-15.295 43.325-35.719l46.589-191.074c4.82-23.136 24.836-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.937-15.295 43.325-35.719l46.589-191.075c4.819-23.136 24.835-40.492 48.815-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712m-1109.691.019c21.219 0 38.936-15.295 43.324-35.719l46.588-191.073c4.821-23.136 24.836-40.493 48.821-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.325-35.719l46.581-191.074c4.822-23.136 24.838-40.493 48.819-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712\"\n }), /*#__PURE__*/React.createElement(\"path\", {\n d: \"M376.033 383.644c21.219 0 38.936-15.295 43.324-35.719l46.589-191.075c4.82-23.136 24.835-40.493 48.816-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.325-35.719l46.587-191.074c4.82-23.136 24.836-40.492 48.817-40.494s44 17.352 48.813 40.487l46.563 191.069c4.385 20.424 22.1 35.715 43.318 35.712m-1109.691.019c21.219 0 38.936-15.295 43.324-35.719L-88.9 156.85c4.82-23.136 24.836-40.493 48.817-40.494s44 17.352 48.813 40.487l46.565 191.069c4.385 20.424 22.1 35.715 43.318 35.712v.019c21.219 0 38.936-15.295 43.323-35.719l46.587-191.074c4.82-23.136 24.836-40.493 48.817-40.494s44 17.352 48.813 40.487l46.562 191.069c4.385 20.424 22.1 35.715 43.318 35.712\"\n }))));\n}\nexport default SvgCardWaveRadiology;","import { transition } from '@helpers/animate';\r\nimport { imageCoverContainer, imageWrapperPreserveRatio } from '@helpers/aspectRatio';\r\nimport brand from '@helpers/brand';\r\nimport { fluid } from '@helpers/fluid';\r\nimport { Device, from, until } from '@helpers/media';\r\nimport styled from 'styled-components';\r\nconst Wrapper = styled.article ``;\r\nconst Container = styled.a `\r\n display: flex;\r\n flex-direction: column;\r\n height: 100%;\r\n text-decoration: none;\r\n color: var(--fgColour);\r\n\r\n &.focus-ring {\r\n outline: auto;\r\n outline-offset: 3px;\r\n outline-style: solid;\r\n outline-width: 2px;\r\n }\r\n\r\n /* Mobile click styles - button should mimic press */\r\n @media ${until(Device.TabletLarge)} {\r\n ${transition('transform', 0.15)};\r\n\r\n &:active {\r\n transform: translateY(1.5px);\r\n }\r\n }\r\n\r\n`;\r\nconst ImageWrapper = styled.div `\r\n ${imageWrapperPreserveRatio(419, 241)};\r\n\r\n background-color: ${brand.primary.purple};\r\n color: var(--bgColour);\r\n\r\n \r\n`;\r\nconst SvgArea = styled.div `\r\n position: absolute;\r\n width: 100%;\r\n height: 100%;\r\n\r\n &[data-branding-type='Burst'] {\r\n width: 50%;\r\n top: 0;\r\n left: 50%;\r\n transform: translateX(-50%);\r\n\r\n svg {\r\n ${transition('transform')};\r\n transform-origin: center;\r\n position: absolute;\r\n\r\n path {\r\n stroke-width: 0.5;\r\n }\r\n\r\n path:last-of-type {\r\n stroke: var(--lineColour, currentColor);\r\n }\r\n\r\n &:first-of-type {\r\n top: 6%;\r\n left: 0%;\r\n width: 100%; \r\n transform: rotate(7deg);\r\n }\r\n }\r\n\r\n ${Container}.focus-ring &,\r\n ${Container}:hover & {\r\n svg:first-of-type {\r\n transform: rotate(32deg);\r\n }\r\n }\r\n }\r\n\r\n &[data-branding-type='Oncology'] {\r\n top: 50%;\r\n left: 0;\r\n transform: translateY(-60%);\r\n\r\n svg {\r\n\r\n path {\r\n ${transition('transform')};\r\n stroke-width: 2.5;\r\n transform: translateX(-15px);\r\n stroke: ${brand.primary.offWhite};\r\n }\r\n\r\n path:first-of-type,\r\n path:nth-child(2) {\r\n stroke: var(--lineColour, currentColor);\r\n }\r\n }\r\n\r\n ${Container}.focus-ring &,\r\n ${Container}:hover & {\r\n path {\r\n transform: translateX(-3px);\r\n }\r\n }\r\n }\r\n\r\n &[data-branding-type='Radiology'] {\r\n top: 50%;\r\n left: 0;\r\n transform: translateY(-60%); \r\n\r\n svg {\r\n\r\n path { \r\n ${transition('transform')}; \r\n stroke-width: 1.5;\r\n transform: translateX(-15px);\r\n stroke: ${brand.tertiary.darkBlue};\r\n }\r\n\r\n \r\n path:nth-child(2) {\r\n stroke: ${brand.secondary.red};\r\n }\r\n }\r\n\r\n ${Container}.focus-ring &,\r\n ${Container}:hover & {\r\n path {\r\n transform: translateX(0);\r\n }\r\n }\r\n }\r\n\r\n`;\r\nconst Image = styled.img `\r\n ${transition('filter', 0.5)};\r\n ${imageCoverContainer()};\r\n\r\n ${Container}.focus-ring &,\r\n ${Container}:hover & {\r\n filter: saturate(0.25);\r\n }\r\n`;\r\nconst ContentOuter = styled.div `\r\n @media ${from(Device.Tablet)} {\r\n display: flex;\r\n }\r\n`;\r\nconst ContentWrapper = styled.div `\r\n flex: 1;\r\n\r\n display: flex;\r\n flex-direction: column;\r\n justify-content: flex-start;\r\n padding: ${fluid(16, 20)} 0;\r\n\r\n @media ${from(Device.Tablet)} {\r\n margin: auto 0;\r\n }\r\n`;\r\nconst ContentInner = styled.div `\r\n > svg {\r\n ${transition('transform')};\r\n\r\n display: block;\r\n width: ${fluid(18, 20)};\r\n margin: auto 0 0 auto;\r\n }\r\n\r\n ${Container}.focus-ring &,\r\n ${Container}:hover & {\r\n > svg {\r\n transform: translateX(15%);\r\n }\r\n }\r\n\r\n @media ${from(Device.Tablet)} {\r\n padding: 0;\r\n }\r\n`;\r\nconst SignpostCardStyles = {\r\n Container,\r\n ContentInner,\r\n ContentOuter,\r\n ContentWrapper,\r\n Image,\r\n ImageWrapper,\r\n SvgArea,\r\n Wrapper,\r\n};\r\nexport default SignpostCardStyles;\r\n","import brand from '@helpers/brand';\r\nimport { getSrcs, imageUrl } from '@helpers/image';\r\nimport { Device, until } from '@helpers/media';\r\nimport WaveOncology from '@img/branding-graphics/card-wave-oncology.svg';\r\nimport WaveRadiology from '@img/branding-graphics/card-wave-radiology.svg';\r\nimport SvgWheel from '@img/branding-graphics/curves-wheel.svg';\r\nimport { FakeButton } from '@stories/Components/Buttons/GeneralButton/Button';\r\nimport * as React from 'react';\r\nimport { FocusRing } from 'react-aria';\r\nimport S from './SignpostCard.styles';\r\nconst HighlightColours = [brand.tertiary.darkBlue, brand.secondary.red];\r\nconst SignpostCard = (props) => {\r\n const imageWidth = 730;\r\n const imageRatio = 241 / 419;\r\n const srcs = props.image ? getSrcs(props.image, imageWidth, 375, 5, imageRatio) : [];\r\n const sizes = `${until(Device.Tablet)} 100vw, ${until(Device.DesktopSmall)} 50vw, ${until(Device.DesktopLarge)} 40vw, 730px`;\r\n /* randomise which colour is used for each wheel */\r\n const lineColours = HighlightColours.sort(() => Math.random() - 0.5);\r\n return (React.createElement(S.Wrapper, null,\r\n React.createElement(FocusRing, { focusRingClass: \"focus-ring\" },\r\n React.createElement(S.Container, { href: props.cta.url, target: props.cta.target },\r\n React.createElement(S.ImageWrapper, null, props.image || props.video ? (React.createElement(React.Fragment, null,\r\n props.image && (React.createElement(S.Image, { src: srcs[0].split(' ')[0], srcSet: srcs.join(','), sizes: sizes, alt: props.image.altText ?? '', loading: 'lazy' })),\r\n props.video && (React.createElement(S.Image, { as: \"video\", autoPlay: true, loop: true, muted: true, playsInline: true, poster: imageUrl(props.video.previewImage, {\r\n width: imageWidth,\r\n height: imageRatio * imageWidth,\r\n }) },\r\n React.createElement(\"source\", { src: props.video.src, type: \"video/mp4\" }))))) : (React.createElement(S.SvgArea, { \"data-branding-type\": props.brandingGraphic === undefined ? 'Burst' : props.brandingGraphic },\r\n props.brandingGraphic === 'Burst' && (React.createElement(SvgWheel, { style: { '--lineColour': lineColours[0] } })),\r\n props.brandingGraphic === 'Oncology' && (React.createElement(WaveOncology, { style: { '--lineColour': lineColours[0] } })),\r\n props.brandingGraphic === 'Radiology' && (React.createElement(WaveRadiology, { style: { '--lineColour': lineColours[0] } }))))),\r\n React.createElement(S.ContentOuter, null,\r\n React.createElement(S.ContentWrapper, null,\r\n React.createElement(S.ContentInner, null,\r\n React.createElement(FakeButton, { branding: \"textOnly\", title: props.cta.text ?? 'Discover more' }))))))));\r\n};\r\nexport default SignpostCard;\r\n","import * as React from 'react';\r\nimport S from './SignpostCards.styles';\r\nimport SignpostCard from '@stories/Components/Cards/SignpostCard/SignpostCard';\r\nimport TitleIntroBlock from '@stories/Components/General/TitleIntroBlock/TitleIntroBlock';\r\nconst SignpostCards = (props) => {\r\n return (React.createElement(S.Container, { variant: props.variant },\r\n React.createElement(S.TopArea, null,\r\n React.createElement(TitleIntroBlock, { title: props.title, intro: props.content })),\r\n React.createElement(S.CardArea, null,\r\n React.createElement(S.CardGrid, null, props.cards.map((card) => (React.createElement(S.Item, { key: card.cta.text },\r\n React.createElement(SignpostCard, { ...card }))))))));\r\n};\r\nexport default SignpostCards;\r\n","'use strict';\nvar token = '%[a-f0-9]{2}';\nvar singleMatcher = new RegExp('(' + token + ')|([^%]+?)', 'gi');\nvar multiMatcher = new RegExp('(' + token + ')+', 'gi');\n\nfunction decodeComponents(components, split) {\n\ttry {\n\t\t// Try to decode the entire string first\n\t\treturn [decodeURIComponent(components.join(''))];\n\t} catch (err) {\n\t\t// Do nothing\n\t}\n\n\tif (components.length === 1) {\n\t\treturn components;\n\t}\n\n\tsplit = split || 1;\n\n\t// Split the array in 2 parts\n\tvar left = components.slice(0, split);\n\tvar right = components.slice(split);\n\n\treturn Array.prototype.concat.call([], decodeComponents(left), decodeComponents(right));\n}\n\nfunction decode(input) {\n\ttry {\n\t\treturn decodeURIComponent(input);\n\t} catch (err) {\n\t\tvar tokens = input.match(singleMatcher) || [];\n\n\t\tfor (var i = 1; i < tokens.length; i++) {\n\t\t\tinput = decodeComponents(tokens, i).join('');\n\n\t\t\ttokens = input.match(singleMatcher) || [];\n\t\t}\n\n\t\treturn input;\n\t}\n}\n\nfunction customDecodeURIComponent(input) {\n\t// Keep track of all the replacements and prefill the map with the `BOM`\n\tvar replaceMap = {\n\t\t'%FE%FF': '\\uFFFD\\uFFFD',\n\t\t'%FF%FE': '\\uFFFD\\uFFFD'\n\t};\n\n\tvar match = multiMatcher.exec(input);\n\twhile (match) {\n\t\ttry {\n\t\t\t// Decode as big chunks as possible\n\t\t\treplaceMap[match[0]] = decodeURIComponent(match[0]);\n\t\t} catch (err) {\n\t\t\tvar result = decode(match[0]);\n\n\t\t\tif (result !== match[0]) {\n\t\t\t\treplaceMap[match[0]] = result;\n\t\t\t}\n\t\t}\n\n\t\tmatch = multiMatcher.exec(input);\n\t}\n\n\t// Add `%C2` at the end of the map to make sure it does not replace the combinator before everything else\n\treplaceMap['%C2'] = '\\uFFFD';\n\n\tvar entries = Object.keys(replaceMap);\n\n\tfor (var i = 0; i < entries.length; i++) {\n\t\t// Replace all decoded components\n\t\tvar key = entries[i];\n\t\tinput = input.replace(new RegExp(key, 'g'), replaceMap[key]);\n\t}\n\n\treturn input;\n}\n\nmodule.exports = function (encodedURI) {\n\tif (typeof encodedURI !== 'string') {\n\t\tthrow new TypeError('Expected `encodedURI` to be of type `string`, got `' + typeof encodedURI + '`');\n\t}\n\n\ttry {\n\t\tencodedURI = encodedURI.replace(/\\+/g, ' ');\n\n\t\t// Try the built in decoder first\n\t\treturn decodeURIComponent(encodedURI);\n\t} catch (err) {\n\t\t// Fallback to a more advanced decoder\n\t\treturn customDecodeURIComponent(encodedURI);\n\t}\n};\n","'use strict';\nmodule.exports = function (obj, predicate) {\n\tvar ret = {};\n\tvar keys = Object.keys(obj);\n\tvar isArr = Array.isArray(predicate);\n\n\tfor (var i = 0; i < keys.length; i++) {\n\t\tvar key = keys[i];\n\t\tvar val = obj[key];\n\n\t\tif (isArr ? predicate.indexOf(key) !== -1 : predicate(key, val, obj)) {\n\t\t\tret[key] = val;\n\t\t}\n\t}\n\n\treturn ret;\n};\n","'use strict';\nconst strictUriEncode = require('strict-uri-encode');\nconst decodeComponent = require('decode-uri-component');\nconst splitOnFirst = require('split-on-first');\nconst filterObject = require('filter-obj');\n\nconst isNullOrUndefined = value => value === null || value === undefined;\n\nconst encodeFragmentIdentifier = Symbol('encodeFragmentIdentifier');\n\nfunction encoderForArrayFormat(options) {\n\tswitch (options.arrayFormat) {\n\t\tcase 'index':\n\t\t\treturn key => (result, value) => {\n\t\t\t\tconst index = result.length;\n\n\t\t\t\tif (\n\t\t\t\t\tvalue === undefined ||\n\t\t\t\t\t(options.skipNull && value === null) ||\n\t\t\t\t\t(options.skipEmptyString && value === '')\n\t\t\t\t) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\tif (value === null) {\n\t\t\t\t\treturn [...result, [encode(key, options), '[', index, ']'].join('')];\n\t\t\t\t}\n\n\t\t\t\treturn [\n\t\t\t\t\t...result,\n\t\t\t\t\t[encode(key, options), '[', encode(index, options), ']=', encode(value, options)].join('')\n\t\t\t\t];\n\t\t\t};\n\n\t\tcase 'bracket':\n\t\t\treturn key => (result, value) => {\n\t\t\t\tif (\n\t\t\t\t\tvalue === undefined ||\n\t\t\t\t\t(options.skipNull && value === null) ||\n\t\t\t\t\t(options.skipEmptyString && value === '')\n\t\t\t\t) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\tif (value === null) {\n\t\t\t\t\treturn [...result, [encode(key, options), '[]'].join('')];\n\t\t\t\t}\n\n\t\t\t\treturn [...result, [encode(key, options), '[]=', encode(value, options)].join('')];\n\t\t\t};\n\n\t\tcase 'colon-list-separator':\n\t\t\treturn key => (result, value) => {\n\t\t\t\tif (\n\t\t\t\t\tvalue === undefined ||\n\t\t\t\t\t(options.skipNull && value === null) ||\n\t\t\t\t\t(options.skipEmptyString && value === '')\n\t\t\t\t) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\tif (value === null) {\n\t\t\t\t\treturn [...result, [encode(key, options), ':list='].join('')];\n\t\t\t\t}\n\n\t\t\t\treturn [...result, [encode(key, options), ':list=', encode(value, options)].join('')];\n\t\t\t};\n\n\t\tcase 'comma':\n\t\tcase 'separator':\n\t\tcase 'bracket-separator': {\n\t\t\tconst keyValueSep = options.arrayFormat === 'bracket-separator' ?\n\t\t\t\t'[]=' :\n\t\t\t\t'=';\n\n\t\t\treturn key => (result, value) => {\n\t\t\t\tif (\n\t\t\t\t\tvalue === undefined ||\n\t\t\t\t\t(options.skipNull && value === null) ||\n\t\t\t\t\t(options.skipEmptyString && value === '')\n\t\t\t\t) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\t// Translate null to an empty string so that it doesn't serialize as 'null'\n\t\t\t\tvalue = value === null ? '' : value;\n\n\t\t\t\tif (result.length === 0) {\n\t\t\t\t\treturn [[encode(key, options), keyValueSep, encode(value, options)].join('')];\n\t\t\t\t}\n\n\t\t\t\treturn [[result, encode(value, options)].join(options.arrayFormatSeparator)];\n\t\t\t};\n\t\t}\n\n\t\tdefault:\n\t\t\treturn key => (result, value) => {\n\t\t\t\tif (\n\t\t\t\t\tvalue === undefined ||\n\t\t\t\t\t(options.skipNull && value === null) ||\n\t\t\t\t\t(options.skipEmptyString && value === '')\n\t\t\t\t) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\tif (value === null) {\n\t\t\t\t\treturn [...result, encode(key, options)];\n\t\t\t\t}\n\n\t\t\t\treturn [...result, [encode(key, options), '=', encode(value, options)].join('')];\n\t\t\t};\n\t}\n}\n\nfunction parserForArrayFormat(options) {\n\tlet result;\n\n\tswitch (options.arrayFormat) {\n\t\tcase 'index':\n\t\t\treturn (key, value, accumulator) => {\n\t\t\t\tresult = /\\[(\\d*)\\]$/.exec(key);\n\n\t\t\t\tkey = key.replace(/\\[\\d*\\]$/, '');\n\n\t\t\t\tif (!result) {\n\t\t\t\t\taccumulator[key] = value;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (accumulator[key] === undefined) {\n\t\t\t\t\taccumulator[key] = {};\n\t\t\t\t}\n\n\t\t\t\taccumulator[key][result[1]] = value;\n\t\t\t};\n\n\t\tcase 'bracket':\n\t\t\treturn (key, value, accumulator) => {\n\t\t\t\tresult = /(\\[\\])$/.exec(key);\n\t\t\t\tkey = key.replace(/\\[\\]$/, '');\n\n\t\t\t\tif (!result) {\n\t\t\t\t\taccumulator[key] = value;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (accumulator[key] === undefined) {\n\t\t\t\t\taccumulator[key] = [value];\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\taccumulator[key] = [].concat(accumulator[key], value);\n\t\t\t};\n\n\t\tcase 'colon-list-separator':\n\t\t\treturn (key, value, accumulator) => {\n\t\t\t\tresult = /(:list)$/.exec(key);\n\t\t\t\tkey = key.replace(/:list$/, '');\n\n\t\t\t\tif (!result) {\n\t\t\t\t\taccumulator[key] = value;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (accumulator[key] === undefined) {\n\t\t\t\t\taccumulator[key] = [value];\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\taccumulator[key] = [].concat(accumulator[key], value);\n\t\t\t};\n\n\t\tcase 'comma':\n\t\tcase 'separator':\n\t\t\treturn (key, value, accumulator) => {\n\t\t\t\tconst isArray = typeof value === 'string' && value.includes(options.arrayFormatSeparator);\n\t\t\t\tconst isEncodedArray = (typeof value === 'string' && !isArray && decode(value, options).includes(options.arrayFormatSeparator));\n\t\t\t\tvalue = isEncodedArray ? decode(value, options) : value;\n\t\t\t\tconst newValue = isArray || isEncodedArray ? value.split(options.arrayFormatSeparator).map(item => decode(item, options)) : value === null ? value : decode(value, options);\n\t\t\t\taccumulator[key] = newValue;\n\t\t\t};\n\n\t\tcase 'bracket-separator':\n\t\t\treturn (key, value, accumulator) => {\n\t\t\t\tconst isArray = /(\\[\\])$/.test(key);\n\t\t\t\tkey = key.replace(/\\[\\]$/, '');\n\n\t\t\t\tif (!isArray) {\n\t\t\t\t\taccumulator[key] = value ? decode(value, options) : value;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tconst arrayValue = value === null ?\n\t\t\t\t\t[] :\n\t\t\t\t\tvalue.split(options.arrayFormatSeparator).map(item => decode(item, options));\n\n\t\t\t\tif (accumulator[key] === undefined) {\n\t\t\t\t\taccumulator[key] = arrayValue;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\taccumulator[key] = [].concat(accumulator[key], arrayValue);\n\t\t\t};\n\n\t\tdefault:\n\t\t\treturn (key, value, accumulator) => {\n\t\t\t\tif (accumulator[key] === undefined) {\n\t\t\t\t\taccumulator[key] = value;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\taccumulator[key] = [].concat(accumulator[key], value);\n\t\t\t};\n\t}\n}\n\nfunction validateArrayFormatSeparator(value) {\n\tif (typeof value !== 'string' || value.length !== 1) {\n\t\tthrow new TypeError('arrayFormatSeparator must be single character string');\n\t}\n}\n\nfunction encode(value, options) {\n\tif (options.encode) {\n\t\treturn options.strict ? strictUriEncode(value) : encodeURIComponent(value);\n\t}\n\n\treturn value;\n}\n\nfunction decode(value, options) {\n\tif (options.decode) {\n\t\treturn decodeComponent(value);\n\t}\n\n\treturn value;\n}\n\nfunction keysSorter(input) {\n\tif (Array.isArray(input)) {\n\t\treturn input.sort();\n\t}\n\n\tif (typeof input === 'object') {\n\t\treturn keysSorter(Object.keys(input))\n\t\t\t.sort((a, b) => Number(a) - Number(b))\n\t\t\t.map(key => input[key]);\n\t}\n\n\treturn input;\n}\n\nfunction removeHash(input) {\n\tconst hashStart = input.indexOf('#');\n\tif (hashStart !== -1) {\n\t\tinput = input.slice(0, hashStart);\n\t}\n\n\treturn input;\n}\n\nfunction getHash(url) {\n\tlet hash = '';\n\tconst hashStart = url.indexOf('#');\n\tif (hashStart !== -1) {\n\t\thash = url.slice(hashStart);\n\t}\n\n\treturn hash;\n}\n\nfunction extract(input) {\n\tinput = removeHash(input);\n\tconst queryStart = input.indexOf('?');\n\tif (queryStart === -1) {\n\t\treturn '';\n\t}\n\n\treturn input.slice(queryStart + 1);\n}\n\nfunction parseValue(value, options) {\n\tif (options.parseNumbers && !Number.isNaN(Number(value)) && (typeof value === 'string' && value.trim() !== '')) {\n\t\tvalue = Number(value);\n\t} else if (options.parseBooleans && value !== null && (value.toLowerCase() === 'true' || value.toLowerCase() === 'false')) {\n\t\tvalue = value.toLowerCase() === 'true';\n\t}\n\n\treturn value;\n}\n\nfunction parse(query, options) {\n\toptions = Object.assign({\n\t\tdecode: true,\n\t\tsort: true,\n\t\tarrayFormat: 'none',\n\t\tarrayFormatSeparator: ',',\n\t\tparseNumbers: false,\n\t\tparseBooleans: false\n\t}, options);\n\n\tvalidateArrayFormatSeparator(options.arrayFormatSeparator);\n\n\tconst formatter = parserForArrayFormat(options);\n\n\t// Create an object with no prototype\n\tconst ret = Object.create(null);\n\n\tif (typeof query !== 'string') {\n\t\treturn ret;\n\t}\n\n\tquery = query.trim().replace(/^[?#&]/, '');\n\n\tif (!query) {\n\t\treturn ret;\n\t}\n\n\tfor (const param of query.split('&')) {\n\t\tif (param === '') {\n\t\t\tcontinue;\n\t\t}\n\n\t\tlet [key, value] = splitOnFirst(options.decode ? param.replace(/\\+/g, ' ') : param, '=');\n\n\t\t// Missing `=` should be `null`:\n\t\t// http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters\n\t\tvalue = value === undefined ? null : ['comma', 'separator', 'bracket-separator'].includes(options.arrayFormat) ? value : decode(value, options);\n\t\tformatter(decode(key, options), value, ret);\n\t}\n\n\tfor (const key of Object.keys(ret)) {\n\t\tconst value = ret[key];\n\t\tif (typeof value === 'object' && value !== null) {\n\t\t\tfor (const k of Object.keys(value)) {\n\t\t\t\tvalue[k] = parseValue(value[k], options);\n\t\t\t}\n\t\t} else {\n\t\t\tret[key] = parseValue(value, options);\n\t\t}\n\t}\n\n\tif (options.sort === false) {\n\t\treturn ret;\n\t}\n\n\treturn (options.sort === true ? Object.keys(ret).sort() : Object.keys(ret).sort(options.sort)).reduce((result, key) => {\n\t\tconst value = ret[key];\n\t\tif (Boolean(value) && typeof value === 'object' && !Array.isArray(value)) {\n\t\t\t// Sort object keys, not values\n\t\t\tresult[key] = keysSorter(value);\n\t\t} else {\n\t\t\tresult[key] = value;\n\t\t}\n\n\t\treturn result;\n\t}, Object.create(null));\n}\n\nexports.extract = extract;\nexports.parse = parse;\n\nexports.stringify = (object, options) => {\n\tif (!object) {\n\t\treturn '';\n\t}\n\n\toptions = Object.assign({\n\t\tencode: true,\n\t\tstrict: true,\n\t\tarrayFormat: 'none',\n\t\tarrayFormatSeparator: ','\n\t}, options);\n\n\tvalidateArrayFormatSeparator(options.arrayFormatSeparator);\n\n\tconst shouldFilter = key => (\n\t\t(options.skipNull && isNullOrUndefined(object[key])) ||\n\t\t(options.skipEmptyString && object[key] === '')\n\t);\n\n\tconst formatter = encoderForArrayFormat(options);\n\n\tconst objectCopy = {};\n\n\tfor (const key of Object.keys(object)) {\n\t\tif (!shouldFilter(key)) {\n\t\t\tobjectCopy[key] = object[key];\n\t\t}\n\t}\n\n\tconst keys = Object.keys(objectCopy);\n\n\tif (options.sort !== false) {\n\t\tkeys.sort(options.sort);\n\t}\n\n\treturn keys.map(key => {\n\t\tconst value = object[key];\n\n\t\tif (value === undefined) {\n\t\t\treturn '';\n\t\t}\n\n\t\tif (value === null) {\n\t\t\treturn encode(key, options);\n\t\t}\n\n\t\tif (Array.isArray(value)) {\n\t\t\tif (value.length === 0 && options.arrayFormat === 'bracket-separator') {\n\t\t\t\treturn encode(key, options) + '[]';\n\t\t\t}\n\n\t\t\treturn value\n\t\t\t\t.reduce(formatter(key), [])\n\t\t\t\t.join('&');\n\t\t}\n\n\t\treturn encode(key, options) + '=' + encode(value, options);\n\t}).filter(x => x.length > 0).join('&');\n};\n\nexports.parseUrl = (url, options) => {\n\toptions = Object.assign({\n\t\tdecode: true\n\t}, options);\n\n\tconst [url_, hash] = splitOnFirst(url, '#');\n\n\treturn Object.assign(\n\t\t{\n\t\t\turl: url_.split('?')[0] || '',\n\t\t\tquery: parse(extract(url), options)\n\t\t},\n\t\toptions && options.parseFragmentIdentifier && hash ? {fragmentIdentifier: decode(hash, options)} : {}\n\t);\n};\n\nexports.stringifyUrl = (object, options) => {\n\toptions = Object.assign({\n\t\tencode: true,\n\t\tstrict: true,\n\t\t[encodeFragmentIdentifier]: true\n\t}, options);\n\n\tconst url = removeHash(object.url).split('?')[0] || '';\n\tconst queryFromUrl = exports.extract(object.url);\n\tconst parsedQueryFromUrl = exports.parse(queryFromUrl, {sort: false});\n\n\tconst query = Object.assign(parsedQueryFromUrl, object.query);\n\tlet queryString = exports.stringify(query, options);\n\tif (queryString) {\n\t\tqueryString = `?${queryString}`;\n\t}\n\n\tlet hash = getHash(object.url);\n\tif (object.fragmentIdentifier) {\n\t\thash = `#${options[encodeFragmentIdentifier] ? encode(object.fragmentIdentifier, options) : object.fragmentIdentifier}`;\n\t}\n\n\treturn `${url}${queryString}${hash}`;\n};\n\nexports.pick = (input, filter, options) => {\n\toptions = Object.assign({\n\t\tparseFragmentIdentifier: true,\n\t\t[encodeFragmentIdentifier]: false\n\t}, options);\n\n\tconst {url, query, fragmentIdentifier} = exports.parseUrl(input, options);\n\treturn exports.stringifyUrl({\n\t\turl,\n\t\tquery: filterObject(query, filter),\n\t\tfragmentIdentifier\n\t}, options);\n};\n\nexports.exclude = (input, filter, options) => {\n\tconst exclusionFilter = Array.isArray(filter) ? key => !filter.includes(key) : (key, value) => !filter(key, value);\n\n\treturn exports.pick(input, exclusionFilter, options);\n};\n","'use strict';\n\nmodule.exports = (string, separator) => {\n\tif (!(typeof string === 'string' && typeof separator === 'string')) {\n\t\tthrow new TypeError('Expected the arguments to be of type `string`');\n\t}\n\n\tif (separator === '') {\n\t\treturn [string];\n\t}\n\n\tconst separatorIndex = string.indexOf(separator);\n\n\tif (separatorIndex === -1) {\n\t\treturn [string];\n\t}\n\n\treturn [\n\t\tstring.slice(0, separatorIndex),\n\t\tstring.slice(separatorIndex + separator.length)\n\t];\n};\n","'use strict';\nmodule.exports = str => encodeURIComponent(str).replace(/[!'()*]/g, x => `%${x.charCodeAt(0).toString(16).toUpperCase()}`);\n"],"names":["_path","_path2","_extends","Object","assign","bind","target","i","arguments","length","source","key","prototype","hasOwnProperty","call","apply","this","props","xmlns","viewBox","className","d","fill","stroke","strokeWidth","strokeMiterlimit","strokeDasharray","aspectRatio","width","height","imageWrapperPreserveRatio","maxWidth","maxHeight","padding","fluidUnit","css","imageCoverContainer","relative","ButtonReset","imageUrl","image","imageParams","params","center","focalPoint","top","left","undefined","paramsString","queryString","src","getSrcs","upper","lower","steps","ratio","sizes","increment","Array","map","_","index","Math","ceil","getRange","size","getRetinaSrcs","dpr","callback","options","observerRef","useRef","rootRef","elementRef","useEffect","current","IntersectionObserver","root","observe","disconnect","useInView","reverse","isEditMode","inView","setInView","useState","useIntersectionObserver","entries","isIntersecting","Text","styled","div","withConfig","displayName","componentId","PrimaryStyles","brand","secondary","red","primary","purple","transition","offWhite","OutlineStyles","OutlineAltStyles","Wave","Arrow","TextOnlyStyles","Icon","Button","button","fluid","fonts","graphikCompact","medium","until","Device","TabletLarge","_ref","branding","ArrowButton","ButtonInner","ButtonStyles","ButtonIcon","HoverLine","disabled","title","toggleOn","type","onClick","icon","iconPosition","otherProps","React","FocusRing","focusRingClass","getSvgFromSystem","SystemIcon","Wave1","ArrowRight","FakeButton","_ref2","as","LinkButton","_ref3","href","_ref4","labelText","Chevron","Container","siteWide","Layers","NavigationTray","paragraphRegular","ref","S","targetEl","document","getElementById","scrollIntoView","focusNext","skipToMain","_ref$current","_wrapperEl","wrapperEl","closest","_ref$current2","nextElementSibling","_wrapperEl2","_wrapperEl2$parentEle","parentElement","skipSection","el","_focusable$","querySelectorAll","focus","baseGrid","Title","h2","from","Tablet","DesktopSmall","Desktop","rightSpans","Content","contentStyles","ButtonWrapper","_props$introCta$text","rootMargin","intro","introCta","altTitleColour","sections","split","section","wrapTitleWords","splitTitleIntoWords","dangerouslySetInnerHTML","__html","url","text","words","word","letters","letter","style","tint","Inner","SiteWide","FocusAnchor","BasePropsContext","SectionWrapper","children","layout","flush","variant","removeSkipLink","baseProps","id","SkipLink","TopArea","CardArea","CardGrid","Item","_g","Wrapper","article","a","ImageWrapper","SvgArea","tertiary","darkBlue","Image","img","ContentOuter","ContentWrapper","ContentInner","HighlightColours","_props$image$altText","_props$cta$text","imageRatio","srcs","DesktopLarge","lineColours","sort","random","cta","video","srcSet","join","alt","altText","loading","autoPlay","loop","muted","playsInline","poster","previewImage","brandingGraphic","SvgWheel","WaveOncology","WaveRadiology","TitleIntroBlock","content","cards","card","SignpostCard","token","singleMatcher","RegExp","multiMatcher","decodeComponents","components","decodeURIComponent","err","slice","right","concat","decode","input","tokens","match","module","exports","encodedURI","TypeError","replace","replaceMap","exec","result","keys","customDecodeURIComponent","obj","predicate","ret","isArr","isArray","val","indexOf","strictUriEncode","decodeComponent","splitOnFirst","filterObject","encodeFragmentIdentifier","Symbol","validateArrayFormatSeparator","value","encode","strict","encodeURIComponent","keysSorter","b","Number","removeHash","hashStart","extract","queryStart","parseValue","parseNumbers","isNaN","trim","parseBooleans","toLowerCase","parse","query","arrayFormat","arrayFormatSeparator","formatter","accumulator","includes","isEncodedArray","newValue","item","test","arrayValue","parserForArrayFormat","create","param","k","reduce","Boolean","stringify","object","shouldFilter","skipNull","skipEmptyString","keyValueSep","encoderForArrayFormat","objectCopy","filter","x","parseUrl","url_","hash","parseFragmentIdentifier","fragmentIdentifier","stringifyUrl","queryFromUrl","parsedQueryFromUrl","getHash","pick","exclude","exclusionFilter","string","separator","separatorIndex","str","charCodeAt","toString","toUpperCase"],"sourceRoot":""}