.elementor-300 .elementor-element.elementor-element-a0016c5{--display:flex;}.elementor-widget-image .widget-image-caption{color:var( --e-global-color-text );font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-300 .elementor-element.elementor-element-f0563d0 > .elementor-widget-container{margin:0px 0px 0px 0px;}.elementor-300 .elementor-element.elementor-element-c186029 > .elementor-widget-container{margin:6px 6px 6px 6px;}.elementor-widget-media-carousel .elementor-carousel-image-overlay{font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}.elementor-300 .elementor-element.elementor-element-b0260ca.elementor-skin-slideshow .elementor-main-swiper:not(.elementor-thumbnails-swiper){margin-bottom:10px;}.elementor-300 .elementor-element.elementor-element-b0260ca .swiper-pagination-bullet-active, .elementor-300 .elementor-element.elementor-element-b0260ca .swiper-pagination-progressbar-fill{background-color:#FF9C00;}.elementor-300 .elementor-element.elementor-element-b0260ca .swiper-pagination-fraction{color:#FF9C00;}.elementor-300 .elementor-element.elementor-element-b0260ca > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-300 .elementor-element.elementor-element-b0260ca .elementor-main-swiper .swiper-slide{background-color:#FFFFFF;border-width:2px 2px 2px 2px;border-radius:25px;border-color:#FFFFFF;padding:0px 0px 0px 0px;}.elementor-300 .elementor-element.elementor-element-b0260ca .elementor-swiper-button{font-size:20px;color:#FFFFFF;}.elementor-300 .elementor-element.elementor-element-b0260ca .elementor-swiper-button svg{fill:#FFFFFF;}.elementor-300 .elementor-element.elementor-element-b0260ca .swiper-pagination-bullet:not(.swiper-pagination-bullet-active){background-color:#FFFFFF;opacity:1;}#elementor-lightbox-slideshow-b0260ca{background-color:#020101;}#elementor-lightbox-slideshow-b0260ca .elementor-video-container{width:50%;}.elementor-300 .elementor-element.elementor-element-b0260ca .elementor-custom-embed-play i{color:#FFFFFF;}.elementor-300 .elementor-element.elementor-element-b0260ca .elementor-custom-embed-play svg{fill:#FFFFFF;}.elementor-300 .elementor-element.elementor-element-d9159f0{--display:flex;}.elementor-widget-button .elementor-button{background-color:var( --e-global-color-accent );font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}@media(max-width:1024px){.elementor-300 .elementor-element.elementor-element-b0260ca.elementor-skin-slideshow .elementor-main-swiper:not(.elementor-thumbnails-swiper){margin-bottom:10px;}}@media(max-width:767px){.elementor-300 .elementor-element.elementor-element-f0563d0 > .elementor-widget-container{margin:-10px -10px -10px -10px;}.elementor-300 .elementor-element.elementor-element-c186029 > .elementor-widget-container{margin:-10px -10px -10px -10px;}.elementor-300 .elementor-element.elementor-element-b0260ca.elementor-skin-slideshow .elementor-main-swiper:not(.elementor-thumbnails-swiper){margin-bottom:0px;}.elementor-300 .elementor-element.elementor-element-b0260ca > .elementor-widget-container{margin:-10px -10px -10px -10px;}.elementor-300 .elementor-element.elementor-element-b0260ca .elementor-main-swiper{height:650px;width:430px;}.elementor-300 .elementor-element.elementor-element-b0260ca .elementor-swiper-button{font-size:20px;}.elementor-300 .elementor-element.elementor-element-b0260ca .swiper-pagination-bullet{--swiper-pagination-bullet-horizontal-gap:1px;--swiper-pagination-bullet-vertical-gap:1px;height:7px;width:7px;}.elementor-300 .elementor-element.elementor-element-b0260ca .swiper-horizontal .swiper-pagination-progressbar{height:7px;}.elementor-300 .elementor-element.elementor-element-b0260ca .elementor-custom-embed-play i{font-size:20px;}}/* Start custom CSS for button, class: .elementor-element-f5129dc */You are given a task to integrate an existing React component in the codebase

The codebase should support:
- shadcn project structure  
- Tailwind CSS
- Typescript

If it doesn't, provide instructions on how to setup project via shadcn CLI, install Tailwind or Typescript.

Determine the default path for components and styles. 
If default path for components is not /components/ui, provide instructions on why it's important to create this folder
Copy-paste this component to /components/ui folder:
```tsx
star-border.tsx
import { cn } from "@/lib/utils"
import { ElementType, ComponentPropsWithoutRef } from "react"

interface StarBorderProps<T extends ElementType> {
  as?: T
  color?: string
  speed?: string
  className?: string
  children: React.ReactNode
}

export function StarBorder<T extends ElementType = "button">({
  as,
  className,
  color,
  speed = "6s",
  children,
  ...props
}: StarBorderProps<T> & Omit<ComponentPropsWithoutRef<T>, keyof StarBorderProps<T>>) {
  const Component = as || "button"
  const defaultColor = color || "hsl(var(--foreground))"

  return (
    <Component 
      className={cn(
        "relative inline-block py-[1px] overflow-hidden rounded-[20px]",
        className
      )} 
      {...props}
    >
      <div
        className={cn(
          "absolute w-[300%] h-[50%] bottom-[-11px] right-[-250%] rounded-full animate-star-movement-bottom z-0",
          "opacity-20 dark:opacity-70" 
        )}
        style={{
          background: `radial-gradient(circle, ${defaultColor}, transparent 10%)`,
          animationDuration: speed,
        }}
      />
      <div
        className={cn(
          "absolute w-[300%] h-[50%] top-[-10px] left-[-250%] rounded-full animate-star-movement-top z-0",
          "opacity-20 dark:opacity-70"
        )}
        style={{
          background: `radial-gradient(circle, ${defaultColor}, transparent 10%)`,
          animationDuration: speed,
        }}
      />
      <div className={cn(
        "relative z-1 border text-foreground text-center text-base py-4 px-6 rounded-[20px]",
        "bg-gradient-to-b from-background/90 to-muted/90 border-border/40",
        "dark:from-background dark:to-muted dark:border-border"
      )}>
        {children}
      </div>
    </Component>
  )
}

demo.tsx
import { cn } from "@/lib/utils"
import { StarBorder } from "@/components/ui/star-border"

export function StarBorderDemo() {
  return (
    <div className="space-y-8">
      <StarBorder>
        Theme-aware Border
      </StarBorder>
    </div>
  )
}
```

Extend existing tailwind.config.js with this code:
```js
/** @type {import('tailwindcss').Config} */
module.exports = {
  theme: {
    extend: {
      animation: {
        'star-movement-bottom': 'star-movement-bottom linear infinite alternate',
        'star-movement-top': 'star-movement-top linear infinite alternate',
      },
      keyframes: {
        'star-movement-bottom': {
          '0%': { transform: 'translate(0%, 0%)', opacity: '1' },
          '100%': { transform: 'translate(-100%, 0%)', opacity: '0' },
        },
        'star-movement-top': {
          '0%': { transform: 'translate(0%, 0%)', opacity: '1' },
          '100%': { transform: 'translate(100%, 0%)', opacity: '0' },
        },
      },
    },
  },
}
```

Implementation Guidelines
 1. Analyze the component structure and identify all required dependencies
 2. Review the component's argumens and state
 3. Identify any required context providers or hooks and install them
 4. Questions to Ask
 - What data/props will be passed to this component?
 - Are there any specific state management requirements?
 - Are there any required assets (images, icons, etc.)?
 - What is the expected responsive behavior?
 - What is the best place to use this component in the app?

Steps to integrate
 0. Copy paste all the code above in the correct directories
 1. Install external dependencies
 2. Fill image assets with Unsplash stock images you know exist
 3. Use lucide-react icons for svgs or logos if component requires them/* End custom CSS */