{"version":3,"file":"static/chunks/160-cde98cd03eca81e2.js","mappings":"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","sources":["webpack://_N_E/./src/components/AOSWrapper/AOSWrapper.tsx","webpack://_N_E/./src/components/GlowCapture/GlowCapture.tsx","webpack://_N_E/./src/components/ThemeSwitcher/ThemeSwitcher.tsx","webpack://_N_E/./src/components/Navigation/MobileMenu.tsx","webpack://_N_E/./src/components/Navigation/Navigation.tsx","webpack://_N_E/./src/lib/utils.ts","webpack://_N_E/./src/ui/elements/Icon/icon-collection.ts","webpack://_N_E/./src/ui/elements/Icon/Icon.tsx","webpack://_N_E/./src/ui/elements/Typography/Title/Title.tsx","webpack://_N_E/./src/ui/elements/Typography/index.ts","webpack://_N_E/./src/ui/elements/Button/Button.tsx","webpack://_N_E/./src/ui/elements/Tag/Tag.tsx","webpack://_N_E/./src/ui/elements/index.ts","webpack://_N_E/./src/ui/layout/Stack/Stack.tsx","webpack://_N_E/./src/ui/layout/index.ts","webpack://_N_E/./src/utils/status.ts","webpack://_N_E/./src/utils/copyToClipboard.ts","webpack://_N_E/./src/utils/utm.ts","webpack://_N_E/./src/utils/index.ts","webpack://_N_E/./src/components/Navigation/logo.png"],"sourcesContent":["\"use client\";\n\nimport AOS from \"aos\";\nimport { useEffect } from \"react\";\nimport { useReducedMotion } from \"framer-motion\";\n\nconst AOSWrapper = () => {\n const prefersReducedMotion = useReducedMotion();\n\n useEffect(() => {\n if (!prefersReducedMotion) {\n AOS.init();\n }\n }, [prefersReducedMotion]);\n\n return null;\n};\n\nexport default AOSWrapper;\n","\"use client\";\n\nimport React, { PropsWithChildren, useEffect, useRef, useState } from \"react\";\n\ntype GlowCaptureProps = PropsWithChildren<{ glowColor?: string }>;\nexport const GlowCapture: React.FC = ({\n children,\n glowColor,\n}) => {\n const [glowPosition, setGlowPosition] = useState({ x: 0, y: 0 });\n const [glowOpacity, setGlowOpacity] = useState(0);\n const captureRef = useRef(null);\n\n useEffect(() => {\n const capture = captureRef.current;\n\n if (capture) {\n const handleMouseMove = (event: MouseEvent) => {\n // Get the bounding box of the container\n const rect = capture.getBoundingClientRect();\n\n // Calculate the mouse position relative to the container\n const x = event.clientX - rect.left;\n const y = event.clientY - rect.top;\n\n setGlowPosition({ x, y });\n setGlowOpacity(1);\n };\n\n const handleMouseLeave = () => {\n setGlowOpacity(0);\n };\n\n // Add event listeners for mouse move and leave\n capture.addEventListener(\"mousemove\", handleMouseMove);\n capture.addEventListener(\"mouseleave\", handleMouseLeave);\n\n // Clean up event listeners on component unmount\n return () => {\n capture.removeEventListener(\"mousemove\", handleMouseMove);\n capture.removeEventListener(\"mouseleave\", handleMouseLeave);\n };\n }\n }, []);\n\n return (\n
\n {children}\n \n {children}\n
\n \n );\n};\n","import { Button, Icon, Icons } from \"@ui/elements\";\nimport { cn } from \"@/lib/utils\";\nimport { useTheme } from \"next-themes\";\nimport { useEffect, useMemo, useRef, useState } from \"react\";\nimport { motion, AnimatePresence } from \"framer-motion\";\n\nexport const ThemeSwitcher = () => {\n const { theme, resolvedTheme, setTheme } = useTheme();\n const [dropdownOpen, setDropdownOpen] = useState(false);\n const contentRef = useRef(null);\n const buttonRef = useRef(null);\n const [mounted, setMounted] = useState(false);\n\n // Refs for focus trapping\n const firstFocusableRef = useRef(null);\n const lastFocusableRef = useRef(null);\n\n useEffect(() => {\n setMounted(true);\n\n const handleClickOutside = (e: MouseEvent) => {\n if (\n dropdownOpen &&\n contentRef.current &&\n !contentRef.current.contains(e.target as Node) &&\n buttonRef.current &&\n !buttonRef.current.contains(e.target as Node)\n ) {\n setDropdownOpen(false);\n }\n };\n\n const handleKeyDown = (e: KeyboardEvent) => {\n if (e.key === \"Escape\") {\n setDropdownOpen(false);\n buttonRef.current?.focus();\n }\n\n if (e.key === \"Tab\" && dropdownOpen) {\n const focusableElements =\n contentRef.current?.querySelectorAll(\n 'button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"])',\n );\n if (focusableElements && focusableElements.length > 0) {\n const firstElement = focusableElements[0];\n const lastElement = focusableElements[focusableElements.length - 1];\n\n if (!e.shiftKey && document.activeElement === lastElement) {\n e.preventDefault();\n firstElement.focus();\n }\n\n if (e.shiftKey && document.activeElement === firstElement) {\n e.preventDefault();\n lastElement.focus();\n }\n }\n }\n };\n\n if (dropdownOpen) {\n document.addEventListener(\"mousedown\", handleClickOutside);\n document.addEventListener(\"keydown\", handleKeyDown);\n // Optionally set focus to the first focusable element\n firstFocusableRef.current?.focus();\n } else {\n document.removeEventListener(\"mousedown\", handleClickOutside);\n document.removeEventListener(\"keydown\", handleKeyDown);\n }\n\n return () => {\n document.removeEventListener(\"mousedown\", handleClickOutside);\n document.removeEventListener(\"keydown\", handleKeyDown);\n };\n }, [dropdownOpen]);\n\n const themeButtonIcon: Icons = useMemo(() => {\n switch (resolvedTheme) {\n case \"light\":\n return \"Sun\";\n case \"dark\":\n return \"Moon\";\n default:\n return \"Sun\";\n }\n }, [resolvedTheme]);\n\n const handleDropdownItemClick = (\n selectedTheme: \"light\" | \"dark\" | \"system\",\n ) => {\n setTheme(selectedTheme);\n setDropdownOpen(false);\n };\n\n const dropdownVariants = {\n open: {\n opacity: 1,\n y: 0,\n transition: { duration: 0.2 },\n },\n closed: {\n opacity: 0,\n y: -10,\n transition: { duration: 0.2 },\n },\n };\n\n if (!mounted) {\n return null;\n }\n\n return (\n
\n setDropdownOpen((prev) => !prev)}\n className={cn(\n \"size-10 rounded-full bg-white shadow-none hover:bg-neutral-100 lg:size-14 dark:bg-neutral-800 dark:text-neutral-300 dark:hover:bg-neutral-700 dark:active:bg-neutral-600\",\n {\n \"bg-neutral-100 dark:bg-neutral-700\": dropdownOpen,\n },\n )}\n aria-haspopup=\"true\"\n aria-expanded={dropdownOpen}\n aria-label=\"Toggle theme switcher\"\n >\n \n \n \n {dropdownOpen && (\n \n
    \n
  • \n handleDropdownItemClick(\"light\")}\n className={cn(\n \"flex w-full cursor-pointer items-center gap-3 rounded-sm px-3 py-2 text-sm text-gray-600 transition-all hover:bg-yellow-300/20 active:bg-yellow-300/30 dark:text-neutral-200 dark:hover:bg-neutral-600 dark:active:bg-neutral-500\",\n {\n \"bg-yellow-300/20 text-yellow-800 hover:bg-yellow-300/30 active:bg-yellow-300/40\":\n theme === \"light\",\n },\n )}\n role=\"menuitem\"\n >\n \n Light\n \n
  • \n
  • \n handleDropdownItemClick(\"dark\")}\n className={cn(\n \"flex w-full cursor-pointer items-center gap-3 rounded-sm px-3 py-2 text-sm text-gray-600 transition-all hover:bg-gray-100 dark:text-neutral-200 dark:hover:bg-neutral-600 dark:active:bg-neutral-500\",\n {\n \"bg-neutral-800/50 text-sky-800 dark:text-neutral-200 dark:hover:bg-neutral-800/50 dark:active:bg-neutral-800/50\":\n theme === \"dark\",\n },\n )}\n role=\"menuitem\"\n >\n \n Dark\n \n
  • \n
  • \n handleDropdownItemClick(\"system\")}\n className={cn(\n \"flex w-full cursor-pointer items-center gap-3 rounded-sm px-3 py-2 text-sm text-gray-600 transition-all hover:bg-sky-400/20 active:bg-sky-400/30 dark:text-neutral-200 dark:hover:bg-neutral-600 dark:active:bg-neutral-500\",\n {\n \"bg-sky-400/20 text-sky-900 hover:bg-sky-400/30 active:bg-sky-400/40 dark:hover:bg-sky-400/30 dark:active:bg-sky-400/40\":\n theme === \"system\",\n },\n )}\n role=\"menuitem\"\n ref={lastFocusableRef}\n >\n \n System\n \n
  • \n
\n \n )}\n
\n
\n );\n};\n","import { Stack } from \"@ui/layout\";\nimport { ThemeSwitcher } from \"@components/ThemeSwitcher/ThemeSwitcher\";\nimport { Button, Icon } from \"@ui/elements\";\nimport Link from \"next/link\";\nimport { FC, useEffect, useRef } from \"react\";\nimport { cn } from \"@/lib/utils\";\nimport { sendGTMEvent } from \"@next/third-parties/google\";\nimport { getUtmParams, useUtmLink } from \"@utils\";\n\ntype MobileMenuProps = {\n open: boolean;\n setOpen: (open: boolean) => void;\n};\n\nexport const MobileMenu: FC = ({ open, setOpen }) => {\n const dashboardLink = useUtmLink(process.env.NEXT_PUBLIC_APP_URL || \"\");\n const mobileMenuRef = useRef(null);\n const mobileMenuButtonRef = useRef(null);\n const firstFocusableRef = useRef(null);\n const lastFocusableRef = useRef(null);\n\n useEffect(() => {\n const handleClickOutside = (e: MouseEvent) => {\n if (\n mobileMenuRef.current &&\n !mobileMenuRef.current.contains(e.target as Node) &&\n mobileMenuButtonRef.current &&\n !mobileMenuButtonRef.current.contains(e.target as Node)\n ) {\n setOpen(false);\n }\n };\n\n const handleKeyDown = (e: KeyboardEvent) => {\n if (e.key === \"Escape\") {\n setOpen(false);\n mobileMenuButtonRef.current?.focus();\n }\n\n if (e.key === \"Tab\" && open) {\n const focusableElements =\n mobileMenuRef.current?.querySelectorAll(\n 'a[href], button:not([disabled]), textarea, input, select, [tabindex]:not([tabindex=\"-1\"])',\n );\n if (focusableElements && focusableElements.length > 0) {\n const firstElement = focusableElements[0];\n const lastElement = focusableElements[focusableElements.length - 1];\n\n if (!e.shiftKey && document.activeElement === lastElement) {\n e.preventDefault();\n firstElement.focus();\n }\n\n if (e.shiftKey && document.activeElement === firstElement) {\n e.preventDefault();\n lastElement.focus();\n }\n }\n }\n };\n\n if (open) {\n document.addEventListener(\"mousedown\", handleClickOutside, {\n passive: true,\n });\n document.addEventListener(\"keydown\", handleKeyDown);\n // Optionally set focus to the first focusable element\n firstFocusableRef.current?.focus();\n } else {\n document.removeEventListener(\"mousedown\", handleClickOutside);\n document.removeEventListener(\"keydown\", handleKeyDown);\n }\n\n return () => {\n document.removeEventListener(\"mousedown\", handleClickOutside);\n document.removeEventListener(\"keydown\", handleKeyDown);\n };\n }, [mobileMenuRef, mobileMenuButtonRef, setOpen, open]);\n\n return (\n <>\n {/* Mobile Menu Button */}\n \n \n setOpen(!open)}\n ref={mobileMenuButtonRef}\n aria-controls=\"mobile-menu\"\n aria-expanded={open}\n aria-label=\"Toggle mobile menu\"\n >\n \n \n \n \n\n \n
    \n
  • \n {\n setOpen(false);\n sendGTMEvent({\n event: \"link_click\",\n value: \"how_it_works\",\n ...getUtmParams(),\n });\n }}\n aria-label=\"Learn How It Works\"\n >\n How it works\n \n
  • \n
  • \n {\n setOpen(false);\n sendGTMEvent({\n event: \"link_click\",\n value: \"features\",\n ...getUtmParams(),\n });\n }}\n aria-label=\"Explore Features\"\n >\n Features\n \n
  • \n
  • \n {\n setOpen(false);\n sendGTMEvent({\n event: \"link_click\",\n value: \"pricing\",\n ...getUtmParams(),\n });\n }}\n aria-label=\"View Pricing Options\"\n >\n Pricing\n \n
  • \n
  • \n {\n setOpen(false);\n sendGTMEvent({\n event: \"link_click\",\n value: \"contact\",\n ...getUtmParams(),\n });\n }}\n aria-label=\"Contact Us\"\n >\n Contact\n \n
  • \n {/* Mobile Button */}\n
  • \n \n sendGTMEvent({\n event: \"cta_click\",\n value: \"navbar_predictions\",\n ...getUtmParams(),\n })\n }\n >\n \n Predictions\n \n \n \n
  • \n
\n \n \n );\n};\n","\"use client\";\n\nimport { Stack } from \"@ui/layout\";\nimport Image from \"next/image\";\nimport logo from \"./logo.png\";\nimport Link from \"next/link\";\nimport { Button, Icon } from \"@ui/elements\";\nimport { useEffect, useState } from \"react\";\nimport classNames from \"classnames\";\nimport { ThemeSwitcher } from \"@components/ThemeSwitcher/ThemeSwitcher\";\nimport { MobileMenu } from \"@components/Navigation/MobileMenu\";\nimport { sendGTMEvent } from \"@next/third-parties/google\";\nimport { getUtmParams, useUtmLink } from \"@utils\";\n\nexport const Navigation = () => {\n const [isVisible, setIsVisible] = useState(true);\n const [lastScrollY, setLastScrollY] = useState(0);\n const [isMenuOpen, setIsMenuOpen] = useState(false);\n const [lastHidePosition, setLastHidePosition] = useState(0);\n const dashboardLink = useUtmLink(process.env.NEXT_PUBLIC_APP_URL || \"\");\n const scrollThresholdDown = 60;\n const scrollThresholdUp = 40;\n let isScrolling = false;\n\n const handleScroll = () => {\n if (isScrolling) return;\n isScrolling = true;\n requestAnimationFrame(() => {\n const currentScrollY = window.scrollY;\n if (\n currentScrollY > lastScrollY &&\n currentScrollY - lastHidePosition > scrollThresholdDown &&\n currentScrollY > 100\n ) {\n setIsVisible(false);\n setIsMenuOpen(false);\n setLastHidePosition(currentScrollY);\n } else if (\n lastScrollY > currentScrollY &&\n lastHidePosition - currentScrollY > scrollThresholdUp\n ) {\n setIsVisible(true);\n }\n\n setLastScrollY(currentScrollY);\n isScrolling = false;\n });\n };\n\n useEffect(() => {\n window.addEventListener(\"scroll\", handleScroll, { passive: true });\n return () => {\n window.removeEventListener(\"scroll\", handleScroll);\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [lastScrollY, lastHidePosition]);\n\n return (\n \n
\n \n \n \n

\n \n Football Genie\n {\" \"}\n \n AI\n \n

\n
\n \n\n {/* Desktop Navigation */}\n \n\n {/* Desktop ThemeSwitcher and Button */}\n \n
\n \n
\n\n \n sendGTMEvent({\n event: \"cta_click\",\n value: \"navbar_predictions\",\n ...getUtmParams(),\n })\n }\n >\n \n Predictions\n \n \n \n \n\n {/* Mobile Menu */}\n \n
\n \n );\n};\n","import { twMerge } from \"tailwind-merge\";\nimport classNames from \"classnames\";\n\nexport function cn(...inputs: classNames.ArgumentArray) {\n return twMerge(classNames(...inputs));\n}\n","export { Database } from \"@phosphor-icons/react/dist/ssr\";\nexport { TrendUp } from \"@phosphor-icons/react/dist/ssr\";\nexport { Brain } from \"@phosphor-icons/react/dist/ssr\";\nexport { ArrowRight } from \"@phosphor-icons/react/dist/ssr\";\nexport { CheckCircle } from \"@phosphor-icons/react/dist/ssr\";\nexport { Fire } from \"@phosphor-icons/react/dist/ssr\";\nexport { Ambulance } from \"@phosphor-icons/react/dist/ssr\";\nexport { Lightbulb } from \"@phosphor-icons/react/dist/ssr\";\nexport { Star } from \"@phosphor-icons/react/dist/ssr\";\nexport { CaretLeft } from \"@phosphor-icons/react/dist/ssr\";\nexport { CaretRight } from \"@phosphor-icons/react/dist/ssr\";\nexport { TelegramLogo } from \"@phosphor-icons/react/dist/ssr\";\nexport { Coins } from \"@phosphor-icons/react/dist/ssr\";\nexport { Wallet } from \"@phosphor-icons/react/dist/ssr\";\nexport { CalendarBlank } from \"@phosphor-icons/react/dist/ssr\";\nexport { Trophy } from \"@phosphor-icons/react/dist/ssr\";\nexport { Target } from \"@phosphor-icons/react/dist/ssr\";\nexport { Newspaper } from \"@phosphor-icons/react/dist/ssr\";\nexport { Heart } from \"@phosphor-icons/react/dist/ssr\";\nexport { ArrowsLeftRight } from \"@phosphor-icons/react/dist/ssr\";\nexport { Check } from \"@phosphor-icons/react/dist/ssr\";\nexport { Checks } from \"@phosphor-icons/react/dist/ssr\";\nexport { ShieldCheck } from \"@phosphor-icons/react/dist/ssr\";\nexport { Siren } from \"@phosphor-icons/react/dist/ssr\";\nexport { ThumbsUp } from \"@phosphor-icons/react/dist/ssr\";\nexport { ThumbsDown } from \"@phosphor-icons/react/dist/ssr\";\nexport { CurrencyDollar } from \"@phosphor-icons/react/dist/ssr\";\nexport { TextAlignLeft } from \"@phosphor-icons/react/dist/ssr\";\nexport { ChatTeardrop } from \"@phosphor-icons/react/dist/ssr\";\nexport { ChatTeardropText } from \"@phosphor-icons/react/dist/ssr\";\nexport { ChatsCircle } from \"@phosphor-icons/react/dist/ssr\";\nexport { ChatCircle } from \"@phosphor-icons/react/dist/ssr\";\nexport { Chat } from \"@phosphor-icons/react/dist/ssr\";\nexport { ChatDots } from \"@phosphor-icons/react/dist/ssr\";\nexport { ChatText } from \"@phosphor-icons/react/dist/ssr\";\nexport { ChatCircleText } from \"@phosphor-icons/react/dist/ssr\";\nexport { X } from \"@phosphor-icons/react/dist/ssr\";\nexport { InstagramLogo } from \"@phosphor-icons/react/dist/ssr\";\nexport { LinkedinLogo } from \"@phosphor-icons/react/dist/ssr\";\nexport { FacebookLogo } from \"@phosphor-icons/react/dist/ssr\";\nexport { XLogo } from \"@phosphor-icons/react/dist/ssr\";\nexport { PaperPlaneRight } from \"@phosphor-icons/react/dist/ssr\";\nexport { EnvelopeSimple } from \"@phosphor-icons/react/dist/ssr\";\nexport { Phone } from \"@phosphor-icons/react/dist/ssr\";\nexport { Buildings } from \"@phosphor-icons/react/dist/ssr\";\nexport { Copy } from \"@phosphor-icons/react/dist/ssr\";\nexport { Monitor } from \"@phosphor-icons/react/dist/ssr\";\nexport { Sun } from \"@phosphor-icons/react/dist/ssr\";\nexport { Moon } from \"@phosphor-icons/react/dist/ssr\";\nexport { Sparkle } from \"@phosphor-icons/react/dist/ssr\";\nexport { Plus } from \"@phosphor-icons/react/dist/ssr\";\nexport { Minus } from \"@phosphor-icons/react/dist/ssr\";\nexport { SealCheck } from \"@phosphor-icons/react/dist/ssr\";\nexport { TiktokLogo } from \"@phosphor-icons/react/dist/ssr\";\nexport { CaretUp } from \"@phosphor-icons/react/dist/ssr\";\nexport { Warning } from \"@phosphor-icons/react/dist/ssr\";\nexport { List } from \"@phosphor-icons/react/dist/ssr\";\nexport { Info } from \"@phosphor-icons/react/dist/ssr\";\nexport { Strategy } from \"@phosphor-icons/react/dist/ssr\";\nexport { CreditCard } from \"@phosphor-icons/react/dist/ssr\";\nexport { Gear } from \"@phosphor-icons/react/dist/ssr\";\n","import React, { FC, PropsWithChildren } from \"react\";\n\nimport { IconProps as PhosphorIconProps } from \"@phosphor-icons/react\";\n\nimport * as AvailableIcons from \"./icon-collection\";\nexport type Icons = keyof typeof AvailableIcons;\n\ntype IconProps = PropsWithChildren<{\n icon: Icons;\n}> &\n PhosphorIconProps;\n\nexport const Icon: FC = ({ icon, weight = \"regular\", ...props }) => {\n const IconComponent = AvailableIcons[icon];\n\n return ;\n};\n","import React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\ntype HeadingTags = \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\";\n\ninterface TitleProps extends React.HTMLAttributes {\n /** The heading level to use (default is 'h1') */\n as?: HeadingTags;\n /** The heading style to use (default is 'h1') */\n styleAs?: HeadingTags;\n /** The content of the title */\n children: React.ReactNode;\n /** Additional CSS classes */\n className?: string;\n /** Text alignment */\n align?: \"left\" | \"center\" | \"right\";\n /** Color variant */\n color?: \"primary\" | \"secondary\" | \"tertiary\" | \"light\";\n type?: \"title\" | \"subtitle\";\n}\n\nexport const Title: React.FC = ({\n as = \"h1\",\n styleAs,\n children,\n className = \"\",\n align = \"left\",\n color = \"primary\",\n type = \"title\",\n ...props\n}) => {\n const HeadingTag = as;\n\n const baseStyles = \"font-bold\";\n\n const sizeStyles: Record = {\n h1: \"text-4xl md:text-5xl md:leading-tight\",\n h2: \"text-2xl md:text-3xl\",\n h3: \"text-xl md:text-2xl\",\n h4: \"text-lg md:text-xl\",\n h5: \"text-md md:text-lg\",\n h6: \"text-base\",\n };\n\n const alignmentStyles: Record = {\n left: \"text-left\",\n center: \"text-center\",\n right: \"text-right\",\n };\n\n const colorStyles: Record = {\n primary: \"text-gray-900 dark:text-neutral-200\",\n secondary: \"text-gray-700\",\n tertiary: \"text-gray-500 dark:text-neutral-400\",\n light: \"text-gray-300 dark:text-neutral-700\",\n };\n\n const weight: Record = {\n title: \"font-bold\",\n subtitle: \"font-light leading-relaxed\",\n };\n\n return (\n \n {children}\n \n );\n};\n","export * from \"./Title/Title\";\n","import React, {\n AnchorHTMLAttributes,\n ButtonHTMLAttributes,\n forwardRef,\n} from \"react\";\nimport { Colors, Variants } from \"@ui/types\";\nimport { cn } from \"@/lib/utils\";\n\ntype ButtonSizes = \"custom\" | \"small\" | \"normal\" | \"medium\" | \"large\";\n\ntype ButtonCommonProps = {\n color?: Colors;\n variant?: Variants;\n size?: ButtonSizes;\n isRounded?: boolean;\n isLoading?: boolean;\n};\n\ntype ButtonAsButtonProps = {\n as?: \"button\";\n} & ButtonCommonProps &\n ButtonHTMLAttributes;\n\ntype ButtonAsLinkProps = {\n as?: \"link\";\n} & ButtonCommonProps &\n AnchorHTMLAttributes;\n\nexport type ButtonProps = ButtonAsButtonProps | ButtonAsLinkProps;\n\nexport const Button = forwardRef(\n (\n {\n as = \"button\",\n children,\n color,\n size = \"normal\",\n className,\n isRounded,\n isLoading,\n ...rest\n },\n ref,\n ) => {\n const buttonClasses: Record = {\n primary:\n \"bg-primary dark:text-gray-900 text-white font-semibold hover:bg-primary-dark active:bg-primary-darker\",\n secondary: \"bg-secondary hover:bg-secondary:100\",\n success: \"bg-green\",\n warning: \"bg-orange\",\n info: \"bg-blue\",\n link: \"bg-blue\",\n danger: \"bg-red\",\n neutral:\n \"bg-white border-gray-200 hover:bg-gray-50 active:bg-gray-100 text-gray-600 ring-1 ring-gray-200 dark:bg-neutral-800 dark:text-neutral-300 dark:border-neutral-700 dark:hover:bg-neutral-700 dark:active:bg-neutral-600 dark:ring-neutral-700 dark:hover:bg-neutral-700 dark:active:bg-neutral-600\",\n };\n\n const buttonSizeClasses: Record = {\n custom: \"\",\n small: \"px-3 py-1\",\n normal: \"px-4 py-2\",\n medium: \"px-6 py-3\",\n large: \"px-9 py-4 text-md font-semibold\",\n };\n\n const radiusClassName = isRounded ? \"rounded-full\" : \"rounded-md\";\n\n const buttonClassName = cn(\n \"inline-flex items-center justify-center truncate text-base font-medium leading-6 whitespace-no-wrap focus:outline-none transition-all tracking-wide focus:shadow-sm active:scale-95 min-w-fit after:content-[''] after:absolute after:top-1/2 after:left-1/2 after:-mt-2.5 after:-ml-2.5 after:size-5 after:border-2 after:border-gray-200 after:border-t-transparent after:rounded-full after:animate-spin after:opacity-0 after:transition-all\",\n color && buttonClasses[color],\n buttonSizeClasses[size],\n radiusClassName,\n className,\n isLoading &&\n \"text-transparent dark:text-transparent pointer-events-none relative after:opacity-100\",\n );\n\n return as === \"link\" ? (\n \n {children}\n \n ) : (\n \n {children}\n \n );\n },\n);\n\nButton.displayName = \"Button\";\n","import React from \"react\";\nimport { StatusColor } from \"@utils\";\nimport { cn } from \"@/lib/utils\";\n\ninterface TagProps extends React.HTMLAttributes {\n /** The content of the tag */\n children: React.ReactNode;\n /** Color variant */\n variant?: StatusColor;\n /** Size of the tag */\n size?: \"sm\" | \"md\" | \"lg\";\n /** If true, the tag will have rounded corners */\n rounded?: boolean;\n /** Optional icon to display on the left */\n icon?: React.ReactNode;\n /** Additional CSS classes */\n className?: string;\n as?: \"span\" | \"p\";\n}\n\nexport const Tag: React.FC = ({\n children,\n variant,\n size = \"md\",\n rounded = false,\n icon,\n className = \"\",\n as = \"span\",\n ...props\n}) => {\n const baseStyles = \"inline-flex items-center font-medium\";\n const TagComponent = as;\n\n const sizeStyles: Record = {\n sm: \"text-xs px-2 py-0.5\",\n md: \"text-xs md:text-sm px-3 py-1.5 md:px-4\",\n lg: \"text-base px-4 py-1.5\",\n };\n\n const variantStyles: Record = {\n primary: \"bg-primary text-white\",\n secondary: \"bg-secondary text-gray-800\",\n success: \"bg-green-500/20 text-green-800 dark:text-neutral-300\",\n warning: \"bg-yellow-500/20 text-yellow-800 dark:text-neutral-300\",\n info: \"bg-blue-500/20 text-blue-800 dark:text-neutral-300\",\n neutral: \"bg-gray-500/10 dark:bg-neutral-800 dark:text-neutral-300\",\n danger: \"bg-red-500/20 text-danger-800\",\n };\n\n const shapeStyles = rounded ? \"rounded-full\" : \"rounded\";\n\n return (\n \n {icon && {icon}}\n {children}\n \n );\n};\n","export * from \"./Typography\";\nexport * from \"./Button/Button\";\nexport * from \"./Tag/Tag\";\nexport * from \"./Icon/Icon\";\n","import React from \"react\";\nimport { cn } from \"@/lib/utils\";\n\ntype Spacings =\n | \"unset\"\n | \"none\"\n | \"xxs\"\n | \"xs\"\n | \"sm\"\n | \"md\"\n | \"lg\"\n | \"xl\"\n | \"xxl\"\n | \"xxxl\";\n\ninterface StackProps extends React.HTMLAttributes {\n /** The content of the stack */\n children: React.ReactNode;\n /** The direction of the stack */\n direction?: \"vertical\" | \"horizontal\";\n /** The alignment of the items */\n align?: \"start\" | \"center\" | \"end\" | \"stretch\" | \"baseline\";\n /** The spacing between the items (Tailwind spacing scale) */\n spacing?: Spacings;\n /** Additional CSS classes */\n className?: string;\n /** If true, the stack will wrap its items to the next line */\n wrap?: boolean;\n as?: string;\n}\n\nexport const Stack: React.FC = ({\n children,\n direction = \"vertical\",\n align = \"start\",\n spacing = \"sm\",\n className = \"\",\n wrap = false,\n ...props\n}) => {\n const flexDirection = direction === \"vertical\" ? \"flex-col\" : \"flex-row\";\n const alignment = {\n start: \"items-start\",\n center: \"items-center\",\n end: \"items-end\",\n stretch: \"items-stretch\",\n baseline: \"items-baseline\",\n }[align];\n\n const spacingClasses: Record = {\n unset: \"\",\n xxs: \"gap-xxs\",\n xs: \"gap-xs\",\n sm: \"gap-sm\",\n md: \"gap-md\",\n lg: \"gap-lg\",\n xl: \"gap-xl\",\n xxl: \"gap-xxl\",\n xxxl: \"gap-xxxl\",\n none: \"gap-none\",\n };\n\n const wrapClass = wrap ? \"flex-wrap\" : \"\";\n\n return (\n \n {children}\n \n );\n};\n","export * from \"./Stack/Stack\";\n","const StatusColor = {\n Success: \"success\",\n Warning: \"warning\",\n Info: \"info\",\n Neutral: \"neutral\",\n Danger: \"danger\",\n} as const;\nexport type StatusColor = (typeof StatusColor)[keyof typeof StatusColor];\n\ntype StatusColorClasses = {\n bg: string;\n text: string;\n mid: string;\n};\n\nexport const statusColorClasses: Record = {\n success: {\n bg: \"bg-green-500/20\",\n mid: \"bg-green-500/60\",\n text: \"text-green-600\",\n },\n warning: {\n bg: \"bg-yellow-500/20\",\n mid: \"bg-yellow-500/60\",\n text: \"text-yellow-600\",\n },\n info: {\n bg: \"bg-blue-500/20\",\n mid: \"bg-blue-500/60\",\n text: \"text-blue-600\",\n },\n neutral: {\n bg: \"bg-neutral-100 dark:bg-neutral-600\",\n mid: \"bg-neutral-500/60\",\n text: \"text-neutral-600\",\n },\n danger: {\n bg: \"bg-red-500/20\",\n mid: \"bg-red-500/60\",\n text: \"text-red-600\",\n },\n};\n","function fallbackCopyTextToClipboard(text: string) {\n const textArea = document.createElement(\"textarea\");\n textArea.value = text;\n\n // Avoid scrolling to bottom\n // Position the textarea off-screen to prevent viewport shifts\n textArea.style.position = \"absolute\";\n textArea.style.top = \"50%\";\n textArea.style.bottom = \"50%\";\n textArea.style.left = \"50%\";\n textArea.style.right = \"50%\";\n\n // Ensure the textarea is as unobtrusive as possible\n textArea.style.width = \"1px\";\n textArea.style.height = \"0.02px\";\n textArea.style.padding = \"0\";\n textArea.style.border = \"none\";\n textArea.style.outline = \"none\";\n textArea.style.boxShadow = \"none\";\n textArea.style.background = \"transparent\";\n textArea.style.opacity = \"0\";\n textArea.style.pointerEvents = \"none\";\n\n document.body.appendChild(textArea);\n textArea.focus();\n textArea.select();\n\n try {\n document.execCommand(\"copy\");\n } catch (err) {\n console.error(\"Fallback: Oops, unable to copy\", err);\n }\n\n document.body.removeChild(textArea);\n}\n\nexport function copyTextToClipboard(text: string) {\n if (!navigator.clipboard) {\n fallbackCopyTextToClipboard(text);\n return;\n }\n\n return navigator.clipboard.writeText(text);\n}\n","import { useEffect, useState } from \"react\";\n\nexport const getUtmParams = () => {\n const safeGetFromLocalStorage = (key: string): string | null => {\n try {\n return localStorage.getItem(key);\n } catch {\n return null;\n }\n };\n\n const safeSetToLocalStorage = (key: string, value: string) => {\n try {\n localStorage.setItem(key, value);\n } catch {\n // Fail silently if localStorage isn't available\n }\n };\n\n const queryParams =\n typeof window !== \"undefined\"\n ? new URLSearchParams(window.location.search)\n : new URLSearchParams(); // Handle SSR gracefully\n\n const utm_source =\n queryParams.get(\"utm_source\") ||\n safeGetFromLocalStorage(\"utm_source\") ||\n \"unknown\";\n\n const utm_medium =\n queryParams.get(\"utm_medium\") ||\n safeGetFromLocalStorage(\"utm_medium\") ||\n \"unknown\";\n\n const utm_campaign =\n queryParams.get(\"utm_campaign\") ||\n safeGetFromLocalStorage(\"utm_campaign\") ||\n \"unknown\";\n\n // Only set known values to localStorage\n if (utm_source !== \"unknown\") {\n safeSetToLocalStorage(\"utm_source\", utm_source);\n }\n if (utm_medium !== \"unknown\") {\n safeSetToLocalStorage(\"utm_medium\", utm_medium);\n }\n if (utm_campaign !== \"unknown\") {\n safeSetToLocalStorage(\"utm_campaign\", utm_campaign);\n }\n\n return {\n utm_source,\n utm_medium,\n utm_campaign,\n };\n};\n\nexport const createLinkWithUtm = (url: string) => {\n const { utm_source, utm_medium, utm_campaign } = getUtmParams();\n\n try {\n const targetUrl = new URL(url, window.location.origin);\n\n // If you prefer not to append unknown parameters, you can conditionally add them only if they are not \"unknown\".\n targetUrl.searchParams.set(\"utm_source\", utm_source);\n targetUrl.searchParams.set(\"utm_medium\", utm_medium);\n targetUrl.searchParams.set(\"utm_campaign\", utm_campaign);\n\n return targetUrl.toString();\n } catch {\n // If url is invalid, just return it as-is.\n // In a production scenario, you might log this error.\n return url;\n }\n};\n\nexport function useUtmLink(originalUrl: string): string {\n const [linkUrl, setLinkUrl] = useState(originalUrl);\n\n useEffect(() => {\n const updatedUrl = createLinkWithUtm(originalUrl);\n setLinkUrl(updatedUrl);\n }, [originalUrl]);\n\n return linkUrl;\n}\n","export * from \"./formatResponsiveClass/formatResponsiveClass\";\nexport * from \"./status\";\nexport * from \"./copyToClipboard\";\nexport * from \"./utm\";\n","export default {\"src\":\"/_next/static/media/logo.62312ab0.png\",\"height\":512,\"width\":512,\"blurDataURL\":\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAICAMAAADz0U65AAAAOVBMVEVMaXEtOzx0dF0eWVQuRkYAJCVv1bMxPDktS0U3d2wt468UjXy1t5pyrpDi/+JhgWvk9tSM48AxRjuxK4zOAAAAD3RSTlMAcOXoFAoPR1f0Zviqx1tUN0vIAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAN0lEQVR4nGNgQAA2Lj42EM3KKyjAw8rAwMDOz83Jz8HAwMAoxMnJDGKwMDIxsbOAVXOwI2llAAAoYAD9gWSlggAAAABJRU5ErkJggg==\",\"blurWidth\":8,\"blurHeight\":8};"],"names":["prefersReducedMotion","useReducedMotion","useEffect","AOSWrapper","AOS","GlowCapture","children","glowColor","glowPosition","setGlowPosition","useState","x","y","glowOpacity","setGlowOpacity","captureRef","useRef","capture","current","handleMouseMove","event","rect","getBoundingClientRect","clientX","left","clientY","top","handleMouseLeave","addEventListener","removeEventListener","div","className","ref","style","ThemeSwitcher","theme","resolvedTheme","setTheme","useTheme","dropdownOpen","setDropdownOpen","contentRef","buttonRef","mounted","setMounted","firstFocusableRef","lastFocusableRef","handleClickOutside","e","contains","target","handleKeyDown","key","focus","focusableElements","querySelectorAll","length","firstElement","lastElement","shiftKey","document","activeElement","preventDefault","themeButtonIcon","useMemo","handleDropdownItemClick","selectedTheme","Button","size","onClick","prev","cn","aria-haspopup","aria-expanded","aria-label","Icon","icon","weight","AnimatePresence","motion","initial","animate","exit","variants","open","opacity","transition","duration","closed","role","ul","li","button","aria-hidden","span","MobileMenu","setOpen","dashboardLink","useUtmLink","process","mobileMenuRef","mobileMenuButtonRef","passive","Stack","direction","spacing","aria-controls","nav","id","Link","href","sendGTMEvent","value","getUtmParams","color","isRounded","as","title","align","isVisible","setIsVisible","lastScrollY","setLastScrollY","isMenuOpen","setIsMenuOpen","lastHidePosition","setLastHidePosition","isScrolling","handleScroll","requestAnimationFrame","currentScrollY","window","scrollY","scrollThresholdDown","scrollThresholdUp","header","classNames","Image","src","logo","alt","priority","width","height","p","inputs","twMerge","props","IconComponent","AvailableIcons","Title","styleAs","type","HeadingTag","baseStyles","h1","h2","h3","h4","h5","h6","alignmentStyles","center","right","colorStyles","primary","secondary","tertiary","light","subtitle","forwardRef","isLoading","rest","buttonClassName","buttonClasses","success","warning","info","link","danger","neutral","custom","small","normal","medium","large","radiusClassName","a","disabled","displayName","Tag","variant","rounded","TagComponent","sm","md","lg","shapeStyles","variantStyles","wrap","flexDirection","alignment","start","end","stretch","baseline","spacingClasses","unset","xxs","xs","xl","xxl","xxxl","none","wrapClass","statusColorClasses","bg","mid","text","copyTextToClipboard","navigator","clipboard","fallbackCopyTextToClipboard","textArea","createElement","position","bottom","padding","border","outline","boxShadow","background","pointerEvents","body","appendChild","select","execCommand","err","console","error","removeChild","writeText","safeGetFromLocalStorage","localStorage","getItem","safeSetToLocalStorage","setItem","queryParams","URLSearchParams","location","search","utm_source","get","utm_medium","utm_campaign","url","targetUrl","URL","origin","searchParams","set","toString","originalUrl","linkUrl","setLinkUrl","createLinkWithUtm","updatedUrl"],"sourceRoot":"","ignoreList":[]}