import { type Config } from 'tailwindcss' import typography from '@tailwindcss/typography' import animate from 'tailwindcss-animate' export default { darkMode: ['class'], content: ['./src/**/*.{ts,tsx,css,html}'], theme: { container: { center: true, padding: '2rem' }, extend: { zIndex: { infinity: 'calc(infinity)' }, colors: { border: 'hsl(var(--border))', input: 'hsl(var(--input))', ring: 'hsl(var(--ring))', background: 'hsl(var(--background))', foreground: 'hsl(var(--foreground))', primary: { DEFAULT: 'hsl(var(--primary))', foreground: 'hsl(var(--primary-foreground))' }, secondary: { DEFAULT: 'hsl(var(--secondary))', foreground: 'hsl(var(--secondary-foreground))' }, destructive: { DEFAULT: 'hsl(var(--destructive))', foreground: 'hsl(var(--destructive-foreground))' }, muted: { DEFAULT: 'hsl(var(--muted))', foreground: 'hsl(var(--muted-foreground))' }, accent: { DEFAULT: 'hsl(var(--accent))', foreground: 'hsl(var(--accent-foreground))' }, popover: { DEFAULT: 'hsl(var(--popover))', foreground: 'hsl(var(--popover-foreground))' }, card: { DEFAULT: 'hsl(var(--card))', foreground: 'hsl(var(--card-foreground))' } }, minWidth: { screen: '100vw' }, backdropBlur: { xs: '2px' }, borderRadius: { lg: 'var(--radius)', md: 'calc(var(--radius) - 2px)', sm: 'calc(var(--radius) - 4px)' }, keyframes: { 'accordion-down': { from: { height: '0' }, to: { height: 'var(--radix-accordion-content-height)' } }, 'accordion-up': { from: { height: 'var(--radix-accordion-content-height)' }, to: { height: '0' } }, pulse: { '0%, 100%': { boxShadow: '0 0 0 0 var(--pulse-color)' }, '50%': { boxShadow: '0 0 0 8px var(--pulse-color)' } }, meteor: { '0%': { transform: 'rotate(215deg) translateX(0)', opacity: '1' }, '70%': { opacity: '1' }, '100%': { transform: 'rotate(215deg) translateX(-500px)', opacity: '0' } }, shimmer: { '0%': { '--shimmer-angle': '0deg' }, '100%': { '--shimmer-angle': '360deg' } } }, animation: { 'accordion-down': 'accordion-down 0.2s ease-out', 'accordion-up': 'accordion-up 0.2s ease-out', pulse: 'pulse var(--duration) ease-out infinite', meteor: 'meteor 5s linear infinite' } } }, plugins: [animate, typography()] } satisfies Config