'use client'; import React from 'react'; import { cn } from '@/lib/utils'; interface ButtonProps extends React.ButtonHTMLAttributes { variant?: 'primary' | 'secondary' | 'outline' | 'ghost'; size?: 'sm' | 'md' | 'lg'; loading?: boolean; } export const Button = React.forwardRef( ({ className, variant = 'primary', size = 'md', loading, children, disabled, ...props }, ref) => { const baseClasses = 'inline-flex items-center justify-center font-medium rounded-lg transition-colors focus:outline-none focus:ring-2 focus:ring-offset-2 disabled:opacity-50 disabled:cursor-not-allowed'; const variants = { primary: 'bg-primary-600 text-white hover:bg-primary-700 focus:ring-primary-500', secondary: 'bg-gray-100 text-gray-900 hover:bg-gray-200 focus:ring-gray-500', outline: 'border border-gray-300 text-gray-700 hover:bg-gray-50 focus:ring-gray-500', ghost: 'text-gray-700 hover:bg-gray-100 focus:ring-gray-500', }; const sizes = { sm: 'px-3 py-1.5 text-sm', md: 'px-4 py-2 text-sm', lg: 'px-6 py-3 text-base', }; return ( ); } ); Button.displayName = 'Button';