@container-size utility (#18901)scrollbar-{auto,thin,none} utilities for scrollbar-width, and scrollbar-thumb-* / scrollbar-track-* color utilities for scrollbar-color (#19981, #20019)scrollbar-gutter-* utilities (#20018)zoom-* utilities (#20020)tab-* utilities (#20022)@variant with stacked variants (e.g. @variant hover:focus { … }) (#19996)@variant with compound variants (e.g. @variant hover, focus { … }) (#19996)--default(…) in --value(…) and --modifier(…) for functional @utility definitions (#19989)@plugin resolves package JavaScript entries instead of browser CSS entries when using @tailwindcss/vite (#19949)@import and @plugin paths resolving from the wrong directory when using @tailwindcss/vite (#19965)@variant are processed by @tailwindcss/vite (#19966)base when result.opts.from is not provided when using @tailwindcss/postcss (#19980)_ whitespace in arbitrary values (#19986)w-[calc(100%---spacing(60))] → w-[calc(100%-(--spacing(60)))]) (#19986)-mt-[20in] → mt-[-20in], not mt-[-1920px]) (#19988):has() variants from [&:has(…)] to has-[…] (#19991)style attributes (e.g. style="flex-grow: 1" → style="flex-grow: 1", not style="grow: 1") (#19918)@utility definitions with the same name but different value types (#19777)PluginWithConfig type from tailwindcss/plugin to fix errors when inferring plugin config types (#19707)start and end legacy utilities without values do not generate CSS (#20003)--value(…) is required in functional @utility definitions (#20005)-left-[(var(--a)+var(--b))]) (#20011)/sorter (#438)canCollapseWhitespaceIn handling for "tailwindPreserveWhitespace": true (#428)@import and @plugin still resolve correctly when using Vite aliases in @tailwindcss/vite (#19947)tracking-* utilities by preferring non-negative utilities (e.g. -tracking-tighter → tracking-wider) (#19827)@tailwindcss/webpack (#19723)px-[1.2rem] py-[1.2rem] → p-[1.2rem]) (#19837)border-{t,b}-* into border-y-*, border-{l,r}-* into border-x-*, and border-{t,r,b,l}-* into border-* (#19842)scroll-m{t,b}-* into scroll-my-*, scroll-m{l,r}-* into scroll-mx-*, and scroll-m{t,r,b,l}-* into scroll-m-* (#19842)scroll-p{t,b}-* into scroll-py-*, scroll-p{l,r}-* into scroll-px-*, and scroll-p{t,r,b,l}-* into scroll-p-* (#19842)overflow-{x,y}-* into overflow-* (#19842)overscroll-{x,y}-* into overscroll-* (#19842)--placeholder-color instead of --background-color for placeholder-* utilities (#19843)config.content when migrating from Tailwind CSS v3 to Tailwind CSS v4 (#19846).env and .env.* to default ignored content files (#19846)overflow-ellipsis into text-ellipsis (#19849)start-full → inset-s-full, start-auto → inset-s-auto, start-px → inset-s-px, and start-<number> → inset-s-<number> as well as negative versions (#19849)end-full → inset-e-full, end-auto → inset-e-auto, end-px → inset-e-px, and end-<number> → inset-e-<number> as well as negative versions (#19849)- sign inside the arbitrary value -left-[9rem] → left-[-9rem] (#19858)- sign outside the arbitrary value ml-[calc(-1*var(--width))] → -ml-(--width) (#19858)NODE_PATH environment variable in standalone CLI (#19617)@tailwindcss/vite (#19790)row-constructor (#19725)calc(var(--spacing)*…) expressions into --spacing(…) (#19769)@property at-rules (e.g. shadow-sm border) (#19727)@tailwindcss/vite (#19745)w-1234 h-1234 → size-1234) (#19809)w-5 h-5 size-5 → '' instead of size-5) (#19812)@tailwindcss/webpack package to run Tailwind CSS as a webpack plugin (#19610)pbs-* and pbe-* utilities for padding-block-start and padding-block-end (#19601)mbs-* and mbe-* utilities for margin-block-start and margin-block-end (#19601)scroll-pbs-* and scroll-pbe-* utilities for scroll-padding-block-start and scroll-padding-block-end (#19601)scroll-mbs-* and scroll-mbe-* utilities for scroll-margin-block-start and scroll-margin-block-end (#19601)border-bs-* and border-be-* utilities for border-block-start and border-block-end (#19601)inline-*, min-inline-*, max-inline-* utilities for inline-size, min-inline-size, and max-inline-size (#19612)block-*, min-block-*, max-block-* utilities for block-size, min-block-size, and max-block-size (#19612)inset-s-*, inset-e-*, inset-bs-*, inset-be-* utilities for inset-inline-start, inset-inline-end, inset-block-start, and inset-block-end (#19613)font-features-* utility for font-feature-settings (#19623)@supports wrapper for color-mix values (#19450)@source inline() argument (#19461)@tailwindcss/cli (#19447)@utility name validation with Oxide scanner rules (#19524)@variant inside @custom-variant (#19633).25 in aspect-* fractions (e.g. aspect-8.5/11) (#19688)@source trigger a full page reload when using @tailwindcss/vite (#19670)@tailwindcss/vite (#19677)@utility names to improve support with formatters such as Biome (#19626).jj to default ignored content directories (#19687)start-* and end-* utilities in favor of inset-s-* and inset-e-* utilities (#19613)source(…) happens relative to the file it is in (#19274)! in the value (#19243)@tailwindcss/vite (#18970)--watch (#19373)ringColor.DEFAULT) in JS configs (#19348)content theme key from JS configs (#19381)future and experimental config keys (#19344)text-* and leading-* classes (#19396)@keyframes (#19419)/dev/stdout (#19421)color-mix fallback (#19069):deep, :slotted, and :global (#19094)not-*, has-*, and in-* (#19100)theme(…) function (#19111)\t is used in at-rules (#19130)0 values (#19095)break-words to wrap-break-word (#19157)postinstall script from oxide (#19149)@source, @plugin, and @config (#387)ParserOptions and RequiredOptions types (#354)prettier-plugin-import-sort (#385)' syntax in ClojureScript when extracting classes (#18888)@variant inside @custom-variant (#18885)@utility (#18900)grid-column utilities when configuring grid-column-start or grid-column-end (#18907)grid-row utilities when configuring grid-row-start or grid-row-end (#18907)default export condition for @tailwindcss/vite (#18948)@theme produce no output when built (#18979)variant = 'outline' during upgrades (#18922)className is migrated (#19031)*ClassName and *Class attributes (#19031)supports-[…] queries in arbitrary values (#13605)require.cache error when loaded through a TypeScript file in Node 22.18+ (#18665)import.meta.resolve(…) in configs for new enough Node.js versions (#18938)postcss-load-config for better ESM and TypeScript PostCSS config support with the CLI (#18938)