Loading...
Loading...
Guide for Tailwind CSS v4 patterns and best practices. Use when styling components with Tailwind CSS, creating responsive layouts, working with Tailwind 4 features, or using tailwind-variants for component styling.
npx skill4agent add pedronauck/skills tailwindcssbg-backgroundtext-foregroundbg-whitetext-blacktailwind-variantsbg-backgroundbg-cardbg-mutedbg-popovertext-foregroundtext-muted-foregroundtext-card-foregroundborder-borderborder-inputborder-ringbg-primary text-primary-foregroundbg-secondary text-secondary-foregroundbg-destructive text-destructive-foregroundbg-accent text-accent-foregroundbg-whitetext-blackborder-gray-200bg-blue-500import { tv } from 'tailwind-variants'
const button = tv({
base: [
'inline-flex items-center justify-center rounded-md',
'text-sm font-medium transition-colors',
'focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring',
],
variants: {
variant: {
default: 'bg-primary text-primary-foreground hover:bg-primary/90',
outline: 'border border-input hover:bg-accent hover:text-accent-foreground',
},
size: {
default: 'h-10 py-2 px-4',
sm: 'h-9 px-3 rounded-md',
icon: 'size-10',
},
},
defaultVariants: {
variant: 'default',
size: 'default',
},
})// Good: Break into logical arrays
const card = tv({
base: [
'relative flex flex-col rounded-xl border border-border',
'bg-card text-card-foreground shadow-xs transition-colors duration-150',
],
})// Mobile-first responsive design
<div className="grid grid-cols-1 gap-4 sm:grid-cols-2 md:grid-cols-3 lg:grid-cols-4">
// Container queries (built-in in v4)
<div className="@container">
<div className="@lg:flex @lg:items-center"><div className="size-10"> {/* Instead of w-10 h-10 */}
<div className="h-dvh"> {/* Dynamic viewport height */}
<div className="grid-cols-15"> {/* Dynamic grid columns */}
<h1 className="text-shadow-md"> {/* Text shadows */}
<div className="bg-(--custom-color)"> {/* CSS variables */}@apply!importantbg-${color}-500tailwind-variantspnpm run lint