@codecademy/gamut

68.5.068.5.1-alpha.469476.0
~

Modified (3 files)

Index: package/dist/Menu/elements.js
===================================================================
--- package/dist/Menu/elements.js
+++ package/dist/Menu/elements.js
@@ -33,9 +33,9 @@
   showBorder: {
     border: 1,
     borderRadius: 'sm'
   }
-}), sharedStates, listProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Menu/elements.tsx"],"names":[],"mappings":"AA6CmB","file":"../../src/Menu/elements.tsx","sourcesContent":["import {\n  styledOptions,\n  system,\n  transitionConcat,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport isObject from 'lodash/isObject';\nimport { ComponentProps, forwardRef } from 'react';\n\nimport { sharedStates } from '../Box/props';\nimport { resetStyles, Selectors } from '../ButtonBase/ButtonBase';\nimport { ToolTip, ToolTipProps } from '../Tip/ToolTip';\nimport { MenuItem } from './MenuItem';\n\nenum MenuItemSelectors {\n  OUTLINE = '&:after',\n  OUTLINE_FOCUS_VISIBLE = '&:focus-visible:after',\n}\n\ntype ListStyleProps = StyleProps<typeof listProps>;\n\ntype StyleStateProps = StyleProps<typeof sharedStates>;\n\nconst listProps = variance.compose(\n  system.layout,\n  system.typography,\n  system.space,\n  system.positioning,\n  system.border,\n  system.color\n);\n\nexport interface ListProps extends ListStyleProps, StyleStateProps {\n  /** How offset spacing should be */\n  spacing?: 'normal' | 'condensed';\n  /** Menu variants for specific use cases and styles */\n  variant?: 'popover' | 'fixed';\n  /** is root menu */\n  root?: boolean;\n  /** bordered */\n  as?: 'ul' | 'ol';\n  showBorder?: boolean;\n}\n\nconst StyledList = styled('ul', styledOptions<'ul'>())<ListProps>(\n  system.css({\n    listStyle: 'none',\n    width: 1,\n    bg: 'inherit',\n    display: 'inline-block',\n    pl: 24,\n    WebkitFontSmoothing: 'antialiased',\n    MozOsxFontSmoothing: 'grayscale',\n  }),\n  system.states({\n    root: {\n      bg: 'background',\n      p: 0,\n    },\n    showBorder: {\n      border: 1,\n      borderRadius: 'sm',\n    },\n  }),\n  sharedStates,\n  listProps\n);\n\nexport const List = forwardRef<\n  HTMLUListElement,\n  ComponentProps<typeof StyledList>\n>(({ context = true, m = 0, root = true, variant, ...rest }, ref) => (\n  <StyledList\n    context={context}\n    m={m}\n    ref={ref}\n    root={root}\n    showBorder={variant !== 'fixed'}\n    variant={variant}\n    {...rest}\n  />\n));\n\nconst interactiveVariants = system.variant({\n  base: {\n    display: 'flex',\n    alignItems: 'center',\n    cursor: 'pointer',\n    width: 1,\n    zIndex: 1,\n    px: 24,\n    py: 12,\n    position: 'relative',\n    transition: transitionConcat(\n      ['color', 'background-color', 'border-color'],\n      'fast',\n      'linear'\n    ),\n    [Selectors.FOCUS_VISIBLE]: {\n      outline: 'none',\n    },\n    [MenuItemSelectors.OUTLINE]: {\n      content: \"''\",\n      position: 'absolute',\n      inset: 4,\n      borderRadius: 'md',\n      border: 2,\n      borderColor: 'primary',\n      opacity: 0,\n      zIndex: -1,\n    },\n    [MenuItemSelectors.OUTLINE_FOCUS_VISIBLE]: {\n      opacity: 1,\n    },\n  },\n  variants: {\n    select: {\n      [Selectors.DISABLED]: {\n        pointerEvents: 'none',\n      },\n      [Selectors.HOVER]: {\n        bg: 'background-hover',\n      },\n    },\n    link: {\n      [Selectors.BEFORE]: {\n        bg: 'inherit',\n        position: 'absolute',\n        display: 'inline-block',\n        left: 0,\n        width: 6,\n      },\n      [Selectors.HOVER]: {\n        textColor: 'primary',\n      },\n    },\n  },\n});\n\nconst activeStates = system.states({\n  selected: {\n    bg: 'background-selected',\n  },\n  active: {\n    fontWeight: 700,\n  },\n  'active-navlink': {\n    fontWeight: 700,\n    bg: 'background-selected',\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'secondary',\n    },\n  },\n  // Is named isDisabled to avoid conflicts with the HTML `disabled` attribute\n  isDisabled: {\n    bg: 'inherit',\n    cursor: 'not-allowed',\n    fontWeight: 400,\n    textColor: 'text-disabled',\n    [Selectors.HOVER]: {\n      textColor: 'text-disabled',\n      textDecoration: 'none',\n    },\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'inherit',\n    },\n  },\n});\n\nconst sizeVariants = system.variant({\n  prop: 'spacing',\n  variants: {\n    condensed: {\n      lineHeight: 'title',\n      minHeight: 40,\n      py: 8,\n      fontSize: 14,\n      [Selectors.BEFORE]: {\n        minHeight: 40,\n      },\n    },\n    normal: {\n      fontSize: 16,\n      minHeight: 48,\n      [Selectors.BEFORE]: {\n        minHeight: 48,\n      },\n    },\n  },\n});\n\nexport interface ListItemProps\n  extends ListStyleProps,\n    StyleStateProps,\n    StyleProps<typeof interactiveVariants>,\n    StyleProps<typeof activeStates>,\n    StyleProps<typeof sizeVariants> {}\n\nexport const ListItem = styled('li', styledOptions<'li'>())<ListItemProps>(\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport interface ListLinkProps extends ListItemProps {\n  active?: boolean;\n  navlink?: boolean;\n}\n\nconst StyledListLink = styled('a', styledOptions<'a'>())<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const ListLink = forwardRef<\n  HTMLAnchorElement,\n  ComponentProps<typeof StyledListLink>\n>(({ zIndex = 1, ...rest }, ref) => (\n  <StyledListLink ref={ref} zIndex={zIndex} {...rest} />\n));\n\nexport const ListButton = styled(\n  'button',\n  styledOptions<'button'>()\n)<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const MenuToolTipWrapper: React.FC<\n  Pick<ComponentProps<typeof MenuItem>, 'children' | 'label'> & {\n    tipId: string;\n  }\n> = ({ children, label, tipId }) => {\n  if (!label) {\n    return <>{children}</>;\n  }\n\n  const defaultTipProps = {\n    placement: 'floating',\n    id: tipId,\n    inheritDims: true,\n    shouldRenderAriaTip: false,\n  };\n\n  const wrapperProps =\n    label && isObject(label)\n      ? {\n          ...defaultTipProps,\n          ...label,\n        }\n      : {\n          info: label,\n          ...defaultTipProps,\n        };\n\n  return <ToolTip {...(wrapperProps as ToolTipProps)}>{children}</ToolTip>;\n};\n"]} */");
+}), sharedStates, listProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Menu/elements.tsx"],"names":[],"mappings":"AA6CmB","file":"../../src/Menu/elements.tsx","sourcesContent":["import {\n  styledOptions,\n  system,\n  transitionConcat,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport isObject from 'lodash/isObject';\nimport { ComponentProps, forwardRef } from 'react';\n\nimport { sharedStates } from '../Box/props';\nimport { resetStyles, Selectors } from '../ButtonBase/ButtonBase';\nimport { ToolTip, ToolTipProps } from '../Tip/ToolTip';\nimport { MenuItem } from './MenuItem';\n\nenum MenuItemSelectors {\n  OUTLINE = '&:after',\n  OUTLINE_FOCUS_VISIBLE = '&:focus-visible:after',\n}\n\ntype ListStyleProps = StyleProps<typeof listProps>;\n\ntype StyleStateProps = StyleProps<typeof sharedStates>;\n\nconst listProps = variance.compose(\n  system.layout,\n  system.typography,\n  system.space,\n  system.positioning,\n  system.border,\n  system.color\n);\n\nexport interface ListProps extends ListStyleProps, StyleStateProps {\n  /** How offset spacing should be */\n  spacing?: 'normal' | 'condensed';\n  /** Menu variants for specific use cases and styles */\n  variant?: 'popover' | 'fixed';\n  /** is root menu */\n  root?: boolean;\n  /** bordered */\n  as?: 'ul' | 'ol';\n  showBorder?: boolean;\n}\n\nconst StyledList = styled('ul', styledOptions<'ul'>())<ListProps>(\n  system.css({\n    listStyle: 'none',\n    width: 1,\n    bg: 'inherit',\n    display: 'inline-block',\n    pl: 24,\n    WebkitFontSmoothing: 'antialiased',\n    MozOsxFontSmoothing: 'grayscale',\n  }),\n  system.states({\n    root: {\n      bg: 'background',\n      p: 0,\n    },\n    showBorder: {\n      border: 1,\n      borderRadius: 'sm',\n    },\n  }),\n  sharedStates,\n  listProps\n);\n\nexport const List = forwardRef<\n  HTMLUListElement,\n  ComponentProps<typeof StyledList>\n>(({ context = true, m = 0, root = true, variant, ...rest }, ref) => (\n  <StyledList\n    context={context}\n    m={m}\n    ref={ref}\n    root={root}\n    showBorder={variant !== 'fixed'}\n    variant={variant}\n    {...rest}\n  />\n));\n\nconst interactiveVariants = system.variant({\n  base: {\n    display: 'flex',\n    alignItems: 'center',\n    cursor: 'pointer',\n    width: 1,\n    zIndex: 1,\n    px: 24,\n    py: 12,\n    position: 'relative',\n    transition: transitionConcat(\n      ['color', 'background-color', 'border-color'],\n      'fast',\n      'linear'\n    ),\n    [Selectors.FOCUS_VISIBLE]: {\n      outline: 'none',\n    },\n    [MenuItemSelectors.OUTLINE]: {\n      content: \"''\",\n      position: 'absolute',\n      inset: 4,\n      borderRadius: 'md',\n      border: 2,\n      borderColor: 'primary',\n      opacity: 0,\n      zIndex: -1,\n    },\n    [MenuItemSelectors.OUTLINE_FOCUS_VISIBLE]: {\n      opacity: 1,\n    },\n  },\n  variants: {\n    select: {\n      [Selectors.DISABLED]: {\n        pointerEvents: 'none',\n      },\n      [Selectors.HOVER]: {\n        bg: 'background-hover',\n      },\n    },\n    link: {\n      [Selectors.BEFORE]: {\n        bg: 'inherit',\n        position: 'absolute',\n        display: 'inline-block',\n        left: 0,\n        width: 6,\n      },\n      [Selectors.HOVER]: {\n        textColor: 'primary',\n      },\n    },\n  },\n});\n\nconst activeStates = system.states({\n  selected: {\n    bg: 'background-selected',\n  },\n  active: {\n    fontWeight: 'title',\n  },\n  'active-navlink': {\n    fontWeight: 'title',\n    bg: 'background-selected',\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'secondary',\n    },\n  },\n  // Is named isDisabled to avoid conflicts with the HTML `disabled` attribute\n  isDisabled: {\n    bg: 'inherit',\n    cursor: 'not-allowed',\n    fontWeight: 400,\n    textColor: 'text-disabled',\n    [Selectors.HOVER]: {\n      textColor: 'text-disabled',\n      textDecoration: 'none',\n    },\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'inherit',\n    },\n  },\n});\n\nconst sizeVariants = system.variant({\n  prop: 'spacing',\n  variants: {\n    condensed: {\n      lineHeight: 'title',\n      minHeight: 40,\n      py: 8,\n      fontSize: 14,\n      [Selectors.BEFORE]: {\n        minHeight: 40,\n      },\n    },\n    normal: {\n      fontSize: 16,\n      minHeight: 48,\n      [Selectors.BEFORE]: {\n        minHeight: 48,\n      },\n    },\n  },\n});\n\nexport interface ListItemProps\n  extends ListStyleProps,\n    StyleStateProps,\n    StyleProps<typeof interactiveVariants>,\n    StyleProps<typeof activeStates>,\n    StyleProps<typeof sizeVariants> {}\n\nexport const ListItem = styled('li', styledOptions<'li'>())<ListItemProps>(\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport interface ListLinkProps extends ListItemProps {\n  active?: boolean;\n  navlink?: boolean;\n}\n\nconst StyledListLink = styled('a', styledOptions<'a'>())<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const ListLink = forwardRef<\n  HTMLAnchorElement,\n  ComponentProps<typeof StyledListLink>\n>(({ zIndex = 1, ...rest }, ref) => (\n  <StyledListLink ref={ref} zIndex={zIndex} {...rest} />\n));\n\nexport const ListButton = styled(\n  'button',\n  styledOptions<'button'>()\n)<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const MenuToolTipWrapper: React.FC<\n  Pick<ComponentProps<typeof MenuItem>, 'children' | 'label'> & {\n    tipId: string;\n  }\n> = ({ children, label, tipId }) => {\n  if (!label) {\n    return <>{children}</>;\n  }\n\n  const defaultTipProps = {\n    placement: 'floating',\n    id: tipId,\n    inheritDims: true,\n    shouldRenderAriaTip: false,\n  };\n\n  const wrapperProps =\n    label && isObject(label)\n      ? {\n          ...defaultTipProps,\n          ...label,\n        }\n      : {\n          info: label,\n          ...defaultTipProps,\n        };\n\n  return <ToolTip {...(wrapperProps as ToolTipProps)}>{children}</ToolTip>;\n};\n"]} */");
 export const List = /*#__PURE__*/forwardRef(({
   context = true,
   m = 0,
   root = true,
@@ -105,12 +105,12 @@
   selected: {
     bg: 'background-selected'
   },
   active: {
-    fontWeight: 700
+    fontWeight: 'title'
   },
   'active-navlink': {
-    fontWeight: 700,
+    fontWeight: 'title',
     bg: 'background-selected',
     [Selectors.BEFORE]: {
       content: "''",
       bg: 'secondary'
@@ -155,13 +155,13 @@
 });
 export const ListItem = /*#__PURE__*/_styled('li', _extends({}, {
   target: "e1dfahz22",
   label: "ListItem"
-}, styledOptions()))(interactiveVariants, activeStates, sizeVariants, sharedStates, listProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Menu/elements.tsx"],"names":[],"mappings":"AAyMwB","file":"../../src/Menu/elements.tsx","sourcesContent":["import {\n  styledOptions,\n  system,\n  transitionConcat,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport isObject from 'lodash/isObject';\nimport { ComponentProps, forwardRef } from 'react';\n\nimport { sharedStates } from '../Box/props';\nimport { resetStyles, Selectors } from '../ButtonBase/ButtonBase';\nimport { ToolTip, ToolTipProps } from '../Tip/ToolTip';\nimport { MenuItem } from './MenuItem';\n\nenum MenuItemSelectors {\n  OUTLINE = '&:after',\n  OUTLINE_FOCUS_VISIBLE = '&:focus-visible:after',\n}\n\ntype ListStyleProps = StyleProps<typeof listProps>;\n\ntype StyleStateProps = StyleProps<typeof sharedStates>;\n\nconst listProps = variance.compose(\n  system.layout,\n  system.typography,\n  system.space,\n  system.positioning,\n  system.border,\n  system.color\n);\n\nexport interface ListProps extends ListStyleProps, StyleStateProps {\n  /** How offset spacing should be */\n  spacing?: 'normal' | 'condensed';\n  /** Menu variants for specific use cases and styles */\n  variant?: 'popover' | 'fixed';\n  /** is root menu */\n  root?: boolean;\n  /** bordered */\n  as?: 'ul' | 'ol';\n  showBorder?: boolean;\n}\n\nconst StyledList = styled('ul', styledOptions<'ul'>())<ListProps>(\n  system.css({\n    listStyle: 'none',\n    width: 1,\n    bg: 'inherit',\n    display: 'inline-block',\n    pl: 24,\n    WebkitFontSmoothing: 'antialiased',\n    MozOsxFontSmoothing: 'grayscale',\n  }),\n  system.states({\n    root: {\n      bg: 'background',\n      p: 0,\n    },\n    showBorder: {\n      border: 1,\n      borderRadius: 'sm',\n    },\n  }),\n  sharedStates,\n  listProps\n);\n\nexport const List = forwardRef<\n  HTMLUListElement,\n  ComponentProps<typeof StyledList>\n>(({ context = true, m = 0, root = true, variant, ...rest }, ref) => (\n  <StyledList\n    context={context}\n    m={m}\n    ref={ref}\n    root={root}\n    showBorder={variant !== 'fixed'}\n    variant={variant}\n    {...rest}\n  />\n));\n\nconst interactiveVariants = system.variant({\n  base: {\n    display: 'flex',\n    alignItems: 'center',\n    cursor: 'pointer',\n    width: 1,\n    zIndex: 1,\n    px: 24,\n    py: 12,\n    position: 'relative',\n    transition: transitionConcat(\n      ['color', 'background-color', 'border-color'],\n      'fast',\n      'linear'\n    ),\n    [Selectors.FOCUS_VISIBLE]: {\n      outline: 'none',\n    },\n    [MenuItemSelectors.OUTLINE]: {\n      content: \"''\",\n      position: 'absolute',\n      inset: 4,\n      borderRadius: 'md',\n      border: 2,\n      borderColor: 'primary',\n      opacity: 0,\n      zIndex: -1,\n    },\n    [MenuItemSelectors.OUTLINE_FOCUS_VISIBLE]: {\n      opacity: 1,\n    },\n  },\n  variants: {\n    select: {\n      [Selectors.DISABLED]: {\n        pointerEvents: 'none',\n      },\n      [Selectors.HOVER]: {\n        bg: 'background-hover',\n      },\n    },\n    link: {\n      [Selectors.BEFORE]: {\n        bg: 'inherit',\n        position: 'absolute',\n        display: 'inline-block',\n        left: 0,\n        width: 6,\n      },\n      [Selectors.HOVER]: {\n        textColor: 'primary',\n      },\n    },\n  },\n});\n\nconst activeStates = system.states({\n  selected: {\n    bg: 'background-selected',\n  },\n  active: {\n    fontWeight: 700,\n  },\n  'active-navlink': {\n    fontWeight: 700,\n    bg: 'background-selected',\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'secondary',\n    },\n  },\n  // Is named isDisabled to avoid conflicts with the HTML `disabled` attribute\n  isDisabled: {\n    bg: 'inherit',\n    cursor: 'not-allowed',\n    fontWeight: 400,\n    textColor: 'text-disabled',\n    [Selectors.HOVER]: {\n      textColor: 'text-disabled',\n      textDecoration: 'none',\n    },\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'inherit',\n    },\n  },\n});\n\nconst sizeVariants = system.variant({\n  prop: 'spacing',\n  variants: {\n    condensed: {\n      lineHeight: 'title',\n      minHeight: 40,\n      py: 8,\n      fontSize: 14,\n      [Selectors.BEFORE]: {\n        minHeight: 40,\n      },\n    },\n    normal: {\n      fontSize: 16,\n      minHeight: 48,\n      [Selectors.BEFORE]: {\n        minHeight: 48,\n      },\n    },\n  },\n});\n\nexport interface ListItemProps\n  extends ListStyleProps,\n    StyleStateProps,\n    StyleProps<typeof interactiveVariants>,\n    StyleProps<typeof activeStates>,\n    StyleProps<typeof sizeVariants> {}\n\nexport const ListItem = styled('li', styledOptions<'li'>())<ListItemProps>(\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport interface ListLinkProps extends ListItemProps {\n  active?: boolean;\n  navlink?: boolean;\n}\n\nconst StyledListLink = styled('a', styledOptions<'a'>())<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const ListLink = forwardRef<\n  HTMLAnchorElement,\n  ComponentProps<typeof StyledListLink>\n>(({ zIndex = 1, ...rest }, ref) => (\n  <StyledListLink ref={ref} zIndex={zIndex} {...rest} />\n));\n\nexport const ListButton = styled(\n  'button',\n  styledOptions<'button'>()\n)<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const MenuToolTipWrapper: React.FC<\n  Pick<ComponentProps<typeof MenuItem>, 'children' | 'label'> & {\n    tipId: string;\n  }\n> = ({ children, label, tipId }) => {\n  if (!label) {\n    return <>{children}</>;\n  }\n\n  const defaultTipProps = {\n    placement: 'floating',\n    id: tipId,\n    inheritDims: true,\n    shouldRenderAriaTip: false,\n  };\n\n  const wrapperProps =\n    label && isObject(label)\n      ? {\n          ...defaultTipProps,\n          ...label,\n        }\n      : {\n          info: label,\n          ...defaultTipProps,\n        };\n\n  return <ToolTip {...(wrapperProps as ToolTipProps)}>{children}</ToolTip>;\n};\n"]} */");
+}, styledOptions()))(interactiveVariants, activeStates, sizeVariants, sharedStates, listProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Menu/elements.tsx"],"names":[],"mappings":"AAyMwB","file":"../../src/Menu/elements.tsx","sourcesContent":["import {\n  styledOptions,\n  system,\n  transitionConcat,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport isObject from 'lodash/isObject';\nimport { ComponentProps, forwardRef } from 'react';\n\nimport { sharedStates } from '../Box/props';\nimport { resetStyles, Selectors } from '../ButtonBase/ButtonBase';\nimport { ToolTip, ToolTipProps } from '../Tip/ToolTip';\nimport { MenuItem } from './MenuItem';\n\nenum MenuItemSelectors {\n  OUTLINE = '&:after',\n  OUTLINE_FOCUS_VISIBLE = '&:focus-visible:after',\n}\n\ntype ListStyleProps = StyleProps<typeof listProps>;\n\ntype StyleStateProps = StyleProps<typeof sharedStates>;\n\nconst listProps = variance.compose(\n  system.layout,\n  system.typography,\n  system.space,\n  system.positioning,\n  system.border,\n  system.color\n);\n\nexport interface ListProps extends ListStyleProps, StyleStateProps {\n  /** How offset spacing should be */\n  spacing?: 'normal' | 'condensed';\n  /** Menu variants for specific use cases and styles */\n  variant?: 'popover' | 'fixed';\n  /** is root menu */\n  root?: boolean;\n  /** bordered */\n  as?: 'ul' | 'ol';\n  showBorder?: boolean;\n}\n\nconst StyledList = styled('ul', styledOptions<'ul'>())<ListProps>(\n  system.css({\n    listStyle: 'none',\n    width: 1,\n    bg: 'inherit',\n    display: 'inline-block',\n    pl: 24,\n    WebkitFontSmoothing: 'antialiased',\n    MozOsxFontSmoothing: 'grayscale',\n  }),\n  system.states({\n    root: {\n      bg: 'background',\n      p: 0,\n    },\n    showBorder: {\n      border: 1,\n      borderRadius: 'sm',\n    },\n  }),\n  sharedStates,\n  listProps\n);\n\nexport const List = forwardRef<\n  HTMLUListElement,\n  ComponentProps<typeof StyledList>\n>(({ context = true, m = 0, root = true, variant, ...rest }, ref) => (\n  <StyledList\n    context={context}\n    m={m}\n    ref={ref}\n    root={root}\n    showBorder={variant !== 'fixed'}\n    variant={variant}\n    {...rest}\n  />\n));\n\nconst interactiveVariants = system.variant({\n  base: {\n    display: 'flex',\n    alignItems: 'center',\n    cursor: 'pointer',\n    width: 1,\n    zIndex: 1,\n    px: 24,\n    py: 12,\n    position: 'relative',\n    transition: transitionConcat(\n      ['color', 'background-color', 'border-color'],\n      'fast',\n      'linear'\n    ),\n    [Selectors.FOCUS_VISIBLE]: {\n      outline: 'none',\n    },\n    [MenuItemSelectors.OUTLINE]: {\n      content: \"''\",\n      position: 'absolute',\n      inset: 4,\n      borderRadius: 'md',\n      border: 2,\n      borderColor: 'primary',\n      opacity: 0,\n      zIndex: -1,\n    },\n    [MenuItemSelectors.OUTLINE_FOCUS_VISIBLE]: {\n      opacity: 1,\n    },\n  },\n  variants: {\n    select: {\n      [Selectors.DISABLED]: {\n        pointerEvents: 'none',\n      },\n      [Selectors.HOVER]: {\n        bg: 'background-hover',\n      },\n    },\n    link: {\n      [Selectors.BEFORE]: {\n        bg: 'inherit',\n        position: 'absolute',\n        display: 'inline-block',\n        left: 0,\n        width: 6,\n      },\n      [Selectors.HOVER]: {\n        textColor: 'primary',\n      },\n    },\n  },\n});\n\nconst activeStates = system.states({\n  selected: {\n    bg: 'background-selected',\n  },\n  active: {\n    fontWeight: 'title',\n  },\n  'active-navlink': {\n    fontWeight: 'title',\n    bg: 'background-selected',\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'secondary',\n    },\n  },\n  // Is named isDisabled to avoid conflicts with the HTML `disabled` attribute\n  isDisabled: {\n    bg: 'inherit',\n    cursor: 'not-allowed',\n    fontWeight: 400,\n    textColor: 'text-disabled',\n    [Selectors.HOVER]: {\n      textColor: 'text-disabled',\n      textDecoration: 'none',\n    },\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'inherit',\n    },\n  },\n});\n\nconst sizeVariants = system.variant({\n  prop: 'spacing',\n  variants: {\n    condensed: {\n      lineHeight: 'title',\n      minHeight: 40,\n      py: 8,\n      fontSize: 14,\n      [Selectors.BEFORE]: {\n        minHeight: 40,\n      },\n    },\n    normal: {\n      fontSize: 16,\n      minHeight: 48,\n      [Selectors.BEFORE]: {\n        minHeight: 48,\n      },\n    },\n  },\n});\n\nexport interface ListItemProps\n  extends ListStyleProps,\n    StyleStateProps,\n    StyleProps<typeof interactiveVariants>,\n    StyleProps<typeof activeStates>,\n    StyleProps<typeof sizeVariants> {}\n\nexport const ListItem = styled('li', styledOptions<'li'>())<ListItemProps>(\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport interface ListLinkProps extends ListItemProps {\n  active?: boolean;\n  navlink?: boolean;\n}\n\nconst StyledListLink = styled('a', styledOptions<'a'>())<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const ListLink = forwardRef<\n  HTMLAnchorElement,\n  ComponentProps<typeof StyledListLink>\n>(({ zIndex = 1, ...rest }, ref) => (\n  <StyledListLink ref={ref} zIndex={zIndex} {...rest} />\n));\n\nexport const ListButton = styled(\n  'button',\n  styledOptions<'button'>()\n)<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const MenuToolTipWrapper: React.FC<\n  Pick<ComponentProps<typeof MenuItem>, 'children' | 'label'> & {\n    tipId: string;\n  }\n> = ({ children, label, tipId }) => {\n  if (!label) {\n    return <>{children}</>;\n  }\n\n  const defaultTipProps = {\n    placement: 'floating',\n    id: tipId,\n    inheritDims: true,\n    shouldRenderAriaTip: false,\n  };\n\n  const wrapperProps =\n    label && isObject(label)\n      ? {\n          ...defaultTipProps,\n          ...label,\n        }\n      : {\n          info: label,\n          ...defaultTipProps,\n        };\n\n  return <ToolTip {...(wrapperProps as ToolTipProps)}>{children}</ToolTip>;\n};\n"]} */");
 const StyledListLink = /*#__PURE__*/_styled('a', _extends({}, {
   target: "e1dfahz21",
   label: "StyledListLink"
-}, styledOptions()))(resetStyles, interactiveVariants, activeStates, sizeVariants, sharedStates, listProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Menu/elements.tsx"],"names":[],"mappings":"AAsNuB","file":"../../src/Menu/elements.tsx","sourcesContent":["import {\n  styledOptions,\n  system,\n  transitionConcat,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport isObject from 'lodash/isObject';\nimport { ComponentProps, forwardRef } from 'react';\n\nimport { sharedStates } from '../Box/props';\nimport { resetStyles, Selectors } from '../ButtonBase/ButtonBase';\nimport { ToolTip, ToolTipProps } from '../Tip/ToolTip';\nimport { MenuItem } from './MenuItem';\n\nenum MenuItemSelectors {\n  OUTLINE = '&:after',\n  OUTLINE_FOCUS_VISIBLE = '&:focus-visible:after',\n}\n\ntype ListStyleProps = StyleProps<typeof listProps>;\n\ntype StyleStateProps = StyleProps<typeof sharedStates>;\n\nconst listProps = variance.compose(\n  system.layout,\n  system.typography,\n  system.space,\n  system.positioning,\n  system.border,\n  system.color\n);\n\nexport interface ListProps extends ListStyleProps, StyleStateProps {\n  /** How offset spacing should be */\n  spacing?: 'normal' | 'condensed';\n  /** Menu variants for specific use cases and styles */\n  variant?: 'popover' | 'fixed';\n  /** is root menu */\n  root?: boolean;\n  /** bordered */\n  as?: 'ul' | 'ol';\n  showBorder?: boolean;\n}\n\nconst StyledList = styled('ul', styledOptions<'ul'>())<ListProps>(\n  system.css({\n    listStyle: 'none',\n    width: 1,\n    bg: 'inherit',\n    display: 'inline-block',\n    pl: 24,\n    WebkitFontSmoothing: 'antialiased',\n    MozOsxFontSmoothing: 'grayscale',\n  }),\n  system.states({\n    root: {\n      bg: 'background',\n      p: 0,\n    },\n    showBorder: {\n      border: 1,\n      borderRadius: 'sm',\n    },\n  }),\n  sharedStates,\n  listProps\n);\n\nexport const List = forwardRef<\n  HTMLUListElement,\n  ComponentProps<typeof StyledList>\n>(({ context = true, m = 0, root = true, variant, ...rest }, ref) => (\n  <StyledList\n    context={context}\n    m={m}\n    ref={ref}\n    root={root}\n    showBorder={variant !== 'fixed'}\n    variant={variant}\n    {...rest}\n  />\n));\n\nconst interactiveVariants = system.variant({\n  base: {\n    display: 'flex',\n    alignItems: 'center',\n    cursor: 'pointer',\n    width: 1,\n    zIndex: 1,\n    px: 24,\n    py: 12,\n    position: 'relative',\n    transition: transitionConcat(\n      ['color', 'background-color', 'border-color'],\n      'fast',\n      'linear'\n    ),\n    [Selectors.FOCUS_VISIBLE]: {\n      outline: 'none',\n    },\n    [MenuItemSelectors.OUTLINE]: {\n      content: \"''\",\n      position: 'absolute',\n      inset: 4,\n      borderRadius: 'md',\n      border: 2,\n      borderColor: 'primary',\n      opacity: 0,\n      zIndex: -1,\n    },\n    [MenuItemSelectors.OUTLINE_FOCUS_VISIBLE]: {\n      opacity: 1,\n    },\n  },\n  variants: {\n    select: {\n      [Selectors.DISABLED]: {\n        pointerEvents: 'none',\n      },\n      [Selectors.HOVER]: {\n        bg: 'background-hover',\n      },\n    },\n    link: {\n      [Selectors.BEFORE]: {\n        bg: 'inherit',\n        position: 'absolute',\n        display: 'inline-block',\n        left: 0,\n        width: 6,\n      },\n      [Selectors.HOVER]: {\n        textColor: 'primary',\n      },\n    },\n  },\n});\n\nconst activeStates = system.states({\n  selected: {\n    bg: 'background-selected',\n  },\n  active: {\n    fontWeight: 700,\n  },\n  'active-navlink': {\n    fontWeight: 700,\n    bg: 'background-selected',\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'secondary',\n    },\n  },\n  // Is named isDisabled to avoid conflicts with the HTML `disabled` attribute\n  isDisabled: {\n    bg: 'inherit',\n    cursor: 'not-allowed',\n    fontWeight: 400,\n    textColor: 'text-disabled',\n    [Selectors.HOVER]: {\n      textColor: 'text-disabled',\n      textDecoration: 'none',\n    },\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'inherit',\n    },\n  },\n});\n\nconst sizeVariants = system.variant({\n  prop: 'spacing',\n  variants: {\n    condensed: {\n      lineHeight: 'title',\n      minHeight: 40,\n      py: 8,\n      fontSize: 14,\n      [Selectors.BEFORE]: {\n        minHeight: 40,\n      },\n    },\n    normal: {\n      fontSize: 16,\n      minHeight: 48,\n      [Selectors.BEFORE]: {\n        minHeight: 48,\n      },\n    },\n  },\n});\n\nexport interface ListItemProps\n  extends ListStyleProps,\n    StyleStateProps,\n    StyleProps<typeof interactiveVariants>,\n    StyleProps<typeof activeStates>,\n    StyleProps<typeof sizeVariants> {}\n\nexport const ListItem = styled('li', styledOptions<'li'>())<ListItemProps>(\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport interface ListLinkProps extends ListItemProps {\n  active?: boolean;\n  navlink?: boolean;\n}\n\nconst StyledListLink = styled('a', styledOptions<'a'>())<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const ListLink = forwardRef<\n  HTMLAnchorElement,\n  ComponentProps<typeof StyledListLink>\n>(({ zIndex = 1, ...rest }, ref) => (\n  <StyledListLink ref={ref} zIndex={zIndex} {...rest} />\n));\n\nexport const ListButton = styled(\n  'button',\n  styledOptions<'button'>()\n)<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const MenuToolTipWrapper: React.FC<\n  Pick<ComponentProps<typeof MenuItem>, 'children' | 'label'> & {\n    tipId: string;\n  }\n> = ({ children, label, tipId }) => {\n  if (!label) {\n    return <>{children}</>;\n  }\n\n  const defaultTipProps = {\n    placement: 'floating',\n    id: tipId,\n    inheritDims: true,\n    shouldRenderAriaTip: false,\n  };\n\n  const wrapperProps =\n    label && isObject(label)\n      ? {\n          ...defaultTipProps,\n          ...label,\n        }\n      : {\n          info: label,\n          ...defaultTipProps,\n        };\n\n  return <ToolTip {...(wrapperProps as ToolTipProps)}>{children}</ToolTip>;\n};\n"]} */");
+}, styledOptions()))(resetStyles, interactiveVariants, activeStates, sizeVariants, sharedStates, listProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Menu/elements.tsx"],"names":[],"mappings":"AAsNuB","file":"../../src/Menu/elements.tsx","sourcesContent":["import {\n  styledOptions,\n  system,\n  transitionConcat,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport isObject from 'lodash/isObject';\nimport { ComponentProps, forwardRef } from 'react';\n\nimport { sharedStates } from '../Box/props';\nimport { resetStyles, Selectors } from '../ButtonBase/ButtonBase';\nimport { ToolTip, ToolTipProps } from '../Tip/ToolTip';\nimport { MenuItem } from './MenuItem';\n\nenum MenuItemSelectors {\n  OUTLINE = '&:after',\n  OUTLINE_FOCUS_VISIBLE = '&:focus-visible:after',\n}\n\ntype ListStyleProps = StyleProps<typeof listProps>;\n\ntype StyleStateProps = StyleProps<typeof sharedStates>;\n\nconst listProps = variance.compose(\n  system.layout,\n  system.typography,\n  system.space,\n  system.positioning,\n  system.border,\n  system.color\n);\n\nexport interface ListProps extends ListStyleProps, StyleStateProps {\n  /** How offset spacing should be */\n  spacing?: 'normal' | 'condensed';\n  /** Menu variants for specific use cases and styles */\n  variant?: 'popover' | 'fixed';\n  /** is root menu */\n  root?: boolean;\n  /** bordered */\n  as?: 'ul' | 'ol';\n  showBorder?: boolean;\n}\n\nconst StyledList = styled('ul', styledOptions<'ul'>())<ListProps>(\n  system.css({\n    listStyle: 'none',\n    width: 1,\n    bg: 'inherit',\n    display: 'inline-block',\n    pl: 24,\n    WebkitFontSmoothing: 'antialiased',\n    MozOsxFontSmoothing: 'grayscale',\n  }),\n  system.states({\n    root: {\n      bg: 'background',\n      p: 0,\n    },\n    showBorder: {\n      border: 1,\n      borderRadius: 'sm',\n    },\n  }),\n  sharedStates,\n  listProps\n);\n\nexport const List = forwardRef<\n  HTMLUListElement,\n  ComponentProps<typeof StyledList>\n>(({ context = true, m = 0, root = true, variant, ...rest }, ref) => (\n  <StyledList\n    context={context}\n    m={m}\n    ref={ref}\n    root={root}\n    showBorder={variant !== 'fixed'}\n    variant={variant}\n    {...rest}\n  />\n));\n\nconst interactiveVariants = system.variant({\n  base: {\n    display: 'flex',\n    alignItems: 'center',\n    cursor: 'pointer',\n    width: 1,\n    zIndex: 1,\n    px: 24,\n    py: 12,\n    position: 'relative',\n    transition: transitionConcat(\n      ['color', 'background-color', 'border-color'],\n      'fast',\n      'linear'\n    ),\n    [Selectors.FOCUS_VISIBLE]: {\n      outline: 'none',\n    },\n    [MenuItemSelectors.OUTLINE]: {\n      content: \"''\",\n      position: 'absolute',\n      inset: 4,\n      borderRadius: 'md',\n      border: 2,\n      borderColor: 'primary',\n      opacity: 0,\n      zIndex: -1,\n    },\n    [MenuItemSelectors.OUTLINE_FOCUS_VISIBLE]: {\n      opacity: 1,\n    },\n  },\n  variants: {\n    select: {\n      [Selectors.DISABLED]: {\n        pointerEvents: 'none',\n      },\n      [Selectors.HOVER]: {\n        bg: 'background-hover',\n      },\n    },\n    link: {\n      [Selectors.BEFORE]: {\n        bg: 'inherit',\n        position: 'absolute',\n        display: 'inline-block',\n        left: 0,\n        width: 6,\n      },\n      [Selectors.HOVER]: {\n        textColor: 'primary',\n      },\n    },\n  },\n});\n\nconst activeStates = system.states({\n  selected: {\n    bg: 'background-selected',\n  },\n  active: {\n    fontWeight: 'title',\n  },\n  'active-navlink': {\n    fontWeight: 'title',\n    bg: 'background-selected',\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'secondary',\n    },\n  },\n  // Is named isDisabled to avoid conflicts with the HTML `disabled` attribute\n  isDisabled: {\n    bg: 'inherit',\n    cursor: 'not-allowed',\n    fontWeight: 400,\n    textColor: 'text-disabled',\n    [Selectors.HOVER]: {\n      textColor: 'text-disabled',\n      textDecoration: 'none',\n    },\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'inherit',\n    },\n  },\n});\n\nconst sizeVariants = system.variant({\n  prop: 'spacing',\n  variants: {\n    condensed: {\n      lineHeight: 'title',\n      minHeight: 40,\n      py: 8,\n      fontSize: 14,\n      [Selectors.BEFORE]: {\n        minHeight: 40,\n      },\n    },\n    normal: {\n      fontSize: 16,\n      minHeight: 48,\n      [Selectors.BEFORE]: {\n        minHeight: 48,\n      },\n    },\n  },\n});\n\nexport interface ListItemProps\n  extends ListStyleProps,\n    StyleStateProps,\n    StyleProps<typeof interactiveVariants>,\n    StyleProps<typeof activeStates>,\n    StyleProps<typeof sizeVariants> {}\n\nexport const ListItem = styled('li', styledOptions<'li'>())<ListItemProps>(\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport interface ListLinkProps extends ListItemProps {\n  active?: boolean;\n  navlink?: boolean;\n}\n\nconst StyledListLink = styled('a', styledOptions<'a'>())<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const ListLink = forwardRef<\n  HTMLAnchorElement,\n  ComponentProps<typeof StyledListLink>\n>(({ zIndex = 1, ...rest }, ref) => (\n  <StyledListLink ref={ref} zIndex={zIndex} {...rest} />\n));\n\nexport const ListButton = styled(\n  'button',\n  styledOptions<'button'>()\n)<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const MenuToolTipWrapper: React.FC<\n  Pick<ComponentProps<typeof MenuItem>, 'children' | 'label'> & {\n    tipId: string;\n  }\n> = ({ children, label, tipId }) => {\n  if (!label) {\n    return <>{children}</>;\n  }\n\n  const defaultTipProps = {\n    placement: 'floating',\n    id: tipId,\n    inheritDims: true,\n    shouldRenderAriaTip: false,\n  };\n\n  const wrapperProps =\n    label && isObject(label)\n      ? {\n          ...defaultTipProps,\n          ...label,\n        }\n      : {\n          info: label,\n          ...defaultTipProps,\n        };\n\n  return <ToolTip {...(wrapperProps as ToolTipProps)}>{children}</ToolTip>;\n};\n"]} */");
 export const ListLink = /*#__PURE__*/forwardRef(({
   zIndex = 1,
   ...rest
 }, ref) => /*#__PURE__*/_jsx(StyledListLink, {
@@ -171,9 +171,9 @@
 }));
 export const ListButton = /*#__PURE__*/_styled('button', _extends({}, {
   target: "e1dfahz20",
   label: "ListButton"
-}, styledOptions()))(resetStyles, interactiveVariants, activeStates, sizeVariants, sharedStates, listProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Menu/elements.tsx"],"names":[],"mappings":"AAsO0B","file":"../../src/Menu/elements.tsx","sourcesContent":["import {\n  styledOptions,\n  system,\n  transitionConcat,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport isObject from 'lodash/isObject';\nimport { ComponentProps, forwardRef } from 'react';\n\nimport { sharedStates } from '../Box/props';\nimport { resetStyles, Selectors } from '../ButtonBase/ButtonBase';\nimport { ToolTip, ToolTipProps } from '../Tip/ToolTip';\nimport { MenuItem } from './MenuItem';\n\nenum MenuItemSelectors {\n  OUTLINE = '&:after',\n  OUTLINE_FOCUS_VISIBLE = '&:focus-visible:after',\n}\n\ntype ListStyleProps = StyleProps<typeof listProps>;\n\ntype StyleStateProps = StyleProps<typeof sharedStates>;\n\nconst listProps = variance.compose(\n  system.layout,\n  system.typography,\n  system.space,\n  system.positioning,\n  system.border,\n  system.color\n);\n\nexport interface ListProps extends ListStyleProps, StyleStateProps {\n  /** How offset spacing should be */\n  spacing?: 'normal' | 'condensed';\n  /** Menu variants for specific use cases and styles */\n  variant?: 'popover' | 'fixed';\n  /** is root menu */\n  root?: boolean;\n  /** bordered */\n  as?: 'ul' | 'ol';\n  showBorder?: boolean;\n}\n\nconst StyledList = styled('ul', styledOptions<'ul'>())<ListProps>(\n  system.css({\n    listStyle: 'none',\n    width: 1,\n    bg: 'inherit',\n    display: 'inline-block',\n    pl: 24,\n    WebkitFontSmoothing: 'antialiased',\n    MozOsxFontSmoothing: 'grayscale',\n  }),\n  system.states({\n    root: {\n      bg: 'background',\n      p: 0,\n    },\n    showBorder: {\n      border: 1,\n      borderRadius: 'sm',\n    },\n  }),\n  sharedStates,\n  listProps\n);\n\nexport const List = forwardRef<\n  HTMLUListElement,\n  ComponentProps<typeof StyledList>\n>(({ context = true, m = 0, root = true, variant, ...rest }, ref) => (\n  <StyledList\n    context={context}\n    m={m}\n    ref={ref}\n    root={root}\n    showBorder={variant !== 'fixed'}\n    variant={variant}\n    {...rest}\n  />\n));\n\nconst interactiveVariants = system.variant({\n  base: {\n    display: 'flex',\n    alignItems: 'center',\n    cursor: 'pointer',\n    width: 1,\n    zIndex: 1,\n    px: 24,\n    py: 12,\n    position: 'relative',\n    transition: transitionConcat(\n      ['color', 'background-color', 'border-color'],\n      'fast',\n      'linear'\n    ),\n    [Selectors.FOCUS_VISIBLE]: {\n      outline: 'none',\n    },\n    [MenuItemSelectors.OUTLINE]: {\n      content: \"''\",\n      position: 'absolute',\n      inset: 4,\n      borderRadius: 'md',\n      border: 2,\n      borderColor: 'primary',\n      opacity: 0,\n      zIndex: -1,\n    },\n    [MenuItemSelectors.OUTLINE_FOCUS_VISIBLE]: {\n      opacity: 1,\n    },\n  },\n  variants: {\n    select: {\n      [Selectors.DISABLED]: {\n        pointerEvents: 'none',\n      },\n      [Selectors.HOVER]: {\n        bg: 'background-hover',\n      },\n    },\n    link: {\n      [Selectors.BEFORE]: {\n        bg: 'inherit',\n        position: 'absolute',\n        display: 'inline-block',\n        left: 0,\n        width: 6,\n      },\n      [Selectors.HOVER]: {\n        textColor: 'primary',\n      },\n    },\n  },\n});\n\nconst activeStates = system.states({\n  selected: {\n    bg: 'background-selected',\n  },\n  active: {\n    fontWeight: 700,\n  },\n  'active-navlink': {\n    fontWeight: 700,\n    bg: 'background-selected',\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'secondary',\n    },\n  },\n  // Is named isDisabled to avoid conflicts with the HTML `disabled` attribute\n  isDisabled: {\n    bg: 'inherit',\n    cursor: 'not-allowed',\n    fontWeight: 400,\n    textColor: 'text-disabled',\n    [Selectors.HOVER]: {\n      textColor: 'text-disabled',\n      textDecoration: 'none',\n    },\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'inherit',\n    },\n  },\n});\n\nconst sizeVariants = system.variant({\n  prop: 'spacing',\n  variants: {\n    condensed: {\n      lineHeight: 'title',\n      minHeight: 40,\n      py: 8,\n      fontSize: 14,\n      [Selectors.BEFORE]: {\n        minHeight: 40,\n      },\n    },\n    normal: {\n      fontSize: 16,\n      minHeight: 48,\n      [Selectors.BEFORE]: {\n        minHeight: 48,\n      },\n    },\n  },\n});\n\nexport interface ListItemProps\n  extends ListStyleProps,\n    StyleStateProps,\n    StyleProps<typeof interactiveVariants>,\n    StyleProps<typeof activeStates>,\n    StyleProps<typeof sizeVariants> {}\n\nexport const ListItem = styled('li', styledOptions<'li'>())<ListItemProps>(\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport interface ListLinkProps extends ListItemProps {\n  active?: boolean;\n  navlink?: boolean;\n}\n\nconst StyledListLink = styled('a', styledOptions<'a'>())<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const ListLink = forwardRef<\n  HTMLAnchorElement,\n  ComponentProps<typeof StyledListLink>\n>(({ zIndex = 1, ...rest }, ref) => (\n  <StyledListLink ref={ref} zIndex={zIndex} {...rest} />\n));\n\nexport const ListButton = styled(\n  'button',\n  styledOptions<'button'>()\n)<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const MenuToolTipWrapper: React.FC<\n  Pick<ComponentProps<typeof MenuItem>, 'children' | 'label'> & {\n    tipId: string;\n  }\n> = ({ children, label, tipId }) => {\n  if (!label) {\n    return <>{children}</>;\n  }\n\n  const defaultTipProps = {\n    placement: 'floating',\n    id: tipId,\n    inheritDims: true,\n    shouldRenderAriaTip: false,\n  };\n\n  const wrapperProps =\n    label && isObject(label)\n      ? {\n          ...defaultTipProps,\n          ...label,\n        }\n      : {\n          info: label,\n          ...defaultTipProps,\n        };\n\n  return <ToolTip {...(wrapperProps as ToolTipProps)}>{children}</ToolTip>;\n};\n"]} */");
+}, styledOptions()))(resetStyles, interactiveVariants, activeStates, sizeVariants, sharedStates, listProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Menu/elements.tsx"],"names":[],"mappings":"AAsO0B","file":"../../src/Menu/elements.tsx","sourcesContent":["import {\n  styledOptions,\n  system,\n  transitionConcat,\n} from '@codecademy/gamut-styles';\nimport { StyleProps, variance } from '@codecademy/variance';\nimport styled from '@emotion/styled';\nimport isObject from 'lodash/isObject';\nimport { ComponentProps, forwardRef } from 'react';\n\nimport { sharedStates } from '../Box/props';\nimport { resetStyles, Selectors } from '../ButtonBase/ButtonBase';\nimport { ToolTip, ToolTipProps } from '../Tip/ToolTip';\nimport { MenuItem } from './MenuItem';\n\nenum MenuItemSelectors {\n  OUTLINE = '&:after',\n  OUTLINE_FOCUS_VISIBLE = '&:focus-visible:after',\n}\n\ntype ListStyleProps = StyleProps<typeof listProps>;\n\ntype StyleStateProps = StyleProps<typeof sharedStates>;\n\nconst listProps = variance.compose(\n  system.layout,\n  system.typography,\n  system.space,\n  system.positioning,\n  system.border,\n  system.color\n);\n\nexport interface ListProps extends ListStyleProps, StyleStateProps {\n  /** How offset spacing should be */\n  spacing?: 'normal' | 'condensed';\n  /** Menu variants for specific use cases and styles */\n  variant?: 'popover' | 'fixed';\n  /** is root menu */\n  root?: boolean;\n  /** bordered */\n  as?: 'ul' | 'ol';\n  showBorder?: boolean;\n}\n\nconst StyledList = styled('ul', styledOptions<'ul'>())<ListProps>(\n  system.css({\n    listStyle: 'none',\n    width: 1,\n    bg: 'inherit',\n    display: 'inline-block',\n    pl: 24,\n    WebkitFontSmoothing: 'antialiased',\n    MozOsxFontSmoothing: 'grayscale',\n  }),\n  system.states({\n    root: {\n      bg: 'background',\n      p: 0,\n    },\n    showBorder: {\n      border: 1,\n      borderRadius: 'sm',\n    },\n  }),\n  sharedStates,\n  listProps\n);\n\nexport const List = forwardRef<\n  HTMLUListElement,\n  ComponentProps<typeof StyledList>\n>(({ context = true, m = 0, root = true, variant, ...rest }, ref) => (\n  <StyledList\n    context={context}\n    m={m}\n    ref={ref}\n    root={root}\n    showBorder={variant !== 'fixed'}\n    variant={variant}\n    {...rest}\n  />\n));\n\nconst interactiveVariants = system.variant({\n  base: {\n    display: 'flex',\n    alignItems: 'center',\n    cursor: 'pointer',\n    width: 1,\n    zIndex: 1,\n    px: 24,\n    py: 12,\n    position: 'relative',\n    transition: transitionConcat(\n      ['color', 'background-color', 'border-color'],\n      'fast',\n      'linear'\n    ),\n    [Selectors.FOCUS_VISIBLE]: {\n      outline: 'none',\n    },\n    [MenuItemSelectors.OUTLINE]: {\n      content: \"''\",\n      position: 'absolute',\n      inset: 4,\n      borderRadius: 'md',\n      border: 2,\n      borderColor: 'primary',\n      opacity: 0,\n      zIndex: -1,\n    },\n    [MenuItemSelectors.OUTLINE_FOCUS_VISIBLE]: {\n      opacity: 1,\n    },\n  },\n  variants: {\n    select: {\n      [Selectors.DISABLED]: {\n        pointerEvents: 'none',\n      },\n      [Selectors.HOVER]: {\n        bg: 'background-hover',\n      },\n    },\n    link: {\n      [Selectors.BEFORE]: {\n        bg: 'inherit',\n        position: 'absolute',\n        display: 'inline-block',\n        left: 0,\n        width: 6,\n      },\n      [Selectors.HOVER]: {\n        textColor: 'primary',\n      },\n    },\n  },\n});\n\nconst activeStates = system.states({\n  selected: {\n    bg: 'background-selected',\n  },\n  active: {\n    fontWeight: 'title',\n  },\n  'active-navlink': {\n    fontWeight: 'title',\n    bg: 'background-selected',\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'secondary',\n    },\n  },\n  // Is named isDisabled to avoid conflicts with the HTML `disabled` attribute\n  isDisabled: {\n    bg: 'inherit',\n    cursor: 'not-allowed',\n    fontWeight: 400,\n    textColor: 'text-disabled',\n    [Selectors.HOVER]: {\n      textColor: 'text-disabled',\n      textDecoration: 'none',\n    },\n    [Selectors.BEFORE]: {\n      content: \"''\",\n      bg: 'inherit',\n    },\n  },\n});\n\nconst sizeVariants = system.variant({\n  prop: 'spacing',\n  variants: {\n    condensed: {\n      lineHeight: 'title',\n      minHeight: 40,\n      py: 8,\n      fontSize: 14,\n      [Selectors.BEFORE]: {\n        minHeight: 40,\n      },\n    },\n    normal: {\n      fontSize: 16,\n      minHeight: 48,\n      [Selectors.BEFORE]: {\n        minHeight: 48,\n      },\n    },\n  },\n});\n\nexport interface ListItemProps\n  extends ListStyleProps,\n    StyleStateProps,\n    StyleProps<typeof interactiveVariants>,\n    StyleProps<typeof activeStates>,\n    StyleProps<typeof sizeVariants> {}\n\nexport const ListItem = styled('li', styledOptions<'li'>())<ListItemProps>(\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport interface ListLinkProps extends ListItemProps {\n  active?: boolean;\n  navlink?: boolean;\n}\n\nconst StyledListLink = styled('a', styledOptions<'a'>())<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const ListLink = forwardRef<\n  HTMLAnchorElement,\n  ComponentProps<typeof StyledListLink>\n>(({ zIndex = 1, ...rest }, ref) => (\n  <StyledListLink ref={ref} zIndex={zIndex} {...rest} />\n));\n\nexport const ListButton = styled(\n  'button',\n  styledOptions<'button'>()\n)<ListLinkProps>(\n  resetStyles,\n  interactiveVariants,\n  activeStates,\n  sizeVariants,\n  sharedStates,\n  listProps\n);\n\nexport const MenuToolTipWrapper: React.FC<\n  Pick<ComponentProps<typeof MenuItem>, 'children' | 'label'> & {\n    tipId: string;\n  }\n> = ({ children, label, tipId }) => {\n  if (!label) {\n    return <>{children}</>;\n  }\n\n  const defaultTipProps = {\n    placement: 'floating',\n    id: tipId,\n    inheritDims: true,\n    shouldRenderAriaTip: false,\n  };\n\n  const wrapperProps =\n    label && isObject(label)\n      ? {\n          ...defaultTipProps,\n          ...label,\n        }\n      : {\n          info: label,\n          ...defaultTipProps,\n        };\n\n  return <ToolTip {...(wrapperProps as ToolTipProps)}>{children}</ToolTip>;\n};\n"]} */");
 export const MenuToolTipWrapper = ({
   children,
   label,
   tipId
Index: package/dist/Tabs/TabButton.js
===================================================================
--- package/dist/Tabs/TabButton.js
+++ package/dist/Tabs/TabButton.js
@@ -2,9 +2,9 @@
 import { states, variant } from '@codecademy/gamut-styles';
 import { ButtonBase } from '../ButtonBase';
 import { tabElementBaseProps, TabSelectors } from './props';
 const tabSelectedStyles = {
-  fontWeight: 700,
+  fontWeight: 'title',
   pt: 12,
   pb: 8,
   borderBottomWidth: 4,
   borderColor: 'primary'
@@ -81,5 +81,5 @@
 });
 export const TabButton = /*#__PURE__*/_styled(ButtonBase, {
   target: "e1fxx1y10",
   label: "TabButton"
-})(tabVariants, tabStates, tabElementBaseProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9UYWJzL1RhYkJ1dHRvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0d5QiIsImZpbGUiOiIuLi8uLi9zcmMvVGFicy9UYWJCdXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgc3RhdGVzLCB2YXJpYW50IH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQtc3R5bGVzJztcbmltcG9ydCB7IFN0eWxlUHJvcHMgfSBmcm9tICdAY29kZWNhZGVteS92YXJpYW5jZSc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmltcG9ydCB7IEJ1dHRvbkJhc2UgfSBmcm9tICcuLi9CdXR0b25CYXNlJztcbmltcG9ydCB7XG4gIHRhYkVsZW1lbnRCYXNlUHJvcHMsXG4gIFRhYkVsZW1lbnRTdHlsZVByb3BzLFxuICBUYWJTZWxlY3RvcnMsXG59IGZyb20gJy4vcHJvcHMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFRhYkJ1dHRvblByb3BzXG4gIGV4dGVuZHMgU3R5bGVQcm9wczx0eXBlb2YgdGFiVmFyaWFudHM+LFxuICAgIFN0eWxlUHJvcHM8dHlwZW9mIHRhYlN0YXRlcz4sXG4gICAgVGFiRWxlbWVudFN0eWxlUHJvcHMge31cblxuY29uc3QgdGFiU2VsZWN0ZWRTdHlsZXMgPSB7XG4gIGZvbnRXZWlnaHQ6IDcwMCxcbiAgcHQ6IDEyLFxuICBwYjogOCxcbiAgYm9yZGVyQm90dG9tV2lkdGg6IDQsXG4gIGJvcmRlckNvbG9yOiAncHJpbWFyeScsXG59IGFzIGNvbnN0O1xuXG5jb25zdCBmb2N1c1Zpc2libGVTdHlsZXMgPSB7XG4gIFtUYWJTZWxlY3RvcnMuRk9DVVNfVklTSUJMRSArIFRhYlNlbGVjdG9ycy5CRUZPUkVdOiB7XG4gICAgY29udGVudDogJ1wiXCInLFxuICAgIGJvcmRlcjogMixcbiAgICBib3JkZXJDb2xvcjogJ3ByaW1hcnknLFxuICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgIGluc2V0OiAwLFxuICAgIHpJbmRleDogMCxcbiAgICBib3JkZXJSYWRpdXNUb3A6ICdtZCcsXG4gICAgYm9yZGVyUmFkaXVzQm90dG9tOiAnbm9uZScsXG4gIH0sXG59IGFzIGNvbnN0O1xuXG5leHBvcnQgY29uc3QgdGFiVmFyaWFudHMgPSB2YXJpYW50KHtcbiAgYmFzZToge1xuICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgIGRpc3BsYXk6ICdpbmxpbmUtZmxleCcsXG4gICAganVzdGlmeUNvbnRlbnQ6ICdjZW50ZXInLFxuICAgIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICAgIHdoaXRlU3BhY2U6ICdub3dyYXAnLFxuICAgIGJvcmRlclJhZGl1czogJ25vbmUnLFxuICAgIHB4OiAyNCxcbiAgICB0ZXh0T3ZlcmZsb3c6ICdlbGxpcHNpcycsXG4gICAgY29sb3I6ICd0ZXh0JyxcbiAgICBmb250OiAnaW5oZXJpdCcsXG4gICAgY3Vyc29yOiAncG9pbnRlcicsXG4gICAgekluZGV4OiAxLFxuICAgIFtUYWJTZWxlY3RvcnMuRElTQUJMRURdOiB7XG4gICAgICBvcGFjaXR5OiAwLjI1LFxuICAgICAgY3Vyc29yOiAnbm90LWFsbG93ZWQnLFxuICAgIH0sXG4gICAgLi4uZm9jdXNWaXNpYmxlU3R5bGVzLFxuICB9LFxuICB2YXJpYW50czoge1xuICAgIHN0YW5kYXJkOiB7XG4gICAgICBiYWNrZ3JvdW5kOiAnbm9uZScsXG4gICAgICBib3JkZXJDb2xvcjogJ2JvcmRlci1wcmltYXJ5JyxcbiAgICAgIGJvcmRlckxlZnQ6ICdub25lJyxcbiAgICAgIGJvcmRlclJpZ2h0OiAnbm9uZScsXG4gICAgICBib3JkZXJUb3A6ICdub25lJyxcbiAgICAgIGJvcmRlckJvdHRvbVN0eWxlOiAnc29saWQnLFxuICAgICAgYm9yZGVyQm90dG9tV2lkdGg6IDEsXG4gICAgICBmb250U2l6ZTogMTYsXG4gICAgICBmb250V2VpZ2h0OiA0MDAsXG4gICAgICBwdDogMTIsXG4gICAgICBwYjogMTEgYXMgMTIsIC8vIGJvcmRlciArIHBhZGRpbmcgPSAxMnB4XG4gICAgICBbVGFiU2VsZWN0b3JzLkhPVkVSXToge1xuICAgICAgICBiZzogJ2JhY2tncm91bmQtc2VsZWN0ZWQnLFxuICAgICAgfSxcbiAgICAgIFtUYWJTZWxlY3RvcnMuU0VMRUNURURdOiB7XG4gICAgICAgIC4uLnRhYlNlbGVjdGVkU3R5bGVzLFxuICAgICAgICBmb250V2VpZ2h0OiAnYm9sZCcsXG4gICAgICB9LFxuICAgIH0sXG4gICAgYmxvY2s6IHtcbiAgICAgIGZvbnRXZWlnaHQ6ICdub3JtYWwnLFxuICAgICAgZm9udFNpemU6IDE0LFxuICAgICAgcHk6IDEyLFxuICAgICAgW1RhYlNlbGVjdG9ycy5TRUxFQ1RFRF06IHtcbiAgICAgICAgYmc6ICdiYWNrZ3JvdW5kJyxcbiAgICAgICAgZm9udFdlaWdodDogJ2JvbGQnLFxuICAgICAgfSxcbiAgICB9LFxuICB9LFxufSk7XG5cbmV4cG9ydCBjb25zdCB0YWJTdGF0ZXMgPSBzdGF0ZXMoe1xuICBzZWxlY3RlZDoge1xuICAgIC4uLnRhYlNlbGVjdGVkU3R5bGVzLFxuICB9LFxufSk7XG5cbmV4cG9ydCBjb25zdCBUYWJCdXR0b24gPSBzdHlsZWQoQnV0dG9uQmFzZSk8VGFiQnV0dG9uUHJvcHM+KFxuICB0YWJWYXJpYW50cyxcbiAgdGFiU3RhdGVzLFxuICB0YWJFbGVtZW50QmFzZVByb3BzXG4pO1xuIl19 */");
\ No newline at end of file
+})(tabVariants, tabStates, tabElementBaseProps, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9UYWJzL1RhYkJ1dHRvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0d5QiIsImZpbGUiOiIuLi8uLi9zcmMvVGFicy9UYWJCdXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgc3RhdGVzLCB2YXJpYW50IH0gZnJvbSAnQGNvZGVjYWRlbXkvZ2FtdXQtc3R5bGVzJztcbmltcG9ydCB7IFN0eWxlUHJvcHMgfSBmcm9tICdAY29kZWNhZGVteS92YXJpYW5jZSc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmltcG9ydCB7IEJ1dHRvbkJhc2UgfSBmcm9tICcuLi9CdXR0b25CYXNlJztcbmltcG9ydCB7XG4gIHRhYkVsZW1lbnRCYXNlUHJvcHMsXG4gIFRhYkVsZW1lbnRTdHlsZVByb3BzLFxuICBUYWJTZWxlY3RvcnMsXG59IGZyb20gJy4vcHJvcHMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFRhYkJ1dHRvblByb3BzXG4gIGV4dGVuZHMgU3R5bGVQcm9wczx0eXBlb2YgdGFiVmFyaWFudHM+LFxuICAgIFN0eWxlUHJvcHM8dHlwZW9mIHRhYlN0YXRlcz4sXG4gICAgVGFiRWxlbWVudFN0eWxlUHJvcHMge31cblxuY29uc3QgdGFiU2VsZWN0ZWRTdHlsZXMgPSB7XG4gIGZvbnRXZWlnaHQ6ICd0aXRsZScsXG4gIHB0OiAxMixcbiAgcGI6IDgsXG4gIGJvcmRlckJvdHRvbVdpZHRoOiA0LFxuICBib3JkZXJDb2xvcjogJ3ByaW1hcnknLFxufSBhcyBjb25zdDtcblxuY29uc3QgZm9jdXNWaXNpYmxlU3R5bGVzID0ge1xuICBbVGFiU2VsZWN0b3JzLkZPQ1VTX1ZJU0lCTEUgKyBUYWJTZWxlY3RvcnMuQkVGT1JFXToge1xuICAgIGNvbnRlbnQ6ICdcIlwiJyxcbiAgICBib3JkZXI6IDIsXG4gICAgYm9yZGVyQ29sb3I6ICdwcmltYXJ5JyxcbiAgICBwb3NpdGlvbjogJ2Fic29sdXRlJyxcbiAgICBpbnNldDogMCxcbiAgICB6SW5kZXg6IDAsXG4gICAgYm9yZGVyUmFkaXVzVG9wOiAnbWQnLFxuICAgIGJvcmRlclJhZGl1c0JvdHRvbTogJ25vbmUnLFxuICB9LFxufSBhcyBjb25zdDtcblxuZXhwb3J0IGNvbnN0IHRhYlZhcmlhbnRzID0gdmFyaWFudCh7XG4gIGJhc2U6IHtcbiAgICBwb3NpdGlvbjogJ3JlbGF0aXZlJyxcbiAgICBkaXNwbGF5OiAnaW5saW5lLWZsZXgnLFxuICAgIGp1c3RpZnlDb250ZW50OiAnY2VudGVyJyxcbiAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICB3aGl0ZVNwYWNlOiAnbm93cmFwJyxcbiAgICBib3JkZXJSYWRpdXM6ICdub25lJyxcbiAgICBweDogMjQsXG4gICAgdGV4dE92ZXJmbG93OiAnZWxsaXBzaXMnLFxuICAgIGNvbG9yOiAndGV4dCcsXG4gICAgZm9udDogJ2luaGVyaXQnLFxuICAgIGN1cnNvcjogJ3BvaW50ZXInLFxuICAgIHpJbmRleDogMSxcbiAgICBbVGFiU2VsZWN0b3JzLkRJU0FCTEVEXToge1xuICAgICAgb3BhY2l0eTogMC4yNSxcbiAgICAgIGN1cnNvcjogJ25vdC1hbGxvd2VkJyxcbiAgICB9LFxuICAgIC4uLmZvY3VzVmlzaWJsZVN0eWxlcyxcbiAgfSxcbiAgdmFyaWFudHM6IHtcbiAgICBzdGFuZGFyZDoge1xuICAgICAgYmFja2dyb3VuZDogJ25vbmUnLFxuICAgICAgYm9yZGVyQ29sb3I6ICdib3JkZXItcHJpbWFyeScsXG4gICAgICBib3JkZXJMZWZ0OiAnbm9uZScsXG4gICAgICBib3JkZXJSaWdodDogJ25vbmUnLFxuICAgICAgYm9yZGVyVG9wOiAnbm9uZScsXG4gICAgICBib3JkZXJCb3R0b21TdHlsZTogJ3NvbGlkJyxcbiAgICAgIGJvcmRlckJvdHRvbVdpZHRoOiAxLFxuICAgICAgZm9udFNpemU6IDE2LFxuICAgICAgZm9udFdlaWdodDogNDAwLFxuICAgICAgcHQ6IDEyLFxuICAgICAgcGI6IDExIGFzIDEyLCAvLyBib3JkZXIgKyBwYWRkaW5nID0gMTJweFxuICAgICAgW1RhYlNlbGVjdG9ycy5IT1ZFUl06IHtcbiAgICAgICAgYmc6ICdiYWNrZ3JvdW5kLXNlbGVjdGVkJyxcbiAgICAgIH0sXG4gICAgICBbVGFiU2VsZWN0b3JzLlNFTEVDVEVEXToge1xuICAgICAgICAuLi50YWJTZWxlY3RlZFN0eWxlcyxcbiAgICAgICAgZm9udFdlaWdodDogJ2JvbGQnLFxuICAgICAgfSxcbiAgICB9LFxuICAgIGJsb2NrOiB7XG4gICAgICBmb250V2VpZ2h0OiAnbm9ybWFsJyxcbiAgICAgIGZvbnRTaXplOiAxNCxcbiAgICAgIHB5OiAxMixcbiAgICAgIFtUYWJTZWxlY3RvcnMuU0VMRUNURURdOiB7XG4gICAgICAgIGJnOiAnYmFja2dyb3VuZCcsXG4gICAgICAgIGZvbnRXZWlnaHQ6ICdib2xkJyxcbiAgICAgIH0sXG4gICAgfSxcbiAgfSxcbn0pO1xuXG5leHBvcnQgY29uc3QgdGFiU3RhdGVzID0gc3RhdGVzKHtcbiAgc2VsZWN0ZWQ6IHtcbiAgICAuLi50YWJTZWxlY3RlZFN0eWxlcyxcbiAgfSxcbn0pO1xuXG5leHBvcnQgY29uc3QgVGFiQnV0dG9uID0gc3R5bGVkKEJ1dHRvbkJhc2UpPFRhYkJ1dHRvblByb3BzPihcbiAgdGFiVmFyaWFudHMsXG4gIHRhYlN0YXRlcyxcbiAgdGFiRWxlbWVudEJhc2VQcm9wc1xuKTtcbiJdfQ== */");
\ No newline at end of file
Index: package/package.json
===================================================================
--- package/package.json
+++ package/package.json
@@ -1,15 +1,15 @@
 {
   "name": "@codecademy/gamut",
   "description": "Styleguide & Component library for Codecademy",
-  "version": "68.5.0",
+  "version": "68.5.1-alpha.469476.0",
   "author": "Codecademy Engineering <[email protected]>",
   "dependencies": {
-    "@codecademy/gamut-icons": "9.57.4",
-    "@codecademy/gamut-illustrations": "0.58.10",
-    "@codecademy/gamut-patterns": "0.10.29",
-    "@codecademy/gamut-styles": "17.14.0",
-    "@codecademy/variance": "0.26.1",
+    "@codecademy/gamut-icons": "9.57.5-alpha.469476.0",
+    "@codecademy/gamut-illustrations": "0.58.11-alpha.469476.0",
+    "@codecademy/gamut-patterns": "0.10.30-alpha.469476.0",
+    "@codecademy/gamut-styles": "17.14.1-alpha.469476.0",
+    "@codecademy/variance": "0.26.2-alpha.469476.0",
     "@formatjs/intl-locale": "^5.3.1",
     "@react-aria/interactions": "3.25.0",
     "@types/marked": "^4.0.8",
     "@vidstack/react": "^1.12.12",