Tailwind CSS styling with CVA variants, data-slots, layout patterns, and z-index management
#ui_code_tools scaffold for proper cva and data-slot setupcn() helper (clsx + tailwind-merge)import { cva } from "class-variance-authority";
import { cn } from "@/lib/utils";
const buttonVariants = cva(
// Base styles
"inline-flex items-center justify-center rounded-md font-medium transition-colors",
{
variants: {
variant: {
primary: [
"bg-fg-brand-primary text-text-neutral-white",
"border border-transparent",
"hover:bg-fg-brand-secondary",
"disabled:border-border-neutral-disabled_subtle disabled:text-text-neutral-quinary-disabled disabled:bg-fg-neutral-disabled",
],
secondary: "bg-secondary text-secondary-foreground hover:bg-secondary/80",
},
size: {
default: "h-10 px-4 py-2",
sm: "h-9 px-3 text-sm",
lg: "h-11 px-8",
}
},
defaultVariants: {
variant: "primary",
size: "default",
}
}
);
export function Button({ className, variant, size, ...props }) {
return (
<button
className={cn(buttonVariants({ variant, size }), className)}
{...props}
/>
);
}
Group related state classes together: