Created
May 3, 2025 17:27
-
-
Save ckng/c6480e79c2328c06a4aa47259faded91 to your computer and use it in GitHub Desktop.
Tailwind 4.1 docs llms.txt
This file has been truncated, but you can view the full file.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Directory Structure: | |
└── ./ | |
└── src | |
└── docs | |
├── accent-color.mdx | |
├── adding-custom-styles.mdx | |
├── align-content.mdx | |
├── align-items.mdx | |
├── align-self.mdx | |
├── animation.mdx | |
├── appearance.mdx | |
├── aspect-ratio.mdx | |
├── backdrop-filter-blur.mdx | |
├── backdrop-filter-brightness.mdx | |
├── backdrop-filter-contrast.mdx | |
├── backdrop-filter-grayscale.mdx | |
├── backdrop-filter-hue-rotate.mdx | |
├── backdrop-filter-invert.mdx | |
├── backdrop-filter-opacity.mdx | |
├── backdrop-filter-saturate.mdx | |
├── backdrop-filter-sepia.mdx | |
├── backdrop-filter.mdx | |
├── backface-visibility.mdx | |
├── background-attachment.mdx | |
├── background-blend-mode.mdx | |
├── background-clip.mdx | |
├── background-color.mdx | |
├── background-image.mdx | |
├── background-origin.mdx | |
├── background-position.mdx | |
├── background-repeat.mdx | |
├── background-size.mdx | |
├── border-collapse.mdx | |
├── border-color.mdx | |
├── border-radius.mdx | |
├── border-spacing.mdx | |
├── border-style.mdx | |
├── border-width.mdx | |
├── box-decoration-break.mdx | |
├── box-shadow.mdx | |
├── box-sizing.mdx | |
├── break-after.mdx | |
├── break-before.mdx | |
├── break-inside.mdx | |
├── caption-side.mdx | |
├── caret-color.mdx | |
├── clear.mdx | |
├── color-scheme.mdx | |
├── color.mdx | |
├── colors.mdx | |
├── columns.mdx | |
├── compatibility.mdx | |
├── content.mdx | |
├── cursor.mdx | |
├── dark-mode.mdx | |
├── detecting-classes-in-source-files.mdx | |
├── display.mdx | |
├── editor-setup.mdx | |
├── field-sizing.mdx | |
├── fill.mdx | |
├── filter-blur.mdx | |
├── filter-brightness.mdx | |
├── filter-contrast.mdx | |
├── filter-drop-shadow.mdx | |
├── filter-grayscale.mdx | |
├── filter-hue-rotate.mdx | |
├── filter-invert.mdx | |
├── filter-saturate.mdx | |
├── filter-sepia.mdx | |
├── filter.mdx | |
├── flex-basis.mdx | |
├── flex-direction.mdx | |
├── flex-grow.mdx | |
├── flex-shrink.mdx | |
├── flex-wrap.mdx | |
├── flex.mdx | |
├── float.mdx | |
├── font-family.mdx | |
├── font-size.mdx | |
├── font-smoothing.mdx | |
├── font-stretch.mdx | |
├── font-style.mdx | |
├── font-variant-numeric.mdx | |
├── font-weight.mdx | |
├── forced-color-adjust.mdx | |
├── functions-and-directives.mdx | |
├── gap.mdx | |
├── grid-auto-columns.mdx | |
├── grid-auto-flow.mdx | |
├── grid-auto-rows.mdx | |
├── grid-column.mdx | |
├── grid-row.mdx | |
├── grid-template-columns.mdx | |
├── grid-template-rows.mdx | |
├── height.mdx | |
├── hover-focus-and-other-states.mdx | |
├── hyphens.mdx | |
├── isolation.mdx | |
├── justify-content.mdx | |
├── justify-items.mdx | |
├── justify-self.mdx | |
├── letter-spacing.mdx | |
├── line-clamp.mdx | |
├── line-height.mdx | |
├── list-style-image.mdx | |
├── list-style-position.mdx | |
├── list-style-type.mdx | |
├── margin.mdx | |
├── mask-clip.mdx | |
├── mask-composite.mdx | |
├── mask-image.mdx | |
├── mask-mode.mdx | |
├── mask-origin.mdx | |
├── mask-position.mdx | |
├── mask-repeat.mdx | |
├── mask-size.mdx | |
├── mask-type.mdx | |
├── max-height.mdx | |
├── max-width.mdx | |
├── min-height.mdx | |
├── min-width.mdx | |
├── mix-blend-mode.mdx | |
├── object-fit.mdx | |
├── object-position.mdx | |
├── opacity.mdx | |
├── order.mdx | |
├── outline-color.mdx | |
├── outline-offset.mdx | |
├── outline-style.mdx | |
├── outline-width.mdx | |
├── overflow-wrap.mdx | |
├── overflow.mdx | |
├── overscroll-behavior.mdx | |
├── padding.mdx | |
├── perspective-origin.mdx | |
├── perspective.mdx | |
├── place-content.mdx | |
├── place-items.mdx | |
├── place-self.mdx | |
├── pointer-events.mdx | |
├── position.mdx | |
├── preflight.mdx | |
├── resize.mdx | |
├── responsive-design.mdx | |
├── rotate.mdx | |
├── scale.mdx | |
├── scroll-behavior.mdx | |
├── scroll-margin.mdx | |
├── scroll-padding.mdx | |
├── scroll-snap-align.mdx | |
├── scroll-snap-stop.mdx | |
├── scroll-snap-type.mdx | |
├── skew.mdx | |
├── stroke-width.mdx | |
├── stroke.mdx | |
├── styling-with-utility-classes.mdx | |
├── table-layout.mdx | |
├── text-align.mdx | |
├── text-decoration-color.mdx | |
├── text-decoration-line.mdx | |
├── text-decoration-style.mdx | |
├── text-decoration-thickness.mdx | |
├── text-indent.mdx | |
├── text-overflow.mdx | |
├── text-shadow.mdx | |
├── text-transform.mdx | |
├── text-underline-offset.mdx | |
├── text-wrap.mdx | |
├── theme.mdx | |
├── top-right-bottom-left.mdx | |
├── touch-action.mdx | |
├── transform-origin.mdx | |
├── transform-style.mdx | |
├── transform.mdx | |
├── transition-behavior.mdx | |
├── transition-delay.mdx | |
├── transition-duration.mdx | |
├── transition-property.mdx | |
├── transition-timing-function.mdx | |
├── translate.mdx | |
├── upgrade-guide.mdx | |
├── user-select.mdx | |
├── vertical-align.mdx | |
├── visibility.mdx | |
├── white-space.mdx | |
├── width.mdx | |
├── will-change.mdx | |
├── word-break.mdx | |
└── z-index.mdx | |
--- | |
File: /src/docs/accent-color.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { | |
CustomizingYourThemeColors, | |
ResponsiveDesign, | |
TargetingSpecificStates, | |
UsingACustomValue, | |
} from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import colors from "./utils/colors"; | |
export const title = "accent-color"; | |
export const description = "Utilities for controlling the accented color of a form control."; | |
<ApiTable | |
rows={[ | |
["accent-inherit", "accent-color: inherit;"], | |
["accent-current", "accent-color: currentColor;"], | |
["accent-transparent", "accent-color: transparent;"], | |
...Object.entries(colors).map(([name, value]) => [ | |
`accent-${name}`, | |
`accent-color: var(--color-${name}); /* ${value} */`, | |
]), | |
["accent-<custom-property>", "accent-color: var(<custom-property>);"], | |
["accent-[<value>]", "accent-color: <value>;"], | |
]} | |
/> | |
## Examples | |
### Setting the accent color | |
Use utilities like `accent-rose-500` and `accent-lime-600` to change the accent color of an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-wrap justify-center gap-6"> | |
<label className="flex items-center space-x-2"> | |
<input type="checkbox" defaultChecked /> | |
<div className="text-sm font-semibold text-gray-900 dark:text-gray-200">Browser default</div> | |
</label> | |
<label className="flex items-center space-x-2"> | |
<input type="checkbox" className="accent-pink-500" defaultChecked /> | |
<div className="text-sm font-semibold text-gray-900 dark:text-gray-200">Customized</div> | |
</label> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:accent-pink-500] --> | |
<label> | |
<input type="checkbox" checked /> | |
Browser default | |
</label> | |
<label> | |
<input class="accent-pink-500" type="checkbox" checked /> | |
Customized | |
</label> | |
``` | |
</Figure> | |
This is helpful for styling elements like checkboxes and radio groups by overriding the browser's default color. | |
### Changing the opacity | |
Use the color opacity modifier to control the opacity of an element's accent color: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-wrap justify-center gap-6"> | |
<label className="flex items-center space-x-2"> | |
<input type="checkbox" defaultChecked className="accent-purple-500/25" /> | |
<div className="text-sm font-semibold text-gray-900 dark:text-gray-200">accent-purple-500/25</div> | |
</label> | |
<label className="flex items-center space-x-2"> | |
<input type="checkbox" className="accent-purple-500/75" defaultChecked /> | |
<div className="text-sm font-semibold text-gray-900 dark:text-gray-200">accent-purple-500/75</div> | |
</label> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code word:/25] --> | |
<!-- [!code word:/75] --> | |
<input class="accent-purple-500/25" type="checkbox" checked /> | |
<input class="accent-purple-500/75" type="checkbox" checked /> | |
``` | |
</Figure> | |
Setting the accent color opacity has limited browser-support and only works in Firefox at this time. | |
### Using a custom value | |
<UsingACustomValue | |
element="input" | |
elementAttributes={{ type: "checkbox" }} | |
utility="accent" | |
value="#50d71e" | |
name="accent color" | |
variable="accent-color" | |
/> | |
### Applying on hover | |
<TargetingSpecificStates property="accent-color"> | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-wrap justify-center gap-6"> | |
<label className="flex items-center space-x-2"> | |
<input type="checkbox" className="accent-black hover:accent-pink-500" defaultChecked /> | |
<div className="text-sm font-semibold text-gray-900 dark:text-gray-200">Agree to terms</div> | |
</label> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:hover:accent-pink-500] --> | |
<input class="accent-black hover:accent-pink-500" type="checkbox" /> | |
``` | |
</Figure> | |
</TargetingSpecificStates> | |
### Responsive design | |
<ResponsiveDesign | |
element="input" | |
elementAttributes={{ type: "checkbox" }} | |
property="accent-color" | |
defaultClass="accent-black" | |
featuredClass="accent-pink-500" | |
/> | |
## Customizing your theme | |
<CustomizingYourThemeColors element="input" elementAttributes={{ type: "checkbox" }} utility="accent" /> | |
--- | |
File: /src/docs/adding-custom-styles.mdx | |
--- | |
import { CodeExampleStack } from "@/components/code-example"; | |
export const title = "Adding custom styles"; | |
export const description = "Best practices for adding your own custom styles in Tailwind projects."; | |
Often the biggest challenge when working with a framework is figuring out what you’re supposed to do when there’s something you need that the framework doesn’t handle for you. | |
Tailwind has been designed from the ground up to be extensible and customizable, so that no matter what you’re building you never feel like you’re fighting the framework. | |
This guide covers topics like customizing your design tokens, how to break out of those constraints when necessary, adding your own custom CSS, and extending the framework with plugins. | |
## Customizing your theme | |
If you want to change things like your color palette, spacing scale, typography scale, or breakpoints, add your customizations using the `@theme` directive in your CSS: | |
```css | |
/* [!code filename:CSS] */ | |
@theme { | |
--font-display: "Satoshi", "sans-serif"; | |
--breakpoint-3xl: 120rem; | |
--color-avocado-100: oklch(0.99 0 0); | |
--color-avocado-200: oklch(0.98 0.04 113.22); | |
--color-avocado-300: oklch(0.94 0.11 115.03); | |
--color-avocado-400: oklch(0.92 0.19 114.08); | |
--color-avocado-500: oklch(0.84 0.18 117.33); | |
--color-avocado-600: oklch(0.53 0.12 118.34); | |
--ease-fluid: cubic-bezier(0.3, 0, 0, 1); | |
--ease-snappy: cubic-bezier(0.2, 0, 0, 1); | |
/* ... */ | |
} | |
``` | |
Learn more about customizing your theme in the [theme variables documentation](/docs/theme). | |
## Using arbitrary values | |
While you can usually build the bulk of a well-crafted design using a constrained set of design tokens, once in a while you need to break out of those constraints to get things pixel-perfect. | |
When you find yourself really needing something like `top: 117px` to get a background image in just the right spot, use Tailwind's square bracket notation to generate a class on the fly with any arbitrary value: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:top-[117px]] --> | |
<div class="top-[117px]"> | |
<!-- ... --> | |
</div> | |
``` | |
This is basically like inline styles, with the major benefit that you can combine it with interactive modifiers like `hover` and responsive modifiers like `lg`: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:top-[117px],lg:top-[344px]] --> | |
<div class="top-[117px] lg:top-[344px]"> | |
<!-- ... --> | |
</div> | |
``` | |
This works for everything in the framework, including things like background colors, font sizes, pseudo-element content, and more: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:bg-[#bada55],text-[22px],before:content-['Festivus']] --> | |
<div class="bg-[#bada55] text-[22px] before:content-['Festivus']"> | |
<!-- ... --> | |
</div> | |
``` | |
If you're referencing a CSS variable as an arbitrary value, you can use the custom property syntax: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:fill-(--my-brand-color)] --> | |
<div class="fill-(--my-brand-color) ..."> | |
<!-- ... --> | |
</div> | |
``` | |
This is just a shorthand for <code>fill-{'[var(--my-brand-color)]'}</code> that adds the `var()` function for you automatically. | |
### Arbitrary properties | |
If you ever need to use a CSS property that Tailwind doesn't include a utility for out of the box, you can also use square bracket notation to write completely arbitrary CSS: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:[mask-type:luminance]] --> | |
<div class="[mask-type:luminance]"> | |
<!-- ... --> | |
</div> | |
``` | |
This is _really_ like inline styles, but again with the benefit that you can use modifiers: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:[mask-type:luminance],hover:[mask-type:alpha]] --> | |
<div class="[mask-type:luminance] hover:[mask-type:alpha]"> | |
<!-- ... --> | |
</div> | |
``` | |
This can be useful for things like CSS variables as well, especially when they need to change under different conditions: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:[--scroll-offset:56px],lg:[--scroll-offset:44px]] --> | |
<div class="[--scroll-offset:56px] lg:[--scroll-offset:44px]"> | |
<!-- ... --> | |
</div> | |
``` | |
### Arbitrary variants | |
Arbitrary _variants_ are like arbitrary values but for doing on-the-fly selector modification, like you can with built-in pseudo-class variants like `hover:{utility}` or responsive variants like `md:{utility}` but using square bracket notation directly in your HTML. | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code word:\[&\:nth-child(-n+3)\]] --> | |
<ul role="list"> | |
{#each items as item} | |
<li class="lg:[&:nth-child(-n+3)]:hover:underline">{item}</li> | |
{/each} | |
</ul> | |
``` | |
Learn more in the [arbitrary variants](/docs/hover-focus-and-other-states#using-arbitrary-variants) documentation. | |
### Handling whitespace | |
When an arbitrary value needs to contain a space, use an underscore (`_`) instead and Tailwind will automatically convert it to a space at build-time: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:grid-cols-[1fr_500px_2fr]] --> | |
<div class="grid grid-cols-[1fr_500px_2fr]"> | |
<!-- ... --> | |
</div> | |
``` | |
In situations where underscores are common but spaces are invalid, Tailwind will preserve the underscore instead of converting it to a space, for example in URLs: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:bg-[url('/what_a_rush.png')]] --> | |
<div class="bg-[url('/what_a_rush.png')]"> | |
<!-- ... --> | |
</div> | |
``` | |
In the rare case that you actually need to use an underscore but it's ambiguous because a space is valid as well, escape the underscore with a backslash and Tailwind won't convert it to a space: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:before:content-['hello\_world']] --> | |
<div class="before:content-['hello\_world']"> | |
<!-- ... --> | |
</div> | |
``` | |
If you're using something like JSX where the backslash is stripped from the rendered HTML, use [String.raw()](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/raw) so the backslash isn't treated as a JavaScript escape character: | |
```jsx | |
<div className={String.raw`before:content-['hello\_world']`}> | |
<!-- ... --> | |
</div> | |
``` | |
### Resolving ambiguities | |
Many utilities in Tailwind share a common namespace but map to different CSS properties. For example `text-lg` and `text-black` both share the `text-` namespace, but one is for `font-size` and the other is for `color`. | |
When using arbitrary values, Tailwind can generally handle this ambiguity automatically based on the value you pass in: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:text-[22px],text-[#bada55]] --> | |
<!-- Will generate a font-size utility --> | |
<div class="text-[22px]">...</div> | |
<!-- Will generate a color utility --> | |
<div class="text-[#bada55]">...</div> | |
``` | |
Sometimes it really is ambiguous though, for example when using CSS variables: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:text-(--my-var)] --> | |
<div class="text-(--my-var)">...</div> | |
``` | |
In these situations, you can "hint" the underlying type to Tailwind by adding a [CSS data type](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Types) before the value: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:text-(length:--my-var),text-(color:--my-var)] --> | |
<!-- Will generate a font-size utility --> | |
<div class="text-(length:--my-var)">...</div> | |
<!-- Will generate a color utility --> | |
<div class="text-(color:--my-var)">...</div> | |
``` | |
## Using custom CSS | |
While Tailwind is designed to handle the bulk of your styling needs, there is nothing stopping you from just writing plain CSS when you need to: | |
```css | |
/* [!code filename:CSS] */ | |
@import "tailwindcss"; | |
/* [!code highlight:4] */ | |
.my-custom-style { | |
/* ... */ | |
} | |
``` | |
### Adding base styles | |
If you just want to set some defaults for the page (like the text color, background color, or font family), the easiest option is just adding some classes to the `html` or `body` elements: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:bg-gray-100,font-serif,text-gray-900] --> | |
<!doctype html> | |
<html lang="en" class="bg-gray-100 font-serif text-gray-900"> | |
<!-- ... --> | |
</html> | |
``` | |
This keeps your base styling decisions in your markup alongside all of your other styles, instead of hiding them in a separate file. | |
If you want to add your own default base styles for specific HTML elements, use the `@layer` directive to add those styles to Tailwind's `base` layer: | |
```css | |
/* [!code filename:CSS] */ | |
/* [!code highlight:2] */ | |
@layer base { | |
h1 { | |
font-size: var(--text-2xl); | |
} | |
h2 { | |
font-size: var(--text-xl); | |
} | |
/* [!code highlight:2] */ | |
} | |
``` | |
### Adding component classes | |
Use the `components` layer for any more complicated classes you want to add to your project that you'd still like to be able to override with utility classes. | |
Traditionally these would be classes like `card`, `btn`, `badge` — that kind of thing. | |
```css | |
/* [!code filename:CSS] */ | |
/* [!code highlight:2] */ | |
@layer components { | |
.card { | |
background-color: var(--color-white); | |
border-radius: var(--rounded-lg); | |
padding: var(--spacing-6); | |
box-shadow: var(--shadow-xl); | |
} | |
/* [!code highlight:2] */ | |
} | |
``` | |
By defining component classes in the `components` layer, you can still use utility classes to override them when necessary: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:card,rounded-none] --> | |
<!-- Will look like a card, but with square corners --> | |
<div class="card rounded-none"> | |
<!-- ... --> | |
</div> | |
``` | |
Using Tailwind you probably don't need these types of classes as often as you think. Read our guide on [managing duplication](/docs/styling-with-utility-classes#managing-duplication) for our recommendations. | |
The `components` layer is also a good place to put custom styles for any third-party components you're using: | |
```css | |
/* [!code filename:CSS] */ | |
@layer components { | |
.select2-dropdown { | |
/* ... */ | |
} | |
} | |
``` | |
### Using variants | |
Use the `@variant` directive to apply a Tailwind variant within custom CSS: | |
<CodeExampleStack> | |
```css | |
/* [!code filename:app.css] */ | |
.my-element { | |
background: white; | |
/* [!code highlight:4] */ | |
@variant dark { | |
background: black; | |
} | |
} | |
``` | |
```css | |
/* [!code filename:Compiled CSS] */ | |
.my-element { | |
background: white; | |
/* [!code highlight:4] */ | |
@media (prefers-color-scheme: dark) { | |
background: black; | |
} | |
} | |
``` | |
</CodeExampleStack> | |
If you need to apply multiple variants at the same time, use nesting: | |
<CodeExampleStack> | |
```css | |
/* [!code filename:app.css] */ | |
.my-element { | |
background: white; | |
/* [!code highlight:6] */ | |
@variant dark { | |
@variant hover { | |
background: black; | |
} | |
} | |
} | |
``` | |
```css | |
/* [!code filename:Compiled CSS] */ | |
.my-element { | |
background: white; | |
/* [!code highlight:7] */ | |
@media (prefers-color-scheme: dark) { | |
&:hover { | |
@media (hover: hover) { | |
background: black; | |
} | |
} | |
} | |
} | |
``` | |
</CodeExampleStack> | |
## Adding custom utilities | |
### Simple utilities | |
In addition to using the utilities that ship with Tailwind, you can also add your own custom utilities. This can be useful when there's a CSS feature you'd like to use in your project that Tailwind doesn't include utilities for out of the box. | |
Use the `@utility` directive to add a custom utility to your project: | |
```css | |
/* [!code filename:CSS] */ | |
@utility content-auto { | |
content-visibility: auto; | |
} | |
``` | |
You can now use this utility in your HTML: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:content-auto] --> | |
<div class="content-auto"> | |
<!-- ... --> | |
</div> | |
``` | |
It will also work with variants like `hover`, `focus` and `lg`: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:hover:content-auto] --> | |
<div class="hover:content-auto"> | |
<!-- ... --> | |
</div> | |
``` | |
Custom utilities are automatically inserted into the `utilities` layer along with all of the built-in utilities in the framework. | |
### Complex utilities | |
If your custom utility is more complex than a single class name, use nesting to define the utility: | |
```css | |
/* [!code filename:CSS] */ | |
@utility scrollbar-hidden { | |
&::-webkit-scrollbar { | |
display: none; | |
} | |
} | |
``` | |
### Functional utilities | |
In addition to registering simple utilities with the `@utility` directive, you can also register functional utilities that accept an argument: | |
```css | |
/* [!code filename:CSS] */ | |
@utility tab-* { | |
/* prettier-ignore */ | |
tab-size: --value(--tab-size-*); | |
} | |
``` | |
The special `--value()` function is used to resolve the utility value. | |
#### Matching theme values | |
Use the `--value(--theme-key-*)` syntax to resolve the utility value against a set of theme keys: | |
```css | |
/* [!code filename:CSS] */ | |
@theme { | |
--tab-size-2: 2; | |
--tab-size-4: 4; | |
--tab-size-github: 8; | |
} | |
@utility tab-* { | |
/* [!code highlight:2] */ | |
/* prettier-ignore */ | |
tab-size: --value(--tab-size-*); | |
} | |
``` | |
This will match utilities like `tab-2`, `tab-4`, and `tab-github`. | |
#### Bare values | |
To resolve the value as a bare value, use the `--value({type})` syntax, where `{type}` is the data type you want to validate the bare value as: | |
```css | |
/* [!code filename:CSS] */ | |
@utility tab-* { | |
tab-size: --value(integer); | |
} | |
``` | |
This will match utilities like `tab-1` and `tab-76`. | |
#### Literal values | |
To support literal values, use the `--value('literal')` syntax (notice the quotes): | |
```css | |
/* [!code filename:CSS] */ | |
@utility tab-* { | |
tab-size: --value('inherit', 'initial', 'unset'); | |
} | |
``` | |
This will match utilities like `tab-inherit`, `tab-initial`, and `tab-unset`. | |
#### Arbitrary values | |
To support arbitrary values, use the `--value([{type}])` syntax (notice the square brackets) to tell Tailwind which types are supported as an arbitrary value: | |
```css | |
/* [!code filename:CSS] */ | |
@utility tab-* { | |
tab-size: --value([integer]); | |
} | |
``` | |
This will match utilities like `tab-[1]` and `tab-[76]`. If you want to support any data type, you can use `--value([*])`. | |
#### Supporting theme, bare, and arbitrary values together | |
All three forms of the `--value()` function can be used within a rule as multiple declarations, and any declarations that fail to resolve will be omitted in the output: | |
```css | |
/* [!code filename:CSS] */ | |
@theme { | |
--tab-size-github: 8; | |
} | |
@utility tab-* { | |
tab-size: --value([integer]); | |
tab-size: --value(integer); | |
/* prettier-ignore */ | |
tab-size: --value(--tab-size-*); | |
} | |
``` | |
This makes it possible to treat the value differently in each case if necessary, for example translating a bare integer to a percentage: | |
```css | |
/* [!code filename:CSS] */ | |
@utility opacity-* { | |
opacity: --value([percentage]); | |
/* [!code highlight:2] */ | |
opacity: calc(--value(integer) * 1%); | |
/* prettier-ignore */ | |
opacity: --value(--opacity-*); | |
} | |
``` | |
The `--value()` function can also take multiple arguments and resolve them left to right if you don't need to treat the return value differently in different cases: | |
```css | |
/* [!code filename:CSS] */ | |
@theme { | |
--tab-size-github: 8; | |
} | |
@utility tab-* { | |
/* [!code highlight:2] */ | |
/* prettier-ignore */ | |
tab-size: --value(--tab-size-*, integer, [integer]); | |
} | |
@utility opacity-* { | |
opacity: calc(--value(integer) * 1%); | |
/* [!code highlight:2] */ | |
/* prettier-ignore */ | |
opacity: --value(--opacity-*, [percentage]); | |
} | |
``` | |
#### Negative values | |
To support negative values, register separate positive and negative utilities into separate declarations: | |
```css | |
/* [!code filename:CSS] */ | |
@utility inset-* { | |
inset: calc(var(--spacing) * --value([percentage], [length])); | |
} | |
/* [!code highlight:4] */ | |
@utility -inset-* { | |
inset: calc(var(--spacing) * --value([percentage], [length]) * -1); | |
} | |
``` | |
#### Modifiers | |
Modifiers are handled using the `--modifier()` function which works exactly like the `--value()` function but operates on a modifier if present: | |
```css | |
/* [!code filename:CSS] */ | |
@utility text-* { | |
/* prettier-ignore */ | |
font-size: --value(--text-*, [length]); | |
/* [!code highlight:2] */ | |
/* prettier-ignore */ | |
line-height: --modifier(--leading-*, [length], [*]); | |
} | |
``` | |
If a modifier isn't present, any declaration depending on a modifier is just not included in the output. | |
#### Fractions | |
To handle fractions, we rely on the CSS `ratio` data type. If this is used with `--value()`, it's a signal to Tailwind to treat the value and modifier as a single value: | |
```css | |
/* [!code filename:CSS] */ | |
@utility aspect-* { | |
/* [!code word:ratio, \[ratio\]] */ | |
/* prettier-ignore */ | |
aspect-ratio: --value(--aspect-ratio-*, ratio, [ratio]); | |
} | |
``` | |
This will match utilities like `aspect-square`, `aspect-3/4`, and `aspect-[7/9]`. | |
## Adding custom variants | |
In addition to using the variants that ship with Tailwind, you can also add your own custom variants using the `@custom-variant` directive: | |
```css | |
@custom-variant theme-midnight { | |
&:where([data-theme="midnight"] *) { | |
@slot; | |
} | |
} | |
``` | |
Now you can use the `theme-midnight:<utility>` variant in your HTML: | |
```html | |
<!-- [!code classes:theme-midnight:bg-black] --> | |
<html data-theme="midnight"> | |
<button class="theme-midnight:bg-black ..."></button> | |
</html> | |
``` | |
You can create variants using the shorthand syntax when nesting isn't required: | |
```css | |
@custom-variant theme-midnight (&:where([data-theme="midnight"] *)); | |
``` | |
When a custom variant has multiple rules, they can be nested within each other: | |
```css | |
@custom-variant any-hover { | |
@media (any-hover: hover) { | |
&:hover { | |
@slot; | |
} | |
} | |
} | |
``` | |
--- | |
File: /src/docs/align-content.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "align-content"; | |
export const description = "Utilities for controlling how rows are positioned in multi-row flex and grid containers."; | |
<ApiTable | |
rows={[ | |
["content-normal", "align-content: normal;"], | |
["content-center", "align-content: center;"], | |
["content-start", "align-content: flex-start;"], | |
["content-end", "align-content: flex-end;"], | |
["content-between", "align-content: space-between;"], | |
["content-around", "align-content: space-around;"], | |
["content-evenly", "align-content: space-evenly;"], | |
["content-baseline", "align-content: baseline;"], | |
["content-stretch", "align-content: stretch;"], | |
]} | |
/> | |
## Examples | |
### Start | |
Use `content-start` to pack rows in a container against the start of the cross axis: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid h-56 grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 grid grid-cols-3 content-start gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="rounded-lg bg-purple-500 p-4">01</div> | |
<div className="rounded-lg bg-purple-500 p-4">02</div> | |
<div className="rounded-lg bg-purple-500 p-4">03</div> | |
<div className="rounded-lg bg-purple-500 p-4">04</div> | |
<div className="rounded-lg bg-purple-500 p-4">05</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:content-start] --> | |
<div class="grid h-56 grid-cols-3 content-start gap-4 ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
<div>04</div> | |
<div>05</div> | |
</div> | |
``` | |
</Figure> | |
### Center | |
Use `content-center` to pack rows in a container in the center of the cross axis: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid h-56 grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 grid h-56 w-full grid-cols-3 content-center gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="rounded-lg bg-sky-500 p-4">01</div> | |
<div className="rounded-lg bg-sky-500 p-4">02</div> | |
<div className="rounded-lg bg-sky-500 p-4">03</div> | |
<div className="rounded-lg bg-sky-500 p-4">04</div> | |
<div className="rounded-lg bg-sky-500 p-4">05</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:content-center] --> | |
<div class="grid h-56 grid-cols-3 content-center gap-4 ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
<div>04</div> | |
<div>05</div> | |
</div> | |
``` | |
</Figure> | |
### End | |
Use `content-end` to pack rows in a container against the end of the cross axis: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid h-56 grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 grid h-56 w-full grid-cols-3 content-end gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="rounded-lg bg-pink-500 p-4">01</div> | |
<div className="rounded-lg bg-pink-500 p-4">02</div> | |
<div className="rounded-lg bg-pink-500 p-4">03</div> | |
<div className="rounded-lg bg-pink-500 p-4">04</div> | |
<div className="rounded-lg bg-pink-500 p-4">05</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:content-end] --> | |
<div class="grid h-56 grid-cols-3 content-end gap-4 ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
<div>04</div> | |
<div>05</div> | |
</div> | |
``` | |
</Figure> | |
### Space between | |
Use `content-between` to distribute rows in a container such that there is an equal amount of space between each line: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid h-56 grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 grid h-56 w-full grid-cols-3 content-between gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="rounded-lg bg-violet-500 p-4">01</div> | |
<div className="rounded-lg bg-violet-500 p-4">02</div> | |
<div className="rounded-lg bg-violet-500 p-4">03</div> | |
<div className="rounded-lg bg-violet-500 p-4">04</div> | |
<div className="rounded-lg bg-violet-500 p-4">05</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:content-between] --> | |
<div class="grid h-56 grid-cols-3 content-between gap-4 ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
<div>04</div> | |
<div>05</div> | |
</div> | |
``` | |
</Figure> | |
### Space around | |
Use `content-around` to distribute rows in a container such that there is an equal amount of space around each line: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid h-56 grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 grid h-56 w-full grid-cols-3 content-around gap-x-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="rounded-lg bg-blue-500 p-4">01</div> | |
<div className="rounded-lg bg-blue-500 p-4">02</div> | |
<div className="rounded-lg bg-blue-500 p-4">03</div> | |
<div className="rounded-lg bg-blue-500 p-4">04</div> | |
<div className="rounded-lg bg-blue-500 p-4">05</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:content-around] --> | |
<div class="grid h-56 grid-cols-3 content-around gap-4 ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
<div>04</div> | |
<div>05</div> | |
</div> | |
``` | |
</Figure> | |
### Space evenly | |
Use `content-evenly` to distribute rows in a container such that there is an equal amount of space around each item, but also accounting for the doubling of space you would normally see between each item when using `content-around`: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid h-56 grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 grid h-56 w-full grid-cols-3 content-evenly gap-x-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="rounded-lg bg-indigo-500 p-4">01</div> | |
<div className="rounded-lg bg-indigo-500 p-4">02</div> | |
<div className="rounded-lg bg-indigo-500 p-4">03</div> | |
<div className="rounded-lg bg-indigo-500 p-4">04</div> | |
<div className="rounded-lg bg-indigo-500 p-4">05</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:content-evenly] --> | |
<div class="grid h-56 grid-cols-3 content-evenly gap-4 ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
<div>04</div> | |
<div>05</div> | |
</div> | |
``` | |
</Figure> | |
### Stretch | |
Use `content-stretch` to allow content items to fill the available space along the container’s cross axis: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid h-56 grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 grid h-56 w-full grid-cols-3 content-stretch gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex items-center justify-center rounded-lg bg-fuchsia-500 p-4">01</div> | |
<div className="flex items-center justify-center rounded-lg bg-fuchsia-500 p-4">02</div> | |
<div className="flex items-center justify-center rounded-lg bg-fuchsia-500 p-4">03</div> | |
<div className="flex items-center justify-center rounded-lg bg-fuchsia-500 p-4">04</div> | |
<div className="flex items-center justify-center rounded-lg bg-fuchsia-500 p-4">05</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:content-stretch] --> | |
<div class="grid h-56 grid-cols-3 content-stretch gap-4 ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
<div>04</div> | |
<div>05</div> | |
</div> | |
``` | |
</Figure> | |
### Normal | |
Use `content-normal` to pack content items in their default position as if no `align-content` value was set: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid h-56 grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 grid h-56 w-full grid-cols-3 gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex items-center justify-center rounded-lg bg-indigo-500 p-4">01</div> | |
<div className="flex items-center justify-center rounded-lg bg-indigo-500 p-4">02</div> | |
<div className="flex items-center justify-center rounded-lg bg-indigo-500 p-4">03</div> | |
<div className="flex items-center justify-center rounded-lg bg-indigo-500 p-4">04</div> | |
<div className="flex items-center justify-center rounded-lg bg-indigo-500 p-4">05</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:content-normal] --> | |
<div class="grid h-56 grid-cols-3 content-normal gap-4 ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
<div>04</div> | |
<div>05</div> | |
</div> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="align-content" defaultClass="grid content-start" featuredClass="content-around" /> | |
--- | |
File: /src/docs/align-items.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "align-items"; | |
export const description = | |
"Utilities for controlling how flex and grid items are positioned along a container's cross axis."; | |
<ApiTable | |
rows={[ | |
["items-start", "align-items: flex-start;"], | |
["items-end", "align-items: flex-end;"], | |
["items-end-safe", "align-items: safe flex-end;"], | |
["items-center", "align-items: center;"], | |
["items-center-safe", "align-items: safe center;"], | |
["items-baseline", "align-items: baseline;"], | |
["items-baseline-last", "align-items: last baseline;"], | |
["items-stretch", "align-items: stretch;"], | |
]} | |
/> | |
## Examples | |
### Stretch | |
Use the `items-stretch` utility to stretch items to fill the container's cross axis: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex w-full items-stretch gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-cyan-500 py-4">01</div> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-cyan-500 py-12">02</div> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-cyan-500 py-8">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:items-stretch] --> | |
<div class="flex items-stretch ..."> | |
<div class="py-4">01</div> | |
<div class="py-12">02</div> | |
<div class="py-8">03</div> | |
</div> | |
``` | |
</Figure> | |
### Start | |
Use the `items-start` utility to align items to the start of the container's cross axis: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex w-full items-start gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-pink-500 py-4">01</div> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-pink-500 py-12">02</div> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-pink-500 py-8">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:items-start] --> | |
<div class="flex items-start ..."> | |
<div class="py-4">01</div> | |
<div class="py-12">02</div> | |
<div class="py-8">03</div> | |
</div> | |
``` | |
</Figure> | |
### Center | |
Use the `items-center` utility to align items along the center of the container's cross axis: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex w-full items-center gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-violet-500 py-4">01</div> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-violet-500 py-12">02</div> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-violet-500 py-8">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:items-center] --> | |
<div class="flex items-center ..."> | |
<div class="py-4">01</div> | |
<div class="py-12">02</div> | |
<div class="py-8">03</div> | |
</div> | |
``` | |
</Figure> | |
### End | |
Use the `items-end` utility to align items to the end of the container's cross axis: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex w-full items-end gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-sky-500 py-4">01</div> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-sky-500 py-12">02</div> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-sky-500 py-8">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:items-end] --> | |
<div class="flex items-end ..."> | |
<div class="py-4">01</div> | |
<div class="py-12">02</div> | |
<div class="py-8">03</div> | |
</div> | |
``` | |
</Figure> | |
### Baseline | |
Use the `items-baseline` utility to align items along the container's cross axis such that all of their baselines align: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex w-full items-baseline gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-blue-500 pt-2 pb-6">01</div> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-blue-500 pt-8 pb-12">02</div> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-blue-500 pt-12 pb-4">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:items-baseline] --> | |
<div class="flex items-baseline ..."> | |
<div class="pt-2 pb-6">01</div> | |
<div class="pt-8 pb-12">02</div> | |
<div class="pt-12 pb-4">03</div> | |
</div> | |
``` | |
</Figure> | |
### Last baseline | |
Use the `items-baseline-last` utility to align items along the container's cross axis such that all of their baselines align with the last baseline in the container: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="mx-auto grid max-w-md divide-y divide-gray-100 border-x border-x-gray-200 text-gray-700 dark:divide-gray-800 dark:border-x-gray-800 dark:bg-gray-950/10 dark:text-gray-300"> | |
<div className="grid grid-cols-[1fr_auto] items-baseline-last gap-x-4 px-4 py-6"> | |
<div className="grid grid-cols-[auto_1fr] gap-x-4 max-sm:grid-cols-1"> | |
<img | |
className="size-[2rem] rounded-full" | |
src="https://spotlight.tailwindui.com/_next/image?url=%2F_next%2Fstatic%2Fmedia%2Favatar.51a13c67.jpg&w=128&q=80" | |
alt="" | |
/> | |
<div className="font-semibold text-gray-900 sm:col-start-2 dark:text-white">Spencer Sharp</div> | |
<p className="text-sm sm:col-start-2">Working on the future of astronaut recruitment at Space Recruit.</p> | |
</div> | |
<a | |
href="#" | |
className="font-mono text-xs font-medium text-gray-400 underline hover:text-blue-500 dark:text-gray-500" | |
> | |
spacerecruit.com | |
</a> | |
</div> | |
<div className="grid grid-cols-[1fr_auto] items-baseline-last gap-x-4 px-4 py-6"> | |
<div className="grid grid-cols-[auto_1fr] gap-x-4 max-sm:grid-cols-1"> | |
<img | |
className="size-[2rem] rounded-full" | |
src="https://images.unsplash.com/photo-1590895340509-793cb98788c9?q=80&w=256&h=256&&auto=format&fit=crop&ixlib=rb-4.0.3&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D" | |
alt="" | |
/> | |
<div className="font-semibold text-gray-900 sm:col-start-2 dark:text-white">Alex Reed</div> | |
<p className="text-sm sm:col-start-2">A multidisciplinary designer.</p> | |
</div> | |
<a | |
href="#" | |
className="font-mono text-xs font-medium text-gray-400 underline hover:text-blue-500 dark:text-gray-500" | |
> | |
alex-reed.com | |
</a> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:items-baseline-last] --> | |
<div class="grid grid-cols-[1fr_auto] items-baseline-last"> | |
<div> | |
<img src="img/spencer-sharp.jpg" /> | |
<h4>Spencer Sharp</h4> | |
<p>Working on the future of astronaut recruitment at Space Recruit.</p> | |
</div> | |
<p>spacerecruit.com</p> | |
</div> | |
``` | |
</Figure> | |
This is useful for ensuring that text items align with each other, even if they have different heights. | |
### Responsive design | |
<ResponsiveDesign property="align-items" defaultClass="flex items-stretch" featuredClass="items-center" /> | |
--- | |
File: /src/docs/align-self.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "align-self"; | |
export const description = | |
"Utilities for controlling how an individual flex or grid item is positioned along its container's cross axis."; | |
<ApiTable | |
rows={[ | |
["self-auto", "align-self: auto;"], | |
["self-start", "align-self: flex-start;"], | |
["self-end", "align-self: flex-end;"], | |
["self-end-safe", "align-self: safe flex-end;"], | |
["self-center", "align-self: center;"], | |
["self-center-safe", "align-self: safe center;"], | |
["self-stretch", "align-self: stretch;"], | |
["self-baseline", "align-self: baseline;"], | |
["self-baseline", "align-self: last baseline;"], | |
]} | |
/> | |
## Examples | |
### Auto | |
Use the `self-auto` utility to align an item based on the value of the container's `align-items` property: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex h-24 w-full items-stretch gap-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-sky-300 p-4 dark:bg-sky-800 dark:text-sky-500"> | |
01 | |
</div> | |
<div className="flex flex-1 items-center justify-center self-auto rounded-lg bg-sky-500 p-4">02</div> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-sky-300 p-4 dark:bg-sky-800 dark:text-sky-500"> | |
03 | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:self-auto] --> | |
<div class="flex items-stretch ..."> | |
<div>01</div> | |
<div class="self-auto ...">02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Start | |
Use the `self-start` utility to align an item to the start of the container's cross axis, despite the container's `align-items` value: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex h-24 w-full items-stretch gap-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-pink-300 p-4 dark:bg-pink-800 dark:text-pink-400"> | |
01 | |
</div> | |
<div className="flex flex-1 items-center justify-center self-start rounded-lg bg-pink-500 p-4">02</div> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-pink-300 p-4 dark:bg-pink-800 dark:text-pink-400"> | |
03 | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:self-start] --> | |
<div class="flex items-stretch ..."> | |
<div>01</div> | |
<div class="self-start ...">02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Center | |
Use the `self-center` utility to align an item along the center of the container's cross axis, despite the container's `align-items` value: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex h-24 w-full items-stretch gap-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-purple-300 p-4 dark:bg-purple-800 dark:text-purple-400"> | |
01 | |
</div> | |
<div className="flex flex-1 items-center justify-center self-center rounded-lg bg-purple-500 p-4">02</div> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-purple-300 p-4 dark:bg-purple-800 dark:text-purple-400"> | |
03 | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:self-center] --> | |
<div class="flex items-stretch ..."> | |
<div>01</div> | |
<div class="self-center ...">02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### End | |
Use the `self-end` utility to align an item to the end of the container's cross axis, despite the container's `align-items` value: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex h-24 w-full items-stretch gap-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-indigo-300 p-4 dark:bg-indigo-800 dark:text-indigo-400"> | |
01 | |
</div> | |
<div className="flex flex-1 items-center justify-center self-end rounded-lg bg-indigo-500 p-4">02</div> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-indigo-300 p-4 dark:bg-indigo-800 dark:text-indigo-400"> | |
03 | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:self-end] --> | |
<div class="flex items-stretch ..."> | |
<div>01</div> | |
<div class="self-end ...">02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Stretch | |
Use the `self-stretch` utility to stretch an item to fill the container's cross axis, despite the container's `align-items` value: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex h-24 w-full items-stretch gap-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-fuchsia-300 p-4 dark:bg-fuchsia-800 dark:text-fuchsia-400"> | |
01 | |
</div> | |
<div className="flex flex-1 items-center justify-center self-stretch rounded-lg bg-fuchsia-500 p-4">02</div> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-fuchsia-300 p-4 dark:bg-fuchsia-800 dark:text-fuchsia-400"> | |
03 | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:self-stretch] --> | |
<div class="flex items-stretch ..."> | |
<div>01</div> | |
<div class="self-stretch ...">02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Baseline | |
Use the `self-baseline` utility to align an item such that its baseline aligns with the baseline of the flex container's cross axis: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex w-full gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex flex-1 items-center justify-center self-baseline rounded-lg bg-blue-500 pt-2 pb-6">01</div> | |
<div className="flex flex-1 items-center justify-center self-baseline rounded-lg bg-blue-500 pt-8 pb-12"> | |
02 | |
</div> | |
<div className="flex flex-1 items-center justify-center self-baseline rounded-lg bg-blue-500 pt-12 pb-4"> | |
03 | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:self-baseline] --> | |
<div class="flex ..."> | |
<div class="self-baseline pt-2 pb-6">01</div> | |
<div class="self-baseline pt-8 pb-12">02</div> | |
<div class="self-baseline pt-12 pb-4">03</div> | |
</div> | |
``` | |
</Figure> | |
### Last baseline | |
Use the `self-baseline-last` utility to align an item along the container's cross axis such that its baseline aligns with the last baseline in the container: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="mx-auto grid max-w-md divide-y divide-gray-100 border-x border-x-gray-200 text-gray-700 dark:divide-gray-800 dark:border-x-gray-800 dark:bg-gray-950/10 dark:text-gray-300"> | |
<div className="grid grid-cols-[auto_1fr_auto] gap-x-4 px-4 py-6"> | |
<img | |
className="size-[2rem] rounded-full" | |
src="https://spotlight.tailwindui.com/_next/image?url=%2F_next%2Fstatic%2Fmedia%2Favatar.51a13c67.jpg&w=128&q=80" | |
alt="" | |
/> | |
<div className="font-semibold text-gray-900 sm:col-start-2 dark:text-white">Spencer Sharp</div> | |
<p className="self-baseline-last text-sm sm:col-start-2"> | |
Working on the future of astronaut recruitment at Space Recruit. | |
</p> | |
<a | |
href="#" | |
className="self-baseline-last font-mono text-xs font-medium text-gray-400 underline hover:text-blue-500 dark:text-gray-500" | |
> | |
spacerecruit.com | |
</a> | |
</div> | |
<div className="grid grid-cols-[auto_1fr_auto] gap-x-4 px-4 py-6"> | |
<img | |
className="size-[2rem] rounded-full" | |
src="https://images.unsplash.com/photo-1590895340509-793cb98788c9?q=80&w=256&h=256&&auto=format&fit=crop&ixlib=rb-4.0.3&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D" | |
alt="" | |
/> | |
<div className="font-semibold text-gray-900 sm:col-start-2 dark:text-white">Alex Reed</div> | |
<p className="self-baseline-last text-sm sm:col-start-2">A multidisciplinary designer.</p> | |
<a | |
href="#" | |
className="self-baseline-last font-mono text-xs font-medium text-gray-400 underline hover:text-blue-500 dark:text-gray-500" | |
> | |
alex-reed.com | |
</a> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:self-baseline-last] --> | |
<div class="grid grid-cols-[1fr_auto]"> | |
<div> | |
<img src="img/spencer-sharp.jpg" /> | |
<h4>Spencer Sharp</h4> | |
<p class="self-baseline-last">Working on the future of astronaut recruitment at Space Recruit.</p> | |
</div> | |
<p class="self-baseline-last">spacerecruit.com</p> | |
</div> | |
``` | |
</Figure> | |
This is useful for ensuring that text items align with each other, even if they have different heights. | |
### Responsive design | |
<ResponsiveDesign property="align-self" defaultClass="self-auto" featuredClass="self-end" /> | |
--- | |
File: /src/docs/animation.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourTheme, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import dedent from "dedent"; | |
export const title = "animation"; | |
export const description = "Utilities for animating elements with CSS animations."; | |
<ApiTable | |
rows={[ | |
[ | |
"animate-spin", | |
dedent` | |
animation: var(--animate-spin); /* spin 1s linear infinite */ | |
@keyframes spin { | |
to { | |
transform: rotate(360deg); | |
} | |
} | |
`, | |
], | |
[ | |
"animate-ping", | |
dedent` | |
animation: var(--animate-ping); /* ping 1s cubic-bezier(0, 0, 0.2, 1) infinite */ | |
@keyframes ping { | |
75%, 100% { | |
transform: scale(2); | |
opacity: 0; | |
} | |
} | |
`, | |
], | |
[ | |
"animate-pulse", | |
dedent` | |
animation: var(--animate-pulse); /* pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite */ | |
@keyframes pulse { | |
50% { | |
opacity: 0.5; | |
} | |
} | |
`, | |
], | |
[ | |
"animate-bounce", | |
dedent` | |
animation: var(--animate-bounce); /* bounce 1s infinite */ | |
@keyframes bounce { | |
0%, 100% { | |
transform: translateY(-25%); | |
animation-timing-function: cubic-bezier(0.8, 0, 1, 1); | |
} | |
50% { | |
transform: none; | |
animation-timing-function: cubic-bezier(0, 0, 0.2, 1); | |
} | |
} | |
`, | |
], | |
["animate-none", "animation: none;"], | |
["animate-(<custom-property>)", "animation: var(<custom-property>);"], | |
["animate-[<value>]", "animation: <value>;"], | |
]} | |
/> | |
## Examples | |
### Adding a spin animation | |
Use the `animate-spin` utility to add a linear spin animation to elements like loading indicators: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex items-center justify-center"> | |
<button | |
type="button" | |
className="inline-flex cursor-not-allowed items-center rounded-md bg-indigo-500 px-4 py-2 text-sm leading-6 font-semibold text-white transition duration-150 ease-in-out hover:bg-indigo-400" | |
disabled | |
> | |
<svg | |
className="mr-3 -ml-1 size-5 animate-spin text-white" | |
xmlns="http://www.w3.org/2000/svg" | |
fill="none" | |
viewBox="0 0 24 24" | |
> | |
<circle className="opacity-25" cx="12" cy="12" r="10" stroke="currentColor" strokeWidth="4"></circle> | |
<path | |
className="opacity-75" | |
fill="currentColor" | |
d="M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z" | |
></path> | |
</svg> | |
Processing… | |
</button> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:animate-spin] --> | |
<button type="button" class="bg-indigo-500 ..." disabled> | |
<svg class="mr-3 size-5 animate-spin ..." viewBox="0 0 24 24"> | |
<!-- ... --> | |
</svg> | |
Processing… | |
</button> | |
``` | |
</Figure> | |
### Adding a ping animation | |
Use the `animate-ping` utility to make an element scale and fade like a radar ping or ripple of water—useful for things like notification badges: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex items-center justify-center"> | |
<span className="relative inline-flex"> | |
<button | |
type="button" | |
className="inline-flex cursor-not-allowed items-center rounded-md bg-white px-4 py-2 text-sm leading-6 font-semibold text-sky-500 ring-1 ring-gray-900/10 transition duration-150 ease-in-out dark:bg-white/5 dark:ring-white/20" | |
disabled | |
> | |
Transactions | |
</button> | |
<span className="absolute top-0 right-0 -mt-1 -mr-1 flex size-3"> | |
<span className="absolute inline-flex h-full w-full animate-ping rounded-full bg-sky-400 opacity-75"></span> | |
<span className="relative inline-flex size-3 rounded-full bg-sky-500"></span> | |
</span> | |
</span> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:animate-ping] --> | |
<span class="relative flex size-3"> | |
<span class="absolute inline-flex h-full w-full animate-ping rounded-full bg-sky-400 opacity-75"></span> | |
<span class="relative inline-flex size-3 rounded-full bg-sky-500"></span> | |
</span> | |
``` | |
</Figure> | |
### Adding a pulse animation | |
Use the `animate-pulse` utility to make an element gently fade in and out—useful for things like skeleton loaders: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex items-center justify-center"> | |
<div className="-lg h-28 w-full max-w-xs rounded-lg bg-white p-4 ring-1 ring-gray-900/5 dark:bg-gray-800"> | |
<div className="flex animate-pulse space-x-4"> | |
<div className="size-10 rounded-full bg-gray-200 dark:bg-gray-700"></div> | |
<div className="flex-1 space-y-6 py-1"> | |
<div className="h-2 rounded bg-gray-200 dark:bg-gray-700"></div> | |
<div className="space-y-3"> | |
<div className="grid grid-cols-3 gap-4"> | |
<div className="col-span-2 h-2 rounded bg-gray-200 dark:bg-gray-700"></div> | |
<div className="col-span-1 h-2 rounded bg-gray-200 dark:bg-gray-700"></div> | |
</div> | |
<div className="h-2 rounded bg-gray-200 dark:bg-gray-700"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:animate-pulse] --> | |
<div class="mx-auto w-full max-w-sm rounded-md border border-blue-300 p-4"> | |
<div class="flex animate-pulse space-x-4"> | |
<div class="size-10 rounded-full bg-gray-200"></div> | |
<div class="flex-1 space-y-6 py-1"> | |
<div class="h-2 rounded bg-gray-200"></div> | |
<div class="space-y-3"> | |
<div class="grid grid-cols-3 gap-4"> | |
<div class="col-span-2 h-2 rounded bg-gray-200"></div> | |
<div class="col-span-1 h-2 rounded bg-gray-200"></div> | |
</div> | |
<div class="h-2 rounded bg-gray-200"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
``` | |
</Figure> | |
### Adding a bounce animation | |
Use the `animate-bounce` utility to make an element bounce up and down—useful for things like "scroll down" indicators: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex justify-center"> | |
<div className="-lg flex size-10 animate-bounce items-center justify-center rounded-full bg-white p-2 ring-1 ring-gray-900/5 dark:bg-white/5 dark:ring-white/20"> | |
<svg | |
className="size-6 text-violet-500" | |
fill="none" | |
strokeLinecap="round" | |
strokeLinejoin="round" | |
strokeWidth="2" | |
viewBox="0 0 24 24" | |
stroke="currentColor" | |
> | |
<path d="M19 14l-7 7m0 0l-7-7m7 7V3"></path> | |
</svg> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:animate-bounce] --> | |
<svg class="size-6 animate-bounce ..."> | |
<!-- ... --> | |
</svg> | |
``` | |
</Figure> | |
### Supporting reduced motion | |
For situations where the user has specified that they prefer reduced motion, you can conditionally apply animations and transitions using the `motion-safe` and `motion-reduce` variants: | |
```html | |
<!-- [!code classes:motion-safe:animate-spin] --> | |
<button type="button" class="bg-indigo-600 ..." disabled> | |
<svg class="mr-3 size-5 motion-safe:animate-spin ..." viewBox="0 0 24 24"> | |
<!-- ... --> | |
</svg> | |
Processing | |
</button> | |
``` | |
### Using a custom value | |
<UsingACustomValue utility="animate" name="animation" value="wiggle_1s_ease-in-out_infinite" variable="animation" /> | |
### Responsive design | |
<ResponsiveDesign property="animation" defaultClass="animate-none" featuredClass="animate-spin" /> | |
## Customizing your theme | |
<CustomizingYourTheme | |
utility="animate" | |
name="animation" | |
customName="wiggle" | |
customCSS={ | |
dedent` | |
@theme { | |
/* [!code highlight:12] */ | |
--animate-wiggle: wiggle 1s ease-in-out infinite; | |
@keyframes wiggle { | |
0%, | |
100% { | |
transform: rotate(-3deg); | |
} | |
50% { | |
transform: rotate(3deg); | |
} | |
} | |
} | |
`} | |
/> | |
--- | |
File: /src/docs/appearance.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "appearance"; | |
export const description = "Utilities for suppressing native form control styling."; | |
<ApiTable | |
rows={[ | |
["appearance-none", "appearance: none;"], | |
["appearance-auto", "appearance: auto;"], | |
]} | |
/> | |
## Examples | |
### Removing default appearance | |
Use `appearance-none` to reset any browser specific styling on an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="mx-auto max-w-sm items-center"> | |
<div className="my-6 flex"> | |
<select className="w-20"> | |
<option>Yes</option> | |
<option>No</option> | |
<option>Maybe</option> | |
</select> | |
<div className="mx-6 text-sm font-semibold text-gray-900 dark:text-gray-200"> | |
Default browser styles applied | |
</div> | |
</div> | |
<div className="my-6 flex items-center"> | |
<div className="grid"> | |
<svg | |
className="pointer-events-none relative right-1 z-10 col-start-1 row-start-1 h-4 w-4 self-center justify-self-end forced-colors:hidden" | |
viewBox="0 0 16 16" | |
fill="currentColor" | |
aria-hidden="true" | |
> | |
<path | |
fillRule="evenodd" | |
d="M4.22 6.22a.75.75 0 0 1 1.06 0L8 8.94l2.72-2.72a.75.75 0 1 1 1.06 1.06l-3.25 3.25a.75.75 0 0 1-1.06 0L4.22 7.28a.75.75 0 0 1 0-1.06Z" | |
clipRule="evenodd" | |
/> | |
</svg> | |
<select className="col-start-1 row-start-1 w-20 appearance-none rounded-lg border border-gray-300 bg-gray-50 px-2 text-gray-700 hover:border-cyan-500 hover:bg-white dark:border-gray-600 dark:bg-gray-800 dark:text-gray-200 dark:hover:border-cyan-700 dark:hover:bg-gray-700 forced-colors:appearance-auto"> | |
<option>Yes</option> | |
<option>No</option> | |
<option>Maybe</option> | |
</select> | |
</div> | |
<div className="mx-6 text-sm font-semibold text-gray-900 dark:text-gray-200">Remove default browser styles</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:appearance-none] --> | |
<select> | |
<option>Yes</option> | |
<option>No</option> | |
<option>Maybe</option> | |
</select> | |
<div class="grid"> | |
<select class="col-start-1 row-start-1 appearance-none bg-gray-50 dark:bg-gray-800 ..."> | |
<option>Yes</option> | |
<option>No</option> | |
<option>Maybe</option> | |
</select> | |
<svg class="pointer-events-none col-start-1 row-start-1 ..."> | |
<!-- ... --> | |
</svg> | |
</div> | |
``` | |
</Figure> | |
This utility is often used when creating custom form components. | |
### Restoring default appearance | |
Use `appearance-auto` to restore the default browser specific styling on an element: | |
<Figure hint="Try emulating `forced-colors: active` in your developer tools to see the difference"> | |
<Example> | |
{ | |
<div className="mx-auto my-6 grid max-w-sm items-center justify-center gap-8"> | |
<div className="flex items-center"> | |
<label | |
htmlFor="checkbox_2" | |
className="mx-6 grid grid-flow-col items-center gap-3 text-sm font-semibold text-gray-900 select-none dark:text-gray-200" | |
> | |
<div className="grid items-center justify-center"> | |
<input | |
type="checkbox" | |
id="checkbox_2" | |
defaultChecked | |
className="peer col-start-1 row-start-1 h-4 w-4 appearance-none rounded border border-gray-300 ring-transparent checked:border-violet-600 checked:bg-violet-600 dark:border-gray-600 dark:checked:border-violet-600 forced-colors:appearance-auto" | |
/> | |
<svg | |
viewBox="0 0 14 14" | |
fill="none" | |
className="invisible col-start-1 row-start-1 stroke-white peer-checked:visible dark:text-violet-300 forced-colors:hidden" | |
> | |
<path d="M3 8L6 11L11 3.5" strokeWidth="2" strokeLinecap="round" strokeLinejoin="round"></path> | |
</svg> | |
</div> | |
Falls back to default appearance | |
</label> | |
</div> | |
<div className="flex items-center"> | |
<label | |
htmlFor="checkbox_1" | |
className="mx-6 grid grid-flow-col items-center gap-3 text-sm font-semibold text-gray-900 select-none dark:text-gray-200" | |
> | |
<div className="grid items-center justify-center"> | |
<input | |
type="checkbox" | |
id="checkbox_1" | |
defaultChecked | |
className="peer col-start-1 row-start-1 h-4 w-4 appearance-none rounded border border-gray-300 ring-transparent checked:border-violet-600 checked:bg-violet-600 dark:border-gray-600 dark:checked:border-violet-600" | |
/> | |
<svg | |
viewBox="0 0 14 14" | |
fill="none" | |
className="invisible col-start-1 row-start-1 stroke-white peer-checked:visible dark:text-violet-300" | |
> | |
<path d="M3 8L6 11L11 3.5" strokeWidth="2" strokeLinecap="round" strokeLinejoin="round"></path> | |
</svg> | |
</div> | |
Keeps custom appearance | |
</label> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:forced-colors:appearance-auto,forced-colors:hidden] --> | |
<label> | |
<div> | |
<input type="checkbox" class="appearance-none forced-colors:appearance-auto ..." /> | |
<svg class="invisible peer-checked:visible forced-colors:hidden ..."> | |
<!-- ... --> | |
</svg> | |
</div> | |
Falls back to default appearance | |
</label> | |
<label> | |
<div> | |
<input type="checkbox" class="appearance-none ..." /> | |
<svg class="invisible peer-checked:visible ..."> | |
<!-- ... --> | |
</svg> | |
</div> | |
Keeps custom appearance | |
</label> | |
``` | |
</Figure> | |
This is useful for reverting to the standard browser controls in certain accessibility modes. | |
### Responsive design | |
<ResponsiveDesign | |
element="select" | |
property="appearance" | |
defaultClass="appearance-auto" | |
featuredClass="appearance-none" | |
/> | |
--- | |
File: /src/docs/aspect-ratio.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { UsingACustomValue, ResponsiveDesign, CustomizingYourTheme } from "@/components/content.tsx"; | |
export const title = "aspect-ratio"; | |
export const description = "Utilities for controlling the aspect ratio of an element."; | |
<ApiTable | |
rows={[ | |
["aspect-<ratio>", "aspect-ratio: <ratio>;"], | |
["aspect-square", "aspect-ratio: 1 / 1;"], | |
["aspect-video", "aspect-ratio: var(--aspect-ratio-video); /* 16 / 9 */"], | |
["aspect-auto", "aspect-ratio: auto;"], | |
["aspect-(<custom-property>)", "aspect-ratio: var(<custom-property>);"], | |
["aspect-[<value>]", "aspect-ratio: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use <code>aspect-<var><ratio></var></code> utilities like `aspect-3/2` to give an element a specific aspect ratio: | |
<Figure desktopHint="Resize the example to see the expected behavior"> | |
<Example resizable> | |
{ | |
<img | |
className="mx-auto aspect-3/2 w-full max-w-sm rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1590523277543-a94d2e4eb00b?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=1200&q=80" | |
/> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:aspect-3/2] --> | |
<img class="aspect-3/2 object-cover ..." src="/img/villas.jpg" /> | |
``` | |
</Figure> | |
### Using a video aspect ratio | |
Use the `aspect-video` utility to give a video element a 16 / 9 aspect ratio: | |
<Figure desktopHint="Resize the example to see the expected behavior"> | |
<Example resizable> | |
{ | |
<iframe | |
className="aspect-video w-full rounded-lg" | |
src="https://www.youtube.com/embed/dQw4w9WgXcQ" | |
allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" | |
allowFullScreen | |
></iframe> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:aspect-video] --> | |
<iframe class="aspect-video ..." src="https://www.youtube.com/embed/dQw4w9WgXcQ"></iframe> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue | |
element="img" | |
elementAttributes={{ src: "/img/villas.jpg" }} | |
utility="aspect" | |
name="aspect ratio" | |
value="calc(4*3+1)/3" | |
variable="aspect-ratio" | |
/> | |
### Responsive design | |
<ResponsiveDesign | |
element="iframe" | |
elementAttributes={{ src: "https://www.youtube.com/embed/dQw4w9WgXcQ" }} | |
property="aspect-ratio" | |
defaultClass="aspect-video" | |
featuredClass="aspect-square" | |
/> | |
## Customizing your theme | |
<CustomizingYourTheme | |
element="iframe" | |
elementAttributes={{ src: "https://www.youtube.com/embed/dQw4w9WgXcQ" }} | |
utility="aspect" | |
name="aspect ratio" | |
customName="retro" | |
customValue="4 / 3" | |
/> | |
--- | |
File: /src/docs/backdrop-filter-blur.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourTheme, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
export const title = "backdrop-filter: blur()"; | |
export const description = "Utilities for applying backdrop blur filters to an element."; | |
<ApiTable | |
rows={[ | |
["backdrop-blur-xs", "backdrop-filter: blur(var(--blur-xs)); /* 4px */"], | |
["backdrop-blur-sm", "backdrop-filter: blur(var(--blur-sm)); /* 8px */"], | |
["backdrop-blur-md", "backdrop-filter: blur(var(--blur-md)); /* 12px */"], | |
["backdrop-blur-lg", "backdrop-filter: blur(var(--blur-lg)); /* 16px */"], | |
["backdrop-blur-xl", "backdrop-filter: blur(var(--blur-xl)); /* 24px */"], | |
["backdrop-blur-2xl", "backdrop-filter: blur(var(--blur-2xl)); /* 40px */"], | |
["backdrop-blur-3xl", "backdrop-filter: blur(var(--blur-3xl)); /* 64px */"], | |
["backdrop-blur-none", "backdrop-filter: ;"], | |
["backdrop-blur-(<custom-property>)", "backdrop-filter: blur(var(<custom-property>));"], | |
["backdrop-blur-[<value>]", "backdrop-filter: blur(<value>);"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `backdrop-blur-sm` and `backdrop-blur-lg` to control an element’s backdrop blur: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 justify-start overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-6 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-blur-none | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-blur-none"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-blur-sm | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-blur-sm"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-blur-md | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-blur-md"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:backdrop-blur-none,backdrop-blur-sm,backdrop-blur-md] --> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-blur-none ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-blur-sm ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-blur-md ..."></div> | |
</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="backdrop-blur" value="2px" name="backdrop blur" /> | |
### Responsive design | |
<ResponsiveDesign | |
property="backdrop-filter: blur()" | |
defaultClass="backdrop-blur-none" | |
featuredClass="backdrop-blur-lg" | |
/> | |
## Customizing your theme | |
<CustomizingYourTheme utility="backdrop-blur" themeKey="blur" name="backdrop blur" customName="2xs" customValue="2px" /> | |
--- | |
File: /src/docs/backdrop-filter-brightness.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "backdrop-filter: brightness()"; | |
export const description = "Utilities for applying backdrop brightness filters to an element."; | |
<ApiTable | |
rows={[ | |
["backdrop-brightness-<number>", "backdrop-filter: brightness(<number>%);"], | |
["backdrop-brightness-(<custom-property>)", "backdrop-filter: brightness(var(<custom-property>));"], | |
["backdrop-brightness-[<value>]", "backdrop-filter: brightness(<value>);"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `backdrop-brightness-50` and `backdrop-brightness-100` to control an element's backdrop brightness: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 justify-start overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-6 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-brightness-50 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-brightness-50"></div> | |
<img | |
className="h-32 w-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-brightness-150 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-brightness-150"></div> | |
<img | |
className="h-32 w-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:backdrop-brightness-50,backdrop-brightness-150] --> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-brightness-50 ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-brightness-150 ..."></div> | |
</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="backdrop-brightness" value="1.75" name="backdrop brightness" /> | |
### Responsive design | |
<ResponsiveDesign | |
property="backdrop-filter: brightness()" | |
defaultClass="backdrop-brightness-110" | |
featuredClass="backdrop-brightness-150" | |
/> | |
--- | |
File: /src/docs/backdrop-filter-contrast.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "backdrop-filter: contrast()"; | |
export const description = "Utilities for applying backdrop contrast filters to an element."; | |
<ApiTable | |
rows={[ | |
["backdrop-contrast-<number>", "backdrop-filter: contrast(<number>%);"], | |
["backdrop-contrast-(<custom-property>)", "backdrop-filter: contrast(var(<custom-property>));"], | |
["backdrop-contrast-[<value>]", "backdrop-filter: contrast(<value>);"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `backdrop-contrast-50` and `backdrop-contrast-100` to control an element's backdrop contrast: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 justify-start overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-6 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-contrast-50 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-contrast-50"></div> | |
<img | |
className="h-32 w-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-contrast-200 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-contrast-200"></div> | |
<img | |
className="h-32 w-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:backdrop-contrast-50,backdrop-contrast-200] --> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-contrast-50 ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-contrast-200 ..."></div> | |
</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="backdrop-contrast" value=".25" name="backdrop contrast" /> | |
### Responsive design | |
<ResponsiveDesign | |
property="backdrop-filter: contrast()" | |
defaultClass="backdrop-contrast-125" | |
featuredClass="backdrop-contrast-150" | |
/> | |
--- | |
File: /src/docs/backdrop-filter-grayscale.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "backdrop-filter: grayscale()"; | |
export const description = "Utilities for applying backdrop grayscale filters to an element."; | |
<ApiTable | |
rows={[ | |
["backdrop-grayscale", "backdrop-filter: grayscale(100%);"], | |
["backdrop-grayscale-<number>", "backdrop-filter: grayscale(<number>%);"], | |
["backdrop-grayscale-(<custom-property>)", "backdrop-filter: grayscale(var(<custom-property>));"], | |
["backdrop-grayscale-[<value>]", "backdrop-filter: grayscale(<value>);"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `backdrop-grayscale-50` and `backdrop-grayscale` to control the grayscale effect applied to an element's backdrop: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 justify-start overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-6 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-grayscale-0 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-grayscale-0"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-grayscale-50 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-grayscale-50"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-grayscale | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-grayscale"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:backdrop-grayscale-0,backdrop-grayscale-50,backdrop-grayscale] --> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-grayscale-0 ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-grayscale-50 ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-grayscale-200 ..."></div> | |
</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="backdrop-grayscale" value="0.5" name="backdrop grayscale" /> | |
### Responsive design | |
<ResponsiveDesign | |
property="backdrop-filter: grayscale()" | |
defaultClass="backdrop-grayscale" | |
featuredClass="backdrop-grayscale-0" | |
/> | |
--- | |
File: /src/docs/backdrop-filter-hue-rotate.mdx | |
--- | |
import { ApiTable } from "@/components/api-table"; | |
import { Example } from "@/components/example"; | |
import { Figure } from "@/components/figure"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content"; | |
export const title = "backdrop-filter: hue-rotate()"; | |
export const description = "Utilities for applying backdrop hue-rotate filters to an element."; | |
<ApiTable | |
rows={[ | |
["backdrop-hue-rotate-<number>", "backdrop-filter: hue-rotate(<number>deg);"], | |
["-backdrop-hue-rotate-<number>", "backdrop-filter: hue-rotate(calc(<number>deg * -1));"], | |
["backdrop-hue-rotate-(<custom-property>)", "backdrop-filter: hue-rotate(var(<custom-property>));"], | |
["backdrop-hue-rotate-[<value>]", "backdrop-filter: hue-rotate(<value>);"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `backdrop-hue-rotate-90` and `backdrop-hue-rotate-180` to rotate the hue of an element's backdrop: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 justify-start overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-6 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-hue-rotate-90 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-hue-rotate-90"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-hue-rotate-180 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-hue-rotate-180"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-hue-rotate-270 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-hue-rotate-270"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:backdrop-hue-rotate-90,backdrop-hue-rotate-180,backdrop-hue-rotate-270] --> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-hue-rotate-90 ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-hue-rotate-180 ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-hue-rotate-270 ..."></div> | |
</div> | |
``` | |
</Figure> | |
### Using negative values | |
Use utilities like `-backdrop-hue-rotate-90` and `-backdrop-hue-rotate-180` to set a negative backdrop hue rotation value: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 justify-start overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-6 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
-backdrop-hue-rotate-15 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 -backdrop-hue-rotate-15"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
-backdrop-hue-rotate-45 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 -backdrop-hue-rotate-45"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
-backdrop-hue-rotate-90 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 -backdrop-hue-rotate-90"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:-backdrop-hue-rotate-15,-backdrop-hue-rotate-45,-backdrop-hue-rotate-90] --> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 -backdrop-hue-rotate-15 ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 -backdrop-hue-rotate-45 ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 -backdrop-hue-rotate-90 ..."></div> | |
</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue | |
utility="backdrop-hue-rotate" | |
value="3.142rad" | |
name="backdrop hue rotation" | |
variable="backdrop-hue-rotation" | |
/> | |
### Responsive design | |
<ResponsiveDesign | |
property="backdrop-filter: hue-rotate()" | |
defaultClass="backdrop-hue-rotate-15" | |
featuredClass="backdrop-hue-rotate-0" | |
/> | |
--- | |
File: /src/docs/backdrop-filter-invert.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "backdrop-filter: invert()"; | |
export const description = "Utilities for applying backdrop invert filters to an element."; | |
<ApiTable | |
rows={[ | |
["backdrop-invert", "backdrop-filter: invert(100%);"], | |
["backdrop-invert-<number>", "backdrop-filter: invert(<number>%);"], | |
["backdrop-invert-(<custom-property>)", "backdrop-filter: invert(var(<custom-property>))"], | |
["backdrop-invert-[<value>]", "backdrop-filter: invert(<value>);"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `backdrop-invert` and `backdrop-invert-65` to control the color inversion of an element's backdrop: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 justify-start overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-6 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-invert-0 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-invert-0"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-invert-65 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-invert-65"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-invert | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-invert"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:backdrop-invert-0,backdrop-invert-65,backdrop-invert] --> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-invert-0 ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-invert-65 ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-invert ..."></div> | |
</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="backdrop-invert" value=".25" name="backdrop inversion" variable="backdrop-inversion" /> | |
### Responsive design | |
<ResponsiveDesign | |
property="backdrop-filter: invert()" | |
defaultClass="backdrop-invert-0" | |
featuredClass="backdrop-invert" | |
/> | |
--- | |
File: /src/docs/backdrop-filter-opacity.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "backdrop-filter: opacity()"; | |
export const description = "Utilities for applying backdrop opacity filters to an element."; | |
<ApiTable | |
rows={[ | |
["backdrop-opacity-<number>", "backdrop-filter: opacity(<number>%);"], | |
["backdrop-opacity-(<custom-property>)", "backdrop-filter: opacity(var(<custom-property>));"], | |
["backdrop-opacity-[<value>]", "backdrop-filter: opacity(<value>);"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `backdrop-opacity-50` and `backdrop-opacity-75` to control the opacity of all the backdrop filters applied to an element: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 justify-start overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-6 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-opacity-10 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-invert backdrop-opacity-10"></div> | |
<img | |
className="object-coveryea size-32 rounded-lg" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-opacity-60 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-invert backdrop-opacity-60"></div> | |
<img | |
className="object-coveryea size-32 rounded-lg" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-opacity-95 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-invert backdrop-opacity-95"></div> | |
<img | |
className="object-coveryea size-32 rounded-lg" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:backdrop-opacity-10,backdrop-opacity-60,backdrop-opacity-95] --> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-invert backdrop-opacity-10 ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-invert backdrop-opacity-60 ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-invert backdrop-opacity-95 ..."></div> | |
</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue | |
utility="backdrop-opacity" | |
value=".15" | |
name="backdrop filter opacity" | |
variable="backdrop-filter-opacity" | |
/> | |
### Responsive design | |
<ResponsiveDesign | |
property="backdrop-filter: opacity()" | |
defaultClass="backdrop-opacity-100" | |
featuredClass="backdrop-opacity-60" | |
/> | |
--- | |
File: /src/docs/backdrop-filter-saturate.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "backdrop-filter: saturate()"; | |
export const description = "Utilities for applying backdrop saturation filters to an element."; | |
<ApiTable | |
rows={[ | |
["backdrop-saturate-<number>", "backdrop-filter: saturate(<number>%);"], | |
["backdrop-saturate-(<custom-property>)", "backdrop-filter: saturate(var(<custom-property>));"], | |
["backdrop-saturate-[<value>]", "backdrop-filter: saturate(<value>);"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `backdrop-saturate-50` and `backdrop-saturate-100` utilities to control the saturation of an element's backdrop: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 justify-start overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-6 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-saturate-50 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-saturate-50"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-saturate-125 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-saturate-125"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-saturate-200 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-saturate-200"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:backdrop-saturate-50,backdrop-saturate-125,backdrop-saturate-200] --> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-saturate-50 ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-saturate-125 ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-saturate-200 ..."></div> | |
</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="backdrop-saturate" value=".25" name="backdrop saturation" variable="backdrop-saturation" /> | |
### Responsive design | |
<ResponsiveDesign | |
property="backdrop-filter: saturate()" | |
defaultClass="backdrop-saturate-50" | |
featuredClass="backdrop-saturate-150" | |
/> | |
--- | |
File: /src/docs/backdrop-filter-sepia.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "backdrop-filter: sepia()"; | |
export const description = "Utilities for applying backdrop sepia filters to an element."; | |
<ApiTable | |
rows={[ | |
["backdrop-sepia", "backdrop-filter: sepia(100%);"], | |
["backdrop-sepia-<number>", "backdrop-filter: sepia(<number>%);"], | |
["backdrop-sepia-(<custom-property>)", "backdrop-filter: sepia(var(<custom-property>));"], | |
["backdrop-sepia-[<value>]", "backdrop-filter: sepia(<value>);"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `backdrop-sepia` and `backdrop-sepia-50` to control the sepia effect applied to an element's backdrop: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 justify-start overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-6 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-sepia-0 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-sepia-0"></div> | |
<img | |
className="size-32 rounded-lg object-cover shadow-xl" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-sepia-50 | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-sepia-50"></div> | |
<img | |
className="size-32 rounded-lg object-cover shadow-xl" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-sepia | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-sepia"></div> | |
<img | |
className="size-32 rounded-lg object-cover shadow-xl" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:backdrop-sepia-0,backdrop-sepia-50,backdrop-sepia] --> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-sepia-0 ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-sepia-50 ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)]"> | |
<div class="bg-white/30 backdrop-sepia ..."></div> | |
</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="backdrop-sepia" value=".25" name="backdrop sepia" /> | |
### Responsive design | |
<ResponsiveDesign property="backdrop-filter: sepia()" defaultClass="backdrop-sepia" featuredClass="backdrop-sepia-0" /> | |
--- | |
File: /src/docs/backdrop-filter.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, TargetingSpecificStates, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "backdrop-filter"; | |
export const description = "Utilities for applying backdrop filters to an element."; | |
<ApiTable | |
rows={[ | |
["backdrop-filter-none", "backdrop-filter: none;"], | |
["backdrop-filter-(<custom-property>)", "backdrop-filter: var(<custom-property>);"], | |
["backdrop-filter-[<value>]", "backdrop-filter: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `backdrop-blur-xs` and `backdrop-grayscale` to apply filters to an element's backdrop: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 justify-start overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-6 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-blur-xs | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-blur-xs"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backdrop-grayscale | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-grayscale"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 italic dark:text-gray-400"> | |
combined | |
</p> | |
<div className="relative"> | |
<div className="absolute inset-6 size-20 bg-white/30 backdrop-blur-xs backdrop-grayscale"></div> | |
<img | |
className="size-32 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:backdrop-blur-xs,backdrop-grayscale] --> | |
<div class="bg-[url(/img/mountains.jpg)] ..."> | |
<div class="backdrop-blur-xs ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)] ..."> | |
<div class="backdrop-grayscale ..."></div> | |
</div> | |
<div class="bg-[url(/img/mountains.jpg)] ..."> | |
<div class="backdrop-blur-xs backdrop-grayscale ..."></div> | |
</div> | |
``` | |
</Figure> | |
You can combine the following backdrop filter utilities: [blur](/docs/backdrop-filter-blur), [brightness](/docs/backdrop-filter-brightness), [contrast](/docs/backdrop-filter-contrast), [grayscale](/docs/backdrop-filter-grayscale), [hue-rotate](/docs/backdrop-filter-hue-rotate), [invert](/docs/backdrop-filter-invert), [opacity](/docs/backdrop-filter-opacity), [saturate](/docs/backdrop-filter-saturate), and [sepia](/docs/backdrop-filter-sepia). | |
### Removing filters | |
Use the `backdrop-filter-none` utility to remove all of the backdrop filters applied to an element: | |
```html | |
<!-- [!code classes:md:backdrop-filter-none] --> | |
<div class="backdrop-blur-md backdrop-brightness-150 md:backdrop-filter-none"></div> | |
``` | |
### Using a custom value | |
<UsingACustomValue utility="backdrop-filter" value="url('filters.svg#filter-id')" name="backdrop filter" /> | |
### Applying on hover | |
<TargetingSpecificStates | |
property="backdrop-filter" | |
defaultClass="backdrop-blur-sm" | |
featuredClass="backdrop-filter-none" | |
/> | |
### Responsive design | |
<ResponsiveDesign property="backdrop-filter" defaultClass="backdrop-blur-sm" featuredClass="backdrop-filter-none" /> | |
--- | |
File: /src/docs/backface-visibility.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "backface-visibility"; | |
export const description = "Utilities for controlling if an element's backface is visible."; | |
<ApiTable | |
rows={[ | |
["backface-hidden", "backface-visibility: hidden;"], | |
["backface-visible", "backface-visibility: visible;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use the `backface-visible` utility to show the backface of an element, like a cube, even when it's rotated away from view: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col justify-around gap-8 text-sm leading-6 font-bold text-white sm:flex-row sm:gap-0"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backface-hidden | |
</p> | |
<div className="size-40 p-10"> | |
<div className="size-20 rotate-[0.75_1_0.75_45deg] transform-3d"> | |
<div className="absolute inset-0 translate-z-12 rotate-x-0 bg-sky-300/75 text-center text-4xl leading-20 font-bold text-sky-900 backface-hidden dark:bg-sky-400/85 dark:text-white"> | |
1 | |
</div> | |
<div className="absolute inset-0 -translate-z-12 rotate-y-180 bg-sky-300/75 text-center text-4xl leading-20 font-bold text-sky-900 opacity-75 backface-hidden dark:bg-sky-400/85 dark:text-white"> | |
2 | |
</div> | |
<div className="absolute inset-0 translate-x-12 rotate-y-90 bg-sky-300/75 text-center text-4xl leading-20 font-bold text-sky-900 opacity-75 backface-hidden dark:bg-sky-400/85 dark:text-white"> | |
3 | |
</div> | |
<div className="absolute inset-0 -translate-x-12 -rotate-y-90 bg-sky-300/75 text-center text-4xl leading-20 font-bold text-sky-900 backface-hidden dark:bg-sky-400/85 dark:text-white"> | |
4 | |
</div> | |
<div className="absolute inset-0 -translate-y-12 rotate-x-90 bg-sky-300/75 text-center text-4xl leading-20 font-bold text-sky-900 opacity-75 backface-hidden dark:bg-sky-400/85 dark:text-white"> | |
5 | |
</div> | |
<div className="absolute inset-0 translate-y-12 -rotate-x-90 bg-sky-300/75 text-center text-4xl leading-20 font-bold text-sky-900 backface-hidden dark:bg-sky-400/85 dark:text-white"> | |
6 | |
</div> | |
</div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
backface-visible | |
</p> | |
<div className="size-40 p-10"> | |
<div className="size-20 rotate-[0.75_1_0.75_45deg] transform-3d"> | |
<div className="absolute inset-0 translate-z-12 rotate-x-0 bg-sky-300/75 text-center text-4xl leading-20 font-bold text-sky-900 backface-visible dark:bg-sky-400/85 dark:text-white"> | |
1 | |
</div> | |
<div className="absolute inset-0 -translate-z-12 rotate-y-180 bg-sky-300/75 text-center text-4xl leading-20 font-bold text-sky-900 opacity-75 backface-visible dark:bg-sky-400/85 dark:text-white"> | |
2 | |
</div> | |
<div className="absolute inset-0 translate-x-12 rotate-y-90 bg-sky-300/75 text-center text-4xl leading-20 font-bold text-sky-900 opacity-75 backface-visible dark:bg-sky-400/85 dark:text-white"> | |
3 | |
</div> | |
<div className="absolute inset-0 -translate-x-12 -rotate-y-90 bg-sky-300/75 text-center text-4xl leading-20 font-bold text-sky-900 backface-visible dark:bg-sky-400/85 dark:text-white"> | |
4 | |
</div> | |
<div className="absolute inset-0 -translate-y-12 rotate-x-90 bg-sky-300/75 text-center text-4xl leading-20 font-bold text-sky-900 opacity-75 backface-visible dark:bg-sky-400/85 dark:text-white"> | |
5 | |
</div> | |
<div className="absolute inset-0 translate-y-12 -rotate-x-90 bg-sky-300/75 text-center text-4xl leading-20 font-bold text-sky-900 backface-visible dark:bg-sky-400/85 dark:text-white"> | |
6 | |
</div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:backface-hidden,backface-visible] --> | |
<div class="size-20 ..."> | |
<div class="translate-z-12 rotate-x-0 bg-sky-300/75 backface-hidden ...">1</div> | |
<div class="-translate-z-12 rotate-y-18 bg-sky-300/75 backface-hidden ...">2</div> | |
<div class="translate-x-12 rotate-y-90 bg-sky-300/75 backface-hidden ...">3</div> | |
<div class="-translate-x-12 -rotate-y-90 bg-sky-300/75 backface-hidden ...">4</div> | |
<div class="-translate-y-12 rotate-x-90 bg-sky-300/75 backface-hidden ...">5</div> | |
<div class="translate-y-12 -rotate-x-90 bg-sky-300/75 backface-hidden ...">6</div> | |
</div> | |
<div class="size-20 ..."> | |
<div class="translate-z-12 rotate-x-0 bg-sky-300/75 backface-visible ...">1</div> | |
<div class="-translate-z-12 rotate-y-18 bg-sky-300/75 backface-visible ...">2</div> | |
<div class="translate-x-12 rotate-y-90 bg-sky-300/75 backface-visible ...">3</div> | |
<div class="-translate-x-12 -rotate-y-90 bg-sky-300/75 backface-visible ...">4</div> | |
<div class="-translate-y-12 rotate-x-90 bg-sky-300/75 backface-visible ...">5</div> | |
<div class="translate-y-12 -rotate-x-90 bg-sky-300/75 backface-visible ...">6</div> | |
</div> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="backface-visibility" defaultClass="backface-visible" featuredClass="backface-hidden" /> | |
--- | |
File: /src/docs/background-attachment.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "background-attachment"; | |
export const description = "Utilities for controlling how a background image behaves when scrolling."; | |
<ApiTable | |
rows={[ | |
["bg-fixed", "background-attachment: fixed;"], | |
["bg-local", "background-attachment: local;"], | |
["bg-scroll", "background-attachment: scroll;"], | |
]} | |
/> | |
## Examples | |
### Fixing the background image | |
Use the `bg-fixed` utility to fix the background image relative to the viewport: | |
<Figure hint="Scroll the content to see the background image fixed in place"> | |
<Example padding={false}> | |
{ | |
<div className="mx-auto h-80 overflow-y-scroll border-x border-x-gray-200 bg-[url('https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1200&h=800&q=80')] bg-cover bg-[center_-100px] dark:border-gray-800"> | |
<div className="mt-45"> | |
<div className="border-x border-x-gray-200 bg-white p-4 text-gray-500 sm:p-8 dark:border-x-gray-800 dark:bg-gray-900 dark:text-gray-400"> | |
<div className="font-inter text-2xl font-extrabold tracking-tight text-black dark:text-white"> | |
My trip to the summit | |
</div> | |
<div className="mt-1 text-sm font-medium text-gray-500">November 16, 2021 · 4 min read</div> | |
<p className="mt-4 leading-7"> | |
Maybe we can live without libraries, people like you and me. Maybe. Sure, we're too old to change the world, | |
but what about that kid, sitting down, opening a book, right now, in a branch at the local library and | |
finding drawings of pee-pees and wee-wees on the Cat in the Hat and the Five Chinese Brothers? Doesn't HE | |
deserve better? | |
</p> | |
<p className="mt-4 leading-7"> | |
Look. If you think this is about overdue fines and missing books, you'd better think again. This is about | |
that kid's right to read a book without getting his mind warped! Or: maybe that turns you on, Seinfeld; | |
maybe that's how y'get your kicks. You and your good-time buddies. | |
</p> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:bg-fixed] --> | |
<div class="bg-[url(/img/mountains.jpg)] bg-fixed ..."> | |
<!-- ... --> | |
</div> | |
``` | |
</Figure> | |
### Scrolling with the container | |
Use the `bg-local` utility to scroll the background image with the container and the viewport: | |
<Figure hint="Scroll the content to see the background image scroll with the container"> | |
<Example padding={false}> | |
{ | |
<div> | |
<div className="h-64 overflow-y-scroll bg-[url('https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=666&q=80')] bg-cover bg-local"> | |
<div className="min-h-full bg-black/40 p-8 sm:px-16 sm:py-12"> | |
<p className="text-center font-serif text-xl leading-6 text-white italic sm:text-2xl sm:leading-8"> | |
Because the mail never stops. It just keeps coming and coming and coming, there's never a let-up. It's | |
relentless. Every day it piles up more and more and more. And you gotta get it out but the more you get it | |
out the more it keeps coming in. And then the barcode reader breaks and it's Publisher's Clearing House day. | |
</p> | |
<div className="font-inter mt-6 text-center text-sm font-bold text-white sm:text-base">— Newman</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:bg-local] --> | |
<div class="bg-[url(/img/mountains.jpg)] bg-local ..."> | |
<!-- ... --> | |
</div> | |
``` | |
</Figure> | |
### Scrolling with the viewport | |
Use the `bg-scroll` utility to scroll the background image with the viewport, but not with the container: | |
<Figure hint="Scroll the content to see the background image fixed in the container"> | |
<Example padding={false}> | |
{ | |
<div> | |
<div className="h-64 overflow-y-scroll bg-[url('https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=666&q=80')] bg-cover bg-scroll"> | |
<div className="min-h-full bg-black/40 p-8 sm:px-16 sm:py-12"> | |
<p className="text-center font-serif text-xl leading-6 text-white italic sm:text-2xl sm:leading-8"> | |
Because the mail never stops. It just keeps coming and coming and coming, there's never a let-up. It's | |
relentless. Every day it piles up more and more and more. And you gotta get it out but the more you get it | |
out the more it keeps coming in. And then the barcode reader breaks and it's Publisher's Clearing House day. | |
</p> | |
<div className="font-inter mt-6 text-center text-sm font-bold text-white sm:text-base">— Newman</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:bg-scroll] --> | |
<div class="bg-[url(/img/mountains.jpg)] bg-scroll ..."> | |
<!-- ... --> | |
</div> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="background-attachment" defaultClass="bg-local" featuredClass="bg-fixed" /> | |
--- | |
File: /src/docs/background-blend-mode.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "background-blend-mode"; | |
export const description = | |
"Utilities for controlling how an element's background image should blend with its background color."; | |
<ApiTable | |
rows={[ | |
["bg-blend-normal", "background-blend-mode: normal;"], | |
["bg-blend-multiply", "background-blend-mode: multiply;"], | |
["bg-blend-screen", "background-blend-mode: screen;"], | |
["bg-blend-overlay", "background-blend-mode: overlay;"], | |
["bg-blend-darken", "background-blend-mode: darken;"], | |
["bg-blend-lighten", "background-blend-mode: lighten;"], | |
["bg-blend-color-dodge", "background-blend-mode: color-dodge;"], | |
["bg-blend-color-burn", "background-blend-mode: color-burn;"], | |
["bg-blend-hard-light", "background-blend-mode: hard-light;"], | |
["bg-blend-soft-light", "background-blend-mode: soft-light;"], | |
["bg-blend-difference", "background-blend-mode: difference;"], | |
["bg-blend-exclusion", "background-blend-mode: exclusion;"], | |
["bg-blend-hue", "background-blend-mode: hue;"], | |
["bg-blend-saturation", "background-blend-mode: saturation;"], | |
["bg-blend-color", "background-blend-mode: color;"], | |
["bg-blend-luminosity", "background-blend-mode: luminosity;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `bg-blend-difference` and `bg-blend-saturation` to control how the background image and color of an element are blended: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col items-center justify-between gap-y-6 px-1 sm:flex-row md:px-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
bg-blend-multiply | |
</p> | |
<div className="size-24 bg-blue-500 bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] bg-cover bg-center bg-no-repeat bg-blend-multiply md:size-32"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
bg-blend-soft-light | |
</p> | |
<div className="size-24 bg-blue-500 bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] bg-cover bg-center bg-no-repeat bg-blend-soft-light md:size-32"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
bg-blend-overlay | |
</p> | |
<div className="size-24 bg-blue-500 bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] bg-cover bg-center bg-no-repeat bg-blend-overlay md:size-32"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:bg-blend-multiply,bg-blend-soft-light,bg-blend-overlay] --> | |
<div class="bg-blue-500 bg-[url(/img/mountains.jpg)] bg-blend-multiply ..."></div> | |
<div class="bg-blue-500 bg-[url(/img/mountains.jpg)] bg-blend-soft-light ..."></div> | |
<div class="bg-blue-500 bg-[url(/img/mountains.jpg)] bg-blend-overlay ..."></div> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign | |
property="background-blend-mode" | |
defaultClass="bg-blue-500 bg-[url(/img/mountains.jpg)] bg-blend-lighten" | |
featuredClass="bg-blend-darken" | |
/> | |
--- | |
File: /src/docs/background-clip.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "background-clip"; | |
export const description = "Utilities for controlling the bounding box of an element's background."; | |
<ApiTable | |
rows={[ | |
["bg-clip-border", "background-clip: border-box;"], | |
["bg-clip-padding", "background-clip: padding-box;"], | |
["bg-clip-content", "background-clip: content-box;"], | |
["bg-clip-text", "background-clip: text;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use the `bg-clip-border`, `bg-clip-padding`, and `bg-clip-content` utilities to control the bounding box of an element's background: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col items-center justify-center space-y-10 sm:flex-row sm:space-y-0 sm:space-x-10"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
bg-clip-border | |
</p> | |
<div className="flex h-24 w-24 items-center justify-center rounded-lg border-3 border-dashed border-white/50 bg-indigo-500 bg-clip-border p-3 font-mono text-sm font-extrabold text-white"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
bg-clip-padding | |
</p> | |
<div className="flex h-24 w-24 items-center justify-center rounded-lg border-3 border-dashed border-indigo-500/50 bg-indigo-500 bg-clip-padding p-3 font-mono text-sm font-extrabold text-white"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
bg-clip-content | |
</p> | |
<div className="flex h-24 w-24 items-center justify-center rounded-lg border-3 border-dashed border-indigo-500/50 bg-indigo-500 bg-clip-content p-3 font-mono text-sm font-extrabold text-white"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:bg-clip-border,bg-clip-padding,bg-clip-content] --> | |
<div class="border-4 bg-indigo-500 bg-clip-border p-3"></div> | |
<div class="border-4 bg-indigo-500 bg-clip-padding p-3"></div> | |
<div class="border-4 bg-indigo-500 bg-clip-content p-3"></div> | |
``` | |
</Figure> | |
### Cropping to text | |
Use the `bg-clip-text` utility to crop an element's background to match the shape of the text: | |
<Figure> | |
<Example> | |
{ | |
<p className="bg-gradient-to-r from-pink-500 to-violet-500 bg-clip-text text-center text-4xl leading-none font-extrabold tracking-tight text-transparent sm:text-5xl"> | |
Hello world | |
</p> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:bg-clip-text] --> | |
<p class="bg-gradient-to-r from-pink-500 to-violet-500 bg-clip-text text-5xl font-extrabold text-transparent ..."> | |
Hello world | |
</p> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="background-clip" defaultClass="bg-clip-border" featuredClass="bg-clip-padding" /> | |
--- | |
File: /src/docs/background-color.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { | |
CustomizingYourThemeColors, | |
ResponsiveDesign, | |
TargetingSpecificStates, | |
UsingACustomValue, | |
} from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import colors from "./utils/colors"; | |
export const title = "background-color"; | |
export const description = "Utilities for controlling an element's background color."; | |
<ApiTable | |
rows={[ | |
["bg-inherit", "background-color: inherit;"], | |
["bg-current", "background-color: currentColor;"], | |
["bg-transparent", "background-color: transparent;"], | |
...Object.entries(colors).map(([name, value]) => [ | |
`bg-${name}`, | |
`background-color: var(--color-${name}); /* ${value} */`, | |
]), | |
["bg-(<custom-property>)", "background-color: var(<custom-property>);"], | |
["bg-[<value>]", "background-color: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `bg-white`, `bg-indigo-500` and `bg-transparent` to control the background color of an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1 gap-4 text-sm text-white sm:grid-cols-3"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">bg-blue-500</p> | |
<button | |
type="button" | |
tabIndex="-1" | |
className="rounded-md bg-blue-500 px-4 py-2 text-sm font-semibold text-white opacity-100 focus:outline-none" | |
> | |
Button A | |
</button> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">bg-cyan-500</p> | |
<button | |
type="button" | |
tabIndex="-1" | |
className="rounded-md bg-cyan-500 px-4 py-2 text-sm font-semibold text-white opacity-100 focus:outline-none" | |
> | |
Button B | |
</button> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">bg-pink-500</p> | |
<button | |
type="button" | |
tabIndex="-1" | |
className="rounded-md bg-pink-500 px-4 py-2 text-sm font-semibold text-white opacity-100 focus:outline-none" | |
> | |
Button C | |
</button> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:bg-blue-500,bg-cyan-500,bg-pink-500] --> | |
<button class="bg-blue-500 ...">Button A</button> | |
<button class="bg-cyan-500 ...">Button B</button> | |
<button class="bg-pink-500 ...">Button C</button> | |
``` | |
</Figure> | |
### Changing the opacity | |
Use the color opacity modifier to control the opacity of an element's background color: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1 gap-4 text-sm text-white sm:grid-cols-3"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
bg-sky-500/100 | |
</p> | |
<button | |
type="button" | |
tabIndex="-1" | |
className="rounded-md bg-sky-500/100 px-4 py-2 text-sm font-semibold text-white opacity-100 focus:outline-none" | |
> | |
Button A | |
</button> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">bg-sky-500/75</p> | |
<button | |
type="button" | |
tabIndex="-1" | |
className="rounded-md bg-sky-500/75 px-4 py-2 text-sm font-semibold text-white opacity-100 focus:outline-none" | |
> | |
Button B | |
</button> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">bg-sky-500/50</p> | |
<button | |
type="button" | |
tabIndex="-1" | |
className="rounded-md bg-sky-500/50 px-4 py-2 text-sm font-semibold text-white opacity-100 focus:outline-none" | |
> | |
Button C | |
</button> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code word:/100] --> | |
<!-- [!code word:/75] --> | |
<!-- [!code word:/50] --> | |
<button class="bg-sky-500/100 ..."></button> | |
<button class="bg-sky-500/75 ..."></button> | |
<button class="bg-sky-500/50 ..."></button> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="bg" value="#50d71e" name="background color" variable="color" /> | |
### Applying on hover | |
<TargetingSpecificStates property="background-color"> | |
<Figure> | |
<Example> | |
{ | |
<button | |
type="button" | |
tabIndex="-1" | |
className="mx-auto block rounded-md bg-indigo-500 px-3 py-2 text-sm font-semibold text-white hover:bg-fuchsia-500 focus:outline-none" | |
> | |
Save changes | |
</button> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:hover:bg-fuchsia-500] --> | |
<button class="bg-indigo-500 hover:bg-fuchsia-500 ...">Save changes</button> | |
``` | |
</Figure> | |
</TargetingSpecificStates> | |
### Responsive design | |
<ResponsiveDesign property="background-color" defaultClass="bg-blue-500" featuredClass="bg-green-500" /> | |
## Customizing your theme | |
<CustomizingYourThemeColors utility="bg" /> | |
--- | |
File: /src/docs/background-image.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourThemeColors, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
export const title = "background-image"; | |
export const description = "Utilities for controlling an element's background image."; | |
<svg className="hidden"> | |
<symbol id="gradient-color-stop" viewBox="0 0 32 34"> | |
<path d="M1 4a4 4 0 0 1 4-4h22a4 4 0 0 1 4 4v19.6a4 4 0 0 1-2.118 3.53L16 34 3.118 27.13A4 4 0 0 1 1 23.6V4Z" /> | |
<path | |
fill="none" | |
stroke="#000" | |
strokeOpacity=".05" | |
d="M5 .5h22A3.5 3.5 0 0 1 30.5 4v19.6a3.5 3.5 0 0 1-1.853 3.088L16 33.433 3.353 26.688A3.5 3.5 0 0 1 1.5 23.6V4A3.5 3.5 0 0 1 5 .5Z" | |
/> | |
</symbol> | |
</svg> | |
<ApiTable | |
rows={[ | |
["bg-[<value>]", "background-image: <value>;"], | |
["bg-(image:<custom-property>)", "background-image: var(<custom-property>);"], | |
["bg-none", "background-image: none;"], | |
["bg-linear-to-t", "background-image: linear-gradient(to top, var(--tw-gradient-stops));"], | |
["bg-linear-to-tr", "background-image: linear-gradient(to top right, var(--tw-gradient-stops));"], | |
["bg-linear-to-r", "background-image: linear-gradient(to right, var(--tw-gradient-stops));"], | |
["bg-linear-to-br", "background-image: linear-gradient(to bottom right, var(--tw-gradient-stops));"], | |
["bg-linear-to-b", "background-image: linear-gradient(to bottom, var(--tw-gradient-stops));"], | |
["bg-linear-to-bl", "background-image: linear-gradient(to bottom left, var(--tw-gradient-stops));"], | |
["bg-linear-to-l", "background-image: linear-gradient(to left, var(--tw-gradient-stops));"], | |
["bg-linear-to-tl", "background-image: linear-gradient(to top left, var(--tw-gradient-stops));"], | |
["bg-linear-<angle>", "background-image: linear-gradient(<angle> in oklab, var(--tw-gradient-stops));"], | |
["-bg-linear-<angle>", "background-image: linear-gradient(-<angle> in oklab, var(--tw-gradient-stops));"], | |
[ | |
"bg-linear-(<custom-property>)", | |
"background-image: linear-gradient(var(--tw-gradient-stops, var(<custom-property>)));", | |
], | |
["bg-linear-[<value>]", "background-image: linear-gradient(var(--tw-gradient-stops, <value>));"], | |
["bg-radial", "background-image: radial-gradient(in oklab, var(--tw-gradient-stops));"], | |
[ | |
"bg-radial-(<custom-property>)", | |
"background-image: radial-gradient(var(--tw-gradient-stops, var(<custom-property>)));", | |
], | |
["bg-radial-[<value>]", "background-image: radial-gradient(var(--tw-gradient-stops, <value>));"], | |
["bg-conic-<angle>", "background-image: conic-gradient(from <angle> in oklab, var(--tw-gradient-stops));"], | |
["-bg-conic-<angle>", "background-image: conic-gradient(from -<angle> in oklab, var(--tw-gradient-stops));"], | |
["bg-conic-(<custom-property>)", "background-image: var(<custom-property>);"], | |
["bg-conic-[<value>]", "background-image: <image>;"], | |
["from-<color>", "--tw-gradient-from: <color>;"], | |
["from-<percentage>", "--tw-gradient-from-position: <percentage>;"], | |
["from-(<custom-property>)", "--tw-gradient-from: var(<custom-property>);"], | |
["from-[<value>]", "--tw-gradient-from: <value>;"], | |
["via-<color>", "--tw-gradient-via: <color>;"], | |
["via-<percentage>", "--tw-gradient-via-position: <percentage>;"], | |
["via-(<custom-property>)", "--tw-gradient-via: var(<custom-property>);"], | |
["via-[<value>]", "--tw-gradient-via: <value>;"], | |
["to-<color>", "--tw-gradient-to: <color>;"], | |
["to-<percentage>", "--tw-gradient-to-position: <percentage>;"], | |
["to-(<custom-property>)", "--tw-gradient-to: var(<custom-property>);"], | |
["to-[<value>]", "--tw-gradient-to: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use the `bg-[<value>]` syntax to set the background image of an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="relative mx-auto flex h-48 w-96 items-center justify-center overflow-hidden rounded-lg sm:w-96"> | |
<div className="h-full w-full bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] bg-cover bg-center bg-no-repeat"></div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:bg-[url(/img/mountains.jpg)]] --> | |
<div class="bg-[url(/img/mountains.jpg)] ..."></div> | |
``` | |
</Figure> | |
### Adding a linear gradient | |
Use utilities like `bg-linear-to-r` and `bg-linear-<angle>` with the [color stop utilities](#setting-gradient-color-stops) to add a linear gradient to an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="space-y-4"> | |
<div className="h-14 rounded-lg bg-linear-to-r from-cyan-500 to-blue-500"></div> | |
<div className="h-14 rounded-lg bg-linear-to-t from-sky-500 to-indigo-500"></div> | |
<div className="h-14 rounded-lg bg-linear-to-bl from-violet-500 to-fuchsia-500"></div> | |
<div className="h-14 rounded-lg bg-linear-65 from-purple-500 to-pink-500"></div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:bg-linear-to-r,bg-linear-to-t,bg-linear-to-bl,bg-linear-65] --> | |
<div class="h-14 bg-linear-to-r from-cyan-500 to-blue-500"></div> | |
<div class="h-14 bg-linear-to-t from-sky-500 to-indigo-500"></div> | |
<div class="h-14 bg-linear-to-bl from-violet-500 to-fuchsia-500"></div> | |
<div class="h-14 bg-linear-65 from-purple-500 to-pink-500"></div> | |
``` | |
</Figure> | |
### Adding a radial gradient | |
Use the `bg-radial` and `bg-radial-[<position>]` utilities with the [color stop utilities](#setting-gradient-color-stops) to add a radial gradient to an element: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex justify-around p-8 sm:p-12"> | |
<div className="size-18 rounded-full bg-radial from-pink-400 from-40% to-fuchsia-700 sm:size-24"></div> | |
<div className="size-18 rounded-full bg-radial-[at_50%_75%] from-sky-200 via-blue-400 to-indigo-900 to-90% sm:size-24"></div> | |
<div className="size-18 rounded-full bg-radial-[at_25%_25%] from-white to-zinc-900 to-75% sm:size-24"></div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:bg-radial-[at_50%_75%],bg-radial-[at_25%_25%],bg-radial] --> | |
<div class="size-18 rounded-full bg-radial from-pink-400 from-40% to-fuchsia-700"></div> | |
<div class="size-18 rounded-full bg-radial-[at_50%_75%] from-sky-200 via-blue-400 to-indigo-900 to-90%"></div> | |
<div class="size-18 rounded-full bg-radial-[at_25%_25%] from-white to-zinc-900 to-75%"></div> | |
``` | |
</Figure> | |
### Adding a conic gradient | |
Use the `bg-conic` and `bg-conic-<angle>` utilities with the [color stop utilities](#setting-gradient-color-stops) to add a conic gradient to an element: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex justify-around p-8 sm:p-12"> | |
<div className="size-18 rounded-full bg-conic from-blue-600 to-sky-400 to-50% sm:size-24"></div> | |
<div className="size-18 rounded-full bg-conic-180 from-indigo-600 via-indigo-50 to-indigo-600 sm:size-24"></div> | |
<div className="size-18 rounded-full bg-conic/decreasing from-violet-700 via-lime-300 to-violet-700 sm:size-24"></div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:bg-conic-180,bg-conic/decreasing,bg-conic] --> | |
<div class="size-24 rounded-full bg-conic from-blue-600 to-sky-400 to-50%"></div> | |
<div class="size-24 rounded-full bg-conic-180 from-indigo-600 via-indigo-50 to-indigo-600"></div> | |
<div class="size-24 rounded-full bg-conic/decreasing from-violet-700 via-lime-300 to-violet-700"></div> | |
``` | |
</Figure> | |
### Setting gradient color stops | |
Use utilities like `from-indigo-500`, `via-purple-500`, and `to-pink-500` to set the colors of the gradient stops: | |
<Figure> | |
<Example> | |
{ | |
<div className="mx-5"> | |
<div className="relative h-[3.625rem]"> | |
<div className="absolute top-0 left-px -ml-4 flex h-12 flex-col items-center"> | |
<svg viewBox="0 0 32 34" className="w-8 flex-none fill-indigo-500 drop-shadow"> | |
<use href="#gradient-color-stop" /> | |
</svg> | |
<div className="mt-2 h-2 w-0.5 bg-gray-900/30 dark:bg-white/30"></div> | |
</div> | |
<div className="absolute top-0 left-1/2 -ml-4 flex h-12 flex-col items-center"> | |
<svg viewBox="0 0 32 34" className="w-8 flex-none fill-purple-500 drop-shadow"> | |
<use href="#gradient-color-stop" /> | |
</svg> | |
<div className="mt-2 h-2 w-0.5 bg-gray-900/30 dark:bg-white/30"></div> | |
</div> | |
<div className="absolute top-0 right-px -mr-4 flex h-12 flex-col items-center"> | |
<svg viewBox="0 0 32 34" className="w-8 flex-none fill-pink-500 drop-shadow"> | |
<use href="#gradient-color-stop" /> | |
</svg> | |
<div className="mt-2 h-2 w-0.5 bg-gray-900/30 dark:bg-white/30"></div> | |
</div> | |
</div> | |
<div className="h-10 rounded-lg bg-gradient-to-r from-indigo-500 via-purple-500 to-pink-500"></div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:from-indigo-500,via-purple-500,to-pink-500] --> | |
<div class="bg-gradient-to-r from-indigo-500 via-purple-500 to-pink-500 ..."></div> | |
``` | |
</Figure> | |
### Setting gradient stop positions | |
Use utilities like `from-10%`, `via-30%`, and `to-90%` to set more precise positions for the gradient color stops: | |
<Figure> | |
<Example> | |
{ | |
<div className="mx-5"> | |
<div className="relative h-[3.625rem]"> | |
<div className="absolute top-0 left-[10%] -ml-4 flex h-12 flex-col items-center"> | |
<svg viewBox="0 0 32 34" className="w-8 flex-none fill-indigo-500 drop-shadow"> | |
<use href="#gradient-color-stop" /> | |
</svg> | |
<div className="mt-2 h-2 w-0.5 bg-gray-900/30 dark:bg-white/30"></div> | |
<div className="absolute top-0 left-0 flex h-8 w-full items-center justify-center font-mono text-[0.6875rem] font-semibold tracking-wider text-white"> | |
10% | |
</div> | |
</div> | |
<div className="absolute top-0 left-[30%] -ml-4 flex h-12 flex-col items-center"> | |
<svg viewBox="0 0 32 34" className="w-8 flex-none fill-sky-500 drop-shadow"> | |
<use href="#gradient-color-stop" /> | |
</svg> | |
<div className="mt-2 h-2 w-0.5 bg-gray-900/30 dark:bg-white/30"></div> | |
<div className="absolute top-0 left-0 flex h-8 w-full items-center justify-center font-mono text-[0.6875rem] font-semibold tracking-wider text-white"> | |
30% | |
</div> | |
</div> | |
<div className="absolute top-0 right-[10%] -mr-4 flex h-12 flex-col items-center"> | |
<svg viewBox="0 0 32 34" className="w-8 flex-none fill-emerald-500 drop-shadow"> | |
<use href="#gradient-color-stop" /> | |
</svg> | |
<div className="mt-2 h-2 w-0.5 bg-gray-900/30 dark:bg-white/30"></div> | |
<div className="absolute top-0 left-0 flex h-8 w-full items-center justify-center font-mono text-[0.6875rem] font-semibold tracking-wider text-white"> | |
90% | |
</div> | |
</div> | |
</div> | |
<div className="h-10 rounded-lg bg-gradient-to-r from-indigo-500 from-10% via-sky-500 via-30% to-emerald-500 to-90%"></div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:from-10%,via-30%,to-90%] --> | |
<div class="bg-gradient-to-r from-indigo-500 from-10% via-sky-500 via-30% to-emerald-500 to-90% ..."></div> | |
``` | |
</Figure> | |
### Changing interpolation mode | |
Use the interpolation modifier to control the interpolation mode of a gradient: | |
<Figure> | |
<Example> | |
{ | |
<div> | |
<div className="grid grid-cols-1 items-center gap-x-4 gap-y-0 sm:grid-cols-[auto_1fr] sm:gap-y-2"> | |
<p className="mt-2 font-mono text-xs font-medium text-gray-500 sm:mt-0 sm:text-right dark:text-gray-400"> | |
srgb | |
</p> | |
<div className="mt-1 h-12 rounded-lg bg-linear-to-r/srgb from-indigo-500 to-teal-400"></div> | |
<p className="mt-2 font-mono text-xs font-medium text-gray-500 sm:mt-0 sm:text-right dark:text-gray-400">hsl</p> | |
<div className="mt-1 h-12 rounded-lg bg-linear-to-r/hsl from-indigo-500 to-teal-400"></div> | |
<p className="mt-2 font-mono text-xs font-medium text-gray-500 sm:mt-0 sm:text-right dark:text-gray-400"> | |
oklab | |
</p> | |
<div className="mt-1 h-12 rounded-lg bg-linear-to-r/oklab from-indigo-500 to-teal-400"></div> | |
<p className="mt-2 font-mono text-xs font-medium text-gray-500 sm:mt-0 sm:text-right dark:text-gray-400"> | |
oklch | |
</p> | |
<div className="mt-1 h-12 rounded-lg bg-linear-to-r/oklch from-indigo-500 to-teal-400"></div> | |
<p className="mt-2 font-mono text-xs font-medium text-gray-500 sm:mt-0 sm:text-right dark:text-gray-400"> | |
longer | |
</p> | |
<div className="mt-1 h-12 rounded-lg bg-linear-to-r/longer from-indigo-500 to-teal-400"></div> | |
<p className="mt-2 font-mono text-xs font-medium text-gray-500 sm:mt-0 sm:text-right dark:text-gray-400"> | |
shorter | |
</p> | |
<div className="mt-1 h-12 rounded-lg bg-linear-to-r/shorter from-indigo-500 to-teal-400"></div> | |
<p className="mt-2 font-mono text-xs font-medium text-gray-500 sm:mt-0 sm:text-right dark:text-gray-400"> | |
increasing | |
</p> | |
<div className="mt-1 h-12 rounded-lg bg-linear-to-r/increasing from-indigo-500 to-teal-400"></div> | |
<p className="mt-2 font-mono text-xs font-medium text-gray-500 sm:mt-0 sm:text-right dark:text-gray-400"> | |
decreasing | |
</p> | |
<div className="mt-1 h-12 rounded-lg bg-linear-to-r/decreasing from-indigo-500 to-teal-400"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code word:/srgb] --> | |
<!-- [!code word:/hsl] --> | |
<!-- [!code word:/oklab] --> | |
<!-- [!code word:/oklch] --> | |
<!-- [!code word:/longer] --> | |
<!-- [!code word:/shorter] --> | |
<!-- [!code word:/increasing] --> | |
<!-- [!code word:/decreasing] --> | |
<div class="bg-linear-to-r/srgb from-indigo-500 to-teal-400"></div> | |
<div class="bg-linear-to-r/hsl from-indigo-500 to-teal-400"></div> | |
<div class="bg-linear-to-r/oklab from-indigo-500 to-teal-400"></div> | |
<div class="bg-linear-to-r/oklch from-indigo-500 to-teal-400"></div> | |
<div class="bg-linear-to-r/longer from-indigo-500 to-teal-400"></div> | |
<div class="bg-linear-to-r/shorter from-indigo-500 to-teal-400"></div> | |
<div class="bg-linear-to-r/increasing from-indigo-500 to-teal-400"></div> | |
<div class="bg-linear-to-r/decreasing from-indigo-500 to-teal-400"></div> | |
``` | |
</Figure> | |
By default gradients are interpolated in the `oklab` color space. | |
### Removing background images | |
Use the `bg-none` utility to remove an existing background image from an element: | |
```html | |
<!-- [!code classes:bg-none] --> | |
<div class="bg-none"></div> | |
``` | |
### Using a custom value | |
<UsingACustomValue | |
utilities={["bg-linear", "from"]} | |
name="gradient" | |
value="25deg,red_5%,yellow_60%,lime_90%,teal" | |
variable="gradient" | |
/> | |
### Responsive design | |
<ResponsiveDesign property="background-image" defaultClass="from-purple-400" featuredClass="from-yellow-500" /> | |
## Customizing your theme | |
<CustomizingYourThemeColors utilities={["from", "via", "to"]} /> | |
--- | |
File: /src/docs/background-origin.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "background-origin"; | |
export const description = | |
"Utilities for controlling how an element's background is positioned relative to borders, padding, and content."; | |
<ApiTable | |
rows={[ | |
["bg-origin-border", "background-origin: border-box;"], | |
["bg-origin-padding", "background-origin: padding-box;"], | |
["bg-origin-content", "background-origin: content-box;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use the `bg-origin-border`, `bg-origin-padding`, and `bg-origin-content` utilities to control where an element's background is rendered: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-12 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
bg-origin-border | |
</p> | |
<div className="h-24 w-24 rounded-lg border-4 border-dashed border-white/75 bg-gray-300 bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90)] bg-cover bg-no-repeat bg-origin-border object-cover p-3 dark:border-white/40"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
bg-origin-padding | |
</p> | |
<div className="h-24 w-24 rounded-lg border-4 border-dashed border-white/75 bg-gray-300 bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90)] bg-cover bg-no-repeat bg-origin-padding object-cover p-3 dark:border-white/25 dark:bg-gray-700"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
bg-origin-content | |
</p> | |
<div className="h-24 w-24 rounded-lg border-4 border-dashed border-white/75 bg-gray-300 bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90)] bg-cover bg-no-repeat bg-origin-content object-cover p-3 dark:border-white/25 dark:bg-gray-700"></div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:bg-origin-border,bg-origin-padding,bg-origin-content] --> | |
<div class="border-4 bg-[url(/img/mountains.jpg)] bg-origin-border p-3 ..."></div> | |
<div class="border-4 bg-[url(/img/mountains.jpg)] bg-origin-padding p-3 ..."></div> | |
<div class="border-4 bg-[url(/img/mountains.jpg)] bg-origin-content p-3 ..."></div> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="background-origin" defaultClass="bg-origin-border" featuredClass="bg-origin-padding" /> | |
--- | |
File: /src/docs/background-position.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "background-position"; | |
export const description = "Utilities for controlling the position of an element's background image."; | |
<ApiTable | |
rows={[ | |
["bg-top-left", "background-position: top left;"], | |
["bg-top", "background-position: top;"], | |
["bg-top-right", "background-position: top right;"], | |
["bg-left", "background-position: left;"], | |
["bg-center", "background-position: center;"], | |
["bg-right", "background-position: right;"], | |
["bg-bottom-left", "background-position: bottom left;"], | |
["bg-bottom", "background-position: bottom;"], | |
["bg-bottom-right", "background-position: bottom right;"], | |
["bg-position-(<custom-property>)", "background-position: var(<custom-property>);"], | |
["bg-position-[<value>]", "background-position: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `bg-center`, `bg-right`, and `bg-top-left` to control the position of an element's background image: | |
<Figure hint="Hover over these examples to see the full image"> | |
<Example padding={false}> | |
{ | |
<div className="w-full"> | |
<div className="flex snap-x scroll-p-4 items-end overflow-x-scroll overflow-y-hidden p-8 pt-16 sm:grid sm:grid-cols-3 sm:gap-16"> | |
<div className="relative w-32 shrink-0 snap-start snap-always sm:w-auto"> | |
<p className="absolute inset-x-0 top-0 mb-3 -translate-y-8 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
bg-top-left | |
</p> | |
<div className="group relative mx-auto h-20 w-20 rounded-lg"> | |
<div className="relative z-10 h-full w-full rounded-md bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90)] bg-[size:8rem] bg-top-left outline -outline-offset-1 outline-black/10"></div> | |
<img | |
className="absolute top-0 left-0 h-32 w-32 max-w-none overflow-hidden rounded-md opacity-0 sm:group-hover:opacity-25" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
</div> | |
</div> | |
<div className="relative w-32 shrink-0 snap-start snap-always sm:w-auto"> | |
<p className="absolute inset-x-0 top-0 mb-3 -translate-y-8 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
bg-top | |
</p> | |
<div className="group relative mx-auto h-20 w-20 rounded-lg"> | |
<div className="relative z-10 h-full w-full rounded-md bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90)] bg-[size:8rem] bg-top outline -outline-offset-1 outline-black/10"></div> | |
<img | |
className="absolute top-0 -left-6 h-32 w-32 max-w-none overflow-hidden rounded-md opacity-0 sm:group-hover:opacity-25" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
</div> | |
</div> | |
<div className="relative w-32 shrink-0 snap-start snap-always sm:w-auto"> | |
<p className="absolute inset-x-0 top-0 mb-3 -translate-y-8 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
bg-top-right | |
</p> | |
<div className="group relative mx-auto h-20 w-20 rounded-lg"> | |
<div className="relative z-10 h-full w-full rounded-md bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90)] bg-[size:8rem] bg-top-right outline -outline-offset-1 outline-black/10"></div> | |
<img | |
className="absolute top-0 right-0 h-32 w-32 max-w-none overflow-hidden rounded-md opacity-0 sm:group-hover:opacity-25" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
</div> | |
</div> | |
<div className="relative w-32 shrink-0 snap-start snap-always sm:w-auto"> | |
<p className="absolute inset-x-0 top-0 mb-3 -translate-y-8 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
bg-left | |
</p> | |
<div className="group relative mx-auto h-20 w-20 rounded-lg"> | |
<div className="relative z-10 h-full w-full rounded-md bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90)] bg-[size:8rem] bg-left outline -outline-offset-1 outline-black/10"></div> | |
<img | |
className="absolute -top-6 left-0 h-32 w-32 max-w-none overflow-hidden rounded-md opacity-0 sm:group-hover:opacity-25" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
</div> | |
</div> | |
<div className="relative w-32 shrink-0 snap-start snap-always sm:w-auto"> | |
<p className="absolute inset-x-0 top-0 mb-3 -translate-y-8 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
bg-center | |
</p> | |
<div className="group relative mx-auto h-20 w-20 rounded-lg"> | |
<div className="relative z-10 h-full w-full rounded-md bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90)] bg-[size:8rem] bg-center outline -outline-offset-1 outline-black/10"></div> | |
<img | |
className="absolute -top-6 -left-6 h-32 w-32 max-w-none overflow-hidden rounded-md opacity-0 sm:group-hover:opacity-25" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
</div> | |
</div> | |
<div className="relative w-32 shrink-0 snap-start snap-always sm:w-auto"> | |
<p className="absolute inset-x-0 top-0 mb-3 -translate-y-8 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
bg-right | |
</p> | |
<div className="group relative mx-auto h-20 w-20 rounded-lg"> | |
<div className="relative z-10 h-full w-full rounded-md bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90)] bg-[size:8rem] bg-right outline -outline-offset-1 outline-black/10"></div> | |
<img | |
className="absolute -top-6 right-0 h-32 w-32 max-w-none overflow-hidden rounded-md opacity-0 sm:group-hover:opacity-25" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
</div> | |
</div> | |
<div className="relative w-32 shrink-0 snap-start snap-always sm:w-auto"> | |
<p className="absolute inset-x-0 top-0 mb-3 -translate-y-8 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
bg-bottom-left | |
</p> | |
<div className="group relative mx-auto h-20 w-20 rounded-lg"> | |
<div className="relative z-10 h-full w-full rounded-md bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90)] bg-[size:8rem] bg-bottom-left outline -outline-offset-1 outline-black/10"></div> | |
<img | |
className="absolute -top-12 left-0 h-32 w-32 max-w-none overflow-hidden rounded-md opacity-0 sm:group-hover:opacity-25" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
</div> | |
</div> | |
<div className="relative w-32 shrink-0 snap-start snap-always sm:w-auto"> | |
<p className="absolute inset-x-0 top-0 mb-3 -translate-y-8 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
bg-bottom | |
</p> | |
<div className="group relative mx-auto h-20 w-20 rounded-lg"> | |
<div className="relative z-10 h-full w-full rounded-md bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90)] bg-[size:8rem] bg-bottom outline -outline-offset-1 outline-black/10"></div> | |
<img | |
className="absolute -top-12 -left-6 h-32 w-32 max-w-none overflow-hidden rounded-md opacity-0 sm:group-hover:opacity-25" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
</div> | |
</div> | |
<div className="relative -mx-8 w-48 shrink-0 snap-start snap-always sm:w-auto"> | |
<p className="absolute inset-x-0 top-0 mb-3 -translate-y-8 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
bg-bottom-right | |
</p> | |
<div className="group relative mx-auto h-20 w-20 rounded-lg"> | |
<div className="relative z-10 h-full w-full rounded-md bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90)] bg-[size:8rem] bg-bottom-right outline -outline-offset-1 outline-black/10"></div> | |
<img | |
className="absolute -top-12 right-0 h-32 w-32 max-w-none overflow-hidden rounded-md opacity-0 sm:group-hover:opacity-25" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:bg-top-left,bg-top-right,bg-bottom-right,bg-bottom-left,bg-center,bg-right,bg-top,bg-bottom,bg-left] --> | |
<div class="bg-[url(/img/mountains.jpg)] bg-top-left"></div> | |
<div class="bg-[url(/img/mountains.jpg)] bg-top"></div> | |
<div class="bg-[url(/img/mountains.jpg)] bg-top-right"></div> | |
<div class="bg-[url(/img/mountains.jpg)] bg-left"></div> | |
<div class="bg-[url(/img/mountains.jpg)] bg-center"></div> | |
<div class="bg-[url(/img/mountains.jpg)] bg-right"></div> | |
<div class="bg-[url(/img/mountains.jpg)] bg-bottom-left"></div> | |
<div class="bg-[url(/img/mountains.jpg)] bg-bottom"></div> | |
<div class="bg-[url(/img/mountains.jpg)] bg-bottom-right"></div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="bg-position" value="center_top_1rem" name="background position" variable="bg-position" /> | |
### Responsive design | |
<ResponsiveDesign property="background-position" defaultClass="bg-center" featuredClass="bg-top" /> | |
--- | |
File: /src/docs/background-repeat.mdx | |
--- | |
import cloudsImg from "@/docs/img/clouds.svg"; | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "background-repeat"; | |
export const description = "Utilities for controlling the repetition of an element's background image."; | |
<ApiTable | |
rows={[ | |
["bg-repeat", "background-repeat: repeat;"], | |
["bg-repeat-x", "background-repeat: repeat-x;"], | |
["bg-repeat-y", "background-repeat: repeat-y;"], | |
["bg-repeat-space", "background-repeat: space;"], | |
["bg-repeat-round", "background-repeat: round;"], | |
["bg-no-repeat", "background-repeat: no-repeat;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use the `bg-repeat` utility to repeat the background image both vertically and horizontally: | |
<Figure> | |
<Example padding={false}> | |
{<div className="h-64 bg-center bg-repeat" style={{ backgroundImage: `url(${cloudsImg.src})` }}></div>} | |
</Example> | |
```html | |
<!-- [!code classes:bg-repeat] --> | |
<div class="bg-[url(/img/clouds.svg)] bg-center bg-repeat ..."></div> | |
``` | |
</Figure> | |
### Repeating horizontally | |
Use the `bg-repeat-x` utility to only repeat the background image horizontally: | |
<Figure> | |
<Example padding={false}> | |
{<div className="h-64 bg-center bg-repeat-x" style={{ backgroundImage: `url(${cloudsImg.src})` }}></div>} | |
</Example> | |
```html | |
<!-- [!code classes:bg-repeat-x] --> | |
<div class="bg-[url(/img/clouds.svg)] bg-center bg-repeat-x ..."></div> | |
``` | |
</Figure> | |
### Repeating vertically | |
Use the `bg-repeat-y` utility to only repeat the background image vertically: | |
<Figure> | |
<Example padding={false}> | |
{<div className="h-64 bg-center bg-repeat-y" style={{ backgroundImage: `url(${cloudsImg.src})` }}></div>} | |
</Example> | |
```html | |
<!-- [!code classes:bg-repeat-y] --> | |
<div class="bg-[url(/img/clouds.svg)] bg-center bg-repeat-y ..."></div> | |
``` | |
</Figure> | |
### Preventing clipping | |
Use the `bg-repeat-space` utility to repeat the background image without clipping: | |
<Figure> | |
<Example padding={false} resizable> | |
{<div className="h-64 bg-center bg-repeat-space" style={{ backgroundImage: `url(${cloudsImg.src})` }}></div>} | |
</Example> | |
```html | |
<!-- [!code classes:bg-repeat-space] --> | |
<div class="bg-[url(/img/clouds.svg)] bg-center bg-repeat-space ..."></div> | |
``` | |
</Figure> | |
### Preventing clipping and gaps | |
Use the `bg-repeat-round` utility to repeat the background image without clipping, stretching if needed to avoid gaps: | |
<Figure> | |
<Example padding={false} resizable> | |
{<div className="h-64 bg-center bg-repeat-round" style={{ backgroundImage: `url(${cloudsImg.src})` }}></div>} | |
</Example> | |
```html | |
<!-- [!code classes:bg-repeat-round] --> | |
<div class="bg-[url(/img/clouds.svg)] bg-center bg-repeat-round ..."></div> | |
``` | |
</Figure> | |
### Disabling repeating | |
Use the `bg-no-repeat` utility to prevent a background image from repeating: | |
<Figure> | |
<Example padding={false}> | |
{<div className="h-64 bg-center bg-no-repeat" style={{ backgroundImage: `url(${cloudsImg.src})` }}></div>} | |
</Example> | |
```html | |
<!-- [!code classes:bg-no-repeat] --> | |
<div class="bg-[url(/img/clouds.svg)] bg-center bg-no-repeat ..."></div> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="background-repeat" defaultClass="bg-repeat" featuredClass="bg-repeat-x" /> | |
--- | |
File: /src/docs/background-size.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "background-size"; | |
export const description = "Utilities for controlling the background size of an element's background image."; | |
<ApiTable | |
rows={[ | |
["bg-auto", "background-size: auto;"], | |
["bg-cover", "background-size: cover;"], | |
["bg-contain", "background-size: contain;"], | |
["bg-size-(<custom-property>)", "background-size: var(<custom-property>);"], | |
["bg-size-[<value>]", "background-size: <value>;"], | |
]} | |
/> | |
## Examples | |
### Filling the container | |
Use the `bg-cover` utility to scale the background image until it fills the background layer, cropping the image if needed: | |
<Figure> | |
<Example> | |
{ | |
<div className="relative mx-auto flex w-56 items-center justify-center overflow-hidden rounded-lg sm:w-96"> | |
<div className="absolute inset-0"> | |
<Stripes border className="h-full rounded-lg" /> | |
</div> | |
<div className="relative z-10 h-48 w-full bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=512&h=640&q=80)] bg-cover bg-center bg-no-repeat"></div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:bg-cover] --> | |
<div class="bg-[url(/img/mountains.jpg)] bg-cover bg-center"></div> | |
``` | |
</Figure> | |
### Filling without cropping | |
Use the `bg-contain` utility to scale the background image to the outer edges without cropping or stretching: | |
<Figure> | |
<Example> | |
{ | |
<div className="relative mx-auto flex w-56 items-center justify-center overflow-hidden rounded-lg sm:w-96"> | |
<div className="absolute inset-0"> | |
<Stripes border className="h-full rounded-lg" /> | |
</div> | |
<div className="relative z-10 h-48 w-full bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=512&h=640&q=80)] bg-contain bg-center bg-no-repeat sm:bg-top"></div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:bg-contain] --> | |
<div class="bg-[url(/img/mountains.jpg)] bg-contain bg-center"></div> | |
``` | |
</Figure> | |
### Using the default size | |
Use the `bg-auto` utility to display the background image at its default size: | |
<Figure> | |
<Example> | |
{ | |
<div className="relative mx-auto flex h-48 w-56 items-center justify-center overflow-hidden rounded-lg sm:w-96"> | |
<div className="absolute inset-0"> | |
<Stripes border className="h-full rounded-lg" /> | |
</div> | |
<div className="relative z-10 h-full w-full bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=128&h=160&q=80)] bg-auto bg-center bg-no-repeat"></div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:bg-auto] --> | |
<div class="bg-[url(/img/mountains.jpg)] bg-auto bg-center bg-no-repeat"></div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="bg-size" value="auto_100px" name="background size" variable="image-size" /> | |
### Responsive design | |
<ResponsiveDesign property="background-size" defaultClass="bg-auto" featuredClass="bg-contain" /> | |
--- | |
File: /src/docs/border-collapse.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "border-collapse"; | |
export const description = "Utilities for controlling whether table borders should collapse or be separated."; | |
<ApiTable | |
rows={[ | |
["border-collapse", "border-collapse: collapse;"], | |
["border-separate", "border-collapse: separate;"], | |
]} | |
/> | |
## Examples | |
### Collapsing table borders | |
Use the `border-collapse` utility to combine adjacent cell borders into a single border when possible: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="px-4 py-8 sm:px-8"> | |
<table className="w-full border-collapse border border-gray-400 bg-white text-sm dark:border-gray-500 dark:bg-gray-800"> | |
<thead className="bg-gray-50 dark:bg-gray-700"> | |
<tr> | |
<th className="w-1/2 border border-gray-300 p-4 text-left font-semibold text-gray-900 dark:border-gray-600 dark:text-gray-200"> | |
State | |
</th> | |
<th className="w-1/2 border border-gray-300 p-4 text-left font-semibold text-gray-900 dark:border-gray-600 dark:text-gray-200"> | |
City | |
</th> | |
</tr> | |
</thead> | |
<tbody> | |
<tr> | |
<td className="border border-gray-300 p-4 text-gray-500 dark:border-gray-700 dark:text-gray-400"> | |
Indiana | |
</td> | |
<td className="border border-gray-300 p-4 text-gray-500 dark:border-gray-700 dark:text-gray-400"> | |
Indianapolis | |
</td> | |
</tr> | |
<tr> | |
<td className="border border-gray-300 p-4 text-gray-500 dark:border-gray-700 dark:text-gray-400">Ohio</td> | |
<td className="border border-gray-300 p-4 text-gray-500 dark:border-gray-700 dark:text-gray-400"> | |
Columbus | |
</td> | |
</tr> | |
<tr> | |
<td className="border border-gray-300 p-4 text-gray-500 dark:border-gray-700 dark:text-gray-400"> | |
Michigan | |
</td> | |
<td className="border border-gray-300 p-4 text-gray-500 dark:border-gray-700 dark:text-gray-400"> | |
Detroit | |
</td> | |
</tr> | |
</tbody> | |
</table> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:border-collapse] --> | |
<table class="border-collapse border border-gray-400 ..."> | |
<thead> | |
<tr> | |
<th class="border border-gray-300 ...">State</th> | |
<th class="border border-gray-300 ...">City</th> | |
</tr> | |
</thead> | |
<tbody> | |
<tr> | |
<td class="border border-gray-300 ...">Indiana</td> | |
<td class="border border-gray-300 ...">Indianapolis</td> | |
</tr> | |
<tr> | |
<td class="border border-gray-300 ...">Ohio</td> | |
<td class="border border-gray-300 ...">Columbus</td> | |
</tr> | |
<tr> | |
<td class="border border-gray-300 ...">Michigan</td> | |
<td class="border border-gray-300 ...">Detroit</td> | |
</tr> | |
</tbody> | |
</table> | |
``` | |
</Figure> | |
Note that this includes collapsing borders on the top-level `<table>` tag. | |
### Separating table borders | |
Use the `border-separate` utility to force each cell to display its own separate borders: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="px-4 py-8 sm:px-8"> | |
<table className="w-full border-separate border border-gray-400 bg-white text-sm dark:border-gray-500 dark:bg-gray-800"> | |
<thead className="bg-gray-50 dark:bg-gray-700"> | |
<tr> | |
<th className="w-1/2 border border-gray-300 p-4 text-left font-semibold text-gray-900 dark:border-gray-600 dark:text-gray-200"> | |
State | |
</th> | |
<th className="w-1/2 border border-gray-300 p-4 text-left font-semibold text-gray-900 dark:border-gray-600 dark:text-gray-200"> | |
City | |
</th> | |
</tr> | |
</thead> | |
<tbody> | |
<tr> | |
<td className="border border-gray-300 p-4 text-gray-500 dark:border-gray-700 dark:text-gray-400"> | |
Indiana | |
</td> | |
<td className="border border-gray-300 p-4 text-gray-500 dark:border-gray-700 dark:text-gray-400"> | |
Indianapolis | |
</td> | |
</tr> | |
<tr> | |
<td className="border border-gray-300 p-4 text-gray-500 dark:border-gray-700 dark:text-gray-400">Ohio</td> | |
<td className="border border-gray-300 p-4 text-gray-500 dark:border-gray-700 dark:text-gray-400"> | |
Columbus | |
</td> | |
</tr> | |
<tr> | |
<td className="border border-gray-300 p-4 text-gray-500 dark:border-gray-700 dark:text-gray-400"> | |
Michigan | |
</td> | |
<td className="border border-gray-300 p-4 text-gray-500 dark:border-gray-700 dark:text-gray-400"> | |
Detroit | |
</td> | |
</tr> | |
</tbody> | |
</table> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:border-separate] --> | |
<table class="border-separate border border-gray-400 ..."> | |
<thead> | |
<tr> | |
<th class="border border-gray-300 ...">State</th> | |
<th class="border border-gray-300 ...">City</th> | |
</tr> | |
</thead> | |
<tbody> | |
<tr> | |
<td class="border border-gray-300 ...">Indiana</td> | |
<td class="border border-gray-300 ...">Indianapolis</td> | |
</tr> | |
<tr> | |
<td class="border border-gray-300 ...">Ohio</td> | |
<td class="border border-gray-300 ...">Columbus</td> | |
</tr> | |
<tr> | |
<td class="border border-gray-300 ...">Michigan</td> | |
<td class="border border-gray-300 ...">Detroit</td> | |
</tr> | |
</tbody> | |
</table> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign | |
element="table" | |
property="border-collapse" | |
defaultClass="border-collapse" | |
featuredClass="border-separate" | |
/> | |
--- | |
File: /src/docs/border-color.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { | |
CustomizingYourThemeColors, | |
ResponsiveDesign, | |
TargetingSpecificStates, | |
UsingACustomValue, | |
} from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import colors from "./utils/colors"; | |
import dedent from "dedent"; | |
export const title = "border-color"; | |
export const description = "Utilities for controlling the color of an element's borders."; | |
<ApiTable | |
rows={[ | |
...[ | |
["border", (value) => `border-color: ${value}`], | |
["border-x", (value) => `border-inline-color: ${value}`], | |
["border-y", (value) => `border-block-color: ${value}`], | |
["border-s", (value) => `border-inline-start-color: ${value}`], | |
["border-e", (value) => `border-inline-end-color: ${value}`], | |
["border-t", (value) => `border-top-color: ${value}`], | |
["border-r", (value) => `border-right-color: ${value}`], | |
["border-b", (value) => `border-bottom-color: ${value}`], | |
["border-l", (value) => `border-left-color: ${value}`], | |
["divide", (value) => `& > :not(:last-child) {\n border-color: ${value}\n}`], | |
].flatMap(([utility, css]) => [ | |
[`${utility}-inherit`, css("inherit;")], | |
[`${utility}-current`, css("currentColor;")], | |
[`${utility}-transparent`, css("transparent;")], | |
...Object.entries(colors).map(([name, value]) => [ | |
`${utility}-${name}`, | |
css(`var(--color-${name}); /* ${value} */`), | |
]), | |
[`${utility}-(<custom-property>)`, css("var(<custom-property>);")], | |
[`${utility}-[<value>]`, css("<value>;")], | |
]), | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `border-rose-500` and `border-lime-100` to control the border color of an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid gap-4 text-center text-sm leading-6 font-bold text-white lg:grid-cols-3"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
border-indigo-500 | |
</p> | |
<div className="size-16 border-4 border-indigo-500 bg-white p-4 dark:bg-gray-900"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
border-purple-500 | |
</p> | |
<div className="size-16 border-4 border-purple-500 bg-white p-4 dark:bg-gray-900"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
border-sky-500 | |
</p> | |
<div className="size-16 border-4 border-sky-500 bg-white p-4 dark:bg-gray-900"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:border-indigo-500,border-purple-500,border-sky-500] --> | |
<div class="border-4 border-indigo-500 ..."></div> | |
<div class="border-4 border-purple-500 ..."></div> | |
<div class="border-4 border-sky-500 ..."></div> | |
``` | |
</Figure> | |
### Changing the opacity | |
Use the color opacity modifier to control the opacity of an element's border color: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid gap-4 text-center text-sm leading-6 font-bold text-white lg:grid-cols-3"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
border-indigo-500/100 | |
</p> | |
<div className="size-16 border-4 border-indigo-500/100 bg-white p-4 dark:bg-gray-900"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
border-indigo-500/75 | |
</p> | |
<div className="size-16 border-4 border-indigo-500/75 bg-white p-4 dark:bg-gray-900"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
border-indigo-500/50 | |
</p> | |
<div className="size-16 border-4 border-indigo-500/50 bg-white p-4 dark:bg-gray-900"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code word:/100] --> | |
<!-- [!code word:/75] --> | |
<!-- [!code word:/50] --> | |
<div class="border-4 border-indigo-500/100 ..."></div> | |
<div class="border-4 border-indigo-500/75 ..."></div> | |
<div class="border-4 border-indigo-500/50 ..."></div> | |
``` | |
</Figure> | |
### Individual sides | |
Use utilities like `border-t-indigo-500` and `border-r-lime-100` to set the border color for one side of an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1 gap-x-4 gap-y-8 text-center text-sm leading-6 font-bold text-white sm:grid-cols-2"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
border-t-indigo-500 | |
</p> | |
<div className="size-16 border-4 border-indigo-200 border-t-indigo-500 bg-white p-4 ring-1 ring-gray-900/5 dark:border-indigo-600/20 dark:border-t-indigo-500 dark:bg-gray-900"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
border-r-indigo-500 | |
</p> | |
<div className="size-16 border-4 border-indigo-200 border-r-indigo-500 bg-white p-4 ring-1 ring-gray-900/5 dark:border-indigo-600/20 dark:border-r-indigo-500 dark:bg-gray-900"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
border-b-indigo-500 | |
</p> | |
<div className="size-16 border-4 border-indigo-200 border-b-indigo-500 bg-white p-4 ring-1 ring-gray-900/5 dark:border-indigo-600/20 dark:border-b-indigo-500 dark:bg-gray-900"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
border-l-indigo-500 | |
</p> | |
<div className="size-16 border-4 border-indigo-200 border-l-indigo-500 bg-white p-4 ring-1 ring-gray-900/5 dark:border-indigo-600/20 dark:border-l-indigo-500 dark:bg-gray-900"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:border-t-indigo-500,border-r-indigo-500,border-b-indigo-500,border-l-indigo-500] --> | |
<div class="border-4 border-indigo-200 border-t-indigo-500 ..."></div> | |
<div class="border-4 border-indigo-200 border-r-indigo-500 ..."></div> | |
<div class="border-4 border-indigo-200 border-b-indigo-500 ..."></div> | |
<div class="border-4 border-indigo-200 border-l-indigo-500 ..."></div> | |
``` | |
</Figure> | |
### Horizontal and vertical sides | |
Use utilities like `border-x-indigo-500` and `border-y-lime-100` to set the border color on two sides of an element at the same time: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col items-center justify-around gap-4 text-center text-sm leading-6 font-bold text-white sm:flex-row"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
border-x-indigo-500 | |
</p> | |
<div className="size-16 border-4 border-indigo-200 border-x-indigo-500 bg-white p-4 ring-1 ring-gray-900/5 dark:border-indigo-600/20 dark:border-x-indigo-500 dark:bg-gray-900"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
border-y-indigo-500 | |
</p> | |
<div className="size-16 border-4 border-indigo-200 border-y-indigo-500 bg-white p-4 ring-1 ring-gray-900/5 dark:border-indigo-600/20 dark:border-y-indigo-500 dark:bg-gray-900"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:border-x-indigo-500,border-y-indigo-500] --> | |
<div class="border-4 border-indigo-200 border-x-indigo-500 ..."></div> | |
<div class="border-4 border-indigo-200 border-y-indigo-500 ..."></div> | |
``` | |
</Figure> | |
### Using logical properties | |
Use utilities like `border-s-indigo-500` and `border-e-lime-100` to set the `border-inline-start-color` and `border-inline-end-color` [logical properties](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Logical_Properties/Basic_concepts), which map to either the left or right border based on the text direction: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-2 place-items-center gap-x-4"> | |
<div className="flex flex-col items-start gap-y-4" dir="ltr"> | |
<p className="text-sm font-medium">Left-to-right</p> | |
<div className="size-16 border-4 border-indigo-200 border-s-indigo-500 bg-white p-4 ring-1 ring-gray-900/5 dark:border-indigo-600/20 dark:border-s-indigo-500 dark:bg-gray-900"></div> | |
</div> | |
<div className="flex flex-col items-start gap-y-4" dir="rtl"> | |
<p className="text-sm font-medium">Right-to-left</p> | |
<div className="size-16 border-4 border-indigo-200 border-s-indigo-500 bg-white p-4 ring-1 ring-gray-900/5 dark:border-indigo-600/20 dark:border-s-indigo-500 dark:bg-gray-900"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:border-s-indigo-500,border-s-indigo-500] --> | |
<!-- [!code word:dir="ltr"] --> | |
<!-- [!code word:dir="rtl"] --> | |
<div dir="ltr"> | |
<div class="border-s-indigo-500 ..."></div> | |
</div> | |
<div dir="rtl"> | |
<div class="border-s-indigo-500 ..."></div> | |
</div> | |
``` | |
</Figure> | |
### Divider between children | |
Use utilities like `divide-indigo-500` and `divide-lime-100` to control the border color between child elements: | |
<Figure> | |
<Example> | |
{ | |
<div className="mx-auto grid max-w-lg grid-cols-3 divide-x-4 divide-indigo-500 rounded-lg text-center font-mono text-sm leading-6 font-bold text-gray-400"> | |
<div className="p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20">01</div> | |
<div className="p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20">02</div> | |
<div className="p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20">03</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:divide-indigo-500] --> | |
<div class="grid grid-cols-3 divide-x-4 divide-indigo-500"> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="border" name="border color" value="#243c5a" /> | |
### Applying on focus | |
<TargetingSpecificStates property="border-color" variant="focus"> | |
<Figure> | |
<Example> | |
{ | |
<label className="mx-auto block max-w-xs"> | |
<span className="text-sm font-medium text-gray-900 dark:text-gray-200">Email address</span> | |
<input | |
type="text" | |
placeholder="[email protected]" | |
className="block w-full rounded-lg border-2 border-gray-700 px-3 py-2 font-sans text-sm leading-5 text-gray-500 focus:border-pink-600 focus:outline-none dark:bg-gray-900 dark:text-gray-400 dark:placeholder:text-gray-600" | |
/> | |
</label> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:focus:border-pink-600] --> | |
<input class="border-2 border-gray-700 focus:border-pink-600 ..." /> | |
``` | |
</Figure> | |
</TargetingSpecificStates> | |
### Responsive design | |
<ResponsiveDesign property="border-color" defaultClass="border-blue-500" featuredClass="border-green-500" /> | |
## Customizing your theme | |
<CustomizingYourThemeColors utility="border" /> | |
--- | |
File: /src/docs/border-radius.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourTheme, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
export const title = "border-radius"; | |
export const description = "Utilities for controlling the border radius of an element."; | |
<ApiTable | |
rows={[ | |
["rounded", ["border-radius"]], | |
["rounded-s", ["border-start-start-radius", "border-end-start-radius"]], | |
["rounded-e", ["border-start-end-radius", "border-end-end-radius"]], | |
["rounded-t", ["border-top-left-radius", "border-top-right-radius"]], | |
["rounded-r", ["border-top-right-radius", "border-bottom-right-radius"]], | |
["rounded-b", ["border-bottom-right-radius", "border-bottom-left-radius"]], | |
["rounded-l", ["border-top-left-radius", "border-bottom-left-radius"]], | |
["rounded-ss", ["border-start-start-radius"]], | |
["rounded-se", ["border-start-end-radius"]], | |
["rounded-ee", ["border-end-end-radius"]], | |
["rounded-es", ["border-end-start-radius"]], | |
["rounded-tl", ["border-top-left-radius"]], | |
["rounded-tr", ["border-top-right-radius"]], | |
["rounded-br", ["border-bottom-right-radius"]], | |
["rounded-bl", ["border-bottom-left-radius"]], | |
].flatMap(([className, properties]) => [ | |
[`${className}-xs`, properties.map((property) => `${property}: var(--radius-xs); /* 0.125rem (2px) */`).join("\n")], | |
[`${className}-sm`, properties.map((property) => `${property}: var(--radius-sm); /* 0.25rem (4px) */`).join("\n")], | |
[`${className}-md`, properties.map((property) => `${property}: var(--radius-md); /* 0.375rem (6px) */`).join("\n")], | |
[`${className}-lg`, properties.map((property) => `${property}: var(--radius-lg); /* 0.5rem (8px) */`).join("\n")], | |
[`${className}-xl`, properties.map((property) => `${property}: var(--radius-xl); /* 0.75rem (12px) */`).join("\n")], | |
[`${className}-2xl`, properties.map((property) => `${property}: var(--radius-2xl); /* 1rem (16px) */`).join("\n")], | |
[ | |
`${className}-3xl`, | |
properties.map((property) => `${property}: var(--radius-3xl); /* 1.5rem (24px) */`).join("\n"), | |
], | |
[`${className}-4xl`, properties.map((property) => `${property}: var(--radius-4xl); /* 2rem (32px) */`).join("\n")], | |
[`${className}-none`, properties.map((property) => `${property}: 0;`).join("\n")], | |
[`${className}-full`, properties.map((property) => `${property}: calc(infinity * 1px);`).join("\n")], | |
[ | |
`${className}-(<custom-property>)`, | |
properties.map((property) => `${property}: var(<custom-property>);`).join("\n"), | |
], | |
[`${className}-[<value>]`, properties.map((property) => `${property}: <value>;`).join("\n")], | |
])} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `rounded-sm` and `rounded-md` to apply different border radius sizes to an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col items-center justify-around gap-4 text-center text-sm leading-6 font-bold text-white sm:flex-row"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">rounded-sm</p> | |
<div className="size-16 rounded-sm bg-purple-500 p-4"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">rounded-md</p> | |
<div className="size-16 rounded-md bg-purple-500 p-4"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">rounded-lg</p> | |
<div className="size-16 rounded-lg bg-purple-500 p-4"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">rounded-xl</p> | |
<div className="size-16 rounded-xl bg-purple-500 p-4"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:rounded-sm,rounded-md,rounded-lg,rounded-xl] --> | |
<div class="rounded-sm ..."></div> | |
<div class="rounded-md ..."></div> | |
<div class="rounded-lg ..."></div> | |
<div class="rounded-xl ..."></div> | |
``` | |
</Figure> | |
### Rounding sides separately | |
Use utilities like `rounded-t-md` and `rounded-r-lg` to only round one side of an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col items-center justify-around gap-4 text-center text-sm leading-6 font-bold text-white sm:flex-row"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">rounded-t-lg</p> | |
<div className="size-16 rounded-t-lg bg-blue-500 p-4"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">rounded-r-lg</p> | |
<div className="size-16 rounded-r-lg bg-blue-500 p-4"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">rounded-b-lg</p> | |
<div className="size-16 rounded-b-lg bg-blue-500 p-4"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">rounded-l-lg</p> | |
<div className="size-16 rounded-l-lg bg-blue-500 p-4"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:rounded-t-lg,rounded-r-lg,rounded-b-lg,rounded-l-lg] --> | |
<div class="rounded-t-lg ..."></div> | |
<div class="rounded-r-lg ..."></div> | |
<div class="rounded-b-lg ..."></div> | |
<div class="rounded-l-lg ..."></div> | |
``` | |
</Figure> | |
### Rounding corners separately | |
Use utilities like `rounded-tr-md` and `rounded-tl-lg` utilities to only round one corner of an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col items-center justify-around gap-4 text-center text-sm leading-6 font-bold text-white sm:flex-row"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">rounded-tl-lg</p> | |
<div className="size-16 rounded-tl-lg bg-pink-500 p-4"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">rounded-tr-lg</p> | |
<div className="size-16 rounded-tr-lg bg-pink-500 p-4"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">rounded-br-lg</p> | |
<div className="size-16 rounded-br-lg bg-pink-500 p-4"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">rounded-bl-lg</p> | |
<div className="size-16 rounded-bl-lg bg-pink-500 p-4"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:rounded-tl-lg,rounded-tr-lg,rounded-br-lg,rounded-bl-lg] --> | |
<div class="rounded-tl-lg ..."></div> | |
<div class="rounded-tr-lg ..."></div> | |
<div class="rounded-br-lg ..."></div> | |
<div class="rounded-bl-lg ..."></div> | |
``` | |
</Figure> | |
### Using logical properties | |
Use utilities like `rounded-s-md` and `rounded-se-xl` to set the border radius using [logical properties](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Logical_Properties/Basic_concepts), which map to the appropriate corners based on the text direction: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-2 place-items-center gap-x-4"> | |
<div className="flex flex-col items-start gap-y-4" dir="ltr"> | |
<p className="text-sm font-medium">Left-to-right</p> | |
<div className="size-16 rounded-s-lg bg-blue-500 p-4"></div> | |
</div> | |
<div className="flex flex-col items-start gap-y-4" dir="rtl"> | |
<p className="text-sm font-medium">Right-to-left</p> | |
<div className="size-16 rounded-s-lg bg-blue-500 p-4"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:rounded-s-lg] --> | |
<!-- [!code word:dir="ltr"] --> | |
<!-- [!code word:dir="rtl"] --> | |
<div dir="ltr"> | |
<div class="rounded-s-lg ..."></div> | |
</div> | |
<div dir="rtl"> | |
<div class="rounded-s-lg ..."></div> | |
</div> | |
``` | |
</Figure> | |
Here are all the available border radius logical property utilities and their physical property equivalents in both LTR and RTL modes. | |
{ | |
<table> | |
<thead> | |
<tr> | |
<th>Class</th> | |
<th>Left-to-right</th> | |
<th>Right-to-left</th> | |
</tr> | |
</thead> | |
<tbody> | |
<tr> | |
<td> | |
<code>rounded-s-*</code> | |
</td> | |
<td> | |
<code>rounded-l-*</code> | |
</td> | |
<td> | |
<code>rounded-r-*</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code>rounded-e-*</code> | |
</td> | |
<td> | |
<code>rounded-r-*</code> | |
</td> | |
<td> | |
<code>rounded-l-*</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code>rounded-ss-*</code> | |
</td> | |
<td> | |
<code>rounded-tl-*</code> | |
</td> | |
<td> | |
<code>rounded-tr-*</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code>rounded-se-*</code> | |
</td> | |
<td> | |
<code>rounded-tr-*</code> | |
</td> | |
<td> | |
<code>rounded-tl-*</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code>rounded-es-*</code> | |
</td> | |
<td> | |
<code>rounded-bl-*</code> | |
</td> | |
<td> | |
<code>rounded-br-*</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code>rounded-ee-*</code> | |
</td> | |
<td> | |
<code>rounded-br-*</code> | |
</td> | |
<td> | |
<code>rounded-bl-*</code> | |
</td> | |
</tr> | |
</tbody> | |
</table> | |
} | |
For more control, you can also use the [LTR and RTL modifiers](/docs/hover-focus-and-other-states#rtl-support) to conditionally apply specific styles depending on the current text direction. | |
### Creating pill buttons | |
Use the `rounded-full` utility to create pill buttons: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex justify-center gap-4 text-center text-sm leading-6 font-bold text-white"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">rounded-full</p> | |
<button className="rounded-full bg-cyan-500 px-4 py-2 text-sm font-semibold text-white">Save Changes</button> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:rounded-full] --> | |
<button class="rounded-full ...">Save Changes</button> | |
``` | |
</Figure> | |
### Removing the border radius | |
Use the `rounded-none` utility to remove an existing border radius from an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex justify-center gap-4 text-center text-sm leading-6 font-bold text-white"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">rounded-none</p> | |
<button className="rounded-none bg-sky-500 px-4 py-2 text-sm font-semibold text-white">Save Changes</button> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:rounded-none] --> | |
<button class="rounded-none ...">Save Changes</button> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="rounded" name="border radius" value="2vw" variable="radius" /> | |
### Responsive design | |
<ResponsiveDesign property="border-radius" defaultClass="rounded" featuredClass="rounded-lg" /> | |
## Customizing your theme | |
<CustomizingYourTheme utility="rounded" themeKey="radius" name="border radius" customName="5xl" customValue="3rem" /> | |
--- | |
File: /src/docs/border-spacing.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourSpacingScale, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
export const title = "border-spacing"; | |
export const description = "Utilities for controlling the spacing between table borders."; | |
<ApiTable | |
rows={[ | |
["border-spacing-<number>", "border-spacing: calc(var(--spacing) * <number>);"], | |
["border-spacing-(<custom-property>)", "border-spacing: var(<custom-property>);"], | |
["border-spacing-[<value>]", "border-spacing: <value>;"], | |
["border-spacing-x-<number>", "border-spacing: calc(var(--spacing) * <number>) var(--tw-border-spacing-y);"], | |
["border-spacing-x-(<custom-property>)", "border-spacing: var(<custom-property>) var(--tw-border-spacing-y);"], | |
["border-spacing-x-[<value>]", "border-spacing: <value> var(--tw-border-spacing-y);"], | |
["border-spacing-y-<number>", "border-spacing: var(--tw-border-spacing-x) calc(var(--spacing) * <number>);"], | |
["border-spacing-y-(<custom-property>)", "border-spacing: var(--tw-border-spacing-x) var(<custom-property>);"], | |
["border-spacing-y-[<value>]", "border-spacing: var(--tw-border-spacing-x) <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use `border-spacing-<number>` utilities like `border-spacing-2` and `border-spacing-x-3` to control the space between the borders of table cells with [separate borders](/docs/border-collapse#separating-table-borders): | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="px-4 py-8 sm:px-8"> | |
<table className="w-full border-separate border-spacing-2 border border-gray-400 bg-white text-sm dark:border-gray-500 dark:bg-gray-800"> | |
<thead className="bg-gray-50 dark:bg-gray-700"> | |
<tr> | |
<th className="w-1/2 border border-gray-300 p-4 text-left font-semibold text-gray-900 dark:border-gray-600 dark:text-gray-200"> | |
State | |
</th> | |
<th className="w-1/2 border border-gray-300 p-4 text-left font-semibold text-gray-900 dark:border-gray-600 dark:text-gray-200"> | |
City | |
</th> | |
</tr> | |
</thead> | |
<tbody> | |
<tr> | |
<td className="border border-gray-300 p-4 text-gray-500 dark:border-gray-700 dark:text-gray-400"> | |
Indiana | |
</td> | |
<td className="border border-gray-300 p-4 text-gray-500 dark:border-gray-700 dark:text-gray-400"> | |
Indianapolis | |
</td> | |
</tr> | |
<tr> | |
<td className="border border-gray-300 p-4 text-gray-500 dark:border-gray-700 dark:text-gray-400">Ohio</td> | |
<td className="border border-gray-300 p-4 text-gray-500 dark:border-gray-700 dark:text-gray-400"> | |
Columbus | |
</td> | |
</tr> | |
<tr> | |
<td className="border border-gray-300 p-4 text-gray-500 dark:border-gray-700 dark:text-gray-400"> | |
Michigan | |
</td> | |
<td className="border border-gray-300 p-4 text-gray-500 dark:border-gray-700 dark:text-gray-400"> | |
Detroit | |
</td> | |
</tr> | |
</tbody> | |
</table> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:border-spacing-2] --> | |
<table class="border-separate border-spacing-2 border border-gray-400 dark:border-gray-500"> | |
<thead> | |
<tr> | |
<th class="border border-gray-300 dark:border-gray-600">State</th> | |
<th class="border border-gray-300 dark:border-gray-600">City</th> | |
</tr> | |
</thead> | |
<tbody> | |
<tr> | |
<td class="border border-gray-300 dark:border-gray-700">Indiana</td> | |
<td class="border border-gray-300 dark:border-gray-700">Indianapolis</td> | |
</tr> | |
<tr> | |
<td class="border border-gray-300 dark:border-gray-700">Ohio</td> | |
<td class="border border-gray-300 dark:border-gray-700">Columbus</td> | |
</tr> | |
<tr> | |
<td class="border border-gray-300 dark:border-gray-700">Michigan</td> | |
<td class="border border-gray-300 dark:border-gray-700">Detroit</td> | |
</tr> | |
</tbody> | |
</table> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue element="table" utility="border-spacing" value="7px" name="border spacing" /> | |
### Responsive design | |
<ResponsiveDesign | |
element="table" | |
property="border-spacing" | |
defaultClass="border-spacing-2" | |
featuredClass="border-spacing-4" | |
/> | |
## Customizing your theme | |
<CustomizingYourSpacingScale utility="border-spacing" /> | |
--- | |
File: /src/docs/border-style.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "border-style"; | |
export const description = "Utilities for controlling the style of an element's borders."; | |
<ApiTable | |
rows={[ | |
["border-solid", "border-style: solid;"], | |
["border-dashed", "border-style: dashed;"], | |
["border-dotted", "border-style: dotted;"], | |
["border-double", "border-style: double;"], | |
["border-hidden", "border-style: hidden;"], | |
["border-none", "border-style: none;"], | |
["divide-solid", "& > :not(:last-child) {\n border-style: solid;\n}"], | |
["divide-dashed", "& > :not(:last-child) {\n border-style: dashed;\n}"], | |
["divide-dotted", "& > :not(:last-child) {\n border-style: dotted;\n}"], | |
["divide-double", "& > :not(:last-child) {\n border-style: double;\n}"], | |
["divide-hidden", "& > :not(:last-child) {\n border-style: hidden;\n}"], | |
["divide-none", "& > :not(:last-child) {\n border-style: none;\n}"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `border-solid` and `border-dotted` to control an element's border style: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1 gap-x-4 gap-y-8 text-center text-sm leading-6 font-bold text-white sm:grid-cols-2"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">border-solid</p> | |
<button className="rounded-md border-2 border-solid border-indigo-500 bg-white px-4 py-2 text-sm font-semibold text-gray-700 dark:border-sky-500 dark:bg-gray-700 dark:text-white"> | |
Button A | |
</button> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">border-dashed</p> | |
<button className="rounded-md border-2 border-dashed border-indigo-500 bg-white px-4 py-2 text-sm font-semibold text-gray-700 dark:border-sky-500 dark:bg-gray-700 dark:text-white"> | |
Button A | |
</button> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">border-dotted</p> | |
<button className="rounded-md border-2 border-dotted border-indigo-500 bg-white px-4 py-2 text-sm font-semibold text-gray-700 dark:border-sky-500 dark:bg-gray-700 dark:text-white"> | |
Button A | |
</button> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">border-double</p> | |
<button className="rounded-md border-4 border-double border-indigo-500 bg-white px-4 py-2 text-sm font-semibold text-gray-700 dark:border-sky-500 dark:bg-gray-700 dark:text-white"> | |
Button A | |
</button> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:border-solid,border-dashed,border-dotted,border-double] --> | |
<div class="border-2 border-solid ..."></div> | |
<div class="border-2 border-dashed ..."></div> | |
<div class="border-2 border-dotted ..."></div> | |
<div class="border-4 border-double ..."></div> | |
``` | |
</Figure> | |
### Removing a border | |
Use the `border-none` utility to remove an existing border from an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex justify-center gap-4 text-center text-sm leading-6 font-bold text-white"> | |
<button className="rounded-md border-2 border-none border-indigo-500 bg-gray-100 px-4 py-2 text-sm font-semibold text-gray-700 dark:bg-gray-700 dark:text-white"> | |
Save Changes | |
</button> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:border-none] --> | |
<button class="border-none ...">Save Changes</button> | |
``` | |
</Figure> | |
This is most commonly used to remove a border style that was applied at a smaller breakpoint. | |
### Setting the divider style | |
Use utilities like `divide-dashed` and `divide-dotted` to control the border style between child elements: | |
<Figure> | |
<Example> | |
{ | |
<div className="mx-auto grid max-w-lg grid-cols-3 divide-x-3 divide-dashed divide-indigo-500 rounded-lg text-center font-mono text-sm leading-6 font-bold text-gray-400"> | |
<div className="p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20">01</div> | |
<div className="p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20">02</div> | |
<div className="p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20">03</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:divide-dashed] --> | |
<div class="grid grid-cols-3 divide-x-3 divide-dashed divide-indigo-500"> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="border-style" defaultClass="border-solid" featuredClass="border-dotted" /> | |
--- | |
File: /src/docs/border-width.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import dedent from "dedent"; | |
export const title = "border-width"; | |
export const description = "Utilities for controlling the width of an element's borders."; | |
<ApiTable | |
rows={[ | |
["border", "border-width: 1px;"], | |
["border-<number>", "border-width: <number>px;"], | |
["border-(length:<custom-property>)", "border-width: var(<custom-property>);"], | |
["border-[<value>]", "border-width: <value>;"], | |
["border-x", "border-inline-width: 1px;"], | |
["border-x-<number>", "border-inline-width: <number>px;"], | |
["border-x-(length:<custom-property>)", "border-inline-width: var(<custom-property>);"], | |
["border-x-[<value>]", "border-inline-width: <value>;"], | |
["border-y", "border-block-width: 1px;"], | |
["border-y-<number>", "border-block-width: <number>px;"], | |
["border-y-(length:<custom-property>)", "border-block-width: var(<custom-property>);"], | |
["border-y-[<value>]", "border-block-width: <value>;"], | |
["border-s", "border-inline-start-width: 1px;"], | |
["border-s-<number>", "border-inline-start-width: <number>px;"], | |
["border-s-(length:<custom-property>)", "border-inline-start-width: var(<custom-property>);"], | |
["border-s-[<value>]", "border-inline-start-width: <value>;"], | |
["border-e", "border-inline-end-width: 1px;"], | |
["border-e-<number>", "border-inline-end-width: <number>px;"], | |
["border-e-(length:<custom-property>)", "border-inline-end-width: var(<custom-property>);"], | |
["border-e-[<value>]", "border-inline-end-width: <value>;"], | |
["border-t", "border-top-width: 1px;"], | |
["border-t-<number>", "border-top-width: <number>px;"], | |
["border-t-(length:<custom-property>)", "border-top-width: var(<custom-property>);"], | |
["border-t-[<value>]", "border-top-width: <value>;"], | |
["border-r", "border-right-width: 1px;"], | |
["border-r-<number>", "border-right-width: <number>px;"], | |
["border-r-(length:<custom-property>)", "border-right-width: var(<custom-property>);"], | |
["border-r-[<value>]", "border-right-width: <value>;"], | |
["border-b", "border-bottom-width: 1px;"], | |
["border-b-<number>", "border-bottom-width: <number>px;"], | |
["border-b-(length:<custom-property>)", "border-bottom-width: var(<custom-property>);"], | |
["border-b-[<value>]", "border-bottom-width: <value>;"], | |
["border-l", "border-left-width: 1px;"], | |
["border-l-<number>", "border-left-width: <number>px;"], | |
["border-l-(length:<custom-property>)", "border-left-width: var(<custom-property>);"], | |
["border-l-[<value>]", "border-left-width: <value>;"], | |
[ | |
"divide-x", | |
dedent` | |
& > :not(:last-child) { | |
border-inline-start-width: 0px; | |
border-inline-end-width: 1px; | |
} | |
`, | |
], | |
[ | |
"divide-x-<number>", | |
dedent` | |
& > :not(:last-child) { | |
border-inline-start-width: 0px; | |
border-inline-end-width: <number>px; | |
} | |
`, | |
], | |
[ | |
"divide-x-(length:<custom-property>)", | |
dedent` | |
& > :not(:last-child) { | |
border-inline-start-width: 0px; | |
border-inline-end-width: var(<custom-property>); | |
} | |
`, | |
], | |
[ | |
"divide-x-[<value>]", | |
dedent` | |
& > :not(:last-child) { | |
border-inline-start-width: 0px; | |
border-inline-end-width: <value>; | |
} | |
`, | |
], | |
[ | |
"divide-y", | |
dedent` | |
& > :not(:last-child) { | |
border-top-width: 0px; | |
border-bottom-width: 1px; | |
} | |
`, | |
], | |
[ | |
"divide-y-<number>", | |
dedent` | |
& > :not(:last-child) { | |
border-top-width: 0px; | |
border-bottom-width: <number>px; | |
} | |
`, | |
], | |
[ | |
"divide-y-(length:<custom-property>)", | |
dedent` | |
& > :not(:last-child) { | |
border-top-width: 0px; | |
border-bottom-width: var(<custom-property>); | |
} | |
`, | |
], | |
[ | |
"divide-y-[<value>]", | |
dedent` | |
& > :not(:last-child) { | |
border-top-width: 0px; | |
border-bottom-width: <value>; | |
} | |
`, | |
], | |
["divide-x-reverse", "--tw-divide-x-reverse: 1;"], | |
["divide-y-reverse", "--tw-divide-y-reverse: 1;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use `border` or `border-<number>` utilities like `border-2` and `border-4` to set the border width for all sides of an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col items-center justify-around gap-4 text-center text-sm leading-6 font-bold text-white sm:flex-row"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">border</p> | |
<div className="size-16 border border-indigo-600 p-4"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">border-2</p> | |
<div className="size-16 border-2 border-indigo-600 p-4"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">border-4</p> | |
<div className="size-16 border-4 border-indigo-600 p-4"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">border-8</p> | |
<div className="size-16 border-8 border-indigo-600 p-4"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:border,border-2,border-4,border-8] --> | |
<div class="border border-indigo-600 ..."></div> | |
<div class="border-2 border-indigo-600 ..."></div> | |
<div class="border-4 border-indigo-600 ..."></div> | |
<div class="border-8 border-indigo-600 ..."></div> | |
``` | |
</Figure> | |
### Individual sides | |
Use utilities like `border-r` and `border-t-4` to set the border width for one side of an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col items-center justify-around gap-4 text-center text-sm leading-6 font-bold text-white sm:flex-row"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">border-t-4</p> | |
<div className="size-16 border-t-4 border-indigo-500 p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">border-r-4</p> | |
<div className="size-16 border-r-4 border-indigo-500 p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">border-b-4</p> | |
<div className="size-16 border-b-4 border-indigo-500 p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">border-l-4</p> | |
<div className="size-16 border-l-4 border-indigo-500 p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:border-t-4,border-r-4,border-b-4,border-l-4] --> | |
<div class="border-t-4 border-indigo-500 ..."></div> | |
<div class="border-r-4 border-indigo-500 ..."></div> | |
<div class="border-b-4 border-indigo-500 ..."></div> | |
<div class="border-l-4 border-indigo-500 ..."></div> | |
``` | |
</Figure> | |
### Horizontal and vertical sides | |
Use utilities like `border-x` and `border-y-4` to set the border width on two sides of an element at the same time: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col items-center justify-around gap-4 text-center text-sm leading-6 font-bold text-white sm:flex-row"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">border-x-4</p> | |
<div className="size-16 border-x-4 border-indigo-500 p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">border-y-4</p> | |
<div className="size-16 border-y-4 border-indigo-500 p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:border-x-4,border-y-4] --> | |
<div class="border-x-4 border-indigo-500 ..."></div> | |
<div class="border-y-4 border-indigo-500 ..."></div> | |
``` | |
</Figure> | |
### Using logical properties | |
Use utilities like `border-s` and `border-e-4` to set the `border-inline-start-width` and `border-inline-end-width` [logical properties](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Logical_Properties/Basic_concepts), which map to either the left or right border based on the text direction: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-2 place-items-center gap-x-4"> | |
<div className="flex flex-col items-start gap-y-4" dir="ltr"> | |
<p className="text-sm font-medium">Left-to-right</p> | |
<div className="size-16 border-s-4 border-indigo-500 p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20"></div> | |
</div> | |
<div className="flex flex-col items-start gap-y-4" dir="rtl"> | |
<p className="text-sm font-medium">Right-to-left</p> | |
<div className="size-16 border-s-4 border-indigo-500 p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code word:dir="ltr"] --> | |
<!-- [!code word:dir="rtl"] --> | |
<!-- [!code classes:border-s-4] --> | |
<div dir="ltr"> | |
<div class="border-s-4 ..."></div> | |
</div> | |
<div dir="rtl"> | |
<div class="border-s-4 ..."></div> | |
</div> | |
``` | |
</Figure> | |
### Between children | |
Use utilities like `divide-x` and `divide-y-4` to add borders between child elements: | |
<Figure> | |
<Example> | |
{ | |
<div className="mx-auto grid max-w-lg grid-cols-3 divide-x-4 divide-indigo-500 rounded-lg text-center font-mono text-sm leading-6 font-bold text-gray-400"> | |
<div className="p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20">01</div> | |
<div className="p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20">02</div> | |
<div className="p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20">03</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:divide-x-4] --> | |
<div class="grid grid-cols-3 divide-x-4"> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
#### Reversing children order | |
If your elements are in reverse order (using say `flex-row-reverse` or `flex-col-reverse`), use the `divide-x-reverse` or `divide-y-reverse` utilities to ensure the border is added to the correct side of each element: | |
<Figure> | |
<Example> | |
{ | |
<div className="mx-auto flex max-w-sm flex-col-reverse divide-y-4 divide-y-reverse divide-indigo-500 rounded-lg text-center font-mono text-sm leading-6 font-bold text-gray-400"> | |
<div className="p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20">01</div> | |
<div className="p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20">02</div> | |
<div className="p-4 outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed dark:outline-white/20">03</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:flex-col-reverse,divide-y-4,divide-y-reverse] --> | |
<div class="flex flex-col-reverse divide-y-4 divide-y-reverse divide-gray-200"> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="border" name="border width" value="2vw" dataType="length" variable="border-width" /> | |
### Responsive design | |
<ResponsiveDesign property="border-width" defaultClass="border-2" featuredClass="border-t-4" /> | |
--- | |
File: /src/docs/box-decoration-break.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "box-decoration-break"; | |
export const description = | |
"Utilities for controlling how element fragments should be rendered across multiple lines, columns, or pages."; | |
<ApiTable | |
rows={[ | |
["box-decoration-clone", "box-decoration-break: clone"], | |
["box-decoration-slice", "box-decoration-break: slice"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use the `box-decoration-slice` and `box-decoration-clone` utilities to control whether properties like background, border, border-image, box-shadow, clip-path, margin, and padding should be rendered as if the element were one continuous fragment, or distinct blocks: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1 gap-10 px-10 font-mono font-bold sm:grid-cols-2"> | |
<div className="flex flex-col"> | |
<p className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">box-decoration-slice</p> | |
<div className="font-sans text-5xl leading-none font-extrabold tracking-tight"> | |
<span className="bg-linear-to-r from-indigo-600 to-pink-500 box-decoration-slice px-2 leading-[3.5rem] text-white"> | |
Hello | |
<br /> | |
World | |
</span> | |
</div> | |
</div> | |
<div className="flex flex-col"> | |
<p className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">box-decoration-clone</p> | |
<div className="font-sans text-5xl leading-none font-extrabold tracking-tight"> | |
<span className="bg-linear-to-r from-indigo-600 to-pink-500 box-decoration-clone px-2 leading-[3.5rem] text-white"> | |
Hello | |
<br /> | |
World | |
</span> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:box-decoration-slice,box-decoration-clone] --> | |
<span class="box-decoration-slice bg-linear-to-r from-indigo-600 to-pink-500 px-2 text-white ..."> | |
Hello<br />World | |
</span> | |
<span class="box-decoration-clone bg-linear-to-r from-indigo-600 to-pink-500 px-2 text-white ..."> | |
Hello<br />World | |
</span> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign | |
property="box-decoration-break" | |
defaultClass="box-decoration-clone" | |
featuredClass="box-decoration-slice" | |
/> | |
--- | |
File: /src/docs/box-shadow.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { | |
CustomizingYourTheme, | |
CustomizingYourThemeColors, | |
ResponsiveDesign, | |
UsingACustomValue, | |
} from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import colors from "./utils/colors"; | |
export const title = "box-shadow"; | |
export const description = "Utilities for controlling the box shadow of an element."; | |
<ApiTable | |
rows={[ | |
// Shadows | |
["shadow-2xs", "box-shadow: var(--shadow-2xs); /* 0 1px rgb(0 0 0 / 0.05) */"], | |
["shadow-xs", "box-shadow: var(--shadow-xs); /* 0 1px 2px 0 rgb(0 0 0 / 0.05) */"], | |
["shadow-sm", "box-shadow: var(--shadow-sm); /* 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1) */"], | |
[ | |
"shadow-md", | |
"box-shadow: var(--shadow-md); /* 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1) */", | |
], | |
[ | |
"shadow-lg", | |
"box-shadow: var(--shadow-lg); /* 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1) */", | |
], | |
[ | |
"shadow-xl", | |
"box-shadow: var(--shadow-xl); /* 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1) */", | |
], | |
["shadow-2xl", "box-shadow: var(--shadow-2xl); /* 0 25px 50px -12px rgb(0 0 0 / 0.25) */"], | |
["shadow-none", "box-shadow: 0 0 #0000;"], | |
["shadow-(<custom-property>)", "box-shadow: var(<custom-property>);"], | |
["shadow-(color:<custom-property>)", "--tw-shadow-color: var(<custom-property>);"], | |
["shadow-[<value>]", "box-shadow: <value>;"], | |
// Shadow colors | |
["shadow-inherit", "--tw-shadow-color: inherit;"], | |
["shadow-current", "--tw-shadow-color: currentColor;"], | |
["shadow-transparent", "--tw-shadow-color: transparent;"], | |
...Object.entries(colors).map(([name, value]) => [ | |
`shadow-${name}`, | |
`--tw-shadow-color: var(--color-${name}); /* ${value} */`, | |
]), | |
// Inset shadows | |
["inset-shadow-2xs", "box-shadow: var(--inset-shadow-2xs); /* inset 0 1px rgb(0 0 0 / 0.05) */"], | |
["inset-shadow-xs", "box-shadow: var(--inset-shadow-xs); /* inset 0 1px 1px rgb(0 0 0 / 0.05) */"], | |
["inset-shadow-sm", "box-shadow: var(--inset-shadow-sm); /* inset 0 2px 4px rgb(0 0 0 / 0.05) */"], | |
["inset-shadow-none", "box-shadow: inset 0 0 #0000;"], | |
["inset-shadow-(<custom-property>)", "box-shadow: var(<custom-property>);"], | |
["inset-shadow-[<value>]", "box-shadow: <value>;"], | |
// Inset shadow colors | |
["inset-shadow-inherit", "--tw-inset-shadow-color: inherit;"], | |
["inset-shadow-current", "--tw-inset-shadow-color: currentColor;"], | |
["inset-shadow-transparent", "--tw-inset-shadow-color: transparent;"], | |
...Object.entries(colors).map(([name, value]) => [ | |
`inset-shadow-${name}`, | |
`--tw-inset-shadow-color: var(--color-${name}); /* ${value} */`, | |
]), | |
// Rings | |
["ring", "--tw-ring-shadow: 0 0 0 1px;"], | |
["ring-<number>", "--tw-ring-shadow: 0 0 0 <number>px;"], | |
["ring-(<custom-property>)", "--tw-ring-shadow: 0 0 0 var(<custom-property>);"], | |
["ring-[<value>]", "--tw-ring-shadow: 0 0 0 <value>;"], | |
// Ring colors | |
["ring-inherit", "--tw-ring-color: inherit;"], | |
["ring-current", "--tw-ring-color: currentColor;"], | |
["ring-transparent", "--tw-ring-color: transparent;"], | |
...Object.entries(colors).map(([name, value]) => [ | |
`ring-${name}`, | |
`--tw-ring-color: var(--color-${name}); /* ${value} */`, | |
]), | |
// Inset rings | |
["inset-ring", "--tw-inset-ring-shadow: inset 0 0 0 1px"], | |
["inset-ring-<number>", "--tw-inset-ring-shadow: inset 0 0 0 <number>px"], | |
["inset-ring-(<custom-property>)", "--tw-inset-ring-shadow: inset 0 0 0 var(<custom-property>);"], | |
["inset-ring-[<value>]", "--tw-inset-ring-shadow: inset 0 0 0 <value>;"], | |
// Inset ring colors | |
["inset-ring-inherit", "--tw-inset-ring-color: inherit;"], | |
["inset-ring-current", "--tw-inset-ring-color: currentColor;"], | |
["inset-ring-transparent", "--tw-inset-ring-color: transparent;"], | |
...Object.entries(colors).map(([name, value]) => [ | |
`inset-ring-${name}`, | |
`--tw-inset-ring-color: var(--color-${name}); /* ${value} */`, | |
]), | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `shadow-sm` and `shadow-lg` to apply different sized outer box shadows to an element: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex items-center justify-around gap-4 gap-y-6 bg-white px-6 py-14 font-mono font-bold max-sm:flex-col max-sm:py-10"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">shadow-md</p> | |
<div className="size-24 rounded-lg bg-white shadow-md"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">shadow-lg</p> | |
<div className="size-24 rounded-lg bg-white shadow-lg"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">shadow-xl</p> | |
<div className="size-24 rounded-lg bg-white shadow-xl"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:shadow-md,shadow-lg,shadow-xl] --> | |
<div class="shadow-md ..."></div> | |
<div class="shadow-lg ..."></div> | |
<div class="shadow-xl ..."></div> | |
``` | |
</Figure> | |
### Changing the opacity | |
Use the opacity modifier to adjust the opacity of the box shadow: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex items-center justify-around gap-4 gap-y-6 bg-white px-6 py-14 font-mono font-bold max-sm:flex-col max-sm:py-10"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">shadow-xl</p> | |
<div className="size-24 rounded-lg bg-white shadow-xl"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">shadow-xl/20</p> | |
<div className="size-24 rounded-lg bg-white shadow-xl/20"></div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">shadow-xl/30</p> | |
<div className="size-24 rounded-lg bg-white shadow-xl/30"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:shadow-xl,shadow-xl/20,shadow-xl/30] --> | |
<div class="shadow-xl ..."></div> | |
<div class="shadow-xl/20 ..."></div> | |
<div class="shadow-xl/30 ..."></div> | |
``` | |
</Figure> | |
The default box shadow opacities are quite low (25% or less), so increasing the opacity (to like 50%) will make the box shadows more pronounced. | |
### Setting the shadow color | |
Use utilities like `shadow-indigo-500` and `shadow-cyan-500/50` to change the color of a box shadow: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col justify-center gap-8 py-6 sm:flex-row sm:gap-12"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
shadow-cyan-500/50 | |
</p> | |
<button className="rounded-md bg-cyan-500 px-3 py-2 text-sm font-semibold text-white shadow-lg shadow-cyan-500/50 focus:outline-none"> | |
Subscribe | |
</button> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
shadow-blue-500/50 | |
</p> | |
<button className="rounded-md bg-blue-500 px-3 py-2 text-sm font-semibold text-white shadow-lg shadow-blue-500/50 focus:outline-none"> | |
Subscribe | |
</button> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
shadow-indigo-500/50 | |
</p> | |
<button className="rounded-md bg-indigo-500 px-3 py-2 text-sm font-semibold text-white shadow-lg shadow-indigo-500/50 focus:outline-none"> | |
Subscribe | |
</button> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:shadow-cyan-500/50,shadow-blue-500/50,shadow-indigo-500/50] --> | |
<button class="bg-cyan-500 shadow-lg shadow-cyan-500/50 ...">Subscribe</button> | |
<button class="bg-blue-500 shadow-lg shadow-blue-500/50 ...">Subscribe</button> | |
<button class="bg-indigo-500 shadow-lg shadow-indigo-500/50 ...">Subscribe</button> | |
``` | |
</Figure> | |
By default colored shadows have an opacity of 100% but you can adjust this using the opacity modifier. | |
### Adding an inset shadow | |
Use utilities like `inset-shadow-xs` and `inset-shadow-sm` to apply an inset box shadow to an element: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex flex-col items-center justify-around gap-4 gap-y-6 bg-white p-6 font-mono font-bold sm:flex-row"> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">inset-shadow-2xs</p> | |
<div className="size-24 rounded-lg bg-white ring-1 inset-shadow-2xs ring-black/5"></div> | |
</div> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">inset-shadow-xs</p> | |
<div className="size-24 rounded-lg bg-white ring-1 inset-shadow-xs ring-black/5"></div> | |
</div> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">inset-shadow-sm</p> | |
<div className="size-24 rounded-lg bg-white ring-1 inset-shadow-sm ring-black/5"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:inset-shadow-2xs,inset-shadow-xs,inset-shadow-sm] --> | |
<div class="inset-shadow-2xs ..."></div> | |
<div class="inset-shadow-xs ..."></div> | |
<div class="inset-shadow-sm ..."></div> | |
``` | |
</Figure> | |
You can adjust the opacity of an inset shadow using the opacity modifier, like `inset-shadow-sm/50`. The default inset shadow opacities are quite low (5%), so increasing the opacity (to like 50%) will make the inset shadows more pronounced. | |
### Setting the inset shadow color | |
Use utilities like `inset-shadow-indigo-500` and `inset-shadow-cyan-500/50` to change the color of an inset box shadow: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex flex-col items-center justify-around gap-4 gap-y-6 bg-white p-6 font-mono font-bold sm:flex-row"> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">inset-shadow-indigo-500</p> | |
<div className="size-24 rounded-lg bg-indigo-200 inset-shadow-sm inset-shadow-indigo-500"></div> | |
</div> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">inset-shadow-indigo-500/50</p> | |
<div className="size-24 rounded-lg bg-indigo-200 inset-shadow-sm inset-shadow-indigo-500/50"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:inset-shadow-indigo-500,inset-shadow-indigo-500/75] --> | |
<div class="inset-shadow-sm inset-shadow-indigo-500 ..."></div> | |
<div class="inset-shadow-sm inset-shadow-indigo-500/50 ..."></div> | |
``` | |
</Figure> | |
By default colored shadows have an opacity of 100% but you can adjust this using the opacity modifier. | |
### Adding a ring | |
Use `ring` or `ring-<number>` utilities like `ring-2` and `ring-4` to apply a solid box-shadow to an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1 gap-x-4 gap-y-6 text-center leading-6 font-bold text-white sm:grid-cols-3"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">ring</p> | |
<button className="rounded-md bg-white px-4 py-2 text-sm font-semibold text-gray-700 ring dark:bg-white/15 dark:text-gray-200"> | |
Subscribe | |
</button> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">ring-2</p> | |
<button className="rounded-md bg-white px-4 py-2 text-sm font-semibold text-gray-700 ring-2 dark:bg-white/15 dark:text-gray-200"> | |
Subscribe | |
</button> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">ring-4</p> | |
<button className="rounded-md bg-white px-4 py-2 text-sm font-semibold text-gray-700 ring-4 dark:bg-white/15 dark:text-gray-200"> | |
Subscribe | |
</button> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:ring,ring-2,ring-4] --> | |
<button class="ring ...">Subscribe</button> | |
<button class="ring-2 ...">Subscribe</button> | |
<button class="ring-4 ...">Subscribe</button> | |
``` | |
</Figure> | |
By default rings match the `currentColor` of the element they are applied to. | |
### Setting the ring color | |
Use utilities like `ring-indigo-500` and `ring-cyan-500/50` to change the color of a ring: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1 gap-x-4 gap-y-6 text-center leading-6 font-bold text-white sm:grid-cols-2"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">ring-blue-500</p> | |
<button className="rounded-md bg-white px-4 py-2 text-sm font-semibold text-gray-700 ring-2 ring-blue-500 dark:bg-white/15 dark:text-gray-200"> | |
Subscribe | |
</button> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
ring-blue-500/50 | |
</p> | |
<button className="rounded-md bg-white px-4 py-2 text-sm font-semibold text-gray-700 ring-2 ring-blue-500/50 dark:bg-white/15 dark:text-gray-200"> | |
Subscribe | |
</button> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:ring-blue-500,ring-blue-500/50] --> | |
<button class="ring-2 ring-blue-500 ...">Subscribe</button> | |
<button class="ring-2 ring-blue-500/50 ...">Subscribe</button> | |
``` | |
</Figure> | |
By default rings have an opacity of 100% but you can adjust this using the opacity modifier. | |
### Adding an inset ring | |
Use `inset-ring` or `inset-ring-<number>` utilities like `inset-ring-2` and `inset-ring-4` to apply a solid inset box-shadow to an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1 gap-x-4 gap-y-6 text-center leading-6 font-bold text-white sm:grid-cols-3"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">inset-ring</p> | |
<button className="rounded-md bg-white px-4 py-2 text-sm font-semibold text-gray-700 inset-ring dark:bg-white/15 dark:text-gray-200"> | |
Subscribe | |
</button> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">inset-ring-2</p> | |
<button className="rounded-md bg-white px-4 py-2 text-sm font-semibold text-gray-700 inset-ring-2 dark:bg-white/15 dark:text-gray-200"> | |
Subscribe | |
</button> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">inset-ring-4</p> | |
<button className="rounded-md bg-white px-4 py-2 text-sm font-semibold text-gray-700 inset-ring-4 dark:bg-white/15 dark:text-gray-200"> | |
Subscribe | |
</button> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:inset-ring,inset-ring-2,inset-ring-4] --> | |
<button class="inset-ring ...">Subscribe</button> | |
<button class="inset-ring-2 ...">Subscribe</button> | |
<button class="inset-ring-4 ...">Subscribe</button> | |
``` | |
</Figure> | |
By default inset rings match the `currentColor` of the element they are applied to. | |
### Setting the inset ring color | |
Use utilities like `inset-ring-indigo-500` and `inset-ring-cyan-500/50` to change the color of an inset ring: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1 gap-x-4 gap-y-6 text-center leading-6 font-bold text-white sm:grid-cols-2"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
inset-ring-blue-500 | |
</p> | |
<button className="rounded-md bg-white px-4 py-2 text-sm font-semibold text-gray-700 inset-ring-2 inset-ring-blue-500 dark:bg-white/15 dark:text-gray-200"> | |
Subscribe | |
</button> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
inset-ring-blue-500/50 | |
</p> | |
<button className="rounded-md bg-white px-4 py-2 text-sm font-semibold text-gray-700 inset-ring-2 inset-ring-blue-500/50 dark:bg-white/15 dark:text-gray-200"> | |
Subscribe | |
</button> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:inset-ring-blue-500,inset-ring-blue-500/50] --> | |
<button class="inset-ring-2 inset-ring-blue-500 ...">Subscribe</button> | |
<button class="inset-ring-2 inset-ring-blue-500/50 ...">Subscribe</button> | |
``` | |
</Figure> | |
By default inset rings have an opacity of 100% but you can adjust this using the opacity modifier. | |
### Removing a box shadow | |
Use the `shadow-none`, `inset-shadow-none`,`ring-0`, and `inset-ring-0` utilities to remove an existing box shadow from an element: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex items-center justify-around gap-4 bg-white p-6 font-mono font-bold"> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">shadow-none</p> | |
<div className="size-24 rounded-lg outline-1 -outline-offset-1 outline-gray-900/20 outline-dashed"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:shadow-none] --> | |
<div class="shadow-none ..."></div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue | |
utilities={["shadow", "inset-shadow", "ring", "inset-ring"]} | |
name="box shadow" | |
value="0_35px_35px_rgba(0,0,0,0.25)" | |
/> | |
### Responsive design | |
<ResponsiveDesign property="box-shadow" defaultClass="shadow-none" featuredClass="shadow-lg" /> | |
## Customizing your theme | |
### Customizing shadows | |
<CustomizingYourTheme | |
utility="shadow" | |
themeKey="shadow" | |
name="box shadow" | |
customName="3xl" | |
customValue="0 35px 35px rgba(0, 0, 0, 0.25)" | |
/> | |
### Customizing inset shadows | |
<CustomizingYourTheme | |
utility="inset-shadow" | |
themeKey="inset-shadow" | |
name="inset box shadow" | |
customName="md" | |
customValue="inset 0 2px 3px rgba(0, 0, 0, 0.25)" | |
/> | |
### Customizing shadow colors | |
<CustomizingYourThemeColors utilities={["shadow", "inset-shadow", "ring", "inset-ring"]} /> | |
--- | |
File: /src/docs/box-sizing.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "box-sizing"; | |
export const description = "Utilities for controlling how the browser should calculate an element's total size."; | |
<ApiTable | |
rows={[ | |
["box-border", "box-sizing: border-box"], | |
["box-content", "box-sizing: content-box"], | |
]} | |
/> | |
## Examples | |
### Including borders and padding | |
Use the `box-border` utility to set an element's `box-sizing` to `border-box`, telling the browser to include the element's borders and padding when you give it a height or width. | |
This means a 100px × 100px element with a 2px border and 4px of padding on all sides will be rendered as 100px × 100px, with an internal content area of 88px × 88px: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="relative grid w-full grid-cols-[1fr_8rem_1fr] grid-rows-[1fr_3fr_1fr] gap-px bg-gray-700/10 font-mono text-sm leading-6 font-bold dark:bg-gray-700"> | |
<div className="col-start-1 row-start-1 bg-white dark:bg-gray-900"></div> | |
<div className="relative col-start-2 row-start-1 bg-white dark:bg-gray-900"> | |
{/* w-measure indicator */} | |
<div className="absolute right-0 bottom-2 left-0 flex"> | |
{/* Horizontal line */} | |
<div className="absolute top-1/2 right-0 left-0 h-px -translate-y-px bg-sky-400"></div> | |
{/* Left chip */} | |
<div className="w-full"> | |
<div className="absolute top-1/2 left-0 h-2 w-px -translate-x-px -translate-y-1 rounded-full bg-sky-400"></div> | |
</div> | |
{/* Badge */} | |
<div className="relative flex w-full flex-auto items-center justify-center bg-white px-1.5 font-mono text-xs leading-none font-bold text-sky-600 dark:bg-gray-900 dark:text-sky-400"> | |
128px | |
</div> | |
{/* Right chip */} | |
<div className="w-full"> | |
<div className="absolute top-1/2 right-0 h-2 w-px translate-x-px -translate-y-1 rounded-full bg-sky-400"></div> | |
</div> | |
</div> | |
</div> | |
<div className="col-start-3 row-start-1 bg-white dark:bg-gray-900"></div> | |
<div className="relative col-start-1 row-start-2 bg-white dark:bg-gray-900"> | |
{/* h-measure indicator */} | |
<div className="absolute top-0 right-2 bottom-0 flex w-3"> | |
{/* Vertical line */} | |
<div className="absolute top-0 bottom-0 left-1/2 w-px -translate-x-[0.5px] bg-sky-400"></div> | |
{/* Top chip */} | |
<div className="w-full"> | |
<div className="absolute top-0 left-1/2 h-px w-2 -translate-x-1 -translate-y-px rounded-full bg-sky-400"></div> | |
</div> | |
{/* Badge */} | |
<div className="relative flex h-3 flex-auto -translate-x-[1.15rem] translate-y-14 -rotate-90 items-center justify-center bg-white px-1.5 font-mono text-xs leading-none font-bold text-sky-600 dark:bg-gray-900 dark:text-sky-400"> | |
128px | |
</div> | |
{/* Bottom chip */} | |
<div className="w-full"> | |
<div className="absolute bottom-0 left-1/2 h-px w-2 -translate-x-1 translate-y-px rounded-full bg-sky-400"></div> | |
</div> | |
</div> | |
</div> | |
<div className="col-start-2 row-start-2 size-32 bg-white ring-1 ring-sky-300 dark:bg-gray-900 dark:ring-sky-400"> | |
<div className="relative box-border size-32 p-5 ring ring-sky-300 ring-inset"> | |
<div className="relative z-1 h-full w-full bg-sky-500 ring-1 ring-sky-500"></div> | |
<div className="absolute inset-0"> | |
<Stripes className="h-full" /> | |
</div> | |
</div> | |
</div> | |
<div className="col-start-3 row-start-2 bg-white dark:bg-gray-900"></div> | |
<div className="col-start-1 row-start-3 bg-white dark:bg-gray-900"></div> | |
<div className="col-start-2 row-start-3 bg-white dark:bg-gray-900"></div> | |
<div className="col-start-3 row-start-3 bg-white dark:bg-gray-900"></div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:box-border] --> | |
<div class="box-border size-32 border-4 p-4 ..."> | |
<!-- ... --> | |
</div> | |
``` | |
</Figure> | |
Tailwind makes this the default for all elements in our [preflight base styles](/docs/preflight). | |
### Excluding borders and padding | |
Use the `box-content` utility to set an element's `box-sizing` to `content-box`, telling the browser to add borders and padding on top of the element's specified width or height. | |
This means a 100px × 100px element with a 2px border and 4px of padding on all sides will actually be rendered as 112px × 112px, with an internal content area of 100px × 100px: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="relative grid grid-cols-[1fr_8rem_1fr] grid-rows-[1fr_2fr_1fr] gap-px bg-gray-700/10 font-mono text-sm leading-6 font-bold dark:bg-gray-700"> | |
<div className="col-start-1 row-start-1 bg-white dark:bg-gray-900"></div> | |
<div className="relative col-start-2 row-start-1 bg-white dark:bg-gray-900"> | |
{/* w-measure indicator */} | |
<div className="absolute right-0 bottom-2 left-0 flex -translate-y-5"> | |
{/* Horizontal line */} | |
<div className="absolute top-1/2 right-0 left-0 h-px -translate-y-px bg-blue-400"></div> | |
{/* Left chip */} | |
<div className="w-full"> | |
<div className="absolute top-1/2 left-0 h-2 w-px -translate-x-px -translate-y-1 rounded-full bg-blue-400"></div> | |
</div> | |
{/* Badge */} | |
<div className="relative flex w-full flex-auto items-center justify-center bg-white px-1.5 font-mono text-xs leading-none font-bold text-blue-600 dark:bg-gray-900 dark:text-blue-400"> | |
128px | |
</div> | |
{/* Right chip */} | |
<div className="w-full"> | |
<div className="absolute top-1/2 right-0 h-2 w-px translate-x-px -translate-y-1 rounded-full bg-blue-400"></div> | |
</div> | |
</div> | |
</div> | |
<div className="col-start-3 row-start-1 bg-white dark:bg-gray-900"></div> | |
<div className="relative col-start-1 row-start-2 bg-white dark:bg-gray-900"> | |
{/* h-measure indicator */} | |
<div className="absolute top-0 right-2 bottom-0 flex w-3 -translate-x-5"> | |
{/* Vertical line */} | |
<div className="absolute top-0 bottom-0 left-1/2 w-px -translate-x-[0.5px] bg-blue-400"></div> | |
{/* Top chip */} | |
<div className="w-full"> | |
<div className="absolute top-0 left-1/2 h-px w-2 -translate-x-1 -translate-y-px rounded-full bg-blue-400"></div> | |
</div> | |
{/* Badge */} | |
<div className="relative flex h-3 flex-auto -translate-x-[1.15rem] translate-y-14 -rotate-90 items-center justify-center bg-white px-1.5 font-mono text-xs leading-none font-bold text-blue-600 dark:bg-gray-900 dark:text-blue-400"> | |
128px | |
</div> | |
{/* Bottom chip */} | |
<div className="w-full"> | |
<div className="absolute bottom-0 left-1/2 h-px w-2 -translate-x-1 translate-y-px rounded-full bg-blue-400"></div> | |
</div> | |
</div> | |
</div> | |
<div className="col-start-2 row-start-2 size-32 bg-white"> | |
<div className="relative box-content size-32 -translate-x-5 -translate-y-5 p-5 ring-4 ring-blue-300 ring-inset dark:ring-blue-500"> | |
<div className="h-full w-full bg-blue-500 ring-1 ring-blue-500"></div> | |
<div className="absolute inset-1 z-10"> | |
<Stripes className="h-full" /> | |
</div> | |
</div> | |
</div> | |
<div className="col-start-3 row-start-2 bg-white dark:bg-gray-900"></div> | |
<div className="col-start-1 row-start-3 bg-white dark:bg-gray-900"></div> | |
<div className="col-start-2 row-start-3 bg-white dark:bg-gray-900"></div> | |
<div className="col-start-3 row-start-3 bg-white dark:bg-gray-900"></div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:box-content] --> | |
<div class="box-content size-32 border-4 p-4 ..."> | |
<!-- ... --> | |
</div> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="box-sizing" defaultClass="box-content" featuredClass="box-border" /> | |
--- | |
File: /src/docs/break-after.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "break-after"; | |
export const description = "Utilities for controlling how a column or page should break after an element."; | |
<ApiTable | |
rows={[ | |
["break-after-auto", "break-after: auto;"], | |
["break-after-avoid", "break-after: avoid;"], | |
["break-after-all", "break-after: all;"], | |
["break-after-avoid-page", "break-after: avoid-page;"], | |
["break-after-page", "break-after: page;"], | |
["break-after-left", "break-after: left;"], | |
["break-after-right", "break-after: right;"], | |
["break-after-column", "break-after: column;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `break-after-column` and `break-after-page` to control how a column or page break should behave after an element: | |
```html | |
<!-- [!code classes:break-after-column] --> | |
<div class="columns-2"> | |
<p>Well, let me tell you something, ...</p> | |
<p class="break-after-column">Sure, go ahead, laugh...</p> | |
<p>Maybe we can live without...</p> | |
<p>Look. If you think this is...</p> | |
</div> | |
``` | |
### Responsive design | |
<ResponsiveDesign property="break-after" defaultClass="break-after-column" featuredClass="break-after-auto" /> | |
--- | |
File: /src/docs/break-before.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "break-before"; | |
export const description = "Utilities for controlling how a column or page should break before an element."; | |
<ApiTable | |
rows={[ | |
["break-before-auto", "break-before: auto;"], | |
["break-before-avoid", "break-before: avoid;"], | |
["break-before-all", "break-before: all;"], | |
["break-before-avoid-page", "break-before: avoid-page;"], | |
["break-before-page", "break-before: page;"], | |
["break-before-left", "break-before: left;"], | |
["break-before-right", "break-before: right;"], | |
["break-before-column", "break-before: column;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `break-before-column` and `break-before-page` to control how a column or page break should behave before an element: | |
```html | |
<!-- [!code classes:break-before-column] --> | |
<div class="columns-2"> | |
<p>Well, let me tell you something, ...</p> | |
<p class="break-before-column">Sure, go ahead, laugh...</p> | |
<p>Maybe we can live without...</p> | |
<p>Look. If you think this is...</p> | |
</div> | |
``` | |
### Responsive design | |
<ResponsiveDesign property="break-before" defaultClass="break-before-column" featuredClass="break-before-auto" /> | |
--- | |
File: /src/docs/break-inside.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "break-inside"; | |
export const description = "Utilities for controlling how a column or page should break within an element."; | |
<ApiTable | |
rows={[ | |
["break-inside-auto", "break-inside: auto;"], | |
["break-inside-avoid", "break-inside: avoid;"], | |
["break-inside-avoid-page", "break-inside: avoid-page;"], | |
["break-inside-avoid-column", "break-inside: avoid-column;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `break-inside-column` and `break-inside-avoid-page` to control how a column or page break should behave within an element: | |
```html | |
<!-- [!code classes:break-inside-avoid-column] --> | |
<div class="columns-2"> | |
<p>Well, let me tell you something, ...</p> | |
<p class="break-inside-avoid-column">Sure, go ahead, laugh...</p> | |
<p>Maybe we can live without...</p> | |
<p>Look. If you think this is...</p> | |
</div> | |
``` | |
### Responsive design | |
<ResponsiveDesign property="break-inside" defaultClass="break-inside-avoid-column" featuredClass="break-inside-auto" /> | |
--- | |
File: /src/docs/caption-side.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "caption-side"; | |
export const description = "Utilities for controlling the alignment of a caption element inside of a table."; | |
<ApiTable | |
rows={[ | |
["caption-top", "caption-side: top;"], | |
["caption-bottom", "caption-side: bottom;"], | |
]} | |
/> | |
## Examples | |
### Placing at top of table | |
Use the `caption-top` utility to position a caption element at the top of a table: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="overflow-hidden px-4 py-8 sm:px-8"> | |
<table className="w-full table-auto border-collapse text-sm"> | |
<caption className="caption-top pb-4 text-xs text-gray-500 dark:text-gray-400"> | |
Table 3.1: Professional wrestlers and their signature moves. | |
</caption> | |
<thead> | |
<tr> | |
<th className="border border-gray-200 bg-gray-50 p-4 py-3 pl-8 text-left font-medium text-gray-400 dark:border-gray-600 dark:bg-gray-700 dark:text-gray-200"> | |
Wrestler | |
</th> | |
<th className="border border-gray-200 bg-gray-50 p-4 py-3 pr-8 text-left font-medium text-gray-400 dark:border-gray-600 dark:bg-gray-700 dark:text-gray-200"> | |
Signature Move(s) | |
</th> | |
</tr> | |
</thead> | |
<tbody className="bg-white dark:bg-gray-800"> | |
<tr> | |
<td className="border border-gray-200 p-4 pl-8 text-gray-500 dark:border-gray-600 dark:text-gray-400"> | |
"Stone Cold" Steve Austin | |
</td> | |
<td className="border border-gray-200 p-4 pr-8 text-gray-500 dark:border-gray-600 dark:text-gray-400"> | |
Stone Cold Stunner, Lou Thesz Press | |
</td> | |
</tr> | |
<tr> | |
<td className="border border-gray-200 p-4 pl-8 text-gray-500 dark:border-gray-600 dark:text-gray-400"> | |
Bret "The Hitman" Hart | |
</td> | |
<td className="border border-gray-200 p-4 pr-8 text-gray-500 dark:border-gray-600 dark:text-gray-400"> | |
The Sharpshooter | |
</td> | |
</tr> | |
<tr> | |
<td className="border border-gray-200 p-4 pl-8 text-gray-500 dark:border-gray-600 dark:text-gray-400"> | |
Razor Ramon | |
</td> | |
<td className="border border-gray-200 p-4 pr-8 text-gray-500 dark:border-gray-600 dark:text-gray-400"> | |
Razor's Edge, Fallaway Slam | |
</td> | |
</tr> | |
</tbody> | |
</table> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:caption-top] --> | |
<table> | |
<caption class="caption-top"> | |
Table 3.1: Professional wrestlers and their signature moves. | |
</caption> | |
<thead> | |
<tr> | |
<th>Wrestler</th> | |
<th>Signature Move(s)</th> | |
</tr> | |
</thead> | |
<tbody> | |
<tr> | |
<td>"Stone Cold" Steve Austin</td> | |
<td>Stone Cold Stunner, Lou Thesz Press</td> | |
</tr> | |
<tr> | |
<td>Bret "The Hitman" Hart</td> | |
<td>The Sharpshooter</td> | |
</tr> | |
<tr> | |
<td>Razor Ramon</td> | |
<td>Razor's Edge, Fallaway Slam</td> | |
</tr> | |
</tbody> | |
</table> | |
``` | |
</Figure> | |
### Placing at bottom of table | |
Use the `caption-bottom` utility to position a caption element at the bottom of a table: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="overflow-hidden px-4 py-8 sm:px-8"> | |
<table className="w-full table-auto border-collapse text-sm"> | |
<caption className="caption-bottom pt-4 text-xs text-gray-500 dark:text-gray-400"> | |
Table 3.1: Professional wrestlers and their signature moves. | |
</caption> | |
<thead> | |
<tr> | |
<th className="border border-gray-200 bg-gray-50 p-4 py-3 pl-8 text-left font-medium text-gray-400 dark:border-gray-600 dark:bg-gray-700 dark:text-gray-200"> | |
Wrestler | |
</th> | |
<th className="border border-gray-200 bg-gray-50 p-4 py-3 pr-8 text-left font-medium text-gray-400 dark:border-gray-600 dark:bg-gray-700 dark:text-gray-200"> | |
Signature Move(s) | |
</th> | |
</tr> | |
</thead> | |
<tbody className="bg-white dark:bg-gray-800"> | |
<tr> | |
<td className="border border-gray-200 p-4 pl-8 text-gray-500 dark:border-gray-600 dark:text-gray-400"> | |
"Stone Cold" Steve Austin | |
</td> | |
<td className="border border-gray-200 p-4 pr-8 text-gray-500 dark:border-gray-600 dark:text-gray-400"> | |
Stone Cold Stunner, Lou Thesz Press | |
</td> | |
</tr> | |
<tr> | |
<td className="border border-gray-200 p-4 pl-8 text-gray-500 dark:border-gray-600 dark:text-gray-400"> | |
Bret "The Hitman" Hart | |
</td> | |
<td className="border border-gray-200 p-4 pr-8 text-gray-500 dark:border-gray-600 dark:text-gray-400"> | |
The Sharpshooter | |
</td> | |
</tr> | |
<tr> | |
<td className="border border-gray-200 p-4 pl-8 text-gray-500 dark:border-gray-600 dark:text-gray-400"> | |
Razor Ramon | |
</td> | |
<td className="border border-gray-200 p-4 pr-8 text-gray-500 dark:border-gray-600 dark:text-gray-400"> | |
Razor's Edge, Fallaway Slam | |
</td> | |
</tr> | |
</tbody> | |
</table> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code word:caption-bottom] --> | |
<table> | |
<caption class="caption-bottom"> | |
Table 3.1: Professional wrestlers and their signature moves. | |
</caption> | |
<thead> | |
<tr> | |
<th>Wrestler</th> | |
<th>Signature Move(s)</th> | |
</tr> | |
</thead> | |
<tbody> | |
<tr> | |
<td>"Stone Cold" Steve Austin</td> | |
<td>Stone Cold Stunner, Lou Thesz Press</td> | |
</tr> | |
<tr> | |
<td>Bret "The Hitman" Hart</td> | |
<td>The Sharpshooter</td> | |
</tr> | |
<tr> | |
<td>Razor Ramon</td> | |
<td>Razor's Edge, Fallaway Slam</td> | |
</tr> | |
</tbody> | |
</table> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="caption-side" element="caption" defaultClass="caption-top" featuredClass="caption-bottom" /> | |
--- | |
File: /src/docs/caret-color.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourThemeColors } from "@/components/content.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { UsingACustomValue } from "@/components/content.tsx"; | |
import colors from "./utils/colors"; | |
export const title = "caret-color"; | |
export const description = "Utilities for controlling the color of the text input cursor."; | |
<ApiTable | |
rows={[ | |
["caret-inherit", "caret-color: inherit;"], | |
["caret-current", "caret-color: currentColor;"], | |
["caret-transparent", "caret-color: transparent;"], | |
...Object.entries(colors).map(([name, value]) => [ | |
`caret-${name}`, | |
`caret-color: var(--color-${name}); /* ${value} */`, | |
]), | |
["caret-<custom-property>", "caret-color: var(<custom-property>);"], | |
["caret-[<value>]", "caret-color: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `caret-rose-500` and `caret-lime-600` to change the color of the text input cursor: | |
<Figure hint="Focus the textarea to see the new caret color"> | |
<Example> | |
{ | |
<div className="flex w-full items-center justify-center"> | |
<textarea | |
className="w-80 rounded-md p-2 text-sm caret-pink-500 ring-1 ring-gray-900/10 focus:ring-2 focus:ring-pink-500 focus:outline-none dark:bg-gray-950/25 dark:ring-1 dark:ring-white/5 dark:focus:bg-gray-950/10 dark:focus:ring-2 dark:focus:ring-pink-500" | |
rows="2" | |
/> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:caret-pink-500] --> | |
<textarea class="caret-pink-500 ..."></textarea> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue element="textarea" utility="caret" value="#50d71e" name="caret color" variable="caret-color" /> | |
### Responsive design | |
<ResponsiveDesign | |
element="textarea" | |
property="caret-color" | |
defaultClass="caret-rose-500" | |
featuredClass="caret-lime-600" | |
/> | |
## Customizing your theme | |
<CustomizingYourThemeColors element="textarea" utility="caret" /> | |
--- | |
File: /src/docs/clear.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "clear"; | |
export const description = "Utilities for controlling the wrapping of content around an element."; | |
<ApiTable | |
rows={[ | |
["clear-left", "clear: left;"], | |
["clear-right", "clear: right;"], | |
["clear-both", "clear: both;"], | |
["clear-start", "clear: inline-start;"], | |
["clear-end", "clear: inline-end;"], | |
["clear-none", "clear: none;"], | |
]} | |
/> | |
## Examples | |
### Clearing left | |
Use the `clear-left` utility to position an element below any preceding left-floated elements: | |
<Figure> | |
<Example resizable> | |
{ | |
<> | |
<img | |
className="float-left mr-6 mb-4 aspect-16/9 w-1/4 rounded-lg object-cover outline -outline-offset-1 outline-black/10" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<img | |
className="float-right ml-6 aspect-6/5 w-2/5 rounded-lg object-cover outline -outline-offset-1 outline-black/10" | |
src="https://images.unsplash.com/photo-1434394354979-a235cd36269d?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<p className="clear-left text-justify"> | |
Maybe we can live without libraries, people like you and me. Maybe. Sure, we're too old to change the world, but | |
what about that kid, sitting down, opening a book, right now, in a branch at the local library and finding | |
drawings of pee-pees and wee-wees on the Cat in the Hat and the Five Chinese Brothers? Doesn't HE deserve | |
better? Look. If you think this is about overdue fines and missing books, you'd better think again. This is | |
about that kid's right to read a book without getting his mind warped! Or: maybe that turns you on, Seinfeld; | |
maybe that's how y'get your kicks. You and your good-time buddies. | |
</p> | |
</> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:clear-left] --> | |
<article> | |
<img class="float-left ..." src="/img/snow-mountains.jpg" /> | |
<img class="float-right ..." src="/img/green-mountains.jpg" /> | |
<p class="clear-left ...">Maybe we can live without libraries...</p> | |
</article> | |
``` | |
</Figure> | |
### Clearing right | |
Use the `clear-right` utility to position an element below any preceding right-floated elements: | |
<Figure> | |
<Example resizable> | |
{ | |
<> | |
<img | |
className="float-left mr-6 aspect-6/5 w-2/5 rounded-lg object-cover outline -outline-offset-1 outline-black/10" | |
src="https://images.unsplash.com/photo-1434394354979-a235cd36269d?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<img | |
className="float-right mb-4 ml-6 aspect-16/9 w-1/4 rounded-lg object-cover outline -outline-offset-1 outline-black/10" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=formathttps://images.unsplash.com/photo-1454496522488-7a8e488e8606?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<p className="clear-right text-justify"> | |
Maybe we can live without libraries, people like you and me. Maybe. Sure, we're too old to change the world, but | |
what about that kid, sitting down, opening a book, right now, in a branch at the local library and finding | |
drawings of pee-pees and wee-wees on the Cat in the Hat and the Five Chinese Brothers? Doesn't HE deserve | |
better? Look. If you think this is about overdue fines and missing books, you'd better think again. This is | |
about that kid's right to read a book without getting his mind warped! Or: maybe that turns you on, Seinfeld; | |
maybe that's how y'get your kicks. You and your good-time buddies. | |
</p> | |
</> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:clear-right] --> | |
<article> | |
<img class="float-left ..." src="/img/green-mountains.jpg" /> | |
<img class="float-right ..." src="/img/snow-mountains.jpg" /> | |
<p class="clear-right ...">Maybe we can live without libraries...</p> | |
</article> | |
``` | |
</Figure> | |
### Clearing all | |
Use the `clear-both` utility to position an element below all preceding floated elements: | |
<Figure> | |
<Example resizable> | |
{ | |
<> | |
<img | |
className="float-left mr-6 mb-4 aspect-16/9 w-1/4 rounded-lg object-cover outline -outline-offset-1 outline-black/10" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=formathttps://images.unsplash.com/photo-1454496522488-7a8e488e8606?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<img | |
className="float-right mb-4 ml-6 aspect-6/5 w-2/5 rounded-lg object-cover outline -outline-offset-1 outline-black/10" | |
src="https://images.unsplash.com/photo-1434394354979-a235cd36269d?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<p className="clear-both text-justify"> | |
Maybe we can live without libraries, people like you and me. Maybe. Sure, we're too old to change the world, but | |
what about that kid, sitting down, opening a book, right now, in a branch at the local library and finding | |
drawings of pee-pees and wee-wees on the Cat in the Hat and the Five Chinese Brothers? Doesn't HE deserve | |
better? Look. If you think this is about overdue fines and missing books, you'd better think again. This is | |
about that kid's right to read a book without getting his mind warped! Or: maybe that turns you on, Seinfeld; | |
maybe that's how y'get your kicks. You and your good-time buddies. | |
</p> | |
</> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:clear-both] --> | |
<article> | |
<img class="float-left ..." src="/img/snow-mountains.jpg" /> | |
<img class="float-right ..." src="/img/green-mountains.jpg" /> | |
<p class="clear-both ...">Maybe we can live without libraries...</p> | |
</article> | |
``` | |
</Figure> | |
### Using logical properties | |
Use the `clear-start` and `clear-end` utilities, which use [logical properties](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Logical_Properties/Basic_concepts) to map to either the left or right side based on the text direction: | |
<Figure> | |
<Example resizable> | |
{ | |
<div dir="rtl"> | |
<img | |
className="float-left mr-6 mb-4 aspect-16/9 w-1/4 rounded-lg object-cover outline -outline-offset-1 outline-black/10" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<img | |
className="float-right ml-6 aspect-6/5 w-2/5 rounded-lg object-cover outline -outline-offset-1 outline-black/10" | |
src="https://images.unsplash.com/photo-1434394354979-a235cd36269d?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<p className="clear-end text-justify"> | |
ربما يمكننا العيش بدون مكتبات، أشخاص مثلي ومثلك. ربما. بالتأكيد، نحن أكبر من أن نغير العالم، ولكن ماذا عن ذلك | |
الطفل الذي يجلس ويفتح كتابًا الآن في أحد فروع المكتبة المحلية ويجد رسومات للتبول والبول على القطة في القبعة | |
والإخوة الصينيون الخمسة؟ ألا يستحق الأفضل؟ ينظر. إذا كنت تعتقد أن الأمر يتعلق بالغرامات المتأخرة والكتب | |
المفقودة، فمن الأفضل أن تفكر مرة أخرى. يتعلق الأمر بحق ذلك الطفل في قراءة كتاب دون أن يتشوه عقله! أو: ربما يثيرك | |
هذا يا سينفيلد؛ ربما هذه هي الطريقة التي تحصل بها على ركلاتك. أنت ورفاقك الطيبين. | |
</p> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code word:dir="rtl"] --> | |
<!-- [!code classes:clear-end] --> | |
<article dir="rtl"> | |
<img class="float-left ..." src="/img/green-mountains.jpg" /> | |
<img class="float-right ..." src="/img/green-mountains.jpg" /> | |
<p class="clear-end ...">...ربما يمكننا العيش بدون مكتبات،</p> | |
</article> | |
``` | |
</Figure> | |
### Disabling clears | |
Use the `clear-none` utility to reset any clears that are applied to an element: | |
<Figure> | |
<Example resizable> | |
{ | |
<> | |
<img | |
className="float-left mr-6 aspect-6/5 w-2/5 rounded-lg object-cover outline -outline-offset-1 outline-black/10" | |
src="https://images.unsplash.com/photo-1434394354979-a235cd36269d?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<img | |
className="float-right ml-6 aspect-16/9 w-1/4 rounded-lg object-cover outline -outline-offset-1 outline-black/10" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=formathttps://images.unsplash.com/photo-1454496522488-7a8e488e8606?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<p className="text-justify"> | |
Maybe we can live without libraries, people like you and me. Maybe. Sure, we're too old to change the world, but | |
what about that kid, sitting down, opening a book, right now, in a branch at the local library and finding | |
drawings of pee-pees and wee-wees on the Cat in the Hat and the Five Chinese Brothers? Doesn't HE deserve | |
better? Look. If you think this is about overdue fines and missing books, you'd better think again. This is | |
about that kid's right to read a book without getting his mind warped! Or: maybe that turns you on, Seinfeld; | |
maybe that's how y'get your kicks. You and your good-time buddies. | |
</p> | |
</> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:clear-none] --> | |
<article> | |
<img class="float-left ..." src="/img/green-mountains.jpg" /> | |
<img class="float-right ..." src="/img/snow-mountains.jpg" /> | |
<p class="clear-none ...">Maybe we can live without libraries...</p> | |
</article> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign element="p" property="clear" defaultClass="clear-left" featuredClass="clear-none" /> | |
--- | |
File: /src/docs/color-scheme.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { TargetingSpecificStates } from "@/components/content.tsx"; | |
export const title = "color-scheme"; | |
export const description = "Utilities for controlling the color scheme of an element."; | |
<ApiTable | |
rows={[ | |
["scheme-normal", "color-scheme: normal;"], | |
["scheme-dark", "color-scheme: dark;"], | |
["scheme-light", "color-scheme: light;"], | |
["scheme-light-dark", "color-scheme: light dark;"], | |
["scheme-only-dark", "color-scheme: only dark;"], | |
["scheme-only-light", "color-scheme: only light;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `scheme-light` and `scheme-light-dark` to control how element should be rendered: | |
<Figure hint="Try switching your system color scheme to see the difference"> | |
<Example> | |
{ | |
<div className="flex justify-between gap-8 text-sm max-sm:flex-col"> | |
<div className="flex flex-grow flex-col items-center gap-3 text-center scheme-light"> | |
<p className="font-mono font-medium text-gray-500 dark:text-gray-400">scheme-light</p> | |
<input | |
type="date" | |
className="w-full rounded-lg border border-gray-950/10 bg-[Field] px-3 py-2 text-[FieldText] dark:border-white/10" | |
/> | |
</div> | |
<div className="flex flex-grow flex-col items-center gap-3 text-center scheme-dark"> | |
<p className="font-mono font-medium text-gray-500 dark:text-gray-400">scheme-dark</p> | |
<input | |
type="date" | |
className="w-full rounded-lg border border-gray-950/10 bg-[Field] px-3 py-2 text-[FieldText] dark:border-white/10" | |
/> | |
</div> | |
<div className="flex flex-grow flex-col items-center gap-3 text-center scheme-light-dark"> | |
<p className="font-medium text-gray-500 dark:text-gray-400">scheme-light-dark</p> | |
<input | |
type="date" | |
className="w-full rounded-lg border border-gray-950/10 bg-[Field] px-3 py-2 text-[FieldText] dark:border-white/10" | |
/> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:scheme-light-dark,scheme-light,scheme-dark] --> | |
<div class="scheme-light ..."> | |
<input type="date" /> | |
</div> | |
<div class="scheme-dark ..."> | |
<input type="date" /> | |
</div> | |
<div class="scheme-light-dark ..."> | |
<input type="date" /> | |
</div> | |
``` | |
</Figure> | |
### Applying in dark mode | |
<TargetingSpecificStates | |
element="html" | |
property="color-scheme" | |
variant="dark" | |
defaultClass="scheme-light" | |
featuredClass="scheme-dark" | |
/> | |
--- | |
File: /src/docs/color.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { | |
CustomizingYourThemeColors, | |
ResponsiveDesign, | |
TargetingSpecificStates, | |
UsingACustomValue, | |
} from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import colors from "./utils/colors"; | |
export const title = "color"; | |
export const description = "Utilities for controlling the text color of an element."; | |
<ApiTable | |
rows={[ | |
["text-inherit", "color: inherit;"], | |
["text-current", "color: currentColor;"], | |
["text-transparent", "color: transparent;"], | |
...Object.entries(colors).map(([name, value]) => [`text-${name}`, `color: var(--color-${name}); /* ${value} */`]), | |
["text-(<custom-property>)", "color: var(<custom-property>);"], | |
["text-[<value>]", "color: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `text-blue-600` and `text-sky-400` to control the text color of an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="relative text-center text-xl leading-6 font-medium"> | |
<p className="text-blue-600 dark:text-sky-400">The quick brown fox jumps over the lazy dog.</p> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:text-blue-600,dark:text-sky-400] --> | |
<p class="text-blue-600 dark:text-sky-400">The quick brown fox...</p> | |
``` | |
</Figure> | |
### Changing the opacity | |
Use the color opacity modifier to control the text color opacity of an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="space-y-4 text-center text-xl leading-6 font-medium"> | |
<p className="text-blue-600/100 dark:text-sky-400/100">The quick brown fox jumps over the lazy dog.</p> | |
<p className="text-blue-600/75 dark:text-sky-400/75">The quick brown fox jumps over the lazy dog.</p> | |
<p className="text-blue-600/50 dark:text-sky-400/50">The quick brown fox jumps over the lazy dog.</p> | |
<p className="text-blue-600/25 dark:text-sky-400/25">The quick brown fox jumps over the lazy dog.</p> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code word:\/100] --> | |
<!-- [!code word:\/75] --> | |
<!-- [!code word:\/50] --> | |
<!-- [!code word:\/25] --> | |
<p class="text-blue-600/100 dark:text-sky-400/100">The quick brown fox...</p> | |
<p class="text-blue-600/75 dark:text-sky-400/75">The quick brown fox...</p> | |
<p class="text-blue-600/50 dark:text-sky-400/50">The quick brown fox...</p> | |
<p class="text-blue-600/25 dark:text-sky-400/25">The quick brown fox...</p> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue element="p" utility="text" name="text color" variable="color" value="#50d71e" /> | |
### Applying on hover | |
<TargetingSpecificStates property="color"> | |
<Figure hint="Hover over the text to see the expected behavior"> | |
<Example> | |
{ | |
<p className="text-center text-xl font-medium text-gray-900 dark:text-gray-200"> | |
Oh I gotta get on that{" "} | |
<a | |
href="https://en.wikipedia.org/wiki/Internet" | |
target="_blank" | |
className="underline hover:text-blue-600 dark:hover:text-blue-400" | |
> | |
internet | |
</a> | |
, I'm late on everything! | |
</p> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:hover:text-blue-600,dark:hover:text-blue-400] --> | |
<!-- prettier-ignore --> | |
<p class="..."> | |
Oh I gotta get on that | |
<a class="underline hover:text-blue-600 dark:hover:text-blue-400" href="https://en.wikipedia.org/wiki/Internet">internet</a>, | |
I'm late on everything! | |
</p> | |
``` | |
</Figure> | |
</TargetingSpecificStates> | |
### Responsive design | |
<ResponsiveDesign element="p" property="color" defaultClass="text-blue-600" featuredClass="text-green-600" /> | |
## Customizing your theme | |
<CustomizingYourThemeColors element="p" utility="text" /> | |
--- | |
File: /src/docs/colors.mdx | |
--- | |
import { Example } from "@/components/example"; | |
import { Figure } from "@/components/figure"; | |
import { ColorPalette } from "../components/color-palette.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
import { TipGood, TipBad, TipCompat, TipInfo } from "@/components/tips"; | |
export const title = "Colors"; | |
export const description = "Using and customizing the color palette in Tailwind CSS projects."; | |
Tailwind CSS includes a vast, beautiful color palette out of the box, carefully crafted by expert designers and suitable for a wide range of different design styles. | |
<div className="my-10"> | |
{/* <TipInfo>{<>Click to copy OKLCH, shift+click to copy nearest hex</>}</TipInfo> */} | |
{/* <div className="mt-6"> */} | |
<ColorPalette /> | |
{/* </div> */} | |
</div> | |
Every color in the default palette includes 11 steps, with 50 being the lightest, and 950 being the darkest: | |
<Figure> | |
<Example className="flex justify-center"> | |
<div className="mx-auto inline-grid max-w-lg grid-cols-1 justify-center gap-3 *:*:first:size-9 *:*:first:rounded-md *:*:first:inset-ring *:*:first:inset-ring-black/5 sm:grid-cols-11 sm:flex-row sm:*:*:first:aspect-square sm:*:*:first:w-full"> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-50"></div> | |
<p className="text-center font-mono text-xs text-gray-600 dark:text-gray-400">50</p> | |
</div> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-100"></div> | |
<p className="text-center font-mono text-xs text-gray-600 dark:text-gray-400">100</p> | |
</div> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-200"></div> | |
<p className="text-center font-mono text-xs text-gray-600 dark:text-gray-400">200</p> | |
</div> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-300"></div> | |
<p className="text-center font-mono text-xs text-gray-600 dark:text-gray-400">300</p> | |
</div> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-400"></div> | |
<p className="text-center font-mono text-xs text-gray-600 dark:text-gray-400">400</p> | |
</div> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-500"></div> | |
<p className="text-center font-mono text-xs text-gray-600 dark:text-gray-400">500</p> | |
</div> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-600"></div> | |
<p className="text-center font-mono text-xs text-gray-600 dark:text-gray-400">600</p> | |
</div> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-700"></div> | |
<p className="text-center font-mono text-xs text-gray-600 dark:text-gray-400">700</p> | |
</div> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-800"></div> | |
<p className="text-center font-mono text-xs text-gray-600 dark:text-gray-400">800</p> | |
</div> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-900"></div> | |
<p className="text-center font-mono text-xs text-gray-600 dark:text-gray-400">900</p> | |
</div> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-950"></div> | |
<p className="text-center font-mono text-xs text-gray-600 dark:text-gray-400">950</p> | |
</div> | |
</div> | |
</Example> | |
```html | |
<!-- [!code classes:bg-sky-50,bg-sky-100,bg-sky-200,bg-sky-300,bg-sky-400,bg-sky-500,bg-sky-600,bg-sky-700,bg-sky-800,bg-sky-900,bg-sky-950] --> | |
<div> | |
<div class="bg-sky-50"></div> | |
<div class="bg-sky-100"></div> | |
<div class="bg-sky-200"></div> | |
<div class="bg-sky-300"></div> | |
<div class="bg-sky-400"></div> | |
<div class="bg-sky-500"></div> | |
<div class="bg-sky-600"></div> | |
<div class="bg-sky-700"></div> | |
<div class="bg-sky-800"></div> | |
<div class="bg-sky-900"></div> | |
<div class="bg-sky-950"></div> | |
</div> | |
``` | |
</Figure> | |
The entire color palette is available across all color related utilities, including things like [background color](/docs/background-color), [border color](/docs/border-color), [fill](/docs/fill), [caret color](/docs/caret-color), and many more. | |
## Working with colors | |
### Using color utilities | |
Use color utilities like `bg-white`, `border-pink-300`, and `text-gray-950` to set the different color properties of elements in your design: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="bg-black/5 p-8 text-sm"> | |
<div className="mx-auto flex max-w-md items-center gap-4 rounded-lg bg-white p-6 shadow-md outline outline-black/5 dark:bg-gray-800"> | |
<span className="inline-flex shrink-0 rounded-full border border-pink-300 bg-pink-100 p-2 dark:border-pink-300/10 dark:bg-pink-400/10"> | |
<svg | |
xmlns="http://www.w3.org/2000/svg" | |
fill="none" | |
viewBox="0 0 24 24" | |
strokeWidth={1.5} | |
className="size-6 stroke-pink-700 dark:stroke-pink-500" | |
> | |
<path | |
strokeLinecap="round" | |
strokeLinejoin="round" | |
d="M14.857 17.082a23.848 23.848 0 0 0 5.454-1.31A8.967 8.967 0 0 1 18 9.75V9A6 6 0 0 0 6 9v.75a8.967 8.967 0 0 1-2.312 6.022c1.733.64 3.56 1.085 5.455 1.31m5.714 0a24.255 24.255 0 0 1-5.714 0m5.714 0a3 3 0 1 1-5.714 0" | |
/> | |
</svg> | |
</span> | |
<div> | |
<p className="text-gray-700 dark:text-gray-400"> | |
<span className="font-medium text-gray-950 dark:text-white">Tom Watson</span> mentioned you in{" "} | |
<span className="font-medium text-gray-950 dark:text-white">Logo redesign</span> | |
</p> | |
<p className="mt-1 text-gray-500">9:37am</p> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:bg-white,border-pink-300,bg-pink-100,stroke-pink-700,text-gray-950,text-gray-500,outline-black/5,text-gray-700,dark:bg-gray-800,dark:border-pink-300/10,dark:bg-pink-400/10,dark:stroke-pink-500,dark:text-gray-400,dark:text-white] --> | |
<div class="flex items-center gap-4 rounded-lg bg-white p-6 shadow-md outline outline-black/5 dark:bg-gray-800"> | |
<!-- prettier-ignore --> | |
<span class="inline-flex shrink-0 rounded-full border border-pink-300 bg-pink-100 p-2 dark:border-pink-300/10 dark:bg-pink-400/10"> | |
<svg class="size-6 stroke-pink-700 dark:stroke-pink-500"><!-- ... --></svg> | |
</span> | |
<div> | |
<p class="text-gray-700 dark:text-gray-400"> | |
<span class="font-medium text-gray-950 dark:text-white">Tom Watson</span> mentioned you in | |
<span class="font-medium text-gray-950 dark:text-white">Logo redesign</span> | |
</p> | |
<time class="mt-1 block text-gray-500" datetime="9:37">9:37am</time> | |
</div> | |
</div> | |
``` | |
</Figure> | |
Here's a full list of utilities that use your color palette: | |
{ | |
<table> | |
<thead> | |
<tr> | |
<th>Utility</th> | |
<th>Description</th> | |
</tr> | |
</thead> | |
<tbody> | |
<tr> | |
<td> | |
<code>bg-*</code> | |
</td> | |
<td> | |
Sets the <a href="/docs/background-color">background color</a> of an element | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code>text-*</code> | |
</td> | |
<td> | |
Sets the <a href="/docs/text-color">text color</a> of an element | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code>decoration-*</code> | |
</td> | |
<td> | |
Sets the <a href="/docs/text-decoration-color">text decoration color</a> of an element | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code>border-*</code> | |
</td> | |
<td> | |
Sets the <a href="/docs/border-color">border color</a> of an element | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code>outline-*</code> | |
</td> | |
<td> | |
Sets the <a href="/docs/outline-color">outline color</a> of an element | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code>shadow-*</code> | |
</td> | |
<td> | |
Sets the color of <a href="/docs/box-shadow#setting-the-shadow-color">box shadows</a> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code>inset-shadow-*</code> | |
</td> | |
<td> | |
Sets the color of <a href="/docs/box-shadow#setting-the-inset-shadow-color">inset box shadows</a> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code>ring-*</code> | |
</td> | |
<td> | |
Sets the color of <a href="/docs/box-shadow#setting-the-ring-color">ring shadows</a> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code>inset-ring-*</code> | |
</td> | |
<td> | |
Sets the color of <a href="/docs/box-shadow#setting-the-inset-ring-color">inset ring shadows</a> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code>accent-*</code> | |
</td> | |
<td> | |
Sets the <a href="/docs/accent-color">accent color</a> of form controls | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code>caret-*</code> | |
</td> | |
<td> | |
Sets the <a href="/docs/caret-color">caret color</a> in form controls | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code>fill-*</code> | |
</td> | |
<td> | |
Sets the <a href="/docs/fill">fill color</a> of SVG elements | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code>stroke-*</code> | |
</td> | |
<td> | |
Sets the <a href="/docs/stroke">stroke color</a> of SVG elements | |
</td> | |
</tr> | |
</tbody> | |
</table> | |
} | |
### Adjusting opacity | |
You can adjust the opacity of a color using syntax like `bg-black/75`, where `75` sets the alpha channel of the color to 75%: | |
<Figure> | |
<Example padding={false}> | |
<div | |
className="flex items-center justify-center p-8 [--checkered-bg:--alpha(var(--color-gray-950)/10%)] dark:[--checkered-bg:--alpha(var(--color-white)/5%)]" | |
style={{ | |
backgroundImage: ` | |
linear-gradient(45deg, var(--checkered-bg) 25%, transparent 25%), | |
linear-gradient(-45deg, var(--checkered-bg) 25%, transparent 25%), | |
linear-gradient(45deg, transparent 75%, var(--checkered-bg) 75%), | |
linear-gradient(-45deg, transparent 75%, var(--checkered-bg) 75%)`, | |
backgroundSize: "20px 20px", | |
backgroundPosition: "0 0, 0 10px, 10px -10px, -10px 0px", | |
}} | |
> | |
<div className="mx-auto inline-grid max-w-lg grid-cols-1 justify-center gap-3 *:*:first:size-9 *:*:first:rounded-md sm:grid-cols-10 sm:flex-row sm:*:*:first:aspect-square sm:*:*:first:w-full"> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-500/10"></div> | |
</div> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-500/20"></div> | |
</div> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-500/30"></div> | |
</div> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-500/40"></div> | |
</div> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-500/50"></div> | |
</div> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-500/60"></div> | |
</div> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-500/70"></div> | |
</div> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-500/80"></div> | |
</div> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-500/90"></div> | |
</div> | |
<div className="flex items-center gap-1.5 sm:flex-col"> | |
<div className="bg-sky-500/100"></div> | |
</div> | |
</div> | |
</div> | |
</Example> | |
```html | |
<!-- [!code classes:bg-black-50/10,bg-black-100/20,bg-black-200/30,bg-black-300/40,bg-black-400/50,bg-black-500/60,bg-black-600/70,bg-black-700/80,bg-black-800/90,bg-black-900/100] --> | |
<div> | |
<div class="bg-sky-500/10"></div> | |
<div class="bg-sky-500/20"></div> | |
<div class="bg-sky-500/30"></div> | |
<div class="bg-sky-500/40"></div> | |
<div class="bg-sky-500/50"></div> | |
<div class="bg-sky-500/60"></div> | |
<div class="bg-sky-500/70"></div> | |
<div class="bg-sky-500/80"></div> | |
<div class="bg-sky-500/90"></div> | |
<div class="bg-sky-500/100"></div> | |
</div> | |
``` | |
</Figure> | |
This syntax also supports arbitrary values and the CSS variable shorthand: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:bg-pink-500/[71.37%],bg-cyan-400/(--my-alpha-value)] --> | |
<div class="bg-pink-500/[71.37%]"><!-- ... --></div> | |
<div class="bg-cyan-400/(--my-alpha-value)"><!-- ... --></div> | |
``` | |
### Targeting dark mode | |
Use the `dark` variant to write classes like `dark:bg-gray-800` that only apply a color when dark mode is active: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="grid grid-cols-1 sm:grid-cols-2"> | |
<div className="p-8 pt-7"> | |
<p className="mb-2 text-sm font-medium text-gray-500">Light mode</p> | |
<div className="rounded-lg bg-white px-6 py-8 shadow-xl ring ring-gray-900/5"> | |
<div> | |
<span className="inline-flex items-center justify-center rounded-md bg-indigo-500 p-2 shadow-lg"> | |
<svg | |
className="h-6 w-6 text-white" | |
xmlns="http://www.w3.org/2000/svg" | |
fill="none" | |
viewBox="0 0 24 24" | |
stroke="currentColor" | |
aria-hidden="true" | |
> | |
<path | |
strokeLinecap="round" | |
strokeLinejoin="round" | |
strokeWidth="2" | |
d="M11 5H6a2 2 0 00-2 2v11a2 2 0 002 2h11a2 2 0 002-2v-5m-1.414-9.414a2 2 0 112.828 2.828L11.828 15H9v-2.828l8.586-8.586z" | |
/> | |
</svg> | |
</span> | |
</div> | |
<p className="mt-5 text-base font-medium tracking-tight text-gray-900">Writes upside-down</p> | |
<p | |
className="mt-2 text-sm text-gray-500" | |
children={`The Zero Gravity Pen can be used to write in any orientation, | |
including upside-down. It even works in outer space.`} | |
/> | |
</div> | |
</div> | |
<div className="bg-gray-900 p-8 pt-7"> | |
<p className="mb-2 text-sm font-medium text-gray-400">Dark mode</p> | |
<div className="rounded-lg bg-gray-800 px-6 py-8 shadow-xl ring ring-gray-900/5"> | |
<div> | |
<span className="inline-flex items-center justify-center rounded-md bg-indigo-500 p-2 shadow-lg"> | |
<svg | |
className="h-6 w-6 text-white" | |
xmlns="http://www.w3.org/2000/svg" | |
fill="none" | |
viewBox="0 0 24 24" | |
stroke="currentColor" | |
aria-hidden="true" | |
> | |
<path | |
strokeLinecap="round" | |
strokeLinejoin="round" | |
strokeWidth="2" | |
d="M11 5H6a2 2 0 00-2 2v11a2 2 0 002 2h11a2 2 0 002-2v-5m-1.414-9.414a2 2 0 112.828 2.828L11.828 15H9v-2.828l8.586-8.586z" | |
/> | |
</svg> | |
</span> | |
</div> | |
<p className="mt-5 text-base font-medium tracking-tight text-white">Writes upside-down</p> | |
<p | |
className="mt-2 text-sm text-gray-400" | |
children={`The Zero Gravity Pen can be used to write in any orientation, | |
including upside-down. It even works in outer space.`} | |
/> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code word:dark\:bg-gray-800] --> | |
<!-- prettier-ignore --> | |
<div class="bg-white dark:bg-gray-800 rounded-lg px-6 py-8 ring shadow-xl ring-gray-900/5"> | |
<div> | |
<span class="inline-flex items-center justify-center rounded-md bg-indigo-500 p-2 shadow-lg"> | |
<svg class="h-6 w-6 stroke-white" ...> | |
<!-- ... --> | |
</svg> | |
</span> | |
</div> | |
<!-- prettier-ignore --> | |
<!-- [!code word:dark\:text-white] --> | |
<h3 class="text-gray-900 dark:text-white mt-5 text-base font-medium tracking-tight ">Writes upside-down</h3> | |
<!-- prettier-ignore --> | |
<!-- [!code word:dark\:text-gray-400] --> | |
<p class="text-gray-500 dark:text-gray-400 mt-2 text-sm "> | |
The Zero Gravity Pen can be used to write in any orientation, including upside-down. It even works in outer space. | |
</p> | |
</div> | |
``` | |
</Figure> | |
Learn more about styling for dark mode in the [dark mode documentation](/docs/dark-mode). | |
### Referencing in CSS | |
Colors are exposed as CSS variables in the `--color-*` namespace, so you can reference them in CSS with variables like `--color-blue-500` and `--color-pink-700`: | |
```css | |
/* [!code filename:CSS] */ | |
/* [!code word:var(--color-gray-950)] */ | |
/* [!code word:var(--color-blue-500)] */ | |
/* [!code word:var(--color-blue-800)] */ | |
@import "tailwindcss"; | |
@layer components { | |
.typography { | |
color: var(--color-gray-950); | |
a { | |
color: var(--color-blue-500); | |
&:hover { | |
color: var(--color-blue-800); | |
} | |
} | |
} | |
} | |
``` | |
You can also use these as [arbitrary values]() in utility classes: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:bg-[light-dark(var(--color-white),var(--color-gray-950))]] --> | |
<div class="bg-[light-dark(var(--color-white),var(--color-gray-950))]"> | |
<!-- ... --> | |
</div> | |
``` | |
To quickly adjust the opacity of a color when referencing it as a variable in CSS, Tailwind includes a special <code>--alpha()</code> function: | |
```css | |
/* [!code filename:CSS] */ | |
/* [!code word:--alpha(var(--color-gray-950) / 10%)] */ | |
@import "tailwindcss"; | |
@layer components { | |
.DocSearch-Hit--Result { | |
background-color: --alpha(var(--color-gray-950) / 10%); | |
} | |
} | |
``` | |
## Customizing your colors | |
Use `@theme` to add custom colors to your project under the `--color-*` theme namespace: | |
```css | |
/* [!code filename:CSS] */ | |
@import "tailwindcss"; | |
/* [!code highlight:6] */ | |
@theme { | |
--color-midnight: #121063; | |
--color-tahiti: #3ab7bf; | |
--color-bermuda: #78dcca; | |
} | |
``` | |
Now utilities like `bg-midnight`, `text-tahiti`, and `fill-bermuda` will be available in your project in addition to the default colors. | |
Learn more about theme variables in the [theme variables documentation](/docs/theme). | |
### Overriding default colors | |
Override any of the default colors by defining new theme variables with the same name: | |
```css | |
/* [!code filename:CSS] */ | |
@import "tailwindcss"; | |
/* [!code highlight:14] */ | |
@theme { | |
--color-gray-50: oklch(0.984 0.003 247.858); | |
--color-gray-100: oklch(0.968 0.007 247.896); | |
--color-gray-200: oklch(0.929 0.013 255.508); | |
--color-gray-300: oklch(0.869 0.022 252.894); | |
--color-gray-400: oklch(0.704 0.04 256.788); | |
--color-gray-500: oklch(0.554 0.046 257.417); | |
--color-gray-600: oklch(0.446 0.043 257.281); | |
--color-gray-700: oklch(0.372 0.044 257.287); | |
--color-gray-800: oklch(0.279 0.041 260.031); | |
--color-gray-900: oklch(0.208 0.042 265.755); | |
--color-gray-950: oklch(0.129 0.042 264.695); | |
} | |
``` | |
### Disabling default colors | |
Disable any default color by setting the theme namespace for that color to `initial`: | |
```css | |
/* [!code filename:CSS] */ | |
@import "tailwindcss"; | |
/* [!code highlight:5] */ | |
@theme { | |
--color-lime-*: initial; | |
--color-fuchsia-*: initial; | |
} | |
``` | |
This is especially useful for removing the corresponding CSS variables from your output for colors you don't intend to use. | |
### Using a custom palette | |
Use `--color-*: initial` to completely disable all of the default colors and define your own custom color palette: | |
```css | |
/* [!code filename:CSS] */ | |
@import "tailwindcss"; | |
@theme { | |
/* [!code highlight:7] */ | |
--color-*: initial; | |
--color-white: #fff; | |
--color-purple: #3f3cbb; | |
--color-midnight: #121063; | |
--color-tahiti: #3ab7bf; | |
--color-bermuda: #78dcca; | |
} | |
``` | |
### Referencing other variables | |
Use `@theme inline` when defining colors that reference other colors: | |
```css | |
/* [!code filename:CSS] */ | |
@import "tailwindcss"; | |
:root { | |
--acme-canvas-color: oklch(0.967 0.003 264.542); | |
} | |
[data-theme="dark"] { | |
--acme-canvas-color: oklch(0.21 0.034 264.665); | |
} | |
/* [!code highlight:4] */ | |
@theme inline { | |
--color-canvas: var(--acme-canvas-color); | |
} | |
``` | |
Learn more in the theme documentation on [referencing other variables](/docs/theme#referencing-other-variables). | |
## Default color palette reference | |
Here's a complete list of the default colors and their values for reference: | |
```css | |
/* [!code filename:CSS] */ | |
@theme { | |
--color-red-50: oklch(0.971 0.013 17.38); | |
--color-red-100: oklch(0.936 0.032 17.717); | |
--color-red-200: oklch(0.885 0.062 18.334); | |
--color-red-300: oklch(0.808 0.114 19.571); | |
--color-red-400: oklch(0.704 0.191 22.216); | |
--color-red-500: oklch(0.637 0.237 25.331); | |
--color-red-600: oklch(0.577 0.245 27.325); | |
--color-red-700: oklch(0.505 0.213 27.518); | |
--color-red-800: oklch(0.444 0.177 26.899); | |
--color-red-900: oklch(0.396 0.141 25.723); | |
--color-red-950: oklch(0.258 0.092 26.042); | |
--color-orange-50: oklch(0.98 0.016 73.684); | |
--color-orange-100: oklch(0.954 0.038 75.164); | |
--color-orange-200: oklch(0.901 0.076 70.697); | |
--color-orange-300: oklch(0.837 0.128 66.29); | |
--color-orange-400: oklch(0.75 0.183 55.934); | |
--color-orange-500: oklch(0.705 0.213 47.604); | |
--color-orange-600: oklch(0.646 0.222 41.116); | |
--color-orange-700: oklch(0.553 0.195 38.402); | |
--color-orange-800: oklch(0.47 0.157 37.304); | |
--color-orange-900: oklch(0.408 0.123 38.172); | |
--color-orange-950: oklch(0.266 0.079 36.259); | |
--color-amber-50: oklch(0.987 0.022 95.277); | |
--color-amber-100: oklch(0.962 0.059 95.617); | |
--color-amber-200: oklch(0.924 0.12 95.746); | |
--color-amber-300: oklch(0.879 0.169 91.605); | |
--color-amber-400: oklch(0.828 0.189 84.429); | |
--color-amber-500: oklch(0.769 0.188 70.08); | |
--color-amber-600: oklch(0.666 0.179 58.318); | |
--color-amber-700: oklch(0.555 0.163 48.998); | |
--color-amber-800: oklch(0.473 0.137 46.201); | |
--color-amber-900: oklch(0.414 0.112 45.904); | |
--color-amber-950: oklch(0.279 0.077 45.635); | |
--color-yellow-50: oklch(0.987 0.026 102.212); | |
--color-yellow-100: oklch(0.973 0.071 103.193); | |
--color-yellow-200: oklch(0.945 0.129 101.54); | |
--color-yellow-300: oklch(0.905 0.182 98.111); | |
--color-yellow-400: oklch(0.852 0.199 91.936); | |
--color-yellow-500: oklch(0.795 0.184 86.047); | |
--color-yellow-600: oklch(0.681 0.162 75.834); | |
--color-yellow-700: oklch(0.554 0.135 66.442); | |
--color-yellow-800: oklch(0.476 0.114 61.907); | |
--color-yellow-900: oklch(0.421 0.095 57.708); | |
--color-yellow-950: oklch(0.286 0.066 53.813); | |
--color-lime-50: oklch(0.986 0.031 120.757); | |
--color-lime-100: oklch(0.967 0.067 122.328); | |
--color-lime-200: oklch(0.938 0.127 124.321); | |
--color-lime-300: oklch(0.897 0.196 126.665); | |
--color-lime-400: oklch(0.841 0.238 128.85); | |
--color-lime-500: oklch(0.768 0.233 130.85); | |
--color-lime-600: oklch(0.648 0.2 131.684); | |
--color-lime-700: oklch(0.532 0.157 131.589); | |
--color-lime-800: oklch(0.453 0.124 130.933); | |
--color-lime-900: oklch(0.405 0.101 131.063); | |
--color-lime-950: oklch(0.274 0.072 132.109); | |
--color-green-50: oklch(0.982 0.018 155.826); | |
--color-green-100: oklch(0.962 0.044 156.743); | |
--color-green-200: oklch(0.925 0.084 155.995); | |
--color-green-300: oklch(0.871 0.15 154.449); | |
--color-green-400: oklch(0.792 0.209 151.711); | |
--color-green-500: oklch(0.723 0.219 149.579); | |
--color-green-600: oklch(0.627 0.194 149.214); | |
--color-green-700: oklch(0.527 0.154 150.069); | |
--color-green-800: oklch(0.448 0.119 151.328); | |
--color-green-900: oklch(0.393 0.095 152.535); | |
--color-green-950: oklch(0.266 0.065 152.934); | |
--color-emerald-50: oklch(0.979 0.021 166.113); | |
--color-emerald-100: oklch(0.95 0.052 163.051); | |
--color-emerald-200: oklch(0.905 0.093 164.15); | |
--color-emerald-300: oklch(0.845 0.143 164.978); | |
--color-emerald-400: oklch(0.765 0.177 163.223); | |
--color-emerald-500: oklch(0.696 0.17 162.48); | |
--color-emerald-600: oklch(0.596 0.145 163.225); | |
--color-emerald-700: oklch(0.508 0.118 165.612); | |
--color-emerald-800: oklch(0.432 0.095 166.913); | |
--color-emerald-900: oklch(0.378 0.077 168.94); | |
--color-emerald-950: oklch(0.262 0.051 172.552); | |
--color-teal-50: oklch(0.984 0.014 180.72); | |
--color-teal-100: oklch(0.953 0.051 180.801); | |
--color-teal-200: oklch(0.91 0.096 180.426); | |
--color-teal-300: oklch(0.855 0.138 181.071); | |
--color-teal-400: oklch(0.777 0.152 181.912); | |
--color-teal-500: oklch(0.704 0.14 182.503); | |
--color-teal-600: oklch(0.6 0.118 184.704); | |
--color-teal-700: oklch(0.511 0.096 186.391); | |
--color-teal-800: oklch(0.437 0.078 188.216); | |
--color-teal-900: oklch(0.386 0.063 188.416); | |
--color-teal-950: oklch(0.277 0.046 192.524); | |
--color-cyan-50: oklch(0.984 0.019 200.873); | |
--color-cyan-100: oklch(0.956 0.045 203.388); | |
--color-cyan-200: oklch(0.917 0.08 205.041); | |
--color-cyan-300: oklch(0.865 0.127 207.078); | |
--color-cyan-400: oklch(0.789 0.154 211.53); | |
--color-cyan-500: oklch(0.715 0.143 215.221); | |
--color-cyan-600: oklch(0.609 0.126 221.723); | |
--color-cyan-700: oklch(0.52 0.105 223.128); | |
--color-cyan-800: oklch(0.45 0.085 224.283); | |
--color-cyan-900: oklch(0.398 0.07 227.392); | |
--color-cyan-950: oklch(0.302 0.056 229.695); | |
--color-sky-50: oklch(0.977 0.013 236.62); | |
--color-sky-100: oklch(0.951 0.026 236.824); | |
--color-sky-200: oklch(0.901 0.058 230.902); | |
--color-sky-300: oklch(0.828 0.111 230.318); | |
--color-sky-400: oklch(0.746 0.16 232.661); | |
--color-sky-500: oklch(0.685 0.169 237.323); | |
--color-sky-600: oklch(0.588 0.158 241.966); | |
--color-sky-700: oklch(0.5 0.134 242.749); | |
--color-sky-800: oklch(0.443 0.11 240.79); | |
--color-sky-900: oklch(0.391 0.09 240.876); | |
--color-sky-950: oklch(0.293 0.066 243.157); | |
--color-blue-50: oklch(0.97 0.014 254.604); | |
--color-blue-100: oklch(0.932 0.032 255.585); | |
--color-blue-200: oklch(0.882 0.059 254.128); | |
--color-blue-300: oklch(0.809 0.105 251.813); | |
--color-blue-400: oklch(0.707 0.165 254.624); | |
--color-blue-500: oklch(0.623 0.214 259.815); | |
--color-blue-600: oklch(0.546 0.245 262.881); | |
--color-blue-700: oklch(0.488 0.243 264.376); | |
--color-blue-800: oklch(0.424 0.199 265.638); | |
--color-blue-900: oklch(0.379 0.146 265.522); | |
--color-blue-950: oklch(0.282 0.091 267.935); | |
--color-indigo-50: oklch(0.962 0.018 272.314); | |
--color-indigo-100: oklch(0.93 0.034 272.788); | |
--color-indigo-200: oklch(0.87 0.065 274.039); | |
--color-indigo-300: oklch(0.785 0.115 274.713); | |
--color-indigo-400: oklch(0.673 0.182 276.935); | |
--color-indigo-500: oklch(0.585 0.233 277.117); | |
--color-indigo-600: oklch(0.511 0.262 276.966); | |
--color-indigo-700: oklch(0.457 0.24 277.023); | |
--color-indigo-800: oklch(0.398 0.195 277.366); | |
--color-indigo-900: oklch(0.359 0.144 278.697); | |
--color-indigo-950: oklch(0.257 0.09 281.288); | |
--color-violet-50: oklch(0.969 0.016 293.756); | |
--color-violet-100: oklch(0.943 0.029 294.588); | |
--color-violet-200: oklch(0.894 0.057 293.283); | |
--color-violet-300: oklch(0.811 0.111 293.571); | |
--color-violet-400: oklch(0.702 0.183 293.541); | |
--color-violet-500: oklch(0.606 0.25 292.717); | |
--color-violet-600: oklch(0.541 0.281 293.009); | |
--color-violet-700: oklch(0.491 0.27 292.581); | |
--color-violet-800: oklch(0.432 0.232 292.759); | |
--color-violet-900: oklch(0.38 0.189 293.745); | |
--color-violet-950: oklch(0.283 0.141 291.089); | |
--color-purple-50: oklch(0.977 0.014 308.299); | |
--color-purple-100: oklch(0.946 0.033 307.174); | |
--color-purple-200: oklch(0.902 0.063 306.703); | |
--color-purple-300: oklch(0.827 0.119 306.383); | |
--color-purple-400: oklch(0.714 0.203 305.504); | |
--color-purple-500: oklch(0.627 0.265 303.9); | |
--color-purple-600: oklch(0.558 0.288 302.321); | |
--color-purple-700: oklch(0.496 0.265 301.924); | |
--color-purple-800: oklch(0.438 0.218 303.724); | |
--color-purple-900: oklch(0.381 0.176 304.987); | |
--color-purple-950: oklch(0.291 0.149 302.717); | |
--color-fuchsia-50: oklch(0.977 0.017 320.058); | |
--color-fuchsia-100: oklch(0.952 0.037 318.852); | |
--color-fuchsia-200: oklch(0.903 0.076 319.62); | |
--color-fuchsia-300: oklch(0.833 0.145 321.434); | |
--color-fuchsia-400: oklch(0.74 0.238 322.16); | |
--color-fuchsia-500: oklch(0.667 0.295 322.15); | |
--color-fuchsia-600: oklch(0.591 0.293 322.896); | |
--color-fuchsia-700: oklch(0.518 0.253 323.949); | |
--color-fuchsia-800: oklch(0.452 0.211 324.591); | |
--color-fuchsia-900: oklch(0.401 0.17 325.612); | |
--color-fuchsia-950: oklch(0.293 0.136 325.661); | |
--color-pink-50: oklch(0.971 0.014 343.198); | |
--color-pink-100: oklch(0.948 0.028 342.258); | |
--color-pink-200: oklch(0.899 0.061 343.231); | |
--color-pink-300: oklch(0.823 0.12 346.018); | |
--color-pink-400: oklch(0.718 0.202 349.761); | |
--color-pink-500: oklch(0.656 0.241 354.308); | |
--color-pink-600: oklch(0.592 0.249 0.584); | |
--color-pink-700: oklch(0.525 0.223 3.958); | |
--color-pink-800: oklch(0.459 0.187 3.815); | |
--color-pink-900: oklch(0.408 0.153 2.432); | |
--color-pink-950: oklch(0.284 0.109 3.907); | |
--color-rose-50: oklch(0.969 0.015 12.422); | |
--color-rose-100: oklch(0.941 0.03 12.58); | |
--color-rose-200: oklch(0.892 0.058 10.001); | |
--color-rose-300: oklch(0.81 0.117 11.638); | |
--color-rose-400: oklch(0.712 0.194 13.428); | |
--color-rose-500: oklch(0.645 0.246 16.439); | |
--color-rose-600: oklch(0.586 0.253 17.585); | |
--color-rose-700: oklch(0.514 0.222 16.935); | |
--color-rose-800: oklch(0.455 0.188 13.697); | |
--color-rose-900: oklch(0.41 0.159 10.272); | |
--color-rose-950: oklch(0.271 0.105 12.094); | |
--color-slate-50: oklch(0.984 0.003 247.858); | |
--color-slate-100: oklch(0.968 0.007 247.896); | |
--color-slate-200: oklch(0.929 0.013 255.508); | |
--color-slate-300: oklch(0.869 0.022 252.894); | |
--color-slate-400: oklch(0.704 0.04 256.788); | |
--color-slate-500: oklch(0.554 0.046 257.417); | |
--color-slate-600: oklch(0.446 0.043 257.281); | |
--color-slate-700: oklch(0.372 0.044 257.287); | |
--color-slate-800: oklch(0.279 0.041 260.031); | |
--color-slate-900: oklch(0.208 0.042 265.755); | |
--color-slate-950: oklch(0.129 0.042 264.695); | |
--color-gray-50: oklch(0.985 0.002 247.839); | |
--color-gray-100: oklch(0.967 0.003 264.542); | |
--color-gray-200: oklch(0.928 0.006 264.531); | |
--color-gray-300: oklch(0.872 0.01 258.338); | |
--color-gray-400: oklch(0.707 0.022 261.325); | |
--color-gray-500: oklch(0.551 0.027 264.364); | |
--color-gray-600: oklch(0.446 0.03 256.802); | |
--color-gray-700: oklch(0.373 0.034 259.733); | |
--color-gray-800: oklch(0.278 0.033 256.848); | |
--color-gray-900: oklch(0.21 0.034 264.665); | |
--color-gray-950: oklch(0.13 0.028 261.692); | |
--color-zinc-50: oklch(0.985 0 0); | |
--color-zinc-100: oklch(0.967 0.001 286.375); | |
--color-zinc-200: oklch(0.92 0.004 286.32); | |
--color-zinc-300: oklch(0.871 0.006 286.286); | |
--color-zinc-400: oklch(0.705 0.015 286.067); | |
--color-zinc-500: oklch(0.552 0.016 285.938); | |
--color-zinc-600: oklch(0.442 0.017 285.786); | |
--color-zinc-700: oklch(0.37 0.013 285.805); | |
--color-zinc-800: oklch(0.274 0.006 286.033); | |
--color-zinc-900: oklch(0.21 0.006 285.885); | |
--color-zinc-950: oklch(0.141 0.005 285.823); | |
--color-neutral-50: oklch(0.985 0 0); | |
--color-neutral-100: oklch(0.97 0 0); | |
--color-neutral-200: oklch(0.922 0 0); | |
--color-neutral-300: oklch(0.87 0 0); | |
--color-neutral-400: oklch(0.708 0 0); | |
--color-neutral-500: oklch(0.556 0 0); | |
--color-neutral-600: oklch(0.439 0 0); | |
--color-neutral-700: oklch(0.371 0 0); | |
--color-neutral-800: oklch(0.269 0 0); | |
--color-neutral-900: oklch(0.205 0 0); | |
--color-neutral-950: oklch(0.145 0 0); | |
--color-stone-50: oklch(0.985 0.001 106.423); | |
--color-stone-100: oklch(0.97 0.001 106.424); | |
--color-stone-200: oklch(0.923 0.003 48.717); | |
--color-stone-300: oklch(0.869 0.005 56.366); | |
--color-stone-400: oklch(0.709 0.01 56.259); | |
--color-stone-500: oklch(0.553 0.013 58.071); | |
--color-stone-600: oklch(0.444 0.011 73.639); | |
--color-stone-700: oklch(0.374 0.01 67.558); | |
--color-stone-800: oklch(0.268 0.007 34.298); | |
--color-stone-900: oklch(0.216 0.006 56.043); | |
--color-stone-950: oklch(0.147 0.004 49.25); | |
--color-black: #000; | |
--color-white: #fff; | |
} | |
``` | |
This can be useful if you want to reuse any of these scales but under a different name, like redefining `--color-gray-*` to use the `--color-slate-*` scale. | |
--- | |
File: /src/docs/columns.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
import { CustomizingYourTheme } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
import { UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "columns"; | |
export const description = "Utilities for controlling the number of columns within an element."; | |
<ApiTable | |
rows={[ | |
["columns-<number>", "columns: <number>;"], | |
["columns-3xs", "columns: var(--container-3xs); /* 16rem (256px) */"], | |
["columns-2xs", "columns: var(--container-2xs); /* 18rem (288px) */"], | |
["columns-xs", "columns: var(--container-xs); /* 20rem (320px) */"], | |
["columns-sm", "columns: var(--container-sm); /* 24rem (384px) */"], | |
["columns-md", "columns: var(--container-md); /* 28rem (448px) */"], | |
["columns-lg", "columns: var(--container-lg); /* 32rem (512px) */"], | |
["columns-xl", "columns: var(--container-xl); /* 36rem (576px) */"], | |
["columns-2xl", "columns: var(--container-2xl); /* 42rem (672px) */"], | |
["columns-3xl", "columns: var(--container-3xl); /* 48rem (768px) */"], | |
["columns-4xl", "columns: var(--container-4xl); /* 56rem (896px) */"], | |
["columns-5xl", "columns: var(--container-5xl); /* 64rem (1024px) */"], | |
["columns-6xl", "columns: var(--container-6xl); /* 72rem (1152px) */"], | |
["columns-7xl", "columns: var(--container-7xl); /* 80rem (1280px) */"], | |
["columns-auto", "columns: auto;"], | |
["columns-(<custom-property>)", "columns: var(<custom-property>);"], | |
["columns-[<value>]", "columns: <value>;"], | |
]} | |
/> | |
## Examples | |
### Setting by number | |
Use `columns-<number>` utilities like `columns-3` to set the number of columns that should be created for the content within an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="@container relative"> | |
<div className="absolute inset-0 -top-8 -bottom-8 grid grid-cols-3 gap-[5cqw]"> | |
<Stripes border="x" /> | |
<Stripes border="x" /> | |
<Stripes border="x" /> | |
</div> | |
<div className="relative -mb-[5cqw] columns-3 gap-[5cqw] *:mb-[5cqw]"> | |
<img | |
className="aspect-3/2 rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1454496522488-7a8e488e8606?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2952&q=80" | |
/> | |
<img | |
className="aspect-square rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1434394354979-a235cd36269d?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2902&q=80" | |
/> | |
<img | |
className="aspect-square rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1491904768633-2b7e3e7fede5?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=3131&q=80" | |
/> | |
<img | |
className="aspect-square rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1463288889890-a56b2853c40f?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=3132&q=80" | |
/> | |
<img | |
className="aspect-3/2 rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1611605645802-c21be743c321?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2940&q=80" | |
/> | |
<img | |
className="aspect-square rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1498603993951-8a027a8a8f84?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2936&q=80" | |
/> | |
<img | |
className="aspect-square rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1526400473556-aac12354f3db?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2940&q=80" | |
/> | |
<img | |
className="aspect-square rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1617369120004-4fc70312c5e6?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=1587&q=80" | |
/> | |
<img | |
className="aspect-3/2 rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1518892096458-a169843d7f7f?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2940&q=80" | |
/> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:columns-3] --> | |
<div class="columns-3 ..."> | |
<img class="aspect-3/2 ..." src="/img/mountains-1.jpg" /> | |
<img class="aspect-square ..." src="/img/mountains-2.jpg" /> | |
<img class="aspect-square ..." src="/img/mountains-3.jpg" /> | |
<!-- ... --> | |
</div> | |
``` | |
</Figure> | |
The column width will automatically adjust to accommodate the specified number of columns. | |
### Setting by width | |
Use utilities like `columns-xs` and `columns-sm` to set the ideal column width for the content within an element: | |
<Figure desktopHint="Resize the example to see the expected behavior"> | |
<Example resizable> | |
{ | |
<div className="@container relative"> | |
<div className="absolute inset-0 -top-8 -bottom-8 grid grid-cols-1 gap-8 @[34rem]:grid-cols-2"> | |
<Stripes border="x" /> | |
<Stripes border="x" /> | |
<Stripes border="x" className="@[34rem]:hidden" /> | |
</div> | |
<div className="relative -mb-4 columns-3xs gap-4 *:mb-4 @sm:-mb-8 @sm:gap-8 @sm:*:mb-8"> | |
<img | |
className="aspect-3/2 w-full rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1454496522488-7a8e488e8606?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2952&q=80" | |
/> | |
<img | |
className="aspect-square w-full rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1434394354979-a235cd36269d?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2902&q=80" | |
/> | |
<img | |
className="aspect-square w-full rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1491904768633-2b7e3e7fede5?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=3131&q=80" | |
/> | |
<img | |
className="aspect-3/2 w-full rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1463288889890-a56b2853c40f?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=3132&q=80" | |
/> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:columns-3xs] --> | |
<div class="columns-3xs ..."> | |
<img class="aspect-3/2 ..." src="/img/mountains-1.jpg" /> | |
<img class="aspect-square ..." src="/img/mountains-2.jpg" /> | |
<img class="aspect-square ..." src="/img/mountains-3.jpg" /> | |
<!-- ... --> | |
</div> | |
``` | |
</Figure> | |
When setting the column width, the number of columns automatically adjusts to ensure they don't get too narrow. | |
### Setting the column gap | |
Use the `gap-<width>` utilities to specify the width between columns: | |
<Figure> | |
<Example> | |
{ | |
<div className="@container relative"> | |
<div className="absolute inset-0 -top-8 -bottom-8 grid grid-cols-[1fr_2rem_1fr_2rem_1fr]"> | |
<div /> | |
<Stripes border="x" /> | |
<div /> | |
<Stripes border="x" /> | |
<div /> | |
</div> | |
<div className="relative -mb-8 columns-3 gap-8 *:mb-8"> | |
<img | |
className="aspect-3/2 rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1454496522488-7a8e488e8606?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2952&q=80" | |
/> | |
<img | |
className="aspect-square rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1434394354979-a235cd36269d?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2902&q=80" | |
/> | |
<img | |
className="aspect-square rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1491904768633-2b7e3e7fede5?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=3131&q=80" | |
/> | |
<img | |
className="aspect-square rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1463288889890-a56b2853c40f?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=3132&q=80" | |
/> | |
<img | |
className="aspect-3/2 rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1611605645802-c21be743c321?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2940&q=80" | |
/> | |
<img | |
className="aspect-square rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1498603993951-8a027a8a8f84?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2936&q=80" | |
/> | |
<img | |
className="aspect-square rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1526400473556-aac12354f3db?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2940&q=80" | |
/> | |
<img | |
className="aspect-square rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1617369120004-4fc70312c5e6?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=1587&q=80" | |
/> | |
<img | |
className="aspect-3/2 rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1518892096458-a169843d7f7f?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2940&q=80" | |
/> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:gap-8] --> | |
<div class="columns-3 gap-8 ..."> | |
<img class="aspect-3/2 ..." src="/img/mountains-1.jpg" /> | |
<img class="aspect-square ..." src="/img/mountains-2.jpg" /> | |
<img class="aspect-square ..." src="/img/mountains-3.jpg" /> | |
<!-- ... --> | |
</div> | |
``` | |
</Figure> | |
Learn more about the gap utilities in the [gap documentation](/docs/gap). | |
### Using a custom value | |
<UsingACustomValue utility="columns" value="30vw" /> | |
### Responsive design | |
<ResponsiveDesign property="columns" breakpoint="sm" featuredClass="aspect-square"> | |
<Figure desktopHint="Resize the example to see the expected behavior"> | |
<Example resizable> | |
{ | |
<div className="@container relative"> | |
<div className="absolute inset-0 -top-8 -bottom-8 grid grid-cols-2 gap-4 @sm:grid-cols-3 @sm:gap-8"> | |
<Stripes border="x" /> | |
<Stripes border="x" /> | |
<Stripes border="x" className="@max-sm:hidden" /> | |
</div> | |
<div className="relative columns-2 gap-4 *:mb-4 @sm:-mb-8 @sm:columns-3 @sm:gap-8 @sm:*:mb-8"> | |
<img | |
className="aspect-3/2 rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1454496522488-7a8e488e8606?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2952&q=80" | |
/> | |
<img | |
className="aspect-square rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1434394354979-a235cd36269d?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2902&q=80" | |
/> | |
<img | |
className="aspect-square rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1491904768633-2b7e3e7fede5?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=3131&q=80" | |
/> | |
<img | |
className="aspect-square rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1463288889890-a56b2853c40f?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=3132&q=80" | |
/> | |
<img | |
className="aspect-3/2 rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1611605645802-c21be743c321?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2940&q=80" | |
/> | |
<img | |
className="aspect-square rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1498603993951-8a027a8a8f84?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2936&q=80" | |
/> | |
<img | |
className="aspect-square rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1526400473556-aac12354f3db?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2940&q=80" | |
/> | |
<img | |
className="aspect-square rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1617369120004-4fc70312c5e6?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=1587&q=80" | |
/> | |
<img | |
className="aspect-3/2 rounded-lg bg-black/5 object-cover outline -outline-offset-1 outline-black/10 dark:outline-0" | |
src="https://images.unsplash.com/photo-1518892096458-a169843d7f7f?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=2940&q=80" | |
/> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:sm:gap-8,sm:columns-3] --> | |
<div class="columns-2 gap-4 sm:columns-3 sm:gap-8 ..."> | |
<img class="aspect-3/2 ..." src="/img/mountains-1.jpg" /> | |
<img class="aspect-square ..." src="/img/mountains-2.jpg" /> | |
<img class="aspect-square ..." src="/img/mountains-3.jpg" /> | |
<!-- ... --> | |
</div> | |
``` | |
</Figure> | |
</ResponsiveDesign> | |
## Customizing your theme | |
<CustomizingYourTheme | |
utility="columns" | |
themeKey="container" | |
name="fixed-width column" | |
customName="4xs" | |
customValue="14rem" | |
/> | |
--- | |
File: /src/docs/compatibility.mdx | |
--- | |
import { TipGood, TipBad, TipCompat, TipInfo } from "@/components/tips"; | |
export const title = "Compatibility"; | |
export const description = "Learn about browser support and compatibility with other tooling."; | |
## Browser support | |
Tailwind CSS v4.0 is designed for and tested on modern browsers, and the core functionality of the framework specifically depends on these browser versions: | |
- **Chrome 111** _(released March 2023)_ | |
- **Safari 16.4** _(released March 2023)_ | |
- **Firefox 128** _(released July 2024)_ | |
Tailwind also includes support for many bleeding-edge platform features like `field-sizing: content`, `@starting-style`, and `text-wrap: balance` that have limited browser support. It's up to you if you want to use these modern features in your projects — if the browsers you're targeting don't support them, simply don't use those utilities and variants. | |
If you're unsure about the support for a modern platform feature, the [Can I use](https://caniuse.com/mdn-css_at-rules_starting-style) database is a great resource. | |
## Sass, Less, and Stylus | |
Tailwind CSS v4.0 is a full-featured CSS build tool designed for a specific workflow, and is not designed to be used with CSS preprocessors like Sass, Less, or Stylus. | |
**Think of Tailwind CSS itself as your preprocessor** — you shouldn't use Tailwind with Sass for the same reason you wouldn't use Sass with Stylus. | |
Since Tailwind is designed for modern browsers, you actually don't need a preprocessor for things like nesting or variables, and Tailwind itself will do things like bundle your imports and add vendor prefixes. | |
### Build-time imports | |
Tailwind will automatically bundle other CSS files you include with `@import`, without the need for a separate preprocessing tool. | |
```css | |
/* [!code filename:app.css] */ | |
@import "tailwindcss"; | |
@import "./typography.css"; | |
``` | |
In this example, the `typography.css` file will be bundled into your compiled CSS for you by Tailwind, without any other tooling like Sass or `postcss-import`. | |
### Variables | |
All modern browsers support [native CSS variables](https://developer.mozilla.org/en-US/docs/Web/CSS/Using_CSS_custom_properties) without the need for any sort of preprocessor: | |
```css | |
/* [!code filename:typography.css] */ | |
/* [!code word:var(--text-base)] */ | |
.typography { | |
font-size: var(--text-base); | |
color: var(--color-gray-700); | |
} | |
``` | |
Tailwind relies on CSS variables heavily internally, so if you can use Tailwind in your project, you can use native CSS variables. | |
### Nesting | |
Under the hood Tailwind uses [Lightning CSS](https://lightningcss.dev/) to process nested CSS like this: | |
```css | |
/* [!code filename:typography.css] */ | |
.typography { | |
p { | |
font-size: var(--text-base); | |
} | |
img { | |
border-radius: var(--radius-lg); | |
} | |
} | |
``` | |
Tailwind flattens that nested CSS for you so it can be understood by all modern browsers: | |
```css | |
[!code filename:output.css] | |
/* prettier-ignore */ | |
.typography p { | |
font-size: var(--text-base); | |
} | |
.typography img { | |
border-radius: var(--radius-lg); | |
} | |
``` | |
Native CSS nesting support is also very good these days, so you don't really need a preprocessor for nesting even if you aren't using Tailwind. | |
### Loops | |
In Tailwind, the sorts of classes you may have used loops for in the past (like `col-span-1`, `col-span-2`, etc.) are generated for you on-demand by Tailwind whenever you use them instead of having to be predefined. | |
On top of that, when you're building things with Tailwind CSS, you do the vast majority of your styling in your HTML, not in CSS files. Since you're not writing tons of CSS in the first place, you just don't need features like loops that are designed for programmatically generating lots of custom CSS rules. | |
### Color and math functions | |
When using preprocessors like Sass or Less, you may have used functions like `darken` or `lighten` to adjust colors. | |
When using Tailwind, the recommended workflow is to use a predefined color palette that includes light and dark shades of each color, like the expertly designed [default color palette](/docs/colors) included with the framework. | |
```html | |
<!-- [!code word:hover\:bg-indigo-600] --> | |
<button class="bg-indigo-500 hover:bg-indigo-600 ..."> | |
<!-- ... --> | |
</button> | |
``` | |
You can also use modern CSS features like [color-mix()](https://developer.mozilla.org/en-US/docs/Web/CSS/color_value/color-mix) to adjust colors at run-time directly in the browser. This even lets you adjust colors defined using CSS variables or the `currentcolor` keyword, which isn't possible with preprocessors. | |
Similarly, browsers support math functions like `min()`, `max()`, and `round()` natively now, so there's no need to rely on a preprocessor for these features anymore either. | |
## CSS modules | |
Tailwind is compatible with CSS modules and can co-exist with them if you are introducing Tailwind into a project that already uses them, but **we don't recommend using CSS modules and Tailwind together** if you can avoid it. | |
### Scoping concerns | |
CSS modules are designed to solve scoping problems that just don't exist when composing utility classes in your HTML instead of writing custom CSS. | |
Styles are naturally scoped with Tailwind because each utility class always does the same thing, no matter where it's used — there's no risk that adding a utility class to one part of your UI creates some unexpected side effect somewhere else. | |
### Performance | |
When using CSS modules, build tools like Vite, Parcel, and Turbopack process each CSS module separately. That means if you have 50 CSS modules in a project, **Tailwind needs to run 50 separate times**, which leads to much slower build times and a worse developer experience. | |
### Explicit context sharing | |
Since CSS modules are each processed separately, they have no `@theme` unless you import one. | |
This means features like `@apply` won't work the way you expect unless you explicitly import your global styles as reference: | |
<TipInfo>{<>Import your global styles as reference to make sure your theme variables are defined</>}</TipInfo> | |
```css | |
/* [!code filename:Button.module.css] */ | |
/* [!code highlight:2] */ | |
@reference "../app.css"; | |
button { | |
@apply bg-blue-500; | |
} | |
``` | |
Alternatively, you can also just use CSS variables instead of `@apply` which has the added benefit of letting Tailwind skip processing those files and will improve your build performance: | |
```css | |
/* [!code filename:Button.module.css] */ | |
button { | |
/* [!code highlight:2] */ | |
background: var(--color-blue-500); | |
} | |
``` | |
## Vue, Svelte, and Astro | |
Vue, Svelte, and Astro support `<style>` blocks in component files that behave very much like [CSS modules](#css-modules), which means they are each processed by your build tooling totally separately and have all of the same drawbacks. | |
If you're using Tailwind with these tools, **we recommend avoiding `<style>` blocks in your components** and just styling things with utility classes directly in your markup, the way Tailwind is meant to be used. | |
If you do use `<style>` blocks, make sure to import your global styles as reference if you want features like `@apply` to work as expected: | |
<TipInfo | |
children={`Import your global styles as reference to make sure your theme variables are | |
defined`} | |
/> | |
```html | |
<!-- [!code filename:Button.vue] --> | |
<template> | |
<button><slot /></button> | |
</template> | |
<style scoped> | |
/* [!code highlight:2] */ | |
@reference "../app.css"; | |
button { | |
@apply bg-blue-500; | |
} | |
</style> | |
``` | |
Or just use your globally defined CSS variables instead of features like `@apply`, which don't require Tailwind to process your component CSS at all: | |
```html | |
<!-- [!code filename:Button.vue] --> | |
<template> | |
<button><slot /></button> | |
</template> | |
<style scoped> | |
button { | |
/* [!code highlight:2] */ | |
background-color: var(--color-blue-500); | |
} | |
</style> | |
``` | |
--- | |
File: /src/docs/content.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourTheme } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "content"; | |
export const description = "Utilities for controlling the content of the before and after pseudo-elements."; | |
<ApiTable | |
rows={[ | |
["content-[<value>]", "content: <value>;"], | |
["content-(<custom-property>)", "content: var(<custom-property>);"], | |
["content-none", "content: none;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use the `content-[<value>]` syntax, along with the `before` and `after` variants, to set the contents of the `::before` and `::after` pseudo-elements: | |
<Figure> | |
<Example> | |
{ | |
<div className="mx-auto w-full max-w-md text-gray-500 dark:text-gray-400"> | |
Higher resolution means more than just a better-quality image. With a Retina 6K display,{" "} | |
<a | |
href="https://www.apple.com/pro-display-xdr/" | |
className="font-medium text-blue-600 after:text-sm after:font-bold after:content-['_↗'] dark:text-sky-400" | |
target="_blank" | |
> | |
Pro Display XDR | |
</a>{" "} | |
gives you nearly 40 percent more screen real estate than a 5K display. | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:after:content-['_↗']] --> | |
<!-- prettier-ignore --> | |
<p>Higher resolution means more than just a better-quality image. With a | |
Retina 6K display, <a class="text-blue-600 after:content-['_↗']" href="..."> | |
Pro Display XDR</a> gives you nearly 40 percent more screen real estate than | |
a 5K display.</p> | |
``` | |
</Figure> | |
### Referencing an attribute value | |
Use the `content-[attr(<name>)]` syntax to reference a value stored in an attribute using the `attr()` CSS function: | |
<Figure> | |
<Example> | |
{ | |
<p | |
before="Hello World" | |
className="text-center font-semibold text-gray-900 before:content-[attr(before)] dark:text-gray-200" | |
/> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:before:content-[attr(before)]] --> | |
<p before="Hello World" class="before:content-[attr(before)] ..."> | |
<!-- ... --> | |
</p> | |
``` | |
</Figure> | |
### Using spaces and underscores | |
Since whitespace denotes the end of a class in HTML, replace any spaces in an arbitrary value with an underscore: | |
<Figure> | |
<Example> | |
{<p className="text-center font-semibold text-gray-900 before:content-['Hello_World'] dark:text-gray-200" />} | |
</Example> | |
```html | |
<!-- [!code classes:before:content-['Hello_World']] --> | |
<p class="before:content-['Hello_World'] ..."></p> | |
``` | |
</Figure> | |
If you need to include an actual underscore, you can do this by escaping it with a backslash: | |
<Figure> | |
<Example> | |
{<p className="text-center font-semibold text-gray-900 before:content-['Hello\_World'] dark:text-gray-200" />} | |
</Example> | |
```html | |
<!-- [!code classes:before:content-['Hello\_World']] --> | |
<p class="before:content-['Hello\_World']"></p> | |
``` | |
</Figure> | |
### Using a CSS variable | |
Use the <code>content-{'(<custom-property>)'}</code> syntax to control the contents of the `::before` and `::after` pseudo-elements using a CSS variable: | |
```html | |
<!-- [!code classes:content-(--my-content)] --> | |
<p class="content-(--my-content)"></p> | |
``` | |
This is just a shorthand for <code>content-{'[var(<custom-property>)]'}</code> that adds the `var()` function for you automatically. | |
### Responsive design | |
<ResponsiveDesign property="content"> | |
```html | |
<!-- [!code classes:md:before:content-['Desktop']] --> | |
<p class="before:content-['Mobile'] md:before:content-['Desktop'] ..."></p> | |
``` | |
</ResponsiveDesign> | |
--- | |
File: /src/docs/cursor.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "cursor"; | |
export const description = "Utilities for controlling the cursor style when hovering over an element."; | |
<ApiTable | |
rows={[ | |
["cursor-auto", "cursor: auto;"], | |
["cursor-default", "cursor: default;"], | |
["cursor-pointer", "cursor: pointer;"], | |
["cursor-wait", "cursor: wait;"], | |
["cursor-text", "cursor: text;"], | |
["cursor-move", "cursor: move;"], | |
["cursor-help", "cursor: help;"], | |
["cursor-not-allowed", "cursor: not-allowed;"], | |
["cursor-none", "cursor: none;"], | |
["cursor-context-menu", "cursor: context-menu;"], | |
["cursor-progress", "cursor: progress;"], | |
["cursor-cell", "cursor: cell;"], | |
["cursor-crosshair", "cursor: crosshair;"], | |
["cursor-vertical-text", "cursor: vertical-text;"], | |
["cursor-alias", "cursor: alias;"], | |
["cursor-copy", "cursor: copy;"], | |
["cursor-no-drop", "cursor: no-drop;"], | |
["cursor-grab", "cursor: grab;"], | |
["cursor-grabbing", "cursor: grabbing;"], | |
["cursor-all-scroll", "cursor: all-scroll;"], | |
["cursor-col-resize", "cursor: col-resize;"], | |
["cursor-row-resize", "cursor: row-resize;"], | |
["cursor-n-resize", "cursor: n-resize;"], | |
["cursor-e-resize", "cursor: e-resize;"], | |
["cursor-s-resize", "cursor: s-resize;"], | |
["cursor-w-resize", "cursor: w-resize;"], | |
["cursor-ne-resize", "cursor: ne-resize;"], | |
["cursor-nw-resize", "cursor: nw-resize;"], | |
["cursor-se-resize", "cursor: se-resize;"], | |
["cursor-sw-resize", "cursor: sw-resize;"], | |
["cursor-ew-resize", "cursor: ew-resize;"], | |
["cursor-ns-resize", "cursor: ns-resize;"], | |
["cursor-nesw-resize", "cursor: nesw-resize;"], | |
["cursor-nwse-resize", "cursor: nwse-resize;"], | |
["cursor-zoom-in", "cursor: zoom-in;"], | |
["cursor-zoom-out", "cursor: zoom-out;"], | |
["cursor-(<custom-property>)", "cursor: var(<custom-property>);"], | |
["cursor-[<value>]", "cursor: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `cursor-pointer` and `cursor-grab` to control which cursor is displayed when hovering over an element: | |
<Figure hint="Hover over each button to see the cursor change"> | |
<Example> | |
{ | |
<div className="flex flex-col items-center justify-around gap-4 sm:flex-row sm:gap-0"> | |
<button | |
type="button" | |
className="w-full cursor-pointer rounded-md bg-indigo-600 px-3 py-2 text-sm font-semibold text-white hover:bg-indigo-700 focus:outline-none disabled:bg-indigo-300 sm:w-auto dark:disabled:bg-indigo-800 dark:disabled:text-indigo-400" | |
tabIndex="-1" | |
> | |
Submit | |
</button> | |
<button | |
type="button" | |
className="w-full cursor-progress rounded-md bg-indigo-600 px-3 py-2 text-sm font-semibold text-white hover:bg-indigo-700 focus:outline-none disabled:bg-indigo-300 sm:w-auto dark:disabled:bg-indigo-800 dark:disabled:text-indigo-400" | |
tabIndex="-1" | |
> | |
Saving... | |
</button> | |
<button | |
type="button" | |
disabled | |
className="w-full cursor-not-allowed rounded-md bg-indigo-600 px-3 py-2 text-sm font-semibold text-white hover:bg-indigo-700 focus:outline-none disabled:bg-indigo-300 sm:w-auto dark:disabled:bg-indigo-800 dark:disabled:text-indigo-400" | |
tabIndex="-1" | |
> | |
Confirm | |
</button> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:cursor-pointer,cursor-progress,cursor-not-allowed] --> | |
<button class="cursor-pointer ...">Submit</button> | |
<button class="cursor-progress ...">Saving...</button> | |
<button class="cursor-not-allowed ..." disabled>Confirm</button> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue element="button" utility="cursor" value="url(hand.cur),_pointer" /> | |
### Responsive design | |
<ResponsiveDesign element="button" property="cursor" defaultClass="cursor-not-allowed" featuredClass="cursor-auto" /> | |
--- | |
File: /src/docs/dark-mode.mdx | |
--- | |
import { TipGood, TipBad, TipInfo } from "@/components/tips"; | |
import { Iframe } from "@/components/iframe"; | |
import { Example } from "@/components/example"; | |
import { Figure } from "@/components/figure"; | |
export const title = "Dark mode"; | |
export const description = "Using variants to style your site in dark mode."; | |
## Overview | |
Now that dark mode is a first-class feature of many operating systems, it's becoming more and more common to design a dark version of your website to go along with the default design. | |
To make this as easy as possible, Tailwind includes a `dark` variant that lets you style your site differently when dark mode is enabled: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="grid grid-cols-1 sm:grid-cols-2"> | |
<div className="p-8 pt-7"> | |
<p className="mb-2 text-sm font-medium text-gray-500">Light mode</p> | |
<div className="rounded-lg bg-white px-6 py-8 shadow-xl ring ring-gray-900/5"> | |
<div> | |
<span className="inline-flex items-center justify-center rounded-md bg-indigo-500 p-2 shadow-lg"> | |
<svg | |
className="h-6 w-6 text-white" | |
xmlns="http://www.w3.org/2000/svg" | |
fill="none" | |
viewBox="0 0 24 24" | |
stroke="currentColor" | |
aria-hidden="true" | |
> | |
<path | |
strokeLinecap="round" | |
strokeLinejoin="round" | |
strokeWidth="2" | |
d="M11 5H6a2 2 0 00-2 2v11a2 2 0 002 2h11a2 2 0 002-2v-5m-1.414-9.414a2 2 0 112.828 2.828L11.828 15H9v-2.828l8.586-8.586z" | |
/> | |
</svg> | |
</span> | |
</div> | |
<p className="mt-5 text-base font-medium tracking-tight text-gray-900">Writes upside-down</p> | |
<p | |
className="mt-2 text-sm text-gray-500" | |
children={`The Zero Gravity Pen can be used to write in any orientation, | |
including upside-down. It even works in outer space.`} | |
/> | |
</div> | |
</div> | |
<div className="bg-gray-900 p-8 pt-7"> | |
<p className="mb-2 text-sm font-medium text-gray-400">Dark mode</p> | |
<div className="rounded-lg bg-gray-800 px-6 py-8 shadow-xl ring ring-gray-900/5"> | |
<div> | |
<span className="inline-flex items-center justify-center rounded-md bg-indigo-500 p-2 shadow-lg"> | |
<svg | |
className="h-6 w-6 text-white" | |
xmlns="http://www.w3.org/2000/svg" | |
fill="none" | |
viewBox="0 0 24 24" | |
stroke="currentColor" | |
aria-hidden="true" | |
> | |
<path | |
strokeLinecap="round" | |
strokeLinejoin="round" | |
strokeWidth="2" | |
d="M11 5H6a2 2 0 00-2 2v11a2 2 0 002 2h11a2 2 0 002-2v-5m-1.414-9.414a2 2 0 112.828 2.828L11.828 15H9v-2.828l8.586-8.586z" | |
/> | |
</svg> | |
</span> | |
</div> | |
<p className="mt-5 text-base font-medium tracking-tight text-white">Writes upside-down</p> | |
<p | |
className="mt-2 text-sm text-gray-400" | |
children={`The Zero Gravity Pen can be used to write in any orientation, | |
including upside-down. It even works in outer space.`} | |
/> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code word:dark\:bg-gray-800] --> | |
<!-- prettier-ignore --> | |
<div class="bg-white dark:bg-gray-800 rounded-lg px-6 py-8 ring shadow-xl ring-gray-900/5"> | |
<div> | |
<span class="inline-flex items-center justify-center rounded-md bg-indigo-500 p-2 shadow-lg"> | |
<svg class="h-6 w-6 stroke-white" ...> | |
<!-- ... --> | |
</svg> | |
</span> | |
</div> | |
<!-- prettier-ignore --> | |
<!-- [!code word:dark\:text-white] --> | |
<h3 class="text-gray-900 dark:text-white mt-5 text-base font-medium tracking-tight ">Writes upside-down</h3> | |
<!-- prettier-ignore --> | |
<!-- [!code word:dark\:text-gray-400] --> | |
<p class="text-gray-500 dark:text-gray-400 mt-2 text-sm "> | |
The Zero Gravity Pen can be used to write in any orientation, including upside-down. It even works in outer space. | |
</p> | |
</div> | |
``` | |
</Figure> | |
By default this uses the `prefers-color-scheme` CSS media feature, but you can also build sites that support [toggling dark mode manually](#toggling-dark-mode-manually) by overriding the dark variant. | |
## Toggling dark mode manually | |
If you want your dark theme to be driven by a CSS selector instead of the `prefers-color-scheme` media query, override the `dark` variant to use your custom selector: | |
```css | |
/* [!code filename:app.css] */ | |
@import "tailwindcss"; | |
/* [!code highlight:2] */ | |
@custom-variant dark (&:where(.dark, .dark *)); | |
``` | |
Now instead of `dark:*` utilities being applied based on `prefers-color-scheme`, they will be applied whenever the `dark` class is present earlier in the HTML tree: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code word:dark\:bg-black] --> | |
<!-- [!code word:dark] --> | |
<html class="dark"> | |
<body> | |
<div class="bg-white dark:bg-black"> | |
<!-- ... --> | |
</div> | |
</body> | |
</html> | |
``` | |
How you add the `dark` class to the `html` element is up to you, but a common approach is to use a bit of JavaScript that updates the `class` attribute and syncs that preference to somewhere like `localStorage`. | |
### Using a data attribute | |
To use a data attribute instead of a class to activate dark mode, just override the `dark` variant with an attribute selector instead: | |
```css | |
/* [!code filename:app.css] */ | |
@import "tailwindcss"; | |
/* [!code highlight:2] */ | |
@custom-variant dark (&:where([data-theme=dark], [data-theme=dark] *)); | |
``` | |
Now dark mode utilities will be applied whenever the `data-theme` attribute is set to `dark` somewhere up the tree: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code word:dark\:bg-black] --> | |
<!-- [!code word:data-theme="dark"] --> | |
<html data-theme="dark"> | |
<body> | |
<div class="bg-white dark:bg-black"> | |
<!-- ... --> | |
</div> | |
</body> | |
</html> | |
``` | |
### With system theme support | |
To build three-way theme toggles that support light mode, dark mode, and your system theme, use a custom dark mode selector and the [`window.matchMedia()` API](https://developer.mozilla.org/en-US/docs/Web/API/Window/matchMedia) to detect the system theme and update the `html` element when needed. | |
Here's a simple example of how you can support light mode, dark mode, as well as respecting the operating system preference: | |
```js | |
// [!code filename:spaghetti.js] | |
// On page load or when changing themes, best to add inline in `head` to avoid FOUC | |
document.documentElement.classList.toggle( | |
"dark", | |
localStorage.theme === "dark" || | |
(!("theme" in localStorage) && window.matchMedia("(prefers-color-scheme: dark)").matches), | |
); | |
// Whenever the user explicitly chooses light mode | |
localStorage.theme = "light"; | |
// Whenever the user explicitly chooses dark mode | |
localStorage.theme = "dark"; | |
// Whenever the user explicitly chooses to respect the OS preference | |
localStorage.removeItem("theme"); | |
``` | |
Again you can manage this however you like, even storing the preference server-side in a database and rendering the class on the server — it's totally up to you. | |
--- | |
File: /src/docs/detecting-classes-in-source-files.mdx | |
--- | |
import { TipGood, TipBad, TipInfo } from "@/components/tips"; | |
import { Iframe } from "@/components/iframe"; | |
import { Example } from "@/components/example"; | |
import { Figure } from "@/components/figure"; | |
import { CodeExampleStack } from "@/components/code-example"; | |
export const title = "Detecting classes in source files"; | |
export const description = "Understanding and customizing how Tailwind scans your source files."; | |
## Overview | |
Tailwind works by scanning your project for utility classes, then generating all of the necessary CSS based on the classes you've actually used. | |
This makes sure your CSS is as small as possible, and is also what makes features like [arbitrary values](/docs/adding-custom-styles#using-arbitrary-values) possible. | |
### How classes are detected | |
Tailwind treats all of your source files as plain text, and doesn't attempt to actually parse your files as code in any way. | |
Instead it just looks for any tokens in your file that could be classes based on which characters Tailwind is expecting in class names: | |
```jsx | |
// [!code filename:JSX] | |
// [!code word:bg-blue-500] | |
// [!code word:rounded-full] | |
// [!code word:text-white] | |
// [!code word:text-black] | |
// [!code word:font-medium] | |
// [!code word:text-sm\/6] | |
// [!code word:font-sans] | |
// [!code word:bg-black] | |
// [!code word:bg-white] | |
// [!code word:className] | |
// [!code word:function] | |
// [!code word:children] | |
// [!code word:button] | |
// [!code word:shadow] | |
// [!code word:export] | |
// [!code word:colors] | |
// [!code word:color] | |
// [!code word:black] | |
// [!code word:white] | |
// [!code word:const] | |
// [!code word:blue] | |
// [!code word:return] | |
// [!code word:py-1.5] | |
// [!code word:px-2] | |
export function Button({ color, children }) { | |
const colors = { | |
black: "bg-black text-white", | |
blue: "bg-blue-500 text-white", | |
white: "bg-white text-black", | |
}; | |
return ( | |
<button className={`${colors[color]} rounded-full px-2 py-1.5 font-sans text-sm/6 font-medium shadow`}> | |
{children} | |
</button> | |
); | |
} | |
``` | |
Then it tries to generate the CSS for all of these tokens, throwing away any tokens that don't map to a utility class the framework knows about. | |
### Dynamic class names | |
Since Tailwind scans your source files as plain text, it has no way of understanding string concatenation or interpolation in the programming language you're using. | |
<TipBad>{<>Don't construct class names dynamically</>}</TipBad> | |
```html | |
<!-- [!code filename:HTML] --> | |
<div class="text-{{ error ? 'red' : 'green' }}-600"></div> | |
``` | |
In the example above, the strings `text-red-600` and `text-green-600` do not exist, so Tailwind will not generate those classes. | |
Instead, make sure any class names you’re using exist in full: | |
<TipGood>{<>Always use complete class names</>}</TipGood> | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code word:text-red-600] --> | |
<!-- [!code word:text-green-600] --> | |
<div class="{{ error ? 'text-red-600' : 'text-green-600' }}"></div> | |
``` | |
If you're using a component library like React or Vue, this means you shouldn't use props to dynamically construct classes: | |
<TipBad>Don't use props to build class names dynamically</TipBad> | |
```jsx | |
// [!code filename:JSX] | |
function Button({ color, children }) { | |
return <button className={`bg-${color}-600 hover:bg-${color}-500 ...`}>{children}</button>; | |
} | |
``` | |
Instead, map props to complete class names that are statically detectable at build-time: | |
<TipGood>Always map props to static class names</TipGood> | |
```jsx | |
// [!code filename:JSX] | |
function Button({ color, children }) { | |
const colorVariants = { | |
blue: "bg-blue-600 hover:bg-blue-500", | |
red: "bg-red-600 hover:bg-red-500", | |
}; | |
return <button className={`${colorVariants[color]} ...`}>{children}</button>; | |
} | |
``` | |
This has the added benefit of letting you map different prop values to different color shades for example: | |
```jsx | |
// [!code filename:JSX] | |
function Button({ color, children }) { | |
const colorVariants = { | |
blue: "bg-blue-600 hover:bg-blue-500 text-white", | |
red: "bg-red-500 hover:bg-red-400 text-white", | |
yellow: "bg-yellow-300 hover:bg-yellow-400 text-black", | |
}; | |
return <button className={`${colorVariants[color]} ...`}>{children}</button>; | |
} | |
``` | |
As long as you always use complete class names in your code, Tailwind will generate all of your CSS perfectly every time. | |
### Which files are scanned | |
Tailwind will scan every file in your project for class names, except in the following cases: | |
- Files that are in your `.gitignore` file | |
- Binary files like images, videos, or zip files | |
- CSS files | |
- Common package manager lock files | |
If you need to scan any files that Tailwind is ignoring by default, you can [explicitly register](#explicitly-registering-sources) those sources. | |
## Explicitly registering sources | |
Use `@source` to explicitly register source paths relative to the stylesheet: | |
```css | |
/* [!code filename:CSS] */ | |
@import "tailwindcss"; | |
/* [!code highlight:2] */ | |
@source "../node_modules/@acmecorp/ui-lib"; | |
``` | |
This is especially useful when you need to scan an external library that is built with Tailwind, since dependencies are usually listed in your `.gitignore` file and ignored by Tailwind by default. | |
### Setting your base path | |
Tailwind uses the current working directory as its starting point when scanning for class names by default. | |
To set the base path for source detection explicitly, use the `source()` function when importing Tailwind in your CSS: | |
```css | |
/* [!code filename:CSS] */ | |
/* [!code word:source("../src")] */ | |
@import "tailwindcss" source("../src"); | |
``` | |
This can be useful when working with monorepos where your build commands run from the root of the monorepo instead of the root of each project. | |
### Ignoring specific paths | |
Use `@source not` to ignore specific paths, relative to the stylesheet, when scanning for class names: | |
```css | |
/* [!code filename:CSS] */ | |
@import "tailwindcss"; | |
/* [!code highlight:2] */ | |
@source not "../src/components/legacy"; | |
``` | |
This is useful when you have large directories in your project that you know don't use Tailwind classes, like legacy components or third-party libraries. | |
### Disabling automatic detection | |
Use `source(none)` to completely disable automatic source detection if you want to register all of your sources explicitly: | |
```css | |
/* [!code filename:CSS] */ | |
/* [!code word:source("../src")] */ | |
@import "tailwindcss" source(none); | |
@source "../admin"; | |
@source "../shared"; | |
``` | |
This can be useful in projects that have multiple Tailwind stylesheets where you want to make sure each one only includes the classes each stylesheet needs. | |
## Safelisting specific utilities | |
If you need to make sure Tailwind generates certain class names that don’t exist in your content files, use `@source inline()` to force them to be generated: | |
<CodeExampleStack> | |
```css | |
/* [!code filename:CSS] */ | |
@import "tailwindcss"; | |
/* [!code highlight:2] */ | |
@source inline("underline"); | |
``` | |
```css | |
/* [!code filename:Generated CSS] */ | |
.underline { | |
text-decoration: underline; | |
} | |
``` | |
</CodeExampleStack> | |
### Safelisting variants | |
You can also use `@source inline()` to generate classes with variants. For example, to generate the `underline` class with hover and focus variants, add `{hover:,focus:,}` to the source input: | |
<CodeExampleStack> | |
```css | |
/* [!code filename:CSS] */ | |
@import "tailwindcss"; | |
/* [!code highlight:2] */ | |
@source inline("{hover:,focus:,}underline"); | |
``` | |
```css | |
/* [!code filename:Generated CSS] */ | |
.underline { | |
text-decoration: underline; | |
} | |
@media (hover: hover) { | |
.hover\:underline:hover { | |
text-decoration: underline; | |
} | |
} | |
@media (focus: focus) { | |
.focus\:underline:focus { | |
text-decoration: underline; | |
} | |
} | |
``` | |
</CodeExampleStack> | |
### Safelisting with ranges | |
The source input is [brace expanded](https://www.gnu.org/software/bash/manual/html_node/Brace-Expansion.html), so you can generate multiple classes at once. For example, to generate all the red background colors with hover variants, use a range: | |
<CodeExampleStack> | |
```css | |
/* [!code filename:CSS] */ | |
@import "tailwindcss"; | |
/* [!code highlight:2] */ | |
@source inline("{hover:,}bg-red-{50,{100..900..100},950}"); | |
``` | |
```css | |
/* [!code filename:Generated CSS] */ | |
.bg-red-50 { | |
background-color: var(--color-red-50); | |
} | |
.bg-red-100 { | |
background-color: var(--color-red-100); | |
} | |
.bg-red-200 { | |
background-color: var(--color-red-200); | |
} | |
/* ... */ | |
.bg-red-800 { | |
background-color: var(--color-red-800); | |
} | |
.bg-red-900 { | |
background-color: var(--color-red-900); | |
} | |
.bg-red-950 { | |
background-color: var(--color-red-950); | |
} | |
@media (hover: hover) { | |
.hover\:bg-red-50:hover { | |
background-color: var(--color-red-50); | |
} | |
/* ... */ | |
.hover\:bg-red-950:hover { | |
background-color: var(--color-red-950); | |
} | |
} | |
``` | |
</CodeExampleStack> | |
This generates red background colors from 100 to 900 in increments of 100, along with the first and last shades of 50 and 950. It also adds the `hover:` variant for each of those classes. | |
### Explicitly excluding classes | |
Use `@source not inline()` to prevent specific classes from being generated, even if they are detected in your source files: | |
```css | |
/* [!code filename:CSS] */ | |
@import "tailwindcss"; | |
/* [!code highlight:2] */ | |
@source not inline("{hover:,focus:,}bg-red-{50,{100..900..100},950}"); | |
``` | |
This will explicitly exclude the red background utilities, along with their hover and focus variants, from being generated. | |
--- | |
File: /src/docs/display.mdx | |
--- | |
import dedent from "dedent"; | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourTheme, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "display"; | |
export const description = "Utilities for controlling the display box type of an element."; | |
<ApiTable | |
rows={[ | |
["inline", "display: inline;"], | |
["block", "display: block;"], | |
["inline-block", "display: inline-block;"], | |
["flow-root", "display: flow-root;"], | |
["flex", "display: flex;"], | |
["inline-flex", "display: inline-flex;"], | |
["grid", "display: grid;"], | |
["inline-grid", "display: inline-grid;"], | |
["contents", "display: contents;"], | |
["table", "display: table;"], | |
["inline-table", "display: inline-table;"], | |
["table-caption", "display: table-caption;"], | |
["table-cell", "display: table-cell;"], | |
["table-column", "display: table-column;"], | |
["table-column-group", "display: table-column-group;"], | |
["table-footer-group", "display: table-footer-group;"], | |
["table-header-group", "display: table-header-group;"], | |
["table-row-group", "display: table-row-group;"], | |
["table-row", "display: table-row;"], | |
["list-item", "display: list-item;"], | |
["hidden", "display: none;"], | |
[ | |
"sr-only", | |
dedent` | |
position: absolute; | |
width: 1px; | |
height: 1px; | |
padding: 0; | |
margin: -1px; | |
overflow: hidden; | |
clip: rect(0, 0, 0, 0); | |
white-space: nowrap; | |
border-width: 0; | |
`, | |
], | |
[ | |
"not-sr-only", | |
dedent` | |
position: static; | |
width: auto; | |
height: auto; | |
padding: 0; | |
margin: 0; | |
overflow: visible; | |
clip: auto; | |
white-space: normal; | |
`, | |
], | |
]} | |
/> | |
## Examples | |
### Block and Inline | |
Use the `inline`, `inline-block`, and `block` utilities to control the flow of text and elements: | |
<Figure> | |
<Example> | |
{ | |
<div className="mx-auto max-w-xs px-4 text-sm leading-6 text-gray-500 sm:text-base sm:leading-7 dark:text-gray-300"> | |
When controlling the flow of text, using the CSS property{" "} | |
<span className="inline rounded bg-sky-100 font-mono text-sm font-bold text-gray-900 dark:bg-white/15 dark:text-gray-200"> | |
display: inline | |
</span>{" "} | |
will cause the text inside the element to wrap normally. | |
<br /> | |
<br /> | |
While using the property{" "} | |
<span className="inline-block rounded bg-sky-100 font-mono text-sm font-bold text-gray-900 dark:bg-white/15 dark:text-gray-200"> | |
display: inline-block | |
</span>{" "} | |
will wrap the element to prevent the text inside from extending beyond its parent. | |
<br /> | |
<br /> | |
Lastly, using the property{" "} | |
<span className="block rounded bg-sky-100 font-mono text-sm font-bold text-gray-900 dark:bg-white/15 dark:text-gray-200"> | |
display: block | |
</span>{" "} | |
will put the element on its own line and fill its parent. | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:inline,inline-block,block] --> | |
<p> | |
When controlling the flow of text, using the CSS property <span class="inline">display: inline</span> will cause the | |
text inside the element to wrap normally. | |
</p> | |
<p> | |
While using the property <span class="inline-block">display: inline-block</span> will wrap the element to prevent the | |
text inside from extending beyond its parent. | |
</p> | |
<p> | |
Lastly, using the property <span class="block">display: block</span> will put the element on its own line and fill its | |
parent. | |
</p> | |
``` | |
</Figure> | |
### Flow Root | |
Use the `flow-root` utility to create a block-level element with its own [block formatting context](https://developer.mozilla.org/en-US/docs/Web/Guide/CSS/Block_formatting_context): | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="mx-auto max-w-xs p-4 text-sm leading-6 text-gray-500 sm:text-base sm:leading-7 dark:text-gray-300"> | |
<div className="relative mb-0.5 flow-root"> | |
<div className="absolute inset-x-0"> | |
<Stripes border className="h-4 w-full" /> | |
</div> | |
<div className="absolute inset-x-0 bottom-0"> | |
<Stripes border className="h-4" /> | |
</div> | |
<div className="my-4"> | |
Well, let me tell you something, funny boy. Y'know that little stamp, the one that says "New York Public | |
Library"? Well that may not mean anything to you, but that means a lot to me. One whole hell of a lot. | |
</div> | |
</div> | |
<div className="relative mt-0.5 flow-root"> | |
<div className="absolute inset-x-0"> | |
<Stripes border className="h-4 w-full" /> | |
</div> | |
<div className="absolute inset-x-0 bottom-0"> | |
<Stripes border className="h-4" /> | |
</div> | |
<div className="my-4"> | |
Sure, go ahead, laugh if you want to. I've seen your type before: Flashy, making the scene, flaunting | |
convention. Yeah, I know what you're thinking. What's this guy making such a big stink about old library | |
books? Well, let me give you a hint, junior. | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:flow-root] --> | |
<div class="p-4"> | |
<div class="flow-root ..."> | |
<div class="my-4 ...">Well, let me tell you something, ...</div> | |
</div> | |
<div class="flow-root ..."> | |
<div class="my-4 ...">Sure, go ahead, laugh if you want...</div> | |
</div> | |
</div> | |
``` | |
</Figure> | |
### Flex | |
Use the `flex` utility to create a block-level flex container: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="mx-auto flex max-w-xs justify-center p-4 leading-6 text-gray-500 dark:text-gray-400"> | |
<div className="flex items-center gap-4 p-4"> | |
<img | |
className="h-12 w-12 rounded-full" | |
src="https://images.unsplash.com/photo-1501196354995-cbb51c65aaea?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=facearea&facepad=4&w=256&h=256&q=80" | |
/> | |
<div className="flex flex-col"> | |
<strong className="font-medium text-gray-900 dark:text-gray-200">Andrew Alfred</strong> | |
<span className="font-medium text-gray-500 dark:text-gray-400">Technical advisor</span> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:flex] --> | |
<div class="flex items-center"> | |
<img src="path/to/image.jpg" /> | |
<div> | |
<strong>Andrew Alfred</strong> | |
<span>Technical advisor</span> | |
</div> | |
</div> | |
``` | |
</Figure> | |
### Inline Flex | |
Use the `inline-flex` utility to create an inline flex container that flows with text: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<p className="mx-auto max-w-lg p-4 text-sm leading-6 text-gray-500 sm:text-base/7 dark:text-gray-300"> | |
Today I spent most of the day researching ways to take advantage of the fact that bottles can be returned for 10 | |
cents in Michigan, but only 5 cents here.{" "} | |
<span className="ml-1 inline-flex items-baseline"> | |
<img | |
src="https://images.unsplash.com/photo-1501196354995-cbb51c65aaea?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=facearea&facepad=4&w=256&h=256&q=80" | |
alt="" | |
className="mr-1 size-5 self-center rounded-full" | |
/> | |
<span className="font-medium text-gray-900 dark:text-gray-100">Kramer</span> | |
</span>{" "} | |
keeps telling me there is no way to make it work, that he has run the numbers on every possible approach, but I | |
just have to believe there's a way to make it work, there's simply too much opportunity here. | |
</p> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:inline-flex] --> | |
<p> | |
Today I spent most of the day researching ways to ... | |
<span class="inline-flex items-baseline"> | |
<img src="/img/kramer.jpg" class="mx-1 size-5 self-center rounded-full" /> | |
<span>Kramer</span> | |
</span> | |
keeps telling me there is no way to make it work, that ... | |
</p> | |
``` | |
</Figure> | |
### Grid | |
Use the `grid` utility to create a grid container: | |
<Figure> | |
<Example> | |
{ | |
<div className="relative grid grid-cols-3 grid-rows-3 gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="absolute inset-0"> | |
<Stripes border className="h-full rounded-lg" /> | |
</div> | |
<div className="relative rounded-lg bg-fuchsia-500 p-4">01</div> | |
<div className="relative rounded-lg bg-fuchsia-500 p-4">02</div> | |
<div className="relative rounded-lg bg-fuchsia-500 p-4">03</div> | |
<div className="relative rounded-lg bg-fuchsia-500 p-4">04</div> | |
<div className="relative rounded-lg bg-fuchsia-500 p-4">05</div> | |
<div className="relative rounded-lg bg-fuchsia-500 p-4">06</div> | |
<div className="relative rounded-lg bg-fuchsia-500 p-4">07</div> | |
<div className="relative rounded-lg bg-fuchsia-500 p-4">08</div> | |
<div className="relative rounded-lg bg-fuchsia-500 p-4">09</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:grid] --> | |
<div class="grid grid-cols-3 grid-rows-3 gap-4"> | |
<!-- ... --> | |
</div> | |
``` | |
</Figure> | |
### Inline Grid | |
Use the `inline-grid` utility to create an inline grid container: | |
<Figure> | |
<Example> | |
{ | |
<div className="w-full space-x-3 overflow-x-auto p-8 whitespace-nowrap"> | |
<div className="relative inline-grid grid-cols-3 gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="absolute inset-0"> | |
<Stripes border className="h-full rounded-lg" /> | |
</div> | |
<div className="relative size-14 rounded-lg bg-sky-500 p-4">01</div> | |
<div className="relative size-14 rounded-lg bg-sky-500 p-4">02</div> | |
<div className="relative size-14 rounded-lg bg-sky-500 p-4">03</div> | |
<div className="relative size-14 rounded-lg bg-sky-500 p-4">04</div> | |
<div className="relative size-14 rounded-lg bg-sky-500 p-4">05</div> | |
<div className="relative size-14 rounded-lg bg-sky-500 p-4">06</div> | |
</div> | |
<div className="relative inline-grid grid-cols-3 gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="absolute inset-0"> | |
<Stripes border className="h-full rounded-lg" /> | |
</div> | |
<div className="relative size-14 rounded-lg bg-sky-500 p-4">01</div> | |
<div className="relative size-14 rounded-lg bg-sky-500 p-4">02</div> | |
<div className="relative size-14 rounded-lg bg-sky-500 p-4">03</div> | |
<div className="relative size-14 rounded-lg bg-sky-500 p-4">04</div> | |
<div className="relative size-14 rounded-lg bg-sky-500 p-4">05</div> | |
<div className="relative size-14 rounded-lg bg-sky-500 p-4">06</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:inline-grid] --> | |
<span class="inline-grid grid-cols-3 gap-4"> | |
<span>01</span> | |
<span>02</span> | |
<span>03</span> | |
<span>04</span> | |
<span>05</span> | |
<span>06</span> | |
</span> | |
<span class="inline-grid grid-cols-3 gap-4"> | |
<span>01</span> | |
<span>02</span> | |
<span>03</span> | |
<span>04</span> | |
<span>05</span> | |
<span>06</span> | |
</span> | |
``` | |
</Figure> | |
### Contents | |
Use the `contents` utility to create a "phantom" container whose children act like direct children of the parent: | |
<Figure> | |
<Example> | |
{ | |
<div className="relative flex gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="absolute inset-0"> | |
<Stripes border className="h-full rounded-lg" /> | |
</div> | |
<div className="relative flex-1 rounded-lg bg-purple-500 p-4">01</div> | |
<div className="relative contents"> | |
<div className="relative flex-1 rounded-lg bg-purple-500 p-4">02</div> | |
<div className="relative flex-1 rounded-lg bg-purple-500 p-4">03</div> | |
</div> | |
<div className="relative flex-1 rounded-lg bg-purple-500 p-4">04</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:contents] --> | |
<div class="flex ..."> | |
<div class="flex-1 ...">01</div> | |
<div class="contents"> | |
<div class="flex-1 ...">02</div> | |
<div class="flex-1 ...">03</div> | |
</div> | |
<div class="flex-1 ...">04</div> | |
</div> | |
``` | |
</Figure> | |
### Table | |
Use the `table`, `table-row`, `table-cell`, `table-caption`, `table-column`, `table-column-group`, `table-header-group`, `table-row-group`, and `table-footer-group` utilities to create elements that behave like their respective table elements: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="my-8 overflow-hidden"> | |
<div className="table w-full table-auto border-collapse text-sm"> | |
<div className="table-header-group"> | |
<div className="table-row"> | |
<div className="table-cell border-b border-gray-200 p-4 pt-0 pb-3 pl-8 text-left font-medium text-gray-400 dark:border-white/20 dark:text-white"> | |
Song | |
</div> | |
<div className="table-cell border-b border-gray-200 p-4 pt-0 pb-3 text-left font-medium text-gray-400 dark:border-white/20 dark:text-white"> | |
Artist | |
</div> | |
<div className="table-cell border-b border-gray-200 p-4 pt-0 pr-8 pb-3 text-left font-medium text-gray-400 dark:border-white/20 dark:text-white"> | |
Year | |
</div> | |
</div> | |
</div> | |
<div className="table-row-group dark:bg-black/5"> | |
<div className="table-row"> | |
<div className="table-cell border-b border-gray-100 p-4 pl-8 text-gray-500 dark:border-white/10 dark:text-gray-300"> | |
The Sliding Mr. Bones (Next Stop, Pottersville) | |
</div> | |
<div className="table-cell border-b border-gray-100 p-4 text-gray-500 dark:border-white/10 dark:text-gray-300"> | |
Malcolm Lockyer | |
</div> | |
<div className="table-cell border-b border-gray-100 p-4 pr-8 text-gray-500 dark:border-white/10 dark:text-gray-300"> | |
1961 | |
</div> | |
</div> | |
<div className="table-row"> | |
<div className="table-cell border-b border-gray-100 p-4 pl-8 text-gray-500 dark:border-white/10 dark:text-gray-300"> | |
Witchy Woman | |
</div> | |
<div className="table-cell border-b border-gray-100 p-4 text-gray-500 dark:border-white/10 dark:text-gray-300"> | |
The Eagles | |
</div> | |
<div className="table-cell border-b border-gray-100 p-4 pr-8 text-gray-500 dark:border-white/10 dark:text-gray-300"> | |
1972 | |
</div> | |
</div> | |
<div className="table-row"> | |
<div className="table-cell border-b border-gray-100 p-4 pl-8 text-gray-500 dark:border-white/20 dark:text-gray-300"> | |
Shining Star | |
</div> | |
<div className="table-cell border-b border-gray-100 p-4 text-gray-500 dark:border-white/20 dark:text-gray-300"> | |
Earth, Wind, and Fire | |
</div> | |
<div className="table-cell border-b border-gray-100 p-4 pr-8 text-gray-500 dark:border-white/20 dark:text-gray-300"> | |
1975 | |
</div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:table,table-header-group,table-row-group,table-row,table-cell] --> | |
<div class="table w-full ..."> | |
<div class="table-header-group ..."> | |
<div class="table-row"> | |
<div class="table-cell text-left ...">Song</div> | |
<div class="table-cell text-left ...">Artist</div> | |
<div class="table-cell text-left ...">Year</div> | |
</div> | |
</div> | |
<div class="table-row-group"> | |
<div class="table-row"> | |
<div class="table-cell ...">The Sliding Mr. Bones (Next Stop, Pottersville)</div> | |
<div class="table-cell ...">Malcolm Lockyer</div> | |
<div class="table-cell ...">1961</div> | |
</div> | |
<div class="table-row"> | |
<div class="table-cell ...">Witchy Woman</div> | |
<div class="table-cell ...">The Eagles</div> | |
<div class="table-cell ...">1972</div> | |
</div> | |
<div class="table-row"> | |
<div class="table-cell ...">Shining Star</div> | |
<div class="table-cell ...">Earth, Wind, and Fire</div> | |
<div class="table-cell ...">1975</div> | |
</div> | |
</div> | |
</div> | |
``` | |
</Figure> | |
### Hidden | |
Use the `hidden` utility to remove an element from the document: | |
<Figure> | |
<Example> | |
{ | |
<div className="relative flex gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="absolute inset-0"> | |
<Stripes border className="h-full rounded-lg" /> | |
</div> | |
<div className="hidden h-14 w-14 rounded-lg bg-purple-500 p-4">01</div> | |
<div className="relative h-14 w-14 rounded-lg bg-purple-500 p-4">02</div> | |
<div className="relative h-14 w-14 rounded-lg bg-purple-500 p-4">03</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:hidden] --> | |
<div class="flex ..."> | |
<div class="hidden ...">01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
To visually hide an element but keep it in the document, use the [visibility](/docs/visibility#making-elements-invisible) property instead. | |
### Screen-reader only | |
Use `sr-only` to hide an element visually without hiding it from screen readers: | |
```html | |
<!-- [!code classes:sr-only] --> | |
<a href="#"> | |
<svg><!-- ... --></svg> | |
<span class="sr-only">Settings</span> | |
</a> | |
``` | |
Use `not-sr-only` to undo `sr-only`, making an element visible to sighted users as well as screen readers: | |
```html | |
<!-- [!code classes:sm:not-sr-only] --> | |
<a href="#"> | |
<svg><!-- ... --></svg> | |
<span class="sr-only sm:not-sr-only">Settings</span> | |
</a> | |
``` | |
This can be useful when you want to visually hide something on small screens but show it on larger screens for example. | |
### Responsive design | |
<ResponsiveDesign property="display" defaultClass="flex" featuredClass="inline-flex" /> | |
--- | |
File: /src/docs/editor-setup.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
import { CustomizingYourTheme } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "Editor setup"; | |
export const description = "Tooling to improve the developer experience when working with Tailwind CSS."; | |
## Syntax support | |
Tailwind CSS uses custom CSS syntax like `@theme`, `@variant`, and `@source`, and in some editors this can trigger warnings or errors where these rules aren't recognized. | |
If you're using VS Code, our official [Tailwind CSS IntelliSense](https://marketplace.visualstudio.com/items?itemName=bradlc.vscode-tailwindcss) plugin includes a dedicated Tailwind CSS language mode that has support for all of the custom at-rules and functions Tailwind uses. | |
In some cases, you may need to disable native CSS linting/validations if your editor is very strict about the syntax it expects in your CSS files. | |
## IntelliSense for VS Code | |
The official [Tailwind CSS IntelliSense](https://marketplace.visualstudio.com/items?itemName=bradlc.vscode-tailwindcss) extension for Visual Studio Code enhances the Tailwind development experience by providing users with advanced features such as autocomplete, syntax highlighting, and linting. | |
<img | |
src={require("./img/intellisense.png").default.src} | |
alt="Tailwind CSS IntelliSense extension for Visual Studio Code" | |
width={1344} | |
height={672} | |
className="rounded-lg" | |
/> | |
- **Autocomplete** — providing intelligent suggestions for utility classes, as well as [CSS functions and directives](/docs/functions-and-directives). | |
- **Linting** — highlighting errors and potential bugs in both your CSS and your markup. | |
- **Hover previews** — revealing the complete CSS for utility classes when you hover over them. | |
- **Syntax highlighting** — so that Tailwind features that use custom CSS syntax are highlighted correctly. | |
Check out the project [on GitHub](https://github.com/tailwindcss/intellisense) to learn more, or [add it to Visual Studio Code](vscode:extension/bradlc.vscode-tailwindcss) to get started now. | |
## Class sorting with Prettier | |
We maintain an official [Prettier plugin](https://github.com/tailwindlabs/prettier-plugin-tailwindcss) for Tailwind CSS that automatically sorts your classes following our [recommended class order](/blog/automatic-class-sorting-with-prettier#how-classes-are-sorted). | |
<img src={require("./img/prettier-banner.jpg").default.src} alt="" width={2400} height={819} className="rounded-lg" /> | |
It works seamlessly with custom Tailwind configurations, and because it’s just a Prettier plugin, it works anywhere Prettier works—including every popular editor and IDE, and of course on the command line. | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- Before --> | |
<!-- prettier-ignore --> | |
<button class="text-white px-4 sm:px-8 py-2 sm:py-3 bg-sky-700 hover:bg-sky-800">Submit</button> | |
<!-- After --> | |
<button class="bg-sky-700 px-4 py-2 text-white hover:bg-sky-800 sm:px-8 sm:py-3">Submit</button> | |
``` | |
Check out the plugin [on GitHub](https://github.com/tailwindlabs/prettier-plugin-tailwindcss) to learn more and get started. | |
## JetBrains IDEs | |
JetBrains IDEs like WebStorm, PhpStorm, and others include support for intelligent Tailwind CSS completions in your HTML. | |
[Learn more about Tailwind CSS support in JetBrains IDEs →](https://www.jetbrains.com/help/webstorm/tailwind-css.html) | |
--- | |
File: /src/docs/field-sizing.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "field-sizing"; | |
export const description = "Utilities for controlling the sizing of form controls."; | |
<ApiTable | |
rows={[ | |
["field-sizing-fixed", "field-sizing: fixed;"], | |
["field-sizing-content", "field-sizing: content;"], | |
]} | |
/> | |
## Examples | |
### Sizing based on content | |
Use the `field-sizing-content` utility to allow a form control to adjust it's size based on the content: | |
<Figure hint="Type in the input below to see the size change"> | |
<Example> | |
{ | |
<textarea | |
rows="2" | |
defaultValue="Latex Salesman, Vanderlay Industries" | |
className="mx-auto block field-sizing-content rounded-md p-2 text-sm text-gray-950 outline-1 outline-gray-900/10 focus:outline-2 focus:outline-gray-900 dark:bg-gray-950/25 dark:text-white dark:outline-1 dark:outline-white/5 dark:focus:outline-white/20" | |
/> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:field-sizing-content] --> | |
<textarea class="field-sizing-content ..." rows="2"> | |
Latex Salesman, Vanderlay Industries | |
</textarea> | |
``` | |
</Figure> | |
### Using a fixed size | |
Use the `field-sizing-fixed` utility to make a form control use a fixed size: | |
<Figure hint="Type in the input below to see the size remain the same"> | |
<Example> | |
{ | |
<textarea | |
rows="2" | |
defaultValue="Latex Salesman, Vanderlay Industries" | |
className="mx-auto block field-sizing-fixed w-80 rounded-md p-2 text-sm text-gray-950 outline-1 outline-gray-900/10 focus:outline-2 focus:outline-gray-900 dark:bg-gray-950/25 dark:text-white dark:outline-1 dark:outline-white/5 dark:focus:outline-white/20" | |
/> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:field-sizing-fixed] --> | |
<textarea class="field-sizing-fixed w-80 ..." rows="2"> | |
Latex Salesman, Vanderlay Industries | |
</textarea> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign | |
element="input" | |
property="field-sizing" | |
defaultClass="field-sizing-content" | |
featuredClass="field-sizing-fixed" | |
/> | |
--- | |
File: /src/docs/fill.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourThemeColors, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import colors from "./utils/colors"; | |
export const title = "fill"; | |
export const description = "Utilities for styling the fill of SVG elements."; | |
<ApiTable | |
rows={[ | |
["fill-none", "fill: none;"], | |
["fill-inherit", "fill: inherit;"], | |
["fill-current", "fill: currentColor;"], | |
["fill-transparent", "fill: transparent;"], | |
...Object.entries(colors).map(([name, value]) => [`fill-${name}`, `fill: var(--color-${name}); /* ${value} */`]), | |
["fill-(<custom-property>)", "fill: var(<custom-property>);"], | |
["fill-[<color>]", "fill: <color>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `fill-indigo-500` and `fill-lime-600` to change the fill color of an SVG: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex items-center justify-center"> | |
<svg className="h-12 fill-blue-500" viewBox="0 0 46 48"> | |
<path | |
fillRule="evenodd" | |
clipRule="evenodd" | |
d="M23.0002 0C12.5068 0 4.00017 8.50659 4.00017 19V32.5335C4.00017 32.8383 3.9145 33.1371 3.75292 33.3956L0.912672 37.94C0.0801118 39.2721 1.0378 41 2.60867 41H43.3917C44.9625 41 45.9202 39.2721 45.0877 37.94L42.2474 33.3956C42.0858 33.1371 42.0002 32.8383 42.0002 32.5335V19C42.0002 8.50659 33.4936 0 23.0002 0ZM23.0002 48C20.2388 48 18.0002 45.7614 18.0002 43H28.0002C28.0002 45.7614 25.7616 48 23.0002 48Z" | |
/> | |
</svg> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:fill-blue-500] --> | |
<svg class="fill-blue-500 ..."> | |
<!-- ... --> | |
</svg> | |
``` | |
</Figure> | |
This can be useful for styling icon sets like [Heroicons](https://heroicons.com). | |
### Using the current color | |
Use the `fill-current` utility to set the fill color to the current text color: | |
<Figure hint="Hover over the button to see the fill color change"> | |
<Example> | |
{ | |
<div className="flex items-center justify-center"> | |
<button className="inline-flex gap-2 rounded-md border border-indigo-100 bg-white px-3 py-2 text-sm font-semibold text-indigo-600 shadow-sm transition-colors duration-150 hover:border-indigo-600 hover:bg-indigo-600 hover:text-white dark:border-transparent"> | |
<svg viewBox="0 0 20 20" className="size-5 fill-current"> | |
<path | |
d="M15.312 11.424a5.5 5.5 0 0 1-9.201 2.466l-.312-.311h2.433a.75.75 0 0 0 0-1.5H3.989a.75.75 0 0 0-.75.75v4.242a.75.75 0 0 0 1.5 0v-2.43l.31.31a7 7 0 0 0 11.712-3.138.75.75 0 0 0-1.449-.39Zm1.23-3.723a.75.75 0 0 0 .219-.53V2.929a.75.75 0 0 0-1.5 0V5.36l-.31-.31A7 7 0 0 0 3.239 8.188a.75.75 0 1 0 1.448.389A5.5 5.5 0 0 1 13.89 6.11l.311.31h-2.432a.75.75 0 0 0 0 1.5h4.243a.75.75 0 0 0 .53-.219Z" | |
fillRule="evenodd" | |
clipRule="evenodd" | |
/> | |
</svg> | |
Check for updates | |
</button> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:fill-current] --> | |
<button class="bg-white text-indigo-600 hover:bg-indigo-600 hover:text-white ..."> | |
<svg class="size-5 fill-current ..."> | |
<!-- ... --> | |
</svg> | |
Check for updates | |
</button> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue element="svg" utility="fill" name="fill color" value="#243c5a" variable="fill-color" /> | |
### Responsive design | |
<ResponsiveDesign element="svg" property="fill" defaultClass="fill-cyan-500" featuredClass="fill-cyan-700" /> | |
## Customizing your theme | |
<CustomizingYourThemeColors element="svg" utility="fill" /> | |
--- | |
File: /src/docs/filter-blur.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourTheme, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
export const title = "filter: blur()"; | |
export const description = "Utilities for applying blur filters to an element."; | |
<ApiTable | |
rows={[ | |
["blur-xs", "filter: blur(var(--blur-xs)); /* 4px */"], | |
["blur-sm", "filter: blur(var(--blur-sm)); /* 8px */"], | |
["blur-md", "filter: blur(var(--blur-md)); /* 12px */"], | |
["blur-lg", "filter: blur(var(--blur-lg)); /* 16px */"], | |
["blur-xl", "filter: blur(var(--blur-xl)); /* 24px */"], | |
["blur-2xl", "filter: blur(var(--blur-2xl)); /* 40px */"], | |
["blur-3xl", "filter: blur(var(--blur-3xl)); /* 64px */"], | |
["blur-none", "filter: ;"], | |
["blur-(<custom-property>)", "filter: blur(var(<custom-property>));"], | |
["blur-[<value>]", "filter: blur(<value>);"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `blur-sm` and `blur-lg` to blur an element: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-12 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">blur-none</p> | |
<div className="relative blur-none"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">blur-sm</p> | |
<div className="relative blur-sm"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">blur-lg</p> | |
<div className="relative blur-lg"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">blur-2xl</p> | |
<div className="relative blur-2xl"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:blur-none,blur-sm,blur-lg,blur-2xl] --> | |
<img class="blur-none" src="/img/mountains.jpg" /> | |
<img class="blur-sm" src="/img/mountains.jpg" /> | |
<img class="blur-lg" src="/img/mountains.jpg" /> | |
<img class="blur-2xl" src="/img/mountains.jpg" /> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue element="img" elementAttributes={{ src: "/img/mountains.jpg" }} utility="blur" value="2px" /> | |
### Responsive design | |
<ResponsiveDesign | |
element="img" | |
elementAttributes={{ src: "/img/mountains.jpg" }} | |
property="filter: blur()" | |
defaultClass="blur-none" | |
featuredClass="blur-lg" | |
/> | |
## Customizing your theme | |
<CustomizingYourTheme | |
element="img" | |
elementAttributes={{ src: "/img/mountains.jpg" }} | |
utility="blur" | |
name="blur" | |
customName="2xs" | |
customValue="2px" | |
/> | |
--- | |
File: /src/docs/filter-brightness.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "filter: brightness()"; | |
export const description = "Utilities for applying brightness filters to an element."; | |
<ApiTable | |
rows={[ | |
["brightness-<number>", "filter: brightness(<number>%);"], | |
["brightness-(<custom-property>)", "filter: brightness(var(<custom-property>));"], | |
["brightness-[<value>]", "filter: brightness(<value>);"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `brightness-50` and `brightness-100` to control an element's brightness: | |
<Figure> | |
{ | |
<Example padding={false}> | |
<div className="flex scroll-p-8 justify-start overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-6 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
brightness-50 | |
</p> | |
<div className="relative brightness-50"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
brightness-100 | |
</p> | |
<div className="relative brightness-100"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
brightness-125 | |
</p> | |
<div className="relative brightness-125"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
brightness-200 | |
</p> | |
<div className="relative brightness-200"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
</Example> | |
} | |
</Figure> | |
```html | |
<!-- [!code classes:brightness-50,brightness-100,brightness-125,brightness-200] --> | |
<img class="brightness-50 ..." src="/img/mountains.jpg" /> | |
<img class="brightness-100 ..." src="/img/mountains.jpg" /> | |
<img class="brightness-125 ..." src="/img/mountains.jpg" /> | |
<img class="brightness-200 ..." src="/img/mountains.jpg" /> | |
``` | |
### Using a custom value | |
<UsingACustomValue element="img" elementAttributes={{ src: "/img/mountains.jpg" }} utility="brightness" value="1.75" /> | |
### Responsive design | |
<ResponsiveDesign | |
element="img" | |
elementAttributes={{ src: "/img/mountains.jpg" }} | |
property="filter: brightness()" | |
defaultClass="brightness-110" | |
featuredClass="brightness-150" | |
/> | |
--- | |
File: /src/docs/filter-contrast.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { UsingACustomValue, ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "filter: contrast()"; | |
export const description = "Utilities for applying contrast filters to an element."; | |
<ApiTable | |
rows={[ | |
["contrast-<number>", "filter: contrast(<number>%);"], | |
["contrast-(<custom-property>)", "filter: contrast(var(<custom-property>));"], | |
["contrast-[<value>]", "filter: contrast(<value>);"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `contrast-50` and `contrast-100` to control an element's contrast: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 justify-start overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-6 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">contrast-50</p> | |
<div className="relative contrast-50"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
contrast-100 | |
</p> | |
<div className="relative contrast-100"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
contrast-125 | |
</p> | |
<div className="relative contrast-125"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
contrast-200 | |
</p> | |
<div className="relative contrast-200"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:contrast-50,contrast-100,contrast-125,contrast-200] --> | |
<img class="contrast-50 ..." src="/img/mountains.jpg" /> | |
<img class="contrast-100 ..." src="/img/mountains.jpg" /> | |
<img class="contrast-125 ..." src="/img/mountains.jpg" /> | |
<img class="contrast-200 ..." src="/img/mountains.jpg" /> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue element="img" elementAttributes={{ src: "/img/mountains.jpg" }} utility="contrast" value=".25" /> | |
### Responsive design | |
<ResponsiveDesign | |
element="img" | |
elementAttributes={{ src: "/img/mountains.jpg" }} | |
property="filter: contrast()" | |
defaultClass="contrast-125" | |
featuredClass="contrast-150" | |
/> | |
--- | |
File: /src/docs/filter-drop-shadow.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { | |
CustomizingYourTheme, | |
ResponsiveDesign, | |
UsingACustomValue, | |
CustomizingYourThemeColors, | |
} from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import colors from "./utils/colors"; | |
export const title = "filter: drop-shadow()"; | |
export const description = "Utilities for applying drop-shadow filters to an element."; | |
<ApiTable | |
rows={[ | |
["drop-shadow-xs", "filter: drop-shadow(var(--drop-shadow-xs)); /* 0 1px 1px rgb(0 0 0 / 0.05) */"], | |
["drop-shadow-sm", "filter: drop-shadow(var(--drop-shadow-sm)); /* 0 1px 2px rgb(0 0 0 / 0.15) */"], | |
["drop-shadow-md", "filter: drop-shadow(var(--drop-shadow-md)); /* 0 3px 3px rgb(0 0 0 / 0.12) */"], | |
["drop-shadow-lg", "filter: drop-shadow(var(--drop-shadow-lg)); /* 0 4px 4px rgb(0 0 0 / 0.15) */"], | |
["drop-shadow-xl", "filter: drop-shadow(var(--drop-shadow-xl); /* 0 9px 7px rgb(0 0 0 / 0.1) */"], | |
["drop-shadow-2xl", "filter: drop-shadow(var(--drop-shadow-2xl)); /* 0 25px 25px rgb(0 0 0 / 0.15) */"], | |
["drop-shadow-none", "filter: drop-shadow(0 0 #0000);"], | |
["drop-shadow-(<custom-property>)", "filter: drop-shadow(var(<custom-property>));"], | |
["drop-shadow-(color:<custom-property>)", "--tw-drop-shadow-color: var(<custom-property>);"], | |
["drop-shadow-[<value>]", "filter: drop-shadow(<value>);"], | |
["drop-shadow-inherit", "--tw-drop-shadow-color: inherit;"], | |
["drop-shadow-current", "--tw-drop-shadow-color: currentColor;"], | |
["drop-shadow-transparent", "--tw-drop-shadow-color: transparent;"], | |
...Object.entries(colors).map(([name, value]) => [ | |
`drop-shadow-${name}`, | |
`--tw-drop-shadow-color: var(--color-${name}); /* ${value} */`, | |
]), | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `drop-shadow-sm` and `drop-shadow-xl` to add a drop shadow to an element: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="grid grid-cols-3 items-end gap-8 bg-white p-8 max-sm:grid-cols-1"> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">drop-shadow-md</p> | |
<svg className="size-28 text-gray-950/100 drop-shadow-md" viewBox="0 0 84 84"> | |
<path | |
d="M22.0992 77L2.19922 42.5L22.0992 8H61.8992L81.7992 42.5L61.8992 77H22.0992Z" | |
className="fill-white" | |
/> | |
</svg> | |
</div> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">drop-shadow-lg</p> | |
<svg className="size-28 text-gray-950/100 drop-shadow-lg" viewBox="0 0 84 84"> | |
<path | |
d="M22.0992 77L2.19922 42.5L22.0992 8H61.8992L81.7992 42.5L61.8992 77H22.0992Z" | |
className="fill-white" | |
/> | |
</svg> | |
</div> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">drop-shadow-xl</p> | |
<svg className="size-28 text-gray-950/100 drop-shadow-xl" viewBox="0 0 84 84"> | |
<path | |
d="M22.0992 77L2.19922 42.5L22.0992 8H61.8992L81.7992 42.5L61.8992 77H22.0992Z" | |
className="fill-white" | |
/> | |
</svg> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:drop-shadow-md,drop-shadow-lg,drop-shadow-xl] --> | |
<svg class="drop-shadow-md ..."> | |
<!-- ... --> | |
</svg> | |
<svg class="drop-shadow-lg ..."> | |
<!-- ... --> | |
</svg> | |
<svg class="drop-shadow-xl ..."> | |
<!-- ... --> | |
</svg> | |
``` | |
</Figure> | |
This is useful for applying shadows to irregular shapes, like text and SVG elements. For applying shadows to regular elements, you probably want to use [box shadow](/docs/box-shadow) instead. | |
### Changing the opacity | |
Use the opacity modifier to adjust the opacity of the drop shadow: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="grid grid-cols-3 items-end gap-8 bg-white p-8 max-sm:grid-cols-1"> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">drop-shadow-xl</p> | |
<svg className="size-28 text-gray-950/100 drop-shadow-xl" viewBox="0 0 84 84"> | |
<path | |
d="M22.0992 77L2.19922 42.5L22.0992 8H61.8992L81.7992 42.5L61.8992 77H22.0992Z" | |
className="fill-white" | |
/> | |
</svg> | |
</div> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">drop-shadow-xl/25</p> | |
<svg className="size-28 text-gray-950/100 drop-shadow-xl/25" viewBox="0 0 84 84"> | |
<path | |
d="M22.0992 77L2.19922 42.5L22.0992 8H61.8992L81.7992 42.5L61.8992 77H22.0992Z" | |
className="fill-white" | |
/> | |
</svg> | |
</div> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">drop-shadow-xl/50</p> | |
<svg className="size-28 text-gray-950/100 drop-shadow-xl/50" viewBox="0 0 84 84"> | |
<path | |
d="M22.0992 77L2.19922 42.5L22.0992 8H61.8992L81.7992 42.5L61.8992 77H22.0992Z" | |
className="fill-white" | |
/> | |
</svg> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:drop-shadow-xl,drop-shadow-xl/25,drop-shadow-xl/50] --> | |
<svg class="fill-white drop-shadow-xl ...">...</svg> | |
<svg class="fill-white drop-shadow-xl/25 ...">...</svg> | |
<svg class="fill-white drop-shadow-xl/50 ...">...</svg> | |
``` | |
</Figure> | |
The default drop shadow opacities are quite low (15% or less), so increasing the opacity (to like 50%) will make the drop shadows more pronounced. | |
### Setting the shadow color | |
Use utilities like `drop-shadow-indigo-500` and `drop-shadow-cyan-500/50` to change the color of a drop shadow: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-2 items-end p-8 max-sm:grid-cols-1"> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">drop-shadow-cyan-500/50</p> | |
<svg className="size-28 text-gray-950/100 drop-shadow-xl drop-shadow-cyan-500/50" viewBox="0 0 84 84"> | |
<path | |
d="M22.0992 77L2.19922 42.5L22.0992 8H61.8992L81.7992 42.5L61.8992 77H22.0992Z" | |
className="fill-cyan-500" | |
/> | |
</svg> | |
</div> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500">drop-shadow-indigo-500/50</p> | |
<svg className="size-28 text-gray-950/100 drop-shadow-xl drop-shadow-indigo-500/50" viewBox="0 0 84 84"> | |
<path | |
d="M22.0992 77L2.19922 42.5L22.0992 8H61.8992L81.7992 42.5L61.8992 77H22.0992Z" | |
className="fill-indigo-500" | |
/> | |
</svg> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:drop-shadow-cyan-500/50,drop-shadow-indigo-500/50] --> | |
<svg class="fill-cyan-500 drop-shadow-lg drop-shadow-cyan-500/50 ...">...</svg> | |
<svg class="fill-indigo-500 drop-shadow-lg drop-shadow-indigo-500/50 ...">...</svg> | |
``` | |
</Figure> | |
By default colored shadows have an opacity of 100% but you can adjust this using the opacity modifier. | |
### Removing a drop shadow | |
Use the `drop-shadow-none` utility to remove an existing drop shadow from an element: | |
<Figure> | |
```html | |
<!-- [!code classes:dark:drop-shadow-none] --> | |
<svg class="drop-shadow-lg dark:drop-shadow-none"> | |
<!-- ... --> | |
</svg> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue element="svg" utility="drop-shadow" value="0_35px_35px_rgba(0,0,0,0.25)" name="drop shadow" /> | |
### Responsive design | |
<ResponsiveDesign | |
element="svg" | |
property="filter: drop-shadow()" | |
defaultClass="drop-shadow-md" | |
featuredClass="drop-shadow-xl" | |
/> | |
## Customizing your theme | |
### Customizing drop shadows | |
<CustomizingYourTheme | |
element="svg" | |
utility="drop-shadow" | |
name="drop shadow" | |
customName="3xl" | |
customValue="0 35px 35px rgba(0, 0, 0, 0.25)" | |
/> | |
### Customizing shadow colors | |
<CustomizingYourThemeColors element="svg" utility="drop-shadow" /> | |
--- | |
File: /src/docs/filter-grayscale.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "filter: grayscale()"; | |
export const description = "Utilities for applying grayscale filters to an element."; | |
<ApiTable | |
rows={[ | |
["grayscale", "filter: grayscale(100%);"], | |
["grayscale-<number>", "filter: grayscale(<number>%);"], | |
["grayscale-(<custom-property>)", "filter: grayscale(var(<custom-property>));"], | |
["grayscale-[<value>]", "filter: grayscale(<value>);"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `grayscale` and `grayscale-75` to control the amount of grayscale effect applied to an element: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 justify-center overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-6 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">grayscale-0</p> | |
<div className="relative grayscale-0"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
grayscale-25 | |
</p> | |
<div className="relative grayscale-25"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
grayscale-50 | |
</p> | |
<div className="relative grayscale-50"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">grayscale</p> | |
<div className="relative grayscale"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:grayscale-0,grayscale-25,grayscale-50,grayscale] --> | |
<img class="grayscale-0 ..." src="/img/mountains.jpg" /> | |
<img class="grayscale-25 ..." src="/img/mountains.jpg" /> | |
<img class="grayscale-50 ..." src="/img/mountains.jpg" /> | |
<img class="grayscale ..." src="/img/mountains.jpg" /> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue element="img" elementAttributes={{ src: "/img/mountains.jpg" }} utility="grayscale" value="0.5" /> | |
### Responsive design | |
<ResponsiveDesign | |
element="img" | |
elementAttributes={{ src: "/img/mountains.jpg" }} | |
property="filter: grayscale()" | |
defaultClass="grayscale" | |
featuredClass="grayscale-0" | |
/> | |
--- | |
File: /src/docs/filter-hue-rotate.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "filter: hue-rotate()"; | |
export const description = "Utilities for applying hue-rotate filters to an element."; | |
<ApiTable | |
rows={[ | |
["hue-rotate-<number>", "filter: hue-rotate(<number>deg);"], | |
["-hue-rotate-<number>", "filter: hue-rotate(calc(<number>deg * -1));"], | |
["hue-rotate-(<custom-property>)", "filter: hue-rotate(var(<custom-property>));"], | |
["hue-rotate-[<value>]", "filter: hue-rotate(<value>);"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `hue-rotate-90` and `hue-rotate-180` to rotate the hue of an element by degrees: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 justify-start overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-6 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
hue-rotate-15 | |
</p> | |
<div className="relative hue-rotate-15"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
hue-rotate-90 | |
</p> | |
<div className="relative hue-rotate-90"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
hue-rotate-180 | |
</p> | |
<div className="relative hue-rotate-180"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
hue-rotate-270 | |
</p> | |
<div className="relative hue-rotate-270"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:hue-rotate-15,hue-rotate-90,hue-rotate-180,hue-rotate-270] --> | |
<img class="hue-rotate-15" src="/img/mountains.jpg" /> | |
<img class="hue-rotate-90" src="/img/mountains.jpg" /> | |
<img class="hue-rotate-180" src="/img/mountains.jpg" /> | |
<img class="hue-rotate-270" src="/img/mountains.jpg" /> | |
``` | |
</Figure> | |
### Using negative values | |
Use utilities like `-hue-rotate-15` and `-hue-rotate-45` to set a negative hue rotate value: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 justify-start overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-6 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
-hue-rotate-15 | |
</p> | |
<div className="relative -hue-rotate-15"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
-hue-rotate-45 | |
</p> | |
<div className="relative -hue-rotate-45"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
-hue-rotate-90 | |
</p> | |
<div className="relative -hue-rotate-90"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:-hue-rotate-15,-hue-rotate-45,-hue-rotate-90] --> | |
<img class="-hue-rotate-15" src="/img/mountains.jpg" /> | |
<img class="-hue-rotate-45" src="/img/mountains.jpg" /> | |
<img class="-hue-rotate-90" src="/img/mountains.jpg" /> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue | |
element="img" | |
elementAttributes={{ src: "/img/mountains.jpg" }} | |
utility="hue-rotate" | |
value="3.142rad" | |
name="hue rotation" | |
/> | |
### Responsive design | |
<ResponsiveDesign | |
element="img" | |
elementAttributes={{ src: "/img/mountains.jpg" }} | |
property="filter: hue-rotate()" | |
defaultClass="hue-rotate-60" | |
featuredClass="hue-rotate-0" | |
/> | |
--- | |
File: /src/docs/filter-invert.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { UsingACustomValue, ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "filter: invert()"; | |
export const description = "Utilities for applying invert filters to an element."; | |
<ApiTable | |
rows={[ | |
["invert", "filter: invert(100%);"], | |
["invert-<number>", "filter: invert(<number>%);"], | |
["invert-(<custom-property>)", "filter: invert(var(<custom-property>))"], | |
["invert-[<value>]", "filter: invert(<value>);"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `invert` and `invert-20` to control the color inversion of an element: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 justify-center overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-6 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">invert-0</p> | |
<div className="relative invert-0"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">invert-20</p> | |
<div className="relative invert-20"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">invert</p> | |
<div className="relative invert"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:invert-0,invert-20,invert] --> | |
<img class="invert-0" src="/img/mountains.jpg" /> | |
<img class="invert-20" src="/img/mountains.jpg" /> | |
<img class="invert" src="/img/mountains.jpg" /> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue | |
element="img" | |
elementAttributes={{ src: "/img/mountains.jpg" }} | |
utility="invert" | |
value=".25" | |
name="color inversion" | |
variable="inversion" | |
/> | |
### Responsive design | |
<ResponsiveDesign | |
element="img" | |
elementAttributes={{ src: "/img/mountains.jpg" }} | |
property="filter: invert()" | |
defaultClass="invert" | |
featuredClass="invert-0" | |
/> | |
--- | |
File: /src/docs/filter-saturate.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { UsingACustomValue, ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "filter: saturate()"; | |
export const description = "Utilities for applying saturation filters to an element."; | |
<ApiTable | |
rows={[ | |
["saturate-<number>", "filter: saturate(<number>%);"], | |
["saturate-(<custom-property>)", "filter: saturate(var(<custom-property>));"], | |
["saturate-[<value>]", "filter: saturate(<value>);"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `saturate-50` and `saturate-100` to control an element's saturation: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 justify-start overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-6 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">saturate-50</p> | |
<div className="relative saturate-50"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
saturate-100 | |
</p> | |
<div className="relative saturate-100"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
saturate-150 | |
</p> | |
<div className="relative saturate-150"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
saturate-200 | |
</p> | |
<div className="relative saturate-200"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:saturate-50,saturate-100,saturate-150,saturate-200] --> | |
<img class="saturate-50 ..." src="/img/mountains.jpg" /> | |
<img class="saturate-100 ..." src="/img/mountains.jpg" /> | |
<img class="saturate-150 ..." src="/img/mountains.jpg" /> | |
<img class="saturate-200 ..." src="/img/mountains.jpg" /> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue | |
element="img" | |
elementAttributes={{ src: "/img/mountains.jpg" }} | |
utility="saturate" | |
name="saturation" | |
value=".25" | |
variable="saturation" | |
/> | |
### Responsive design | |
<ResponsiveDesign | |
element="img" | |
elementAttributes={{ src: "/img/mountains.jpg" }} | |
property="filter: saturate()" | |
defaultClass="saturate-50" | |
featuredClass="saturate-150" | |
/> | |
--- | |
File: /src/docs/filter-sepia.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "filter: sepia()"; | |
export const description = "Utilities for applying sepia filters to an element."; | |
<ApiTable | |
rows={[ | |
["sepia", "filter: sepia(100%);"], | |
["sepia-<number>", "filter: sepia(<number>%);"], | |
["sepia-(<custom-property>)", "filter: sepia(var(<custom-property>));"], | |
["sepia-[<value>]", "filter: sepia(<value>);"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `sepia` and `sepia-50` to control the sepia effect applied to an element: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 justify-center overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-6 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">sepia-0</p> | |
<div className="relative sepia-0"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">sepia-50</p> | |
<div className="relative sepia-50"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">sepia</p> | |
<div className="relative sepia"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:sepia-0,sepia-50,sepia] --> | |
<img class="sepia-0" src="/img/mountains.jpg" /> | |
<img class="sepia-50" src="/img/mountains.jpg" /> | |
<img class="sepia" src="/img/mountains.jpg" /> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue | |
element="img" | |
elementAttributes={{ src: "/img/mountains.jpg" }} | |
utility="sepia" | |
name="sepia amount" | |
value=".25" | |
/> | |
### Responsive design | |
<ResponsiveDesign | |
element="img" | |
elementAttributes={{ src: "/img/mountains.jpg" }} | |
property="filter: sepia()" | |
defaultClass="sepia" | |
featuredClass="sepia-0" | |
/> | |
--- | |
File: /src/docs/filter.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, TargetingSpecificStates, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "filter"; | |
export const description = "Utilities for applying filters to an element."; | |
<ApiTable | |
rows={[ | |
["filter-none", "filter: none;"], | |
["filter-(<custom-property>)", "filter: var(<custom-property>);"], | |
["filter-[<value>]", "filter: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `blur-xs` and `grayscale` to apply filters to an element: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="flex scroll-p-8 overflow-scroll sm:block sm:overflow-visible"> | |
<div className="flex shrink-0 items-center justify-around gap-12 p-8 font-mono font-bold sm:gap-4"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">blur-xs</p> | |
<div className="relative blur-xs"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">grayscale</p> | |
<div className="relative grayscale"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3 text-center font-mono text-xs font-medium text-gray-500 italic dark:text-gray-400"> | |
combined | |
</p> | |
<div className="relative blur-xs grayscale"> | |
<img | |
className="size-24 rounded-lg object-cover" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<div className="absolute inset-0 rounded-lg ring-1 ring-black/10 ring-inset"></div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:blur-xs,grayscale] --> | |
<img class="blur-xs" src="/img/mountains.jpg" /> | |
<img class="grayscale" src="/img/mountains.jpg" /> | |
<img class="blur-xs grayscale" src="/img/mountains.jpg" /> | |
``` | |
</Figure> | |
You can combine the following filter utilities: [blur](/docs/filter-blur), [brightness](/docs/filter-brightness), [contrast](/docs/filter-contrast), [drop-shadow](/docs/filter-drop-shadow), [grayscale](/docs/filter-grayscale), [hue-rotate](/docs/filter-hue-rotate), [invert](/docs/filter-invert), [saturate](/docs/filter-saturate), and [sepia](/docs/filter-sepia). | |
### Removing filters | |
Use the `filter-none` utility to remove all of the filters applied to an element: | |
```html | |
<!-- [!code classes:md:filter-none] --> | |
<img class="blur-md brightness-150 invert md:filter-none" src="/img/mountains.jpg" /> | |
``` | |
### Using a custom value | |
<UsingACustomValue | |
element="img" | |
elementAttributes={{ src: "/img/mountains.jpg" }} | |
utility="filter" | |
value="url('filters.svg#filter-id')" | |
/> | |
### Applying on hover | |
<TargetingSpecificStates | |
element="img" | |
elementAttributes={{ src: "/img/mountains.jpg" }} | |
property="filter" | |
defaultClass="blur-sm" | |
featuredClass="filter-none" | |
/> | |
### Responsive design | |
<ResponsiveDesign | |
element="img" | |
elementAttributes={{ src: "/img/mountains.jpg" }} | |
property="filter" | |
defaultClass="blur-sm" | |
featuredClass="filter-none" | |
/> | |
--- | |
File: /src/docs/flex-basis.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourTheme, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
export const title = "flex-basis"; | |
export const description = "Utilities for controlling the initial size of flex items."; | |
<ApiTable | |
rows={[ | |
["basis-<number>", "flex-basis: calc(var(--spacing) * <number>);"], | |
["basis-<fraction>", "flex-basis: calc(<fraction> * 100%);"], | |
["basis-full", "flex-basis: 100%;"], | |
["basis-auto", "flex-basis: auto;"], | |
["basis-3xs", "flex-basis: var(--container-3xs); /* 16rem (256px) */"], | |
["basis-2xs", "flex-basis: var(--container-2xs); /* 18rem (288px) */"], | |
["basis-xs", "flex-basis: var(--container-xs); /* 20rem (320px) */"], | |
["basis-sm", "flex-basis: var(--container-sm); /* 24rem (384px) */"], | |
["basis-md", "flex-basis: var(--container-md); /* 28rem (448px) */"], | |
["basis-lg", "flex-basis: var(--container-lg); /* 32rem (512px) */"], | |
["basis-xl", "flex-basis: var(--container-xl); /* 36rem (576px) */"], | |
["basis-2xl", "flex-basis: var(--container-2xl); /* 42rem (672px) */"], | |
["basis-3xl", "flex-basis: var(--container-3xl); /* 48rem (768px) */"], | |
["basis-4xl", "flex-basis: var(--container-4xl); /* 56rem (896px) */"], | |
["basis-5xl", "flex-basis: var(--container-5xl); /* 64rem (1024px) */"], | |
["basis-6xl", "flex-basis: var(--container-6xl); /* 72rem (1152px) */"], | |
["basis-7xl", "flex-basis: var(--container-7xl); /* 80rem (1280px) */"], | |
["basis-(<custom-property>)", "flex-basis: var(<custom-property>);"], | |
["basis-[<value>]", "flex-basis: <value>;"], | |
]} | |
/> | |
## Examples | |
### Using the spacing scale | |
Use `basis-<number>` utilities like `basis-64` and `basis-128` to set the initial size of flex items based on the spacing scale: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-row space-x-4 font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex h-14 basis-64 items-center justify-center rounded-lg bg-purple-500">01</div> | |
<div className="flex h-14 basis-64 items-center justify-center rounded-lg bg-purple-500">02</div> | |
<div className="flex h-14 basis-128 items-center justify-center rounded-lg bg-purple-500">03</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:basis-64,basis-128] --> | |
<div class="flex flex-row"> | |
<div class="basis-64">01</div> | |
<div class="basis-64">02</div> | |
<div class="basis-128">03</div> | |
</div> | |
``` | |
</Figure> | |
### Using the container scale | |
Use utilities like `basis-xs` and `basis-sm` to set the initial size of flex items based on the container scale: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-row space-x-4 font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex h-14 basis-3xs items-center justify-center rounded-lg bg-sky-500">01</div> | |
<div className="flex h-14 basis-2xs items-center justify-center rounded-lg bg-sky-500">02</div> | |
<div className="flex h-14 basis-xs items-center justify-center rounded-lg bg-sky-500">03</div> | |
<div className="flex h-14 basis-sm items-center justify-center rounded-lg bg-sky-500">04</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:basis-3xs,basis-2xs,basis-xs,basis-sm] --> | |
<div class="flex flex-row"> | |
<div class="basis-3xs">01</div> | |
<div class="basis-2xs">02</div> | |
<div class="basis-xs">03</div> | |
<div class="basis-sm">04</div> | |
</div> | |
``` | |
</Figure> | |
### Using percentages | |
Use `basis-<fraction>` utilities like `basis-1/2` and `basis-2/3` to set the initial size of flex items: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-row space-x-4 font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex h-14 basis-1/3 items-center justify-center rounded-lg bg-indigo-500">01</div> | |
<div className="flex h-14 basis-2/3 items-center justify-center rounded-lg bg-indigo-500">02</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:basis-1/3,basis-2/3] --> | |
<div class="flex flex-row"> | |
<div class="basis-1/3">01</div> | |
<div class="basis-2/3">02</div> | |
</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="basis" value="30vw" /> | |
### Responsive design | |
<ResponsiveDesign property="flex-basis"> | |
```html | |
<!-- [!code classes:md:basis-1/3] --> | |
<div class="flex flex-row"> | |
<div class="basis-1/4 md:basis-1/3">01</div> | |
<div class="basis-1/4 md:basis-1/3">02</div> | |
<div class="basis-1/2 md:basis-1/3">03</div> | |
</div> | |
``` | |
</ResponsiveDesign> | |
## Customizing your theme | |
<CustomizingYourTheme | |
utility="basis" | |
themeKey="container" | |
name="fixed-width basis" | |
customName="4xs" | |
customValue="14rem" | |
includeSpacingNote | |
/> | |
--- | |
File: /src/docs/flex-direction.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "flex-direction"; | |
export const description = "Utilities for controlling the direction of flex items."; | |
<ApiTable | |
rows={[ | |
["flex-row", "flex-direction: row;"], | |
["flex-row-reverse", "flex-direction: row-reverse;"], | |
["flex-col", "flex-direction: column;"], | |
["flex-col-reverse", "flex-direction: column-reverse;"], | |
]} | |
/> | |
## Examples | |
### Row | |
Use `flex-row` to position flex items horizontally in the same direction as text: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-row gap-x-4 font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex h-14 w-14 items-center justify-center rounded-lg bg-fuchsia-500">01</div> | |
<div className="flex h-14 w-14 items-center justify-center rounded-lg bg-fuchsia-500">02</div> | |
<div className="flex h-14 w-14 items-center justify-center rounded-lg bg-fuchsia-500">03</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:flex-row] --> | |
<div class="flex flex-row ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Row reversed | |
Use `flex-row-reverse` to position flex items horizontally in the opposite direction: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-row-reverse gap-x-4 space-x-reverse font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex h-14 w-14 items-center justify-center rounded-lg bg-blue-500">01</div> | |
<div className="flex h-14 w-14 items-center justify-center rounded-lg bg-blue-500">02</div> | |
<div className="flex h-14 w-14 items-center justify-center rounded-lg bg-blue-500">03</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:flex-row-reverse] --> | |
<div class="flex flex-row-reverse ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Column | |
Use `flex-col` to position flex items vertically: | |
<Figure> | |
<Example> | |
{ | |
<div className="mx-auto flex max-w-xs flex-col space-y-4 font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex items-center justify-center rounded-lg bg-indigo-500 p-4">01</div> | |
<div className="flex items-center justify-center rounded-lg bg-indigo-500 p-4">02</div> | |
<div className="flex items-center justify-center rounded-lg bg-indigo-500 p-4">03</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:flex-col] --> | |
<div class="flex flex-col ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Column reversed | |
Use `flex-col-reverse` to position flex items vertically in the opposite direction: | |
<Figure> | |
<Example> | |
{ | |
<div className="mx-auto flex max-w-xs flex-col-reverse space-y-4 space-y-reverse font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex items-center justify-center rounded-lg bg-purple-500 p-4">01</div> | |
<div className="flex items-center justify-center rounded-lg bg-purple-500 p-4">02</div> | |
<div className="flex items-center justify-center rounded-lg bg-purple-500 p-4">03</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:flex-col-reverse] --> | |
<div class="flex flex-col-reverse ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="flex-direction" defaultClass="flex flex-col" featuredClass="flex-row" /> | |
--- | |
File: /src/docs/flex-grow.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "flex-grow"; | |
export const description = "Utilities for controlling how flex items grow."; | |
<ApiTable | |
rows={[ | |
["grow", "flex-grow: 1;"], | |
["grow-<number>", "flex-grow: <number>;"], | |
["grow-[<value>]", "flex-grow: <value>;"], | |
["grow-(<custom-property>)", "flex-grow: var(<custom-property>);"], | |
]} | |
/> | |
## Examples | |
### Allowing items to grow | |
Use `grow` to allow a flex item to grow to fill any available space: | |
<Figure> | |
<Example resizable> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex gap-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex size-14 flex-none items-center justify-center rounded-lg bg-sky-300 dark:bg-sky-800 dark:text-sky-400"> | |
01 | |
</div> | |
<div className="flex size-14 grow items-center justify-center rounded-lg bg-sky-500 p-4">02</div> | |
<div className="flex size-14 flex-none items-center justify-center rounded-lg bg-sky-300 p-4 dark:bg-sky-800 dark:text-sky-400"> | |
03 | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:grow] --> | |
<div class="flex ..."> | |
<div class="size-14 flex-none ...">01</div> | |
<div class="size-14 grow ...">02</div> | |
<div class="size-14 flex-none ...">03</div> | |
</div> | |
``` | |
</Figure> | |
### Growing items based on factor | |
Use `grow-<number>` utilities like `grow-3` to make flex items grow proportionally based on their growth factor, allowing them to fill the available space relative to each other: | |
<Figure> | |
<Example resizable> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex gap-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex size-14 grow-3 items-center justify-center rounded-lg bg-indigo-300 dark:bg-indigo-800 dark:text-indigo-400"> | |
01 | |
</div> | |
<div className="flex size-14 grow-7 items-center justify-center rounded-lg bg-indigo-500 p-4">02</div> | |
<div className="flex size-14 grow-3 items-center justify-center rounded-lg bg-indigo-300 p-4 dark:bg-indigo-800 dark:text-indigo-400"> | |
03 | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:grow-3,grow-7] --> | |
<div class="flex ..."> | |
<div class="size-14 grow-3 ...">01</div> | |
<div class="size-14 grow-7 ...">02</div> | |
<div class="size-14 grow-3 ...">03</div> | |
</div> | |
``` | |
</Figure> | |
### Preventing items from growing | |
Use `grow-0` to prevent a flex item from growing: | |
<Figure> | |
<Example resizable> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex gap-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex size-14 grow items-center justify-center rounded-lg bg-pink-300 p-4 dark:bg-pink-800 dark:text-pink-400"> | |
01 | |
</div> | |
<div className="flex size-14 shrink-0 grow-0 items-center justify-center rounded-lg bg-pink-500">02</div> | |
<div className="hidden size-14 grow items-center justify-center rounded-lg bg-pink-300 p-4 md:flex dark:bg-pink-800 dark:text-pink-400"> | |
03 | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:grow-0] --> | |
<div class="flex ..."> | |
<div class="size-14 grow ...">01</div> | |
<div class="size-14 grow-0 ...">02</div> | |
<div class="size-14 grow ...">03</div> | |
</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="grow" name="flex grow factor" value="25vw" /> | |
### Responsive design | |
<ResponsiveDesign property="flex-grow" defaultClass="grow" featuredClass="grow-0" /> | |
--- | |
File: /src/docs/flex-shrink.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "flex-shrink"; | |
export const description = "Utilities for controlling how flex items shrink."; | |
<ApiTable | |
rows={[ | |
["shrink", "flex-shrink: 1;"], | |
["shrink-<number>", "flex-shrink: <number>;"], | |
["shrink-[<value>]", "flex-shrink: <value>;"], | |
["shrink-(<custom-property>)", "flex-shrink: var(<custom-property>);"], | |
]} | |
/> | |
## Examples | |
### Allowing flex items to shrink | |
Use `shrink` to allow a flex item to shrink if needed: | |
<Figure> | |
<Example resizable> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex gap-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex h-14 w-14 flex-none items-center justify-center rounded-lg bg-sky-300 p-4 dark:bg-sky-800 dark:text-sky-400"> | |
01 | |
</div> | |
<div className="flex h-14 w-64 shrink items-center justify-center rounded-lg bg-sky-500 p-4">02</div> | |
<div className="hidden h-14 w-14 flex-none items-center justify-center rounded-lg bg-sky-300 p-4 sm:flex dark:bg-sky-800 dark:text-sky-400"> | |
03 | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:shrink] --> | |
<div class="flex ..."> | |
<div class="h-14 w-14 flex-none ...">01</div> | |
<div class="h-14 w-64 shrink ...">02</div> | |
<div class="h-14 w-14 flex-none ...">03</div> | |
</div> | |
``` | |
</Figure> | |
### Preventing items from shrinking | |
Use `shrink-0` to prevent a flex item from shrinking: | |
<Figure> | |
<Example resizable> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex gap-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex flex-1 items-center justify-center rounded-lg bg-blue-300 p-4 dark:bg-blue-800 dark:text-blue-500"> | |
01 | |
</div> | |
<div className="flex w-16 shrink-0 items-center justify-center rounded-lg bg-blue-500 p-4 sm:w-64">02</div> | |
<div className="hidden flex-1 items-center justify-center rounded-lg bg-blue-300 p-4 sm:flex dark:bg-blue-800 dark:text-blue-500"> | |
03 | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:shrink-0] --> | |
<div class="flex ..."> | |
<div class="h-16 flex-1 ...">01</div> | |
<div class="h-16 w-32 shrink-0 ...">02</div> | |
<div class="h-16 flex-1 ...">03</div> | |
</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="shrink" name="flex shrink factor" value="calc(100vw-var(--sidebar))" /> | |
### Responsive design | |
<ResponsiveDesign property="flex-shrink" defaultClass="shrink" featuredClass="shrink-0" /> | |
--- | |
File: /src/docs/flex-wrap.mdx | |
--- | |
import { Stripes } from "@/components/stripes.tsx"; | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "flex-wrap"; | |
export const description = "Utilities for controlling how flex items wrap."; | |
<ApiTable | |
rows={[ | |
["flex-nowrap", "flex-wrap: nowrap;"], | |
["flex-wrap", "flex-wrap: wrap;"], | |
["flex-wrap-reverse", "flex-wrap: wrap-reverse;"], | |
]} | |
/> | |
## Examples | |
### Don't wrap | |
Use `flex-nowrap` to prevent flex items from wrapping, causing inflexible items to overflow the container if necessary: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex flex-nowrap gap-4 rounded-lg font-mono text-sm/6 font-bold text-white"> | |
<div className="w-2/5 flex-none last:pr-8"> | |
<div className="flex w-full items-center justify-center rounded-lg bg-sky-500 p-4">01</div> | |
</div> | |
<div className="w-2/5 flex-none last:pr-8"> | |
<div className="flex w-full items-center justify-center rounded-lg bg-sky-500 p-4">02</div> | |
</div> | |
<div className="w-2/5 flex-none last:pr-8"> | |
<div className="flex w-full items-center justify-center rounded-lg bg-sky-500 p-4">03</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:flex-nowrap] --> | |
<div class="flex flex-nowrap"> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Wrap normally | |
Use `flex-wrap` to allow flex items to wrap: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex flex-wrap gap-4 rounded-lg font-mono text-sm/6 font-bold text-white"> | |
<div className="flex w-2/5 items-center justify-center rounded-lg bg-indigo-500 p-4">01</div> | |
<div className="flex w-2/5 items-center justify-center rounded-lg bg-indigo-500 p-4">02</div> | |
<div className="flex w-2/5 items-center justify-center rounded-lg bg-indigo-500 p-4">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:flex-wrap] --> | |
<div class="flex flex-wrap"> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Wrap reversed | |
Use `flex-wrap-reverse` to wrap flex items in the reverse direction: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex flex-wrap-reverse gap-4 rounded-lg font-mono text-sm/6 font-bold text-white"> | |
<div className="flex w-2/5 items-center justify-center rounded-lg bg-fuchsia-500 p-4">01</div> | |
<div className="flex w-2/5 items-center justify-center rounded-lg bg-fuchsia-500 p-4">02</div> | |
<div className="flex w-2/5 items-center justify-center rounded-lg bg-fuchsia-500 p-4">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:flex-wrap-reverse] --> | |
<div class="flex flex-wrap-reverse"> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="flex-wrap" defaultClass="flex flex-wrap" featuredClass="flex-wrap-reverse" /> | |
--- | |
File: /src/docs/flex.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "flex"; | |
export const description = "Utilities for controlling how flex items both grow and shrink."; | |
<ApiTable | |
rows={[ | |
["flex-<number>", "flex: <number>;"], | |
["flex-<fraction>", "flex: calc(<fraction> * 100%);"], | |
["flex-auto", "flex: 1 1 auto;"], | |
["flex-initial", "flex: 0 1 auto;"], | |
["flex-none", "flex: none;"], | |
["flex-(<custom-property>)", "flex: var(<custom-property>);"], | |
["flex-[<value>]", "flex: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use `flex-<number>` utilities like `flex-1` to allow a flex item to grow and shrink as needed, ignoring its initial size: | |
<Figure> | |
<Example resizable> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex gap-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex h-14 w-14 flex-none items-center justify-center rounded-lg bg-pink-300 p-4 dark:bg-pink-800 dark:text-pink-400"> | |
01 | |
</div> | |
<div className="flex w-64 flex-1 items-center justify-center rounded-lg bg-pink-500 p-4">02</div> | |
<div className="flex w-32 flex-1 items-center justify-center rounded-lg bg-pink-500 p-4">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code word:flex-1] --> | |
<div class="flex"> | |
<div class="w-14 flex-none ...">01</div> | |
<div class="w-64 flex-1 ...">02</div> | |
<div class="w-32 flex-1 ...">03</div> | |
</div> | |
``` | |
</Figure> | |
### Initial | |
Use `flex-initial` to allow a flex item to shrink but not grow, taking into account its initial size: | |
<Figure> | |
<Example resizable> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex gap-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex h-14 w-14 flex-none items-center justify-center rounded-lg bg-blue-300 p-4 dark:bg-blue-800 dark:text-blue-500"> | |
01 | |
</div> | |
<div className="flex w-24 flex-initial items-center justify-center rounded-lg bg-blue-500 p-4 sm:w-64">02</div> | |
<div className="flex w-14 flex-initial items-center justify-center rounded-lg bg-blue-500 p-4 sm:w-32">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code word:flex-initial] --> | |
<div class="flex"> | |
<div class="w-14 flex-none ...">01</div> | |
<div class="w-64 flex-initial ...">02</div> | |
<div class="w-32 flex-initial ...">03</div> | |
</div> | |
``` | |
</Figure> | |
### Auto | |
Use `flex-auto` to allow a flex item to grow and shrink, taking into account its initial size: | |
<Figure> | |
<Example resizable> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex gap-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex h-14 w-14 flex-none items-center justify-center rounded-lg bg-violet-300 p-4 dark:bg-violet-800 dark:text-violet-400"> | |
01 | |
</div> | |
<div className="flex w-64 flex-auto items-center justify-center rounded-lg bg-violet-500 p-4">02</div> | |
<div className="flex w-32 flex-auto items-center justify-center rounded-lg bg-violet-500 p-4">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code word:flex-auto] --> | |
<div class="flex ..."> | |
<div class="w-14 flex-none ...">01</div> | |
<div class="w-64 flex-auto ...">02</div> | |
<div class="w-32 flex-auto ...">03</div> | |
</div> | |
``` | |
</Figure> | |
### None | |
Use `flex-none` to prevent a flex item from growing or shrinking: | |
<Figure> | |
<Example resizable> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex gap-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex-none last:pr-8 sm:last:pr-0"> | |
<div className="flex h-14 w-14 items-center justify-center rounded-lg bg-indigo-500 p-4">01</div> | |
</div> | |
<div className="flex-none last:pr-8 sm:last:pr-0"> | |
<div className="flex w-32 items-center justify-center rounded-lg bg-indigo-500 p-4">02</div> | |
</div> | |
<div className="flex-1 last:pr-8 sm:last:pr-0"> | |
<div className="flex items-center justify-center rounded-lg bg-indigo-300 p-4 dark:bg-indigo-800 dark:text-indigo-400"> | |
03 | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code word:flex-none] --> | |
<div class="flex ..."> | |
<div class="w-14 flex-none ...">01</div> | |
<div class="w-32 flex-none ...">02</div> | |
<div class="flex-1 ...">03</div> | |
</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="flex" name="flex shorthand property" value="3_1_auto" /> | |
### Responsive design | |
<ResponsiveDesign property="flex" defaultClass="flex-none" featuredClass="flex-1" /> | |
--- | |
File: /src/docs/float.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "float"; | |
export const description = "Utilities for controlling the wrapping of content around an element."; | |
<ApiTable | |
rows={[ | |
["float-right", "float: right;"], | |
["float-left", "float: left;"], | |
["float-start", "float: inline-start;"], | |
["float-end", "float: inline-end;"], | |
["float-none", "float: none;"], | |
]} | |
/> | |
## Examples | |
### Floating elements to the right | |
Use the `float-right` utility to float an element to the right of its container: | |
<Figure> | |
<Example resizable> | |
{ | |
<> | |
<img | |
className="float-right ml-6 aspect-16/9 w-2/5 rounded-lg object-cover outline -outline-offset-1 outline-black/10" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<p className="text-justify"> | |
Maybe we can live without libraries, people like you and me. Maybe. Sure, we're too old to change the world, but | |
what about that kid, sitting down, opening a book, right now, in a branch at the local library and finding | |
drawings of pee-pees and wee-wees on the Cat in the Hat and the Five Chinese Brothers? Doesn't HE deserve | |
better? Look. If you think this is about overdue fines and missing books, you'd better think again. This is | |
about that kid's right to read a book without getting his mind warped! Or: maybe that turns you on, Seinfeld; | |
maybe that's how y'get your kicks. You and your good-time buddies. | |
</p> | |
</> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:float-right] --> | |
<article> | |
<img class="float-right ..." src="/img/mountains.jpg" /> | |
<p>Maybe we can live without libraries, people like you and me. ...</p> | |
</article> | |
``` | |
</Figure> | |
### Floating elements to the left | |
Use the `float-left` utility to float an element to the left of its container: | |
<Figure> | |
<Example resizable> | |
{ | |
<> | |
<img | |
className="float-left mr-6 aspect-16/9 w-2/5 rounded-lg object-cover outline -outline-offset-1 outline-black/10" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<p className="text-justify"> | |
Maybe we can live without libraries, people like you and me. Maybe. Sure, we're too old to change the world, but | |
what about that kid, sitting down, opening a book, right now, in a branch at the local library and finding | |
drawings of pee-pees and wee-wees on the Cat in the Hat and the Five Chinese Brothers? Doesn't HE deserve | |
better? Look. If you think this is about overdue fines and missing books, you'd better think again. This is | |
about that kid's right to read a book without getting his mind warped! Or: maybe that turns you on, Seinfeld; | |
maybe that's how y'get your kicks. You and your good-time buddies. | |
</p> | |
</> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:float-left] --> | |
<article> | |
<img class="float-left ..." src="/img/mountains.jpg" /> | |
<p>Maybe we can live without libraries, people like you and me. ...</p> | |
</article> | |
``` | |
</Figure> | |
### Using logical properties | |
Use the `float-start` and `float-end` utilities, which use [logical properties](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Logical_Properties/Basic_concepts) to map to either the left or right side based on the text direction: | |
<Figure> | |
<Example resizable> | |
{ | |
<> | |
<div dir="ltr"> | |
<p className="mb-4 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">left-to-right</p> | |
<div> | |
<img | |
className="float-start me-6 aspect-16/9 w-2/5 rounded-lg object-cover outline -outline-offset-1 outline-black/10" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<p className="text-justify"> | |
Maybe we can live without libraries, people like you and me. Maybe. Sure, we're too old to change the world, | |
but what about that kid, sitting down, opening a book, right now, in a branch at the local library and | |
finding drawings of pee-pees and wee-wees on the Cat in the Hat and the Five Chinese Brothers? Doesn't HE | |
deserve better? Look. If you think this is about overdue fines and missing books, you'd better think again. | |
This is about that kid's right to read a book without getting his mind warped! Or: maybe that turns you on, | |
Seinfeld; maybe that's how y'get your kicks. You and your good-time buddies. | |
</p> | |
</div> | |
</div> | |
<div dir="rtl" className="mt-6"> | |
<p className="mb-4 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">right-to-left</p> | |
<div> | |
<img | |
className="float-start me-6 aspect-16/9 w-2/5 rounded-lg object-cover outline -outline-offset-1 outline-black/10" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<p className="text-justify"> | |
ربما يمكننا العيش بدون مكتبات، أشخاص مثلي ومثلك. ربما. بالتأكيد، نحن أكبر من أن نغير العالم، ولكن ماذا عن | |
ذلك الطفل الذي يجلس ويفتح كتابًا الآن في أحد فروع المكتبة المحلية ويجد رسومات للتبول والبول على القطة في | |
القبعة والإخوة الصينيون الخمسة؟ ألا يستحق الأفضل؟ ينظر. إذا كنت تعتقد أن الأمر يتعلق بالغرامات المتأخرة | |
والكتب المفقودة، فمن الأفضل أن تفكر مرة أخرى. يتعلق الأمر بحق ذلك الطفل في قراءة كتاب دون أن يتشوه عقله! أو: | |
ربما يثيرك هذا يا سينفيلد؛ ربما هذه هي الطريقة التي تحصل بها على ركلاتك. أنت ورفاقك الطيبين. | |
</p> | |
</div> | |
</div> | |
</> | |
} | |
</Example> | |
```html | |
<!-- [!code word:dir="rtl"] --> | |
<!-- [!code classes:float-start] --> | |
<article> | |
<img class="float-start ..." src="/img/mountains.jpg" /> | |
<p>Maybe we can live without libraries, people like you and me. ...</p> | |
</article> | |
<article dir="rtl"> | |
<img class="float-start ..." src="/img/mountains.jpg" /> | |
<p>... ربما يمكننا العيش بدون مكتبات، أشخاص مثلي ومثلك. ربما. بالتأكيد</p> | |
</article> | |
``` | |
</Figure> | |
### Disabling a float | |
Use the `float-none` utility to reset any floats that are applied to an element: | |
<Figure> | |
<Example resizable> | |
{ | |
<> | |
<img | |
className="mb-4 aspect-16/9 w-2/5 rounded-lg object-cover outline -outline-offset-1 outline-black/10" | |
src="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=90" | |
/> | |
<p className="text-justify"> | |
Maybe we can live without libraries, people like you and me. Maybe. Sure, we're too old to change the world, but | |
what about that kid, sitting down, opening a book, right now, in a branch at the local library and finding | |
drawings of pee-pees and wee-wees on the Cat in the Hat and the Five Chinese Brothers? Doesn't HE deserve | |
better? Look. If you think this is about overdue fines and missing books, you'd better think again. This is | |
about that kid's right to read a book without getting his mind warped! Or: maybe that turns you on, Seinfeld; | |
maybe that's how y'get your kicks. You and your good-time buddies. | |
</p> | |
</> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:float-none] --> | |
<article> | |
<img class="float-none ..." src="/img/mountains.jpg" /> | |
<p>Maybe we can live without libraries, people like you and me. ...</p> | |
</article> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="float"> | |
```html | |
<!-- [!code classes:md:float-left] --> | |
<img class="float-right md:float-left" src="/img/mountains.jpg" /> | |
``` | |
</ResponsiveDesign> | |
--- | |
File: /src/docs/font-family.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourTheme, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
export const title = "font-family"; | |
export const description = "Utilities for controlling the font family of an element."; | |
<ApiTable | |
rows={[ | |
[ | |
"font-sans", | |
"font-family: var(--font-sans); /* ui-sans-serif, system-ui, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol', 'Noto Color Emoji' */", | |
], | |
["font-serif", "font-family: var(--font-serif); /* ui-serif, Georgia, Cambria, 'Times New Roman', Times, serif */"], | |
[ | |
"font-mono", | |
"font-family: var(--font-mono); /* ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace */", | |
], | |
["font-(family-name:<custom-property>)", "font-family: var(<custom-property>);"], | |
["font-[<value>]", "font-family: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `font-sans` and `font-mono` to set the font family of an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col gap-8"> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">font-sans</span> | |
<p className="font-sans text-lg font-medium text-gray-900 dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">font-serif</span> | |
<p className="font-serif text-lg font-medium text-gray-900 dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">font-mono</span> | |
<p className="font-mono text-lg font-medium text-gray-900 dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:font-sans,font-serif,font-mono] --> | |
<p class="font-sans ...">The quick brown fox ...</p> | |
<p class="font-serif ...">The quick brown fox ...</p> | |
<p class="font-mono ...">The quick brown fox ...</p> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="font" name="font family" value="Open_Sans" element="p" dataType="family-name" /> | |
### Responsive design | |
<ResponsiveDesign property="font-family" defaultClass="font-sans" featuredClass="font-serif" element="p" /> | |
## Customizing your theme | |
<CustomizingYourTheme | |
utility="font" | |
name="font family" | |
customName="display" | |
customValue='"Oswald", "sans-serif"' | |
> | |
You can also provide default `font-feature-settings` and `font-variation-settings` values for a font family: | |
```css | |
@theme { | |
--font-display: "Oswald", "sans-serif"; | |
--font-display--font-feature-settings: "cv02", "cv03", "cv04", "cv11"; /* [!code highlight] */ | |
--font-display--font-variation-settings: "opsz" 32; /* [!code highlight] */ | |
} | |
``` | |
If needed, use the [@font-face](https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face) at-rule to load custom fonts: | |
```css | |
@font-face { | |
font-family: Oswald; | |
font-style: normal; | |
font-weight: 200 700; | |
font-display: swap; | |
src: url("/fonts/Oswald.woff2") format("woff2"); | |
} | |
``` | |
If you're loading a font from a service like [Google Fonts](https://fonts.google.com/), make sure to put the `@import` at the very top of your CSS file: | |
```css | |
@import url("https://fonts.googleapis.com/css2?family=Roboto&display=swap"); /* [!code highlight] */ | |
@import "tailwindcss"; | |
@theme { | |
--font-roboto: "Roboto", sans-serif; /* [!code highlight] */ | |
} | |
``` | |
Browsers require that `@import` statements come before any other rules, so URL imports need to be above imports like `@import "tailwindcss"` which are inlined in the compiled CSS. | |
</CustomizingYourTheme> | |
--- | |
File: /src/docs/font-size.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourTheme, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
export const title = "font-size"; | |
export const description = "Utilities for controlling the font size of an element."; | |
<ApiTable | |
rows={[ | |
[ | |
"text-xs", | |
"font-size: var(--text-xs); /* 0.75rem (12px) */ \nline-height: var(--text-xs--line-height); /* calc(1 / 0.75) */", | |
], | |
[ | |
"text-sm", | |
"font-size: var(--text-sm); /* 0.875rem (14px) */ \nline-height: var(--text-sm--line-height); /* calc(1.25 / 0.875) */", | |
], | |
[ | |
"text-base", | |
"font-size: var(--text-base); /* 1rem (16px) */ \nline-height: var(--text-base--line-height); /* calc(1.5 / 1) */", | |
], | |
[ | |
"text-lg", | |
"font-size: var(--text-lg); /* 1.125rem (18px) */ \nline-height: var(--text-lg--line-height); /* calc(1.75 / 1.125) */", | |
], | |
[ | |
"text-xl", | |
"font-size: var(--text-xl); /* 1.25rem (20px) */ \nline-height: var(--text-xl--line-height); /* calc(1.75 / 1.25) */", | |
], | |
[ | |
"text-2xl", | |
"font-size: var(--text-2xl); /* 1.5rem (24px) */ \nline-height: var(--text-2xl--line-height); /* calc(2 / 1.5) */", | |
], | |
[ | |
"text-3xl", | |
"font-size: var(--text-3xl); /* 1.875rem (30px) */ \nline-height: var(--text-3xl--line-height); /* calc(2.25 / 1.875) */", | |
], | |
[ | |
"text-4xl", | |
"font-size: var(--text-4xl); /* 2.25rem (36px) */ \nline-height: var(--text-4xl--line-height); /* calc(2.5 / 2.25) */", | |
], | |
["text-5xl", "font-size: var(--text-5xl); /* 3rem (48px) */ \nline-height: var(--text-5xl--line-height); /* 1 */"], | |
[ | |
"text-6xl", | |
"font-size: var(--text-6xl); /* 3.75rem (60px) */ \nline-height: var(--text-6xl--line-height); /* 1 */", | |
], | |
[ | |
"text-7xl", | |
"font-size: var(--text-7xl); /* 4.5rem (72px) */ \nline-height: var(--text-7xl--line-height); /* 1 */", | |
], | |
["text-8xl", "font-size: var(--text-8xl); /* 6rem (96px) */ \nline-height: var(--text-8xl--line-height); /* 1 */"], | |
["text-9xl", "font-size: var(--text-9xl); /* 8rem (128px) */ \nline-height: var(--text-9xl--line-height); /* 1 */"], | |
["text-(length:<custom-property>)", "font-size: var(<custom-property>);"], | |
["text-[<value>]", "font-size: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `text-sm` and `text-lg` to set the font size of an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col gap-8"> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">text-sm</span> | |
<p className="text-sm font-medium text-gray-900 dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">text-base</span> | |
<p className="text-base font-medium text-gray-900 dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">text-lg</span> | |
<p className="text-lg font-medium text-gray-900 dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">text-xl</span> | |
<p className="text-xl font-medium text-gray-900 dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">text-2xl</span> | |
<p className="text-2xl font-medium text-gray-900 dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:text-sm,text-base,text-lg,text-xl,text-2xl] --> | |
<p class="text-sm ...">The quick brown fox ...</p> | |
<p class="text-base ...">The quick brown fox ...</p> | |
<p class="text-lg ...">The quick brown fox ...</p> | |
<p class="text-xl ...">The quick brown fox ...</p> | |
<p class="text-2xl ...">The quick brown fox ...</p> | |
``` | |
</Figure> | |
### Setting the line-height | |
Use utilities like `text-sm/6` and `text-lg/7` to set the font size and line-height of an element at the same time: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col gap-8"> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">text-sm/6</span> | |
<p className="text-sm/6 text-gray-900 dark:text-gray-200"> | |
So I started to walk into the water. I won't lie to you boys, I was terrified. But I pressed on, and as I made | |
my way past the breakers a strange calm came over me. I don't know if it was divine intervention or the | |
kinship of all living things but I tell you Jerry at that moment, I <em>was</em> a marine biologist. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">text-sm/7</span> | |
<p className="text-sm/7 text-gray-900 dark:text-gray-200"> | |
So I started to walk into the water. I won't lie to you boys, I was terrified. But I pressed on, and as I made | |
my way past the breakers a strange calm came over me. I don't know if it was divine intervention or the | |
kinship of all living things but I tell you Jerry at that moment, I <em>was</em> a marine biologist. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">text-sm/8</span> | |
<p className="text-sm/8 text-gray-900 dark:text-gray-200"> | |
So I started to walk into the water. I won't lie to you boys, I was terrified. But I pressed on, and as I made | |
my way past the breakers a strange calm came over me. I don't know if it was divine intervention or the | |
kinship of all living things but I tell you Jerry at that moment, I <em>was</em> a marine biologist. | |
</p> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:text-sm/6,text-sm/7,text-sm/8] --> | |
<p class="text-sm/6 ...">So I started to walk into the water...</p> | |
<p class="text-sm/7 ...">So I started to walk into the water...</p> | |
<p class="text-sm/8 ...">So I started to walk into the water...</p> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue element="p" utility="text" name="font size" value="14px" variable="text-size" dataType="length" /> | |
### Responsive design | |
<ResponsiveDesign element="p" property="font-size" defaultClass="text-sm" featuredClass="text-base" /> | |
## Customizing your theme | |
<CustomizingYourTheme utility="text" name="font size" customValue="0.625rem" customName="tiny"> | |
You can also provide default `line-height`, `letter-spacing`, and `font-weight` values for a font size: | |
```css | |
@theme { | |
--text-tiny: 0.625rem; | |
--text-tiny--line-height: 1.5rem; /* [!code highlight] */ | |
--text-tiny--letter-spacing: 0.125rem; /* [!code highlight] */ | |
--text-tiny--font-weight: 500; /* [!code highlight] */ | |
} | |
``` | |
</CustomizingYourTheme> | |
--- | |
File: /src/docs/font-smoothing.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "font-smoothing"; | |
export const description = "Utilities for controlling the font smoothing of an element."; | |
<ApiTable | |
rows={[ | |
["antialiased", "-webkit-font-smoothing: antialiased;\n-moz-osx-font-smoothing: grayscale;"], | |
["subpixel-antialiased", "-webkit-font-smoothing: auto;\n-moz-osx-font-smoothing: auto;"], | |
]} | |
/> | |
## Examples | |
### Grayscale antialiasing | |
Use the `antialiased` utility to render text using grayscale antialiasing: | |
<Figure> | |
<Example> | |
{ | |
<p className="text-center text-lg font-medium text-gray-900 antialiased dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:antialiased] --> | |
<p class="antialiased ...">The quick brown fox ...</p> | |
``` | |
</Figure> | |
### Subpixel antialiasing | |
Use the `subpixel-antialiased` utility to render text using subpixel antialiasing: | |
<Figure> | |
<Example> | |
{ | |
<p className="text-center text-lg font-medium text-gray-900 subpixel-antialiased dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:subpixel-antialiased] --> | |
<p class="subpixel-antialiased ...">The quick brown fox ...</p> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign | |
element="p" | |
properties={["-webkit-font-smoothing", "-moz-osx-font-smoothing"]} | |
defaultClass="antialiased" | |
featuredClass="subpixel-antialiased" | |
/> | |
--- | |
File: /src/docs/font-stretch.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "font-stretch"; | |
export const description = "Utilities for selecting the width of a font face."; | |
<ApiTable | |
rows={[ | |
["font-stretch-ultra-condensed", "font-stretch: ultra-condensed; /* 50% */"], | |
["font-stretch-extra-condensed", "font-stretch: extra-condensed; /* 62.5% */"], | |
["font-stretch-condensed", "font-stretch: condensed; /* 75% */"], | |
["font-stretch-semi-condensed", "font-stretch: semi-condensed; /* 87.5% */"], | |
["font-stretch-normal", "font-stretch: normal; /* 100% */"], | |
["font-stretch-semi-expanded", "font-stretch: semi-expanded; /* 112.5% */"], | |
["font-stretch-expanded", "font-stretch: expanded; /* 125% */"], | |
["font-stretch-extra-expanded", "font-stretch: extra-expanded; /* 150% */"], | |
["font-stretch-ultra-expanded", "font-stretch: ultra-expanded; /* 200% */"], | |
["font-stretch-<percentage>", "font-stretch: <percentage>;"], | |
["font-stretch-(<custom-property>)", "font-stretch: var(<custom-property>);"], | |
["font-stretch-[<value>]", "font-stretch: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `font-stretch-condensed` and `font-stretch-expanded` to set the width of a font face: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col gap-8"> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
font-stretch-extra-condensed | |
</span> | |
<p className="font-[system-ui] text-xl font-medium text-gray-900 font-stretch-extra-condensed dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
font-stretch-condensed | |
</span> | |
<p className="font-[system-ui] text-xl font-medium text-gray-900 font-stretch-condensed dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">font-stretch-normal</span> | |
<p className="font-[system-ui] text-xl font-medium text-gray-900 font-stretch-normal dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
font-stretch-expanded | |
</span> | |
<p className="font-[system-ui] text-xl font-medium text-gray-900 font-stretch-expanded dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
font-stretch-extra-expanded | |
</span> | |
<p className="font-[system-ui] text-xl font-medium text-gray-900 font-stretch-extra-expanded dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:font-stretch-extra-condensed,font-stretch-condensed,font-stretch-normal,font-stretch-expanded,font-stretch-extra-expanded] --> | |
<p class="font-stretch-extra-condensed">The quick brown fox...</p> | |
<p class="font-stretch-condensed">The quick brown fox...</p> | |
<p class="font-stretch-normal">The quick brown fox...</p> | |
<p class="font-stretch-expanded">The quick brown fox...</p> | |
<p class="font-stretch-extra-expanded">The quick brown fox...</p> | |
``` | |
</Figure> | |
This only applies to fonts that have multiple width variations available, otherwise the browser selects the closest match. | |
### Using percentages | |
Use `font-stretch-<percentage>` utilities like `font-stretch-50%` and `font-stretch-125%` to set the width of a font face using a percentage: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col gap-8"> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">font-stretch-50%</span> | |
<p className="font-[system-ui] text-xl font-medium text-gray-900 font-stretch-50% dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">font-stretch-100%</span> | |
<p className="font-[system-ui] text-xl font-medium text-gray-900 font-stretch-100% dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">font-stretch-150%</span> | |
<p className="font-[system-ui] text-xl font-medium text-gray-900 font-stretch-150% dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:font-stretch-50%,font-stretch-100%,font-stretch-150%] --> | |
<p class="font-stretch-50%">The quick brown fox...</p> | |
<p class="font-stretch-100%">The quick brown fox...</p> | |
<p class="font-stretch-150%">The quick brown fox...</p> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue element="p" utility="font-stretch" value="66.66%" name="font width" variable="font-width" /> | |
### Responsive design | |
<ResponsiveDesign property="font-stretch" defaultClass="font-stretch-normal" featuredClass="font-stretch-expanded" /> | |
--- | |
File: /src/docs/font-style.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "font-style"; | |
export const description = "Utilities for controlling the style of text."; | |
<ApiTable | |
rows={[ | |
["italic", "font-style: italic;"], | |
["not-italic", "font-style: normal;"], | |
]} | |
/> | |
## Examples | |
### Italicizing text | |
Use the `italic` utility to make text italic: | |
<Figure> | |
<Example> | |
{ | |
<p className="text-center text-lg font-medium text-gray-900 italic dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:italic] --> | |
<p class="italic ...">The quick brown fox ...</p> | |
``` | |
</Figure> | |
### Displaying text normally | |
Use the `not-italic` utility to display text normally: | |
<Figure> | |
<Example> | |
{ | |
<p className="text-center text-lg font-medium text-gray-900 not-italic dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:not-italic] --> | |
<p class="not-italic ...">The quick brown fox ...</p> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="font-style" defaultClass="italic" featuredClass="not-italic" element="p" /> | |
--- | |
File: /src/docs/font-variant-numeric.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "font-variant-numeric"; | |
export const description = "Utilities for controlling the variant of numbers."; | |
<ApiTable | |
rows={[ | |
["normal-nums", "font-variant-numeric: normal;"], | |
["ordinal", "font-variant-numeric: ordinal;"], | |
["slashed-zero", "font-variant-numeric: slashed-zero;"], | |
["lining-nums", "font-variant-numeric: lining-nums;"], | |
["oldstyle-nums", "font-variant-numeric: oldstyle-nums;"], | |
["proportional-nums", "font-variant-numeric: proportional-nums;"], | |
["tabular-nums", "font-variant-numeric: tabular-nums;"], | |
["diagonal-fractions", "font-variant-numeric: diagonal-fractions;"], | |
["stacked-fractions", "font-variant-numeric: stacked-fractions;"], | |
]} | |
/> | |
## Examples | |
### Using ordinal glyphs | |
Use the `ordinal` utility to enable special glyphs for the ordinal markers in fonts that support them: | |
<Figure> | |
<Example>{<p className="text-center font-source text-lg text-gray-900 ordinal dark:text-gray-200">1st</p>}</Example> | |
```html | |
<!-- [!code classes:ordinal] --> | |
<p class="ordinal ...">1st</p> | |
``` | |
</Figure> | |
### Using slashed zeroes | |
Use the `slashed-zero` utility to force a zero with a slash in fonts that support them: | |
<Figure> | |
<Example>{<p className="text-center font-source text-lg text-gray-900 slashed-zero dark:text-gray-200">0</p>}</Example> | |
```html | |
<!-- [!code classes:slashed-zero] --> | |
<p class="slashed-zero ...">0</p> | |
``` | |
</Figure> | |
### Using lining figures | |
Use the `lining-nums` utility to use numeric glyphs that are aligned by their baseline in fonts that support them: | |
<Figure> | |
<Example> | |
{<p className="text-center font-source text-lg text-gray-900 lining-nums dark:text-gray-200">1234567890</p>} | |
</Example> | |
```html | |
<!-- [!code classes:lining-nums] --> | |
<p class="lining-nums ...">1234567890</p> | |
``` | |
</Figure> | |
### Using oldstyle figures | |
Use the `oldstyle-nums` utility to use numeric glyphs where some numbers have descenders in fonts that support them: | |
<Figure> | |
<Example> | |
{<p className="text-center font-source text-lg text-gray-900 oldstyle-nums dark:text-gray-200">1234567890</p>} | |
</Example> | |
```html | |
<!-- [!code classes:oldstyle-nums] --> | |
<p class="oldstyle-nums ...">1234567890</p> | |
``` | |
</Figure> | |
### Using proportional figures | |
Use the `proportional-nums` utility to use numeric glyphs that have proportional widths in fonts that support them: | |
<Figure> | |
<Example> | |
{ | |
<div className="max-w-xs text-right"> | |
<p className="font-source text-lg text-gray-900 proportional-nums dark:text-gray-200">12121</p> | |
<p className="font-source text-lg text-gray-900 proportional-nums dark:text-gray-200">90909</p> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:proportional-nums] --> | |
<p class="proportional-nums ...">12121</p> | |
<p class="proportional-nums ...">90909</p> | |
``` | |
</Figure> | |
### Using tabular figures | |
Use the `tabular-nums` utility to use numeric glyphs that have uniform/tabular widths in fonts that support them: | |
<Figure> | |
<Example> | |
{ | |
<div className="max-w-xs text-right"> | |
<p className="font-source text-lg text-gray-900 tabular-nums dark:text-gray-200">12121</p> | |
<p className="font-source text-lg text-gray-900 tabular-nums dark:text-gray-200">90909</p> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:tabular-nums] --> | |
<p class="tabular-nums ...">12121</p> | |
<p class="tabular-nums ...">90909</p> | |
``` | |
</Figure> | |
### Using diagonal fractions | |
Use the `diagonal-fractions` utility to replace numbers separated by a slash with common diagonal fractions in fonts that support them: | |
<Figure> | |
<Example> | |
{<p className="text-center font-source text-lg text-gray-900 diagonal-fractions dark:text-gray-200">1/2 3/4 5/6</p>} | |
</Example> | |
```html | |
<!-- [!code classes:diagonal-fractions] --> | |
<p class="diagonal-fractions ...">1/2 3/4 5/6</p> | |
``` | |
</Figure> | |
### Using stacked fractions | |
Use the `stacked-fractions` utility to replace numbers separated by a slash with common stacked fractions in fonts that support them: | |
<Figure> | |
<Example> | |
{ | |
<p className="text-center font-ubuntu-mono text-lg text-gray-900 stacked-fractions dark:text-gray-200"> | |
1/2 3/4 5/6 | |
</p> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:stacked-fractions] --> | |
<p class="stacked-fractions ...">1/2 3/4 5/6</p> | |
``` | |
</Figure> | |
### Stacking multiple utilities | |
The `font-variant-numeric` utilities are composable so you can enable multiple variants by combining them: | |
<Figure> | |
<Example> | |
{ | |
<dl className="mx-auto grid max-w-2xs grid-cols-2 text-gray-900 dark:text-gray-200"> | |
<dt className="border-b border-gray-200 py-2 dark:border-white/10">Subtotal</dt> | |
<dd className="border-b border-gray-200 py-2 text-right slashed-zero tabular-nums dark:border-white/10"> | |
$100.00 | |
</dd> | |
<dt className="border-b border-gray-200 py-2 dark:border-white/10">Tax</dt> | |
<dd className="border-b border-gray-200 py-2 text-right slashed-zero tabular-nums dark:border-white/10"> | |
$14.50 | |
</dd> | |
<dt className="py-2">Total</dt> | |
<dd className="slashed-medium py-2 text-right tabular-nums">$114.50</dd> | |
</dl> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:slashed-zero,tabular-nums] --> | |
<dl class="..."> | |
<dt class="...">Subtotal</dt> | |
<dd class="text-right slashed-zero tabular-nums ...">$100.00</dd> | |
<dt class="...">Tax</dt> | |
<dd class="text-right slashed-zero tabular-nums ...">$14.50</dd> | |
<dt class="...">Total</dt> | |
<dd class="text-right slashed-zero tabular-nums ...">$114.50</dd> | |
</dl> | |
``` | |
</Figure> | |
### Resetting numeric font variants | |
Use the `normal-nums` property to reset numeric font variants: | |
```html | |
<!-- [!code classes:slashed-zero,tabular-nums,normal-nums] --> | |
<p class="slashed-zero tabular-nums md:normal-nums ..."> | |
<!-- ... --> | |
</p> | |
``` | |
### Responsive design | |
<ResponsiveDesign | |
property="font-variant-numeric" | |
defaultClass="proportional-nums" | |
featuredClass="tabular-nums" | |
element="p" | |
/> | |
--- | |
File: /src/docs/font-weight.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourTheme, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
export const title = "font-weight"; | |
export const description = "Utilities for controlling the font weight of an element."; | |
<ApiTable | |
rows={[ | |
["font-thin", "font-weight: 100;"], | |
["font-extralight", "font-weight: 200;"], | |
["font-light", "font-weight: 300;"], | |
["font-normal", "font-weight: 400;"], | |
["font-medium", "font-weight: 500;"], | |
["font-semibold", "font-weight: 600;"], | |
["font-bold", "font-weight: 700;"], | |
["font-extrabold", "font-weight: 800;"], | |
["font-black", "font-weight: 900;"], | |
["font-(<custom-property>)", "font-weight: var(<custom-property>);"], | |
["font-[<value>]", "font-weight: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `font-thin` and `font-bold` to set the font weight of an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col gap-8"> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">font-light</span> | |
<p className="text-lg font-light text-gray-900 dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">font-normal</span> | |
<p className="text-lg font-normal text-gray-900 dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">font-medium</span> | |
<p className="text-lg font-medium text-gray-900 dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">font-semibold</span> | |
<p className="text-lg font-semibold text-gray-900 dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">font-bold</span> | |
<p className="text-lg font-bold text-gray-900 dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:font-light,font-normal,font-medium,font-semibold,font-bold] --> | |
<p class="font-light ...">The quick brown fox ...</p> | |
<p class="font-normal ...">The quick brown fox ...</p> | |
<p class="font-medium ...">The quick brown fox ...</p> | |
<p class="font-semibold ...">The quick brown fox ...</p> | |
<p class="font-bold ...">The quick brown fox ...</p> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue element="p" utility="font" value="1000" name="font weight" variable="font-weight" /> | |
### Responsive design | |
<ResponsiveDesign element="p" property="font-weight" defaultClass="font-normal" featuredClass="font-bold" /> | |
## Customizing your theme | |
<CustomizingYourTheme | |
utility="font" | |
themeKey="font-weight" | |
name="font weight" | |
customValue="1000" | |
customName="extrablack" | |
/> | |
--- | |
File: /src/docs/forced-color-adjust.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
import Image from "next/image"; | |
import tshirtImage from "./img/t-shirt.jpg"; | |
export const title = "forced-color-adjust"; | |
export const description = "Utilities for opting in and out of forced colors."; | |
<ApiTable | |
rows={[ | |
["forced-color-adjust-auto", "forced-color-adjust: auto;"], | |
["forced-color-adjust-none", "forced-color-adjust: none;"], | |
]} | |
/> | |
## Examples | |
### Opting out of forced colors | |
Use the `forced-color-adjust-none` utility to opt an element out of the colors enforced by forced colors mode. This is useful in situations where enforcing a limited color palette will degrade usability. | |
<Figure hint="Try emulating `forced-colors: active` in your developer tools to see the changes"> | |
<Example> | |
{ | |
<div className="mx-auto max-w-sm overflow-clip rounded-lg border border-transparent bg-white shadow dark:border-white/10 dark:bg-white/5"> | |
<div className="aspect-h-3 aspect-w-3 overflow-hidden"> | |
<Image | |
src={tshirtImage} | |
alt="Two each of gray, white, and black shirts laying flat." | |
className="h-full w-full object-cover object-center" | |
/> | |
</div> | |
<div className="grid grid-cols-[1fr_auto] items-center gap-4 p-4"> | |
<div> | |
<p className="font-medium text-gray-900 dark:text-white">Basic Tee</p> | |
<p className="text-sm font-medium text-gray-900 dark:text-white">$35</p> | |
</div> | |
<fieldset> | |
<legend className="sr-only">Choose a color</legend> | |
<div className="grid grid-flow-col items-center gap-3 forced-color-adjust-none"> | |
<label className="relative -m-0.5 flex cursor-pointer items-center justify-center rounded-full p-0.5 ring-0 focus:outline-none has-checked:ring-1 has-checked:ring-gray-400 has-checked:ring-offset-1"> | |
<input | |
type="radio" | |
name="color-choice" | |
value="White" | |
className="sr-only" | |
aria-labelledby="color-choice-0-label" | |
/> | |
<span id="color-choice-0-label" className="sr-only"> | |
White | |
</span> | |
<span | |
aria-hidden="true" | |
className="size-6 rounded-full border border-black/10 bg-white dark:border-white/10" | |
></span> | |
</label> | |
<label className="relative -m-0.5 flex cursor-pointer items-center justify-center rounded-full p-0.5 ring-0 focus:outline-none has-checked:ring-1 has-checked:ring-gray-400 has-checked:ring-offset-1"> | |
<input type="radio" defaultChecked name="color-choice" value="Gray" className="sr-only" /> | |
<span id="color-choice-1-label" className="sr-only"> | |
Gray | |
</span> | |
<span | |
aria-hidden="true" | |
className="size-6 rounded-full border border-black/10 bg-gray-200 dark:border-white/10" | |
></span> | |
</label> | |
<label className="relative -m-0.5 flex cursor-pointer items-center justify-center rounded-full p-0.5 ring-0 focus:outline-none has-checked:ring-1 has-checked:ring-gray-900 has-checked:ring-offset-1"> | |
<input | |
type="radio" | |
name="color-choice" | |
value="Black" | |
className="sr-only" | |
aria-labelledby="color-choice-2-label" | |
/> | |
<span id="color-choice-2-label" className="sr-only"> | |
Black | |
</span> | |
<span | |
aria-hidden="true" | |
className="size-6 rounded-full border border-black/10 bg-gray-900 dark:border-white/10" | |
></span> | |
</label> | |
</div> | |
</fieldset> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:forced-color-adjust-none] --> | |
<form> | |
<img src="/img/shirt.jpg" /> | |
<div> | |
<h3>Basic Tee</h3> | |
<h3>$35</h3> | |
<fieldset> | |
<legend class="sr-only">Choose a color</legend> | |
<div class="forced-color-adjust-none ..."> | |
<label> | |
<input class="sr-only" type="radio" name="color-choice" value="White" /> | |
<span class="sr-only">White</span> | |
<span class="size-6 rounded-full border border-black/10 bg-white"></span> | |
</label> | |
<!-- ... --> | |
</div> | |
</fieldset> | |
</div> | |
</form> | |
``` | |
</Figure> | |
You can also use the [forced colors variant](/docs/hover-focus-and-other-states#forced-colors) to conditionally add styles when the user has enabled a forced color mode. | |
### Restoring forced colors | |
Use the `forced-color-adjust-auto` utility to make an element adhere to colors enforced by forced colors mode: | |
```html | |
<!-- [!code classes:lg:forced-color-adjust-auto] --> | |
<form> | |
<fieldset class="forced-color-adjust-none lg:forced-color-adjust-auto ..."> | |
<legend>Choose a color:</legend> | |
<select class="hidden lg:block"> | |
<option value="White">White</option> | |
<option value="Gray">Gray</option> | |
<option value="Black">Black</option> | |
</select> | |
<div class="lg:hidden"> | |
<label> | |
<input class="sr-only" type="radio" name="color-choice" value="White" /> | |
<!-- ... --> | |
</label> | |
<!-- ... --> | |
</div> | |
</fieldset> | |
</form> | |
``` | |
This can be useful if you want to undo the `forced-color-adjust-none` utility, for example on a larger screen size. | |
### Responsive design | |
<ResponsiveDesign | |
property="forced-color-adjust" | |
defaultClass="forced-color-adjust-none" | |
featuredClass="forced-color-adjust-auto" | |
/> | |
--- | |
File: /src/docs/functions-and-directives.mdx | |
--- | |
import { CodeExampleStack } from "@/components/code-example"; | |
export const title = "Functions and directives"; | |
export const description = "A reference for the custom functions and directives Tailwind exposes to your CSS."; | |
## Directives | |
Directives are custom Tailwind-specific [at-rules](https://developer.mozilla.org/en-US/docs/Web/CSS/At-rule) you can use in your CSS that offer special functionality for Tailwind CSS projects. | |
<h3 id="import-directive">@import</h3> | |
Use the `@import` directive to inline import CSS files, including Tailwind itself: | |
```css | |
/* [!code filename:CSS] */ | |
@import "tailwindcss"; | |
``` | |
<h3 id="theme-directive">@theme</h3> | |
Use the `@theme` directive to define your project's custom design tokens, like fonts, colors, and breakpoints: | |
```css | |
/* [!code filename:CSS] */ | |
@theme { | |
--font-display: "Satoshi", "sans-serif"; | |
--breakpoint-3xl: 120rem; | |
--color-avocado-100: oklch(0.99 0 0); | |
--color-avocado-200: oklch(0.98 0.04 113.22); | |
--color-avocado-300: oklch(0.94 0.11 115.03); | |
--color-avocado-400: oklch(0.92 0.19 114.08); | |
--color-avocado-500: oklch(0.84 0.18 117.33); | |
--color-avocado-600: oklch(0.53 0.12 118.34); | |
--ease-fluid: cubic-bezier(0.3, 0, 0, 1); | |
--ease-snappy: cubic-bezier(0.2, 0, 0, 1); | |
/* ... */ | |
} | |
``` | |
Learn more about customizing your theme in the [theme variables documentation](/docs/theme). | |
<h3 id="source-directive">@source</h3> | |
Use the `@source` directive to explicitly specify source files that aren't picked up by Tailwind's automatic content detection: | |
```css | |
/* [!code filename:CSS] */ | |
@source "../node_modules/@my-company/ui-lib"; | |
``` | |
Learn more about automatic content detection in the [detecting classes in source files documentation](/docs/detecting-classes-in-source-files). | |
<h3 id="utility-directive">@utility</h3> | |
Use the `@utility` directive to add custom utilities to your project that work with variants like `hover`, `focus` and `lg`: | |
```css | |
/* [!code filename:CSS] */ | |
@utility tab-4 { | |
tab-size: 4; | |
} | |
``` | |
Learn more about registering custom utilities in the [adding custom utilities documentation](/docs/adding-custom-styles#adding-custom-utilities). | |
<h3 id="variant-directive">@variant</h3> | |
Use the `@variant` directive to apply a Tailwind variant to styles in your CSS: | |
```css | |
/* [!code filename:CSS] */ | |
.my-element { | |
background: white; | |
/* [!code highlight:4] */ | |
@variant dark { | |
background: black; | |
} | |
} | |
``` | |
Learn more using variants in the [using variants documentation](/docs/adding-custom-styles#using-variants). | |
<h3 id="custom-variant-directive">@custom-variant</h3> | |
Use the `@custom-variant` directive to add a custom variant in your project: | |
```css | |
/* [!code filename:CSS] */ | |
@custom-variant theme-midnight (&:where([data-theme="midnight"] *)); | |
``` | |
This lets you write utilities `theme-midnight:bg-black` and `theme-midnight:text-white`. | |
Learn more about adding custom variants in the [adding custom variants documentation](/docs/adding-custom-styles#adding-custom-variants). | |
<h3 id="apply-directive">@apply</h3> | |
Use the `@apply` directive to inline any existing utility classes into your own custom CSS: | |
```css | |
/* [!code filename:CSS] */ | |
.select2-dropdown { | |
/* [!code highlight:2] */ | |
@apply rounded-b-lg shadow-md; | |
} | |
.select2-search { | |
/* [!code highlight:2] */ | |
@apply rounded border border-gray-300; | |
} | |
.select2-results__group { | |
/* [!code highlight:2] */ | |
@apply text-lg font-bold text-gray-900; | |
} | |
``` | |
This is useful when you need to write custom CSS (like to override the styles in a third-party library) but still want to work with your design tokens and use the same syntax you’re used to using in your HTML. | |
<h3 id="reference-directive">@reference</h3> | |
If you want to use `@apply` or `@variant` in the `<style>` block of a Vue or Svelte component, or within CSS modules, you will need to import your theme variables, custom utilities, and custom variants to make those values available in that context. | |
To do this without duplicating any CSS in your output, use the `@reference` directive to import your main stylesheet for reference without actually including the styles: | |
```html | |
<!-- [!code filename:Vue] --> | |
<template> | |
<h1>Hello world!</h1> | |
</template> | |
<style> | |
/* [!code highlight:2] */ | |
@reference "../../app.css"; | |
h1 { | |
@apply text-2xl font-bold text-red-500; | |
} | |
</style> | |
``` | |
If you’re just using the default theme with no customizations, you can import `tailwindcss` directly: | |
```html | |
<!-- [!code filename:Vue] --> | |
<template> | |
<h1>Hello world!</h1> | |
</template> | |
<style> | |
/* [!code highlight:2] */ | |
@reference "tailwindcss"; | |
h1 { | |
@apply text-2xl font-bold text-red-500; | |
} | |
</style> | |
``` | |
## Functions | |
Tailwind provides the following build-time functions to make working with colors and the spacing scale easier. | |
<h3 id="alpha-function">--alpha()</h3> | |
Use the `--alpha()` function to adjust the opacity of a color: | |
<CodeExampleStack> | |
```css | |
/* [!code filename:Input CSS] */ | |
.my-element { | |
/* [!code highlight:2] */ | |
color: --alpha(var(--color-lime-300) / 50%); | |
} | |
``` | |
```css | |
/* [!code filename:Compiled CSS] */ | |
.my-element { | |
color: color-mix(in oklab, var(--color-lime-300) 50%, transparent); | |
} | |
``` | |
</CodeExampleStack> | |
<h3 id="spacing-function">--spacing()</h3> | |
Use the `--spacing()` function to generate a spacing value based on your theme: | |
<CodeExampleStack> | |
```css | |
/* [!code filename:Input CSS] */ | |
.my-element { | |
/* [!code highlight:2] */ | |
margin: --spacing(4); | |
} | |
``` | |
```css | |
/* [!code filename:Compiled CSS] */ | |
.my-element { | |
margin: calc(var(--spacing) * 4); | |
} | |
``` | |
</CodeExampleStack> | |
This can also be useful in arbitrary values, especially in combination with `calc()`: | |
```html | |
<!-- [!code filename:HTML] --> | |
<!-- [!code classes:py-[calc(--spacing(4)-1px)]] --> | |
<div class="py-[calc(--spacing(4)-1px)]"> | |
<!-- ... --> | |
</div> | |
``` | |
## Compatibility | |
The following directives and functions exist solely for compatibility with Tailwind CSS v3.x. | |
<h3 id="config-directive">@config</h3> | |
Use the `@config` directive to load a legacy JavaScript-based configuration file: | |
```css | |
/* [!code filename:CSS] */ | |
@config "../../tailwind.config.js"; | |
``` | |
The `corePlugins`, `safelist`, and `separator` options from the JavaScript-based config are not supported in v4.0. | |
<h3 id="plugin-directive">@plugin</h3> | |
Use the `@plugin` directive to load a legacy JavaScript-based plugin: | |
```css | |
/* [!code filename:CSS] */ | |
@plugin "@tailwindcss/typography"; | |
``` | |
The `@plugin` directive accepts either a package name or a local path. | |
<h3 id="theme-function">theme()</h3> | |
Use the `theme()` function to access your Tailwind theme values using dot notation: | |
```css | |
/* [!code filename:CSS] */ | |
.my-element { | |
/* [!code highlight:2] */ | |
margin: theme(spacing.12); | |
} | |
``` | |
This function is deprecated, and we recommend [using CSS theme variables](/docs/theme#using-your-theme-variables) instead. | |
--- | |
File: /src/docs/gap.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "gap"; | |
export const description = "Utilities for controlling gutters between grid and flexbox items."; | |
<ApiTable | |
rows={[ | |
["gap-<number>", "gap: calc(var(--spacing) * <value>);"], | |
["gap-(<custom-property>)", "gap: var(<custom-property>);"], | |
["gap-[<value>]", "gap: <value>;"], | |
["gap-x-<number>", "column-gap: calc(var(--spacing) * <value>);"], | |
["gap-x-(<custom-property>)", "column-gap: var(<custom-property>);"], | |
["gap-x-[<value>]", "column-gap: <value>;"], | |
["gap-y-<number>", "row-gap: calc(var(--spacing) * <value>);"], | |
["gap-y-(<custom-property>)", "row-gap: var(<custom-property>);"], | |
["gap-y-[<value>]", "row-gap: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use `gap-<number>` utilities like `gap-2` and `gap-4` to change the gap between both rows and columns in grid and flexbox layouts: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 grid grid-cols-2 gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="rounded-lg bg-violet-500 p-4">01</div> | |
<div className="rounded-lg bg-violet-500 p-4">02</div> | |
<div className="rounded-lg bg-violet-500 p-4">03</div> | |
<div className="rounded-lg bg-violet-500 p-4">04</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:gap-4] --> | |
<div class="grid grid-cols-2 gap-4"> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
<div>04</div> | |
</div> | |
``` | |
</Figure> | |
### Changing row and column gaps independently | |
Use `gap-x-<number>` or `gap-y-<number>` utilities like `gap-x-8` and `gap-y-4` to change the gap between columns and rows independently: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 grid grid-cols-3 gap-x-8 gap-y-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="rounded-lg bg-sky-500 p-4">01</div> | |
<div className="rounded-lg bg-sky-500 p-4">02</div> | |
<div className="rounded-lg bg-sky-500 p-4">03</div> | |
<div className="rounded-lg bg-sky-500 p-4">04</div> | |
<div className="rounded-lg bg-sky-500 p-4">05</div> | |
<div className="rounded-lg bg-sky-500 p-4">06</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:gap-x-8,gap-y-4] --> | |
<div class="grid grid-cols-3 gap-x-8 gap-y-4"> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
<div>04</div> | |
<div>05</div> | |
<div>06</div> | |
</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utilities={["gap", "gap-x", "gap-y"]} value="10vw" /> | |
### Responsive design | |
<ResponsiveDesign properties={["gap", "column-gap", "row-gap"]} defaultClass="grid gap-4" featuredClass="gap-6" /> | |
--- | |
File: /src/docs/grid-auto-columns.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "grid-auto-columns"; | |
export const description = "Utilities for controlling the size of implicitly-created grid columns."; | |
<ApiTable | |
rows={[ | |
["auto-cols-auto", "grid-auto-columns: auto;"], | |
["auto-cols-min", "grid-auto-columns: min-content;"], | |
["auto-cols-max", "grid-auto-columns: max-content;"], | |
["auto-cols-fr", "grid-auto-columns: minmax(0, 1fr);"], | |
["auto-cols-(<custom-property>)", "grid-auto-columns: var(<custom-property>);"], | |
["auto-cols-[<value>]", "grid-auto-columns: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `auto-cols-min` and `auto-cols-max` to control the size of implicitly-created grid columns: | |
```html | |
<!-- [!code classes:auto-cols-max] --> | |
<div class="grid auto-cols-max grid-flow-col"> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
### Using a custom value | |
<UsingACustomValue utility="auto-cols" name="size of implicitly-created grid columns" value="minmax(0,2fr)" /> | |
### Responsive design | |
<ResponsiveDesign | |
property="grid-auto-columns" | |
defaultClass="grid grid-flow-col auto-cols-max" | |
featuredClass="auto-cols-min" | |
/> | |
--- | |
File: /src/docs/grid-auto-flow.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "grid-auto-flow"; | |
export const description = "Utilities for controlling how elements in a grid are auto-placed."; | |
<ApiTable | |
rows={[ | |
["grid-flow-row", "grid-auto-flow: row;"], | |
["grid-flow-col", "grid-auto-flow: column;"], | |
["grid-flow-dense", "grid-auto-flow: dense;"], | |
["grid-flow-row-dense", "grid-auto-flow: row dense;"], | |
["grid-flow-col-dense", "grid-auto-flow: column dense;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `grid-flow-col` and `grid-flow-row-dense` to control how the auto-placement algorithm works for a grid layout: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 grid grid-flow-row-dense grid-cols-3 grid-rows-3 gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="col-span-2 rounded-lg bg-purple-300 p-4 dark:bg-purple-800 dark:text-purple-400">01</div> | |
<div className="col-span-2 rounded-lg bg-purple-300 p-4 dark:bg-purple-800 dark:text-purple-400">02</div> | |
<div className="rounded-lg bg-purple-500 p-4">03</div> | |
<div className="rounded-lg bg-purple-300 p-4 dark:bg-purple-800 dark:text-purple-400">04</div> | |
<div className="rounded-lg bg-purple-300 p-4 dark:bg-purple-800 dark:text-purple-400">05</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:grid-flow-row-dense] --> | |
<div class="grid grid-flow-row-dense grid-cols-3 grid-rows-3 ..."> | |
<div class="col-span-2">01</div> | |
<div class="col-span-2">02</div> | |
<div>03</div> | |
<div>04</div> | |
<div>05</div> | |
</div> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="grid-auto-flow" defaultClass="grid grid-flow-col" featuredClass="grid-flow-row" /> | |
--- | |
File: /src/docs/grid-auto-rows.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "grid-auto-rows"; | |
export const description = "Utilities for controlling the size of implicitly-created grid rows."; | |
<ApiTable | |
rows={[ | |
["auto-rows-auto", "grid-auto-rows: auto;"], | |
["auto-rows-min", "grid-auto-rows: min-content;"], | |
["auto-rows-max", "grid-auto-rows: max-content;"], | |
["auto-rows-fr", "grid-auto-rows: minmax(0, 1fr);"], | |
["auto-rows-(<custom-property>)", "grid-auto-rows: var(<custom-property>);"], | |
["auto-rows-[<value>]", "grid-auto-rows: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `auto-rows-min` and `auto-rows-max` to control the size of implicitly-created grid rows: | |
```html | |
<!-- [!code classes:auto-rows-max] --> | |
<div class="grid grid-flow-row auto-rows-max"> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
### Using a custom value | |
<UsingACustomValue utility="auto-rows" name="size of implicitly-created grid rows" value="minmax(0,2fr)" /> | |
### Responsive design | |
<ResponsiveDesign | |
property="grid-auto-rows" | |
defaultClass="grid grid-flow-row auto-rows-max" | |
featuredClass="auto-rows-min" | |
/> | |
--- | |
File: /src/docs/grid-column.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "grid-column"; | |
export const description = "Utilities for controlling how elements are sized and placed across grid columns."; | |
<ApiTable | |
rows={[ | |
["col-span-<number>", "grid-column: span <number> / span <number>;"], | |
["col-span-full", "grid-column: 1 / -1;"], | |
["col-span-(<custom-property>)", "grid-column: span var(<custom-property>) / span var(<custom-property>);"], | |
["col-span-[<value>]", "grid-column: span <value> / span <value>;"], | |
["col-start-<number>", "grid-column-start: <number>;"], | |
["-col-start-<number>", "grid-column-start: calc(<number> * -1);"], | |
["col-start-auto", "grid-column-start: auto;"], | |
["col-start-(<custom-property>)", "grid-column-start: var(<custom-property>);"], | |
["col-start-[<value>]", "grid-column-start: <value>;"], | |
["col-end-<number>", "grid-column-end: <number>;"], | |
["-col-end-<number>", "grid-column-end: calc(<number> * -1);"], | |
["col-end-auto", "grid-column-end: auto;"], | |
["col-end-(<custom-property>)", "grid-column-end: var(<custom-property>);"], | |
["col-end-[<value>]", "grid-column-end: <value>;"], | |
["col-auto", "grid-column: auto;"], | |
["col-<number>", "grid-column: <number>;"], | |
["-col-<number>", "grid-column: calc(<number> * -1);"], | |
["col-(<custom-property>)", "grid-column: var(<custom-property>);"], | |
["col-[<value>]", "grid-column: <value>;"], | |
]} | |
/> | |
## Examples | |
### Spanning columns | |
Use `col-span-<number>` utilities like `col-span-2` and `col-span-4` to make an element span _n_ columns: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 grid grid-cols-3 gap-4 text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="rounded-lg bg-indigo-300 p-4 dark:bg-indigo-800 dark:text-indigo-400">01</div> | |
<div className="rounded-lg bg-indigo-300 p-4 dark:bg-indigo-800 dark:text-indigo-400">02</div> | |
<div className="rounded-lg bg-indigo-300 p-4 dark:bg-indigo-800 dark:text-indigo-400">03</div> | |
<div className="col-span-2 rounded-lg bg-indigo-500 p-4">04</div> | |
<div className="rounded-lg bg-indigo-300 p-4 dark:bg-indigo-800 dark:text-indigo-400">05</div> | |
<div className="rounded-lg bg-indigo-300 p-4 dark:bg-indigo-800 dark:text-indigo-400">06</div> | |
<div className="col-span-2 rounded-lg bg-indigo-500 p-4">07</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:col-span-2] --> | |
<div class="grid grid-cols-3 gap-4"> | |
<div class="...">01</div> | |
<div class="...">02</div> | |
<div class="...">03</div> | |
<div class="col-span-2 ...">04</div> | |
<div class="...">05</div> | |
<div class="...">06</div> | |
<div class="col-span-2 ...">07</div> | |
</div> | |
``` | |
</Figure> | |
### Starting and ending lines | |
Use `col-start-<number>` or `col-end-<number>` utilities like `col-start-2` and `col-end-3` to make an element start or end at the _nth_ grid line: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-6 gap-4 text-center font-mono text-sm leading-6 font-bold text-white"> | |
<Stripes border className="rounded-lg p-4" /> | |
<div className="col-span-4 col-start-2 rounded-lg bg-sky-500 p-4">01</div> | |
<Stripes border className="rounded-lg p-4" /> | |
<div className="col-start-1 col-end-3 rounded-lg bg-sky-500 p-4">02</div> | |
<Stripes border className="rounded-lg p-4" /> | |
<Stripes border className="rounded-lg p-4" /> | |
<div className="col-span-2 col-end-7 rounded-lg bg-sky-500 p-4">03</div> | |
<div className="col-start-1 col-end-7 rounded-lg bg-sky-500 p-4">04</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:col-start-1,col-start-2,col-end-3,col-end-7] --> | |
<div class="grid grid-cols-6 gap-4"> | |
<div class="col-span-4 col-start-2 ...">01</div> | |
<div class="col-start-1 col-end-3 ...">02</div> | |
<div class="col-span-2 col-end-7 ...">03</div> | |
<div class="col-start-1 col-end-7 ...">04</div> | |
</div> | |
``` | |
</Figure> | |
These can also be combined with the `col-span-<number>` utilities to span a specific number of columns. | |
### Using a custom value | |
<UsingACustomValue | |
utilities={["col", "col-span", "col-start", "col-end"]} | |
variable="columns" | |
name="grid column size and location" | |
value="16_/_span_16" | |
/> | |
### Responsive design | |
<ResponsiveDesign | |
properties={["grid-column", "grid-column-start", "grid-column-end"]} | |
defaultClass="col-span-2" | |
featuredClass="col-span-6" | |
/> | |
--- | |
File: /src/docs/grid-row.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "grid-row"; | |
export const description = "Utilities for controlling how elements are sized and placed across grid rows."; | |
<ApiTable | |
rows={[ | |
["row-span-<number>", "grid-row: span <number> / span <number>;"], | |
["row-span-full", "grid-row: 1 / -1;"], | |
["row-span-(<custom-property>)", "grid-row: span var(<custom-property>) / span var(<custom-property>);"], | |
["row-span-[<value>]", "grid-row: span <value> / span <value>;"], | |
["row-start-<number>", "grid-row-start: <number>;"], | |
["-row-start-<number>", "grid-row-start: calc(<number> * -1);"], | |
["row-start-auto", "grid-row-start: auto;"], | |
["row-start-(<custom-property>)", "grid-row-start: var(<custom-property>);"], | |
["row-start-[<value>]", "grid-row-start: <value>;"], | |
["row-end-<number>", "grid-row-end: <number>;"], | |
["-row-end-<number>", "grid-row-end: calc(<number> * -1);"], | |
["row-end-auto", "grid-row-end: auto;"], | |
["row-end-(<custom-property>)", "grid-row-end: var(<custom-property>);"], | |
["row-end-[<value>]", "grid-row-end: <value>;"], | |
["row-auto", "grid-row: auto;"], | |
["row-<number>", "grid-row: <number>;"], | |
["-row-<number>", "grid-row: calc(<number> * -1);"], | |
["row-(<custom-property>)", "grid-row: var(<custom-property>);"], | |
["row-[<value>]", "grid-row: <value>;"], | |
]} | |
/> | |
## Examples | |
### Spanning rows | |
Use `row-span-<number>` utilities like `row-span-2` and `row-span-4` to make an element span _n_ rows: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 grid grid-flow-col grid-rows-3 gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="row-span-3 grid place-content-center rounded-lg bg-fuchsia-500 p-4">01</div> | |
<div className="col-span-2 grid place-content-center rounded-lg bg-fuchsia-300 p-4 dark:bg-fuchsia-800 dark:text-fuchsia-400"> | |
02 | |
</div> | |
<div className="col-span-2 row-span-2 grid place-content-center rounded-lg bg-fuchsia-500 p-4">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:row-span-2,row-span-3] --> | |
<div class="grid grid-flow-col grid-rows-3 gap-4"> | |
<div class="row-span-3 ...">01</div> | |
<div class="col-span-2 ...">02</div> | |
<div class="col-span-2 row-span-2 ...">03</div> | |
</div> | |
``` | |
</Figure> | |
### Starting and ending lines | |
Use `row-start-<number>` or `row-end-<number>` utilities like `row-start-2` and `row-end-3` to make an element start or end at the _nth_ grid line: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 grid grid-flow-col grid-rows-3 gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="row-span-2 row-start-2 grid place-content-center rounded-lg bg-blue-500 p-4 sm:p-12">01</div> | |
<div className="row-span-2 row-end-3 grid place-content-center rounded-lg bg-blue-500 p-4 sm:p-12">02</div> | |
<div className="row-start-1 row-end-4 grid place-content-center rounded-lg bg-blue-500 p-4 sm:p-12">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:row-start-1,row-start-2,row-end-3,row-end-4] --> | |
<div class="grid grid-flow-col grid-rows-3 gap-4"> | |
<div class="row-span-2 row-start-2 ...">01</div> | |
<div class="row-span-2 row-end-3 ...">02</div> | |
<div class="row-start-1 row-end-4 ...">03</div> | |
</div> | |
``` | |
</Figure> | |
These can also be combined with the `row-span-<number>` utilities to span a specific number of rows. | |
### Using a custom value | |
<UsingACustomValue | |
utilities={["row", "row-span", "row-start", "row-end"]} | |
variable="rows" | |
name="grid row size and location" | |
value="span_16_/_span_16" | |
/> | |
### Responsive design | |
<ResponsiveDesign | |
properties={["grid-row", "grid-row-start", "grid-row-end"]} | |
defaultClass="row-span-3" | |
featuredClass="row-span-4" | |
/> | |
--- | |
File: /src/docs/grid-template-columns.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourTheme, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "grid-template-columns"; | |
export const description = "Utilities for specifying the columns in a grid layout."; | |
<ApiTable | |
rows={[ | |
["grid-cols-<number>", "grid-template-columns: repeat(<number>, minmax(0, 1fr));"], | |
["grid-cols-none", "grid-template-columns: none;"], | |
["grid-cols-subgrid", "grid-template-columns: subgrid;"], | |
["grid-cols-[<value>]", "grid-template-columns: <value>;"], | |
["grid-cols-(<custom-property>)", "grid-template-columns: var(<custom-property>);"], | |
]} | |
/> | |
## Examples | |
### Specifying the grid columns | |
Use `grid-cols-<number>` utilities like `grid-cols-2` and `grid-cols-4` to create grids with _n_ equally sized columns: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 grid grid-cols-4 gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="rounded-lg bg-fuchsia-500 p-4">01</div> | |
<div className="rounded-lg bg-fuchsia-500 p-4">02</div> | |
<div className="rounded-lg bg-fuchsia-500 p-4">03</div> | |
<div className="rounded-lg bg-fuchsia-500 p-4">04</div> | |
<div className="rounded-lg bg-fuchsia-500 p-4">05</div> | |
<div className="rounded-lg bg-fuchsia-500 p-4">06</div> | |
<div className="rounded-lg bg-fuchsia-500 p-4">07</div> | |
<div className="rounded-lg bg-fuchsia-500 p-4">08</div> | |
<div className="rounded-lg bg-fuchsia-500 p-4">09</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:grid-cols-4] --> | |
<div class="grid grid-cols-4 gap-4"> | |
<div>01</div> | |
<!-- ... --> | |
<div>09</div> | |
</div> | |
``` | |
</Figure> | |
### Implementing a subgrid | |
Use the `grid-cols-subgrid` utility to adopt the column tracks defined by the item's parent: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-4 gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="rounded-lg bg-indigo-300 p-4 dark:bg-indigo-900">01</div> | |
<div className="rounded-lg bg-indigo-300 p-4 dark:bg-indigo-900">02</div> | |
<div className="rounded-lg bg-indigo-300 p-4 dark:bg-indigo-900">03</div> | |
<div className="rounded-lg bg-indigo-300 p-4 dark:bg-indigo-900">04</div> | |
<div className="rounded-lg bg-indigo-300 p-4 dark:bg-indigo-900">05</div> | |
<div className="col-span-3 grid grid-cols-subgrid gap-4"> | |
<Stripes border className="rounded-lg p-4" /> | |
<div className="rounded-lg bg-pink-500 p-4">06</div> | |
<Stripes border className="rounded-lg p-4" /> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:grid-cols-subgrid] --> | |
<div class="grid grid-cols-4 gap-4"> | |
<div>01</div> | |
<!-- ... --> | |
<div>05</div> | |
<div class="col-span-3 grid grid-cols-subgrid gap-4"> | |
<div class="col-start-2">06</div> | |
</div> | |
</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="grid-cols" name="columns" value="200px_minmax(900px,_1fr)_100px" /> | |
### Responsive design | |
<ResponsiveDesign property="grid-template-columns" defaultClass="grid grid-cols-1" featuredClass="grid-cols-6" /> | |
--- | |
File: /src/docs/grid-template-rows.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "grid-template-rows"; | |
export const description = "Utilities for specifying the rows in a grid layout."; | |
<ApiTable | |
rows={[ | |
["grid-rows-<number>", "grid-template-rows: repeat(<number>, minmax(0, 1fr));"], | |
["grid-rows-none", "grid-template-rows: none;"], | |
["grid-rows-subgrid", "grid-template-rows: subgrid;"], | |
["grid-rows-[<value>]", "grid-template-rows: <value>;"], | |
["grid-rows-(<custom-property>)", "grid-template-rows: var(<custom-property>);"], | |
]} | |
/> | |
## Examples | |
### Specifying the grid rows | |
Use `grid-rows-<number>` utilities like `grid-rows-2` and `grid-rows-4` to create grids with _n_ equally sized rows: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 grid grid-flow-col grid-rows-4 gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="rounded-lg bg-pink-500 p-4">01</div> | |
<div className="rounded-lg bg-pink-500 p-4">02</div> | |
<div className="rounded-lg bg-pink-500 p-4">03</div> | |
<div className="rounded-lg bg-pink-500 p-4">04</div> | |
<div className="rounded-lg bg-pink-500 p-4">05</div> | |
<div className="rounded-lg bg-pink-500 p-4">06</div> | |
<div className="rounded-lg bg-pink-500 p-4">07</div> | |
<div className="rounded-lg bg-pink-500 p-4">08</div> | |
<div className="rounded-lg bg-pink-500 p-4">09</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:grid-rows-4] --> | |
<div class="grid grid-flow-col grid-rows-4 gap-4"> | |
<div>01</div> | |
<!-- ... --> | |
<div>09</div> | |
</div> | |
``` | |
</Figure> | |
### Implementing a subgrid | |
Use the `grid-rows-subgrid` utility to adopt the row tracks defined by the item's parent: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-flow-col grid-rows-4 gap-4 rounded-lg text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="grid h-14 items-center justify-center rounded-lg bg-indigo-300 dark:bg-indigo-900">01</div> | |
<div className="grid h-14 items-center justify-center rounded-lg bg-indigo-300 dark:bg-indigo-900">02</div> | |
<div className="grid h-14 items-center justify-center rounded-lg bg-indigo-300 dark:bg-indigo-900">03</div> | |
<div className="grid h-14 items-center justify-center rounded-lg bg-indigo-300 dark:bg-indigo-900">04</div> | |
<div className="grid h-14 items-center justify-center rounded-lg bg-indigo-300 dark:bg-indigo-900">05</div> | |
<div className="row-span-3 grid grid-rows-subgrid gap-4"> | |
<Stripes border className="h-14 rounded-lg" /> | |
<div className="grid h-14 items-center justify-center rounded-lg bg-fuchsia-500">06</div> | |
<Stripes border className="h-14 rounded-lg" /> | |
</div> | |
<div className="grid h-14 items-center justify-center rounded-lg bg-indigo-300 dark:bg-indigo-900">07</div> | |
<div className="grid h-14 items-center justify-center rounded-lg bg-indigo-300 dark:bg-indigo-900">08</div> | |
<div className="grid h-14 items-center justify-center rounded-lg bg-indigo-300 dark:bg-indigo-900">09</div> | |
<div className="grid h-14 items-center justify-center rounded-lg bg-indigo-300 dark:bg-indigo-900">10</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:grid-rows-subgrid] --> | |
<div class="grid grid-flow-col grid-rows-4 gap-4"> | |
<div>01</div> | |
<!-- ... --> | |
<div>05</div> | |
<div class="row-span-3 grid grid-rows-subgrid gap-4"> | |
<div class="row-start-2">06</div> | |
</div> | |
<div>07</div> | |
<!-- ... --> | |
<div>10</div> | |
</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="grid-rows" name="rows" value="200px_minmax(900px,1fr)_100px" /> | |
### Responsive design | |
<ResponsiveDesign property="grid-template-rows" defaultClass="grid grid-rows-2" featuredClass="grid-rows-6" /> | |
--- | |
File: /src/docs/height.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourSpacingScale, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { DynamicViewportExample } from "@/components/dynamic-viewport-example.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "height"; | |
export const description = "Utilities for setting the height of an element."; | |
<ApiTable | |
rows={[ | |
["h-<number>", "height: calc(var(--spacing) * <number>);"], | |
["h-<fraction>", "height: calc(<fraction> * 100%);"], | |
["h-auto", "height: auto;"], | |
["h-px", "height: 1px;"], | |
["h-full", "height: 100%;"], | |
["h-screen", "height: 100vh;"], | |
["h-dvh", "height: 100dvh;"], | |
["h-dvw", "height: 100dvw;"], | |
["h-lvh", "height: 100lvh;"], | |
["h-lvw", "height: 100lvw;"], | |
["h-svh", "height: 100svh;"], | |
["h-svw", "height: 100svw;"], | |
["h-min", "height: min-content;"], | |
["h-max", "height: max-content;"], | |
["h-fit", "height: fit-content;"], | |
["h-lh", "height: 1lh;"], | |
["h-(<custom-property>)", "height: var(<custom-property>);"], | |
["h-[<value>]", "height: <value>;"], | |
["size-<number>", "width: calc(var(--spacing) * <number>);\nheight: calc(var(--spacing) * <number>);"], | |
["size-<fraction>", "width: calc(<fraction> * 100%);\nheight: calc(<fraction> * 100%);"], | |
["size-auto", "width: auto;\nheight: auto;"], | |
["size-px", "width: 1px;\nheight: 1px;"], | |
["size-full", "width: 100%;\nheight: 100%;"], | |
["size-dvw", "width: 100dvw;\nheight: 100dvw;"], | |
["size-dvh", "width: 100dvh;\nheight: 100dvh;"], | |
["size-lvw", "width: 100lvw;\nheight: 100lvw;"], | |
["size-lvh", "width: 100lvh;\nheight: 100lvh;"], | |
["size-svw", "width: 100svw;\nheight: 100svw;"], | |
["size-svh", "width: 100svh;\nheight: 100svh;"], | |
["size-min", "width: min-content;\nheight: min-content;"], | |
["size-max", "width: max-content;\nheight: max-content;"], | |
["size-fit", "width: fit-content;\nheight: fit-content;"], | |
["size-(<custom-property>)", "width: var(<custom-property>);\nheight: var(<custom-property>);"], | |
["size-[<value>]", "width: <value>;\nheight: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use `h-<number>` utilities like `h-24` and `h-64` to set an element to a fixed height based on the spacing scale: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex items-end justify-center space-x-4 font-mono text-xs font-bold text-white"> | |
<div className="relative flex h-96 w-8 items-end justify-center rounded-lg bg-blue-500"> | |
<div className="mb-4 -rotate-90 text-left text-nowrap">h-96</div> | |
</div> | |
<div className="relative flex h-80 w-8 items-end justify-center rounded-lg bg-blue-500"> | |
<div className="mb-4 -rotate-90 text-left text-nowrap">h-80</div> | |
</div> | |
<div className="relative flex h-64 w-8 items-end justify-center rounded-lg bg-blue-500"> | |
<div className="mb-4 -rotate-90 text-left text-nowrap">h-64</div> | |
</div> | |
<div className="relative flex h-48 w-8 items-end justify-center rounded-lg bg-blue-500"> | |
<div className="mb-4 -rotate-90 text-left text-nowrap">h-48</div> | |
</div> | |
<div className="relative flex h-40 w-8 items-end justify-center rounded-lg bg-blue-500"> | |
<div className="mb-4 -rotate-90 text-left text-nowrap">h-40</div> | |
</div> | |
<div className="relative flex h-32 w-8 items-end justify-center rounded-lg bg-blue-500"> | |
<div className="mb-4 -rotate-90 text-left text-nowrap">h-32</div> | |
</div> | |
<div className="relative flex h-24 w-8 items-end justify-center rounded-lg bg-blue-500"> | |
<div className="mb-4 -rotate-90 text-left text-nowrap">h-24</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:h-96,h-80,h-64,h-48,h-40,h-32,h-24] --> | |
<div class="h-96 ...">h-96</div> | |
<div class="h-80 ...">h-80</div> | |
<div class="h-64 ...">h-64</div> | |
<div class="h-48 ...">h-48</div> | |
<div class="h-40 ...">h-40</div> | |
<div class="h-32 ...">h-32</div> | |
<div class="h-24 ...">h-24</div> | |
``` | |
</Figure> | |
### Using a percentage | |
Use `h-full` or `h-<fraction>` utilities like `h-1/2` and `h-2/5` to give an element a percentage-based height: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex h-96 items-end justify-center space-x-4 font-mono text-xs font-bold text-white"> | |
<div className="relative flex h-full items-end"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative flex h-full w-8 items-end justify-center rounded-lg bg-sky-500"> | |
<div className="mb-6 -rotate-90 text-left text-nowrap">h-full</div> | |
</div> | |
</div> | |
<div className="relative flex h-full items-end"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative flex h-9/10 w-8 items-end justify-center rounded-lg bg-sky-500"> | |
<div className="mb-6 -rotate-90 text-left text-nowrap">h-9/10</div> | |
</div> | |
</div> | |
<div className="relative flex h-full items-end"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative flex h-3/4 w-8 items-end justify-center rounded-lg bg-sky-500"> | |
<div className="mb-6 -rotate-90 text-left text-nowrap">h-3/4</div> | |
</div> | |
</div> | |
<div className="relative flex h-full items-end"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative flex h-1/2 w-8 items-end justify-center rounded-lg bg-sky-500"> | |
<div className="mb-6 -rotate-90 text-left text-nowrap">h-1/2</div> | |
</div> | |
</div> | |
<div className="relative flex h-full items-end"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative flex h-1/3 w-8 items-end justify-center rounded-lg bg-sky-500"> | |
<div className="mb-6 -rotate-90 text-left text-nowrap">h-1/3</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:h-9/10,h-3/4,h-1/2,h-1/3,h-full] --> | |
<div class="h-full ...">h-full</div> | |
<div class="h-9/10 ...">h-9/10</div> | |
<div class="h-3/4 ...">h-3/4</div> | |
<div class="h-1/2 ...">h-1/2</div> | |
<div class="h-1/3 ...">h-1/3</div> | |
``` | |
</Figure> | |
### Matching viewport | |
Use the `h-screen` utility to make an element span the entire height of the viewport: | |
```html | |
<!-- [!code classes:h-screen] --> | |
<div class="h-screen"> | |
<!-- ... --> | |
</div> | |
``` | |
### Matching dynamic viewport | |
Use the `h-dvh` utility to make an element span the entire height of the viewport, which changes as the browser UI expands or contracts: | |
<Figure hint="Scroll the viewport to see the viewport height change"> | |
<Example padding={false}> | |
{<DynamicViewportExample unit="dvh" colorStyles="dark:bg-pink-500 bg-pink-500 border border-pink-400" />} | |
</Example> | |
```html | |
<!-- [!code classes:h-dvh] --> | |
<div class="h-dvh"> | |
<!-- ... --> | |
</div> | |
``` | |
</Figure> | |
### Matching large viewport | |
Use the `h-lvh` utility to set an element's height to the largest possible height of the viewport: | |
<Figure hint="Scroll the viewport to see the viewport height change"> | |
<Example padding={false}> | |
{<DynamicViewportExample unit="lvh" colorStyles="dark:bg-indigo-500 bg-indigo-500 border border-indigo-400" />} | |
</Example> | |
```html | |
<!-- [!code classes:h-lvh] --> | |
<div class="h-lvh"> | |
<!-- ... --> | |
</div> | |
``` | |
</Figure> | |
### Matching small viewport | |
Use the `h-svh` utility to set an element's height to the smallest possible height of the viewport: | |
<Figure hint="Scroll the viewport to see the viewport height change"> | |
<Example padding={false}> | |
{<DynamicViewportExample unit="svh" colorStyles="dark:bg-purple-500 bg-purple-500 border border-purple-400" />} | |
</Example> | |
```html | |
<!-- [!code classes:h-svh] --> | |
<div class="h-svh"> | |
<!-- ... --> | |
</div> | |
``` | |
</Figure> | |
### Setting both width and height | |
Use utilities like `size-px`, `size-4`, and `size-full` to set both the width and height of an element at the same time: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-flow-col justify-center gap-4 text-center font-mono text-xs font-bold text-white"> | |
<div className="grid size-16 items-center justify-center rounded-lg bg-indigo-500">size-16</div> | |
<div className="grid size-20 items-center justify-center rounded-lg bg-indigo-500">size-20</div> | |
<div className="grid size-24 items-center justify-center rounded-lg bg-indigo-500">size-24</div> | |
<div className="hidden size-32 items-center justify-center rounded-lg bg-indigo-500 sm:grid">size-32</div> | |
<div className="hidden size-40 items-center justify-center rounded-lg bg-indigo-500 md:grid">size-40</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:size-16,size-20,size-24,size-32,size-40] --> | |
<div class="size-16 ...">size-16</div> | |
<div class="size-20 ...">size-20</div> | |
<div class="size-24 ...">size-24</div> | |
<div class="size-32 ...">size-32</div> | |
<div class="size-40 ...">size-40</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="h" value="32rem" name="height" variable="height" /> | |
### Responsive design | |
<ResponsiveDesign property="height" defaultClass="h-1/2" featuredClass="h-full" /> | |
## Customizing your theme | |
<CustomizingYourSpacingScale utilities={["h", "size"]} /> | |
--- | |
File: /src/docs/hover-focus-and-other-states.mdx | |
--- | |
import dedent from "dedent"; | |
import { CodeExample, CodeExampleGroup, CodeBlock, svelte, html, css } from "@/components/code-example.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { Iframe } from "@/components/iframe.tsx"; | |
import { TipGood, TipBad, TipInfo } from "@/components/tips"; | |
export const title = "Hover, focus, and other states"; | |
export const description = "Using utilities to style elements on hover, focus, and more."; | |
Every utility class in Tailwind can be applied _conditionally_ by adding a variant to the beginning of the class name that describes the condition you want to target. | |
For example, to apply the `bg-sky-700` class on hover, use the `hover:bg-sky-700` class: | |
<Figure hint="Hover over this button to see the background color change"> | |
<Example> | |
{ | |
<div className="grid place-items-center"> | |
<button className="rounded-full bg-sky-500 px-5 py-2 text-sm leading-5 font-semibold text-white hover:bg-sky-700"> | |
Save changes | |
</button> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:hover:bg-sky-700] --> | |
<button class="bg-sky-500 hover:bg-sky-700 ...">Save changes</button> | |
``` | |
</Figure> | |
<details className="mb-10 rounded-xl border border-gray-200 px-6 py-3 prose open:pb-5 dark:prose-dark dark:border-gray-800"> | |
<summary className="font-medium cursor-default select-none text-gray-900 dark:text-gray-200">How does this compare to traditional CSS?</summary> | |
When writing CSS the traditional way, a single class name would do different things based on the current state: | |
<TipBad>{<>Traditionally the same class name applies different styles on hover</>}</TipBad> | |
```css | |
.btn-primary { | |
background-color: #0ea5e9; | |
} | |
.btn-primary:hover { | |
background-color: #0369a1; | |
} | |
``` | |
In Tailwind, rather than adding the styles for a hover state to an existing class, you add another class to the element that _only_ does something on hover: | |
<TipGood>{<>In Tailwind, separate classes are used for the default state and the hover state</>}</TipGood> | |
```css | |
.bg-sky-500 { | |
background-color: #0ea5e9; | |
} | |
.hover\:bg-sky-700:hover { | |
background-color: #0369a1; | |
} | |
``` | |
Notice how `hover:bg-sky-700` _only_ defines styles for the `:hover` state? It does nothing by default, but as soon as you hover over an element with that class, the background color will change to `sky-700`. | |
This is what we mean when we say a utility class can be applied _conditionally_ — by using variants you can control exactly how your design behaves in different states, without ever leaving your HTML. | |
</details> | |
Tailwind includes variants for just about everything you'll ever need, including: | |
- [Pseudo-classes](#pseudo-classes), like `:hover`, `:focus`, `:first-child`, and `:required` | |
- [Pseudo-elements](#pseudo-elements), like `::before`, `::after`, `::placeholder`, and `::selection` | |
- [Media and feature queries](#media-and-feature-queries), like responsive breakpoints, dark mode, and `prefers-reduced-motion` | |
- [Attribute selectors](#attribute-selectors), like `[dir="rtl"]` and `[open]` | |
- [Child selectors](#child-selectors), like `& > *` and `& *` | |
These variants can even be stacked to target more specific situations, for example changing the background color in dark mode, at the medium breakpoint, on hover: | |
```html | |
<!-- [!code classes:dark:md:hover:bg-fuchsia-600] --> | |
<button class="dark:md:hover:bg-fuchsia-600 ...">Save changes</button> | |
``` | |
In this guide you'll learn about every variant available in the framework, how to use them with your own custom classes, and even how to create your own. | |
## Pseudo-classes | |
### :hover, :focus, and :active | |
Style elements on hover, focus, and active using the `hover`, `focus`, and `active` variants: | |
<Figure hint="Try interacting with this button to see the hover, focus, and active states"> | |
<Example> | |
{ | |
<div className="grid place-items-center"> | |
<button | |
type="button" | |
className="rounded-full bg-violet-500 px-5 py-2 text-sm leading-5 font-semibold text-white hover:bg-violet-600 focus:outline-2 focus:outline-offset-2 focus:outline-violet-500 active:bg-violet-700" | |
> | |
Save changes | |
</button> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:hover:bg-violet-600,focus:outline-2,focus:outline-offset-2,focus:outline-violet-500,active:bg-violet-700] --> | |
<!-- prettier-ignore --> | |
<button class="bg-violet-500 hover:bg-violet-600 focus:outline-2 focus:outline-offset-2 focus:outline-violet-500 active:bg-violet-700 ..."> | |
Save changes | |
</button> | |
``` | |
</Figure> | |
Tailwind also includes variants for other interactive states like `:visited`, `:focus-within`, `:focus-visible`, and more. | |
See the [pseudo-class reference](#pseudo-class-reference) for a complete list of available pseudo-class variants. | |
### :first, :last, :odd, and :even | |
Style an element when it is the first-child or last-child using the `first` and `last` variants: | |
<Figure> | |
<Example className="py-0"> | |
{ | |
<div className="px-4"> | |
<div className="mx-auto max-w-md border-x border-x-gray-200 dark:border-x-gray-800 dark:bg-gray-950/10"> | |
<ul role="list" className="divide-y divide-gray-200 p-6 dark:divide-gray-800"> | |
<li className="flex py-4 first:pt-0 last:pb-0"> | |
<img | |
className="h-10 w-10 rounded-full" | |
src="https://images.unsplash.com/photo-1550525811-e5869dd03032?ixlib=rb-1.2.1&ixid=eyJhcHBfaWQiOjEyMDd9&auto=format&fit=facearea&facepad=2&w=256&h=256&q=80" | |
alt="" | |
/> | |
<div className="ml-3 overflow-hidden"> | |
<p className="text-sm font-medium text-gray-900 dark:text-white">Kristen Ramos</p> | |
<p className="truncate text-sm text-gray-500 dark:text-gray-400">[email protected]</p> | |
</div> | |
</li> | |
<li className="flex py-4 first:pt-0 last:pb-0"> | |
<img | |
className="h-10 w-10 rounded-full" | |
src="https://images.unsplash.com/photo-1463453091185-61582044d556?ixlib=rb-1.2.1&ixid=eyJhcHBfaWQiOjEyMDd9&auto=format&fit=facearea&facepad=2&w=256&h=256&q=80" | |
alt="" | |
/> | |
<div className="ml-3 overflow-hidden"> | |
<p className="text-sm font-medium text-gray-900 dark:text-white">Floyd Miles</p> | |
<p className="truncate text-sm text-gray-500 dark:text-gray-400">[email protected]</p> | |
</div> | |
</li> | |
<li className="flex py-4 first:pt-0 last:pb-0"> | |
<img | |
className="h-10 w-10 rounded-full" | |
src="https://images.unsplash.com/photo-1438761681033-6461ffad8d80?ixlib=rb-1.2.1&ixid=eyJhcHBfaWQiOjEyMDd9&auto=format&fit=facearea&facepad=2&w=256&h=256&q=80" | |
alt="" | |
/> | |
<div className="ml-3 overflow-hidden"> | |
<p className="text-sm font-medium text-gray-900 dark:text-white">Courtney Henry</p> | |
<p className="truncate text-sm text-gray-500 dark:text-gray-400">[email protected]</p> | |
</div> | |
</li> | |
<li className="flex py-4 first:pt-0 last:pb-0"> | |
<img | |
className="h-10 w-10 rounded-full" | |
src="https://images.unsplash.com/photo-1500648767791-00dcc994a43e?ixlib=rb-1.2.1&ixid=eyJhcHBfaWQiOjEyMDd9&auto=format&fit=facearea&facepad=2&w=256&h=256&q=80" | |
alt="" | |
/> | |
<div className="ml-3 overflow-hidden"> | |
<p className="text-sm font-medium text-gray-900 dark:text-white">Ted Fox</p> | |
<p className="truncate text-sm text-gray-500 dark:text-gray-400">[email protected]</p> | |
</div> | |
</li> | |
</ul> | |
</div> | |
</div> | |
} | |
</Example> | |
```svelte | |
<!-- [!code classes:first:pt-0,last:pb-0] --> | |
<ul role="list"> | |
{#each people as person} | |
<!-- Remove top/bottom padding when first/last child --> | |
<li class="flex py-4 first:pt-0 last:pb-0"> | |
<img class="h-10 w-10 rounded-full" src={person.imageUrl} alt="" /> | |
<div class="ml-3 overflow-hidden"> | |
<p class="text-sm font-medium text-gray-900 dark:text-white">{person.name}</p> | |
<p class="truncate text-sm text-gray-500 dark:text-gray-400">{person.email}</p> | |
</div> | |
</li> | |
{/each} | |
</ul> | |
``` | |
</Figure> | |
You can also style an element when it's an odd or even child using the `odd` and `even` variants: | |
<Figure> | |
<Example padding={false} className="py-8"> | |
{ | |
<div className=""> | |
<div className="border-y border-y-gray-200 bg-white dark:border-y-gray-800 dark:bg-gray-950"> | |
<div> | |
<div className="inline-block min-w-full align-middle"> | |
<div className="overflow-hidden"> | |
<table className="min-w-full"> | |
<thead className="border-b border-gray-200 bg-gray-50 dark:border-gray-800 dark:bg-gray-950"> | |
<tr> | |
<th scope="col" className="px-6 py-3 text-left text-sm font-medium text-gray-900 dark:text-white"> | |
Name | |
</th> | |
<th scope="col" className="px-6 py-3 text-left text-sm font-medium text-gray-900 dark:text-white"> | |
Title | |
</th> | |
<th scope="col" className="px-6 py-3 text-left text-sm font-medium text-gray-900 dark:text-white"> | |
</th> | |
</tr> | |
</thead> | |
<tbody> | |
<tr className="odd:bg-white even:bg-gray-50 dark:odd:bg-gray-900/50 dark:even:bg-gray-950"> | |
<td className="px-6 py-4 text-sm font-medium whitespace-nowrap text-gray-900 dark:text-white"> | |
Jane Cooper | |
</td> | |
<td className="px-6 py-4 text-sm whitespace-nowrap text-gray-600 dark:text-gray-400"> | |
Regional Paradigm Technician | |
</td> | |
<td className="px-6 py-4 text-sm whitespace-nowrap text-gray-600 dark:text-gray-400"> | |
[email protected] | |
</td> | |
</tr> | |
<tr className="odd:bg-white even:bg-gray-50 dark:odd:bg-gray-900/50 dark:even:bg-gray-950"> | |
<td className="px-6 py-4 text-sm font-medium whitespace-nowrap text-gray-900 dark:text-white"> | |
Cody Fisher | |
</td> | |
<td className="px-6 py-4 text-sm whitespace-nowrap text-gray-600 dark:text-gray-400"> | |
Product Directives Officer | |
</td> | |
<td className="px-6 py-4 text-sm whitespace-nowrap text-gray-600 dark:text-gray-400"> | |
[email protected] | |
</td> | |
</tr> | |
<tr className="odd:bg-white even:bg-gray-50 dark:odd:bg-gray-900/50 dark:even:bg-gray-950"> | |
<td className="px-6 py-4 text-sm font-medium whitespace-nowrap text-gray-900 dark:text-white"> | |
Leonard Krasner | |
</td> | |
<td className="px-6 py-4 text-sm whitespace-nowrap text-gray-600 dark:text-gray-400"> | |
Senior Designer | |
</td> | |
<td className="px-6 py-4 text-sm whitespace-nowrap text-gray-600 dark:text-gray-400"> | |
[email protected] | |
</td> | |
</tr> | |
<tr className="odd:bg-white even:bg-gray-50 dark:odd:bg-gray-900/50 dark:even:bg-gray-950"> | |
<td className="px-6 py-4 text-sm font-medium whitespace-nowrap text-gray-900 dark:text-white"> | |
Emily Selman | |
</td> | |
<td className="px-6 py-4 text-sm whitespace-nowrap text-gray-600 dark:text-gray-400"> | |
VP, Hardware Engineering | |
</td> | |
<td className="px-6 py-4 text-sm whitespace-nowrap text-gray-600 dark:text-gray-400"> | |
[email protected] | |
</td> | |
</tr> | |
<tr className="odd:bg-white even:bg-gray-50 dark:odd:bg-gray-900/50 dark:even:bg-gray-950"> | |
<td className="px-6 py-4 text-sm font-medium whitespace-nowrap text-gray-900 dark:text-white"> | |
Anna Roberts | |
</td> | |
<td className="px-6 py-4 text-sm whitespace-nowrap text-gray-600 dark:text-gray-400"> | |
Chief Strategy Officer | |
</td> | |
<td className="px-6 py-4 text-sm whitespace-nowrap text-gray-600 dark:text-gray-400"> | |
[email protected] | |
</td> | |
</tr> | |
</tbody> | |
</table> | |
</div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```svelte | |
<!-- [!code classes:odd:bg-white,even:bg-gray-50,dark:odd:bg-gray-900/50,dark:even:bg-gray-950] --> | |
<table> | |
<!-- ... --> | |
<tbody> | |
{#each people as person} | |
<!-- Use different background colors for odd and even rows --> | |
<tr class="odd:bg-white even:bg-gray-50 dark:odd:bg-gray-900/50 dark:even:bg-gray-950"> | |
<td>{person.name}</td> | |
<td>{person.title}</td> | |
<td>{person.email}</td> | |
</tr> | |
{/each} | |
</tbody> | |
</table> | |
``` | |
</Figure> | |
Use the `nth-*` and `nth-last-*` variants to style children based on their position in the list: | |
```html | |
<!-- [!code classes:nth-3:underline,nth-last-5:underline,nth-of-type-4:underline,nth-last-of-type-6:underline] --> | |
<div class="nth-3:underline"> | |
<!-- ... --> | |
</div> | |
<div class="nth-last-5:underline"> | |
<!-- ... --> | |
</div> | |
<div class="nth-of-type-4:underline"> | |
<!-- ... --> | |
</div> | |
<div class="nth-last-of-type-6:underline"> | |
<!-- ... --> | |
</div> | |
``` | |
You can pass any number you want to these by default, and use arbitrary values for more complex expressions like `nth-[2n+1_of_li]`. | |
Tailwind also includes variants for other structural pseudo-classes like `:only-child`, `:first-of-type`, `:empty`, and more. | |
See the [pseudo-class reference](#pseudo-class-reference) for a complete list of available pseudo-class variants. | |
### :required and :disabled | |
Style form elements in different states using variants like `required`, `invalid`, and `disabled`: | |
<Figure hint="Try making the email address valid to see the styles change"> | |
<Example className="py-0"> | |
{ | |
<div className="mx-auto max-w-md border-x border-x-gray-200 px-6 py-5 dark:border-x-gray-800 dark:bg-gray-950/10"> | |
<form> | |
<div> | |
<label htmlFor="username" className="block text-sm font-medium text-gray-700 dark:text-gray-300"> | |
Username | |
</label> | |
<div className="mt-1"> | |
<input | |
type="text" | |
name="username" | |
id="username" | |
className="block w-full rounded-md border border-gray-300 px-3 py-2 placeholder-gray-400 shadow-sm invalid:border-pink-500 invalid:text-pink-600 focus:border-sky-500 focus:outline focus:outline-sky-500 focus:invalid:border-pink-500 focus:invalid:outline-pink-500 disabled:border-gray-200 disabled:bg-gray-50 disabled:text-gray-500 disabled:shadow-none sm:text-sm dark:disabled:border-gray-700 dark:disabled:bg-gray-800/20" | |
defaultValue="tbone" | |
disabled | |
/> | |
</div> | |
</div> | |
<div className="mt-6"> | |
<label htmlFor="email" className="block text-sm font-medium text-gray-700 dark:text-gray-300"> | |
</label> | |
<div className="mt-1"> | |
<input | |
type="email" | |
name="email" | |
id="email-1" | |
className="block w-full rounded-md border border-gray-300 px-3 py-2 placeholder-gray-400 shadow-sm invalid:border-pink-500 invalid:text-pink-600 focus:border-sky-500 focus:outline focus:outline-sky-500 focus:invalid:border-pink-500 focus:invalid:outline-pink-500 disabled:border-gray-200 disabled:bg-gray-50 disabled:text-gray-500 disabled:shadow-none sm:text-sm dark:disabled:border-gray-700 dark:disabled:bg-gray-800/20" | |
defaultValue="george@krugerindustrial." | |
placeholder="[email protected]" | |
/> | |
</div> | |
</div> | |
<div className="mt-6"> | |
<label htmlFor="password" className="block text-sm font-medium text-gray-700 dark:text-gray-300"> | |
Password | |
</label> | |
<div className="mt-1"> | |
<input | |
type="password" | |
name="password" | |
id="password" | |
autoComplete="none" | |
className="block w-full rounded-md border border-gray-300 px-3 py-2 placeholder-gray-400 shadow-sm invalid:border-pink-500 invalid:text-pink-600 focus:border-sky-500 focus:outline focus:outline-sky-500 focus:invalid:border-pink-500 focus:invalid:outline-pink-500 disabled:border-gray-200 disabled:bg-gray-50 disabled:text-gray-500 disabled:shadow-none sm:text-sm dark:disabled:border-gray-700 dark:disabled:bg-gray-800/20" | |
defaultValue="Bosco" | |
/> | |
</div> | |
</div> | |
<div className="mt-6 text-right"> | |
<button className="rounded-md bg-sky-500 px-5 py-2.5 text-sm leading-5 font-semibold text-white hover:bg-sky-700"> | |
Save changes | |
</button> | |
</div> | |
</form> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:invalid:border-pink-500,invalid:text-pink-600,focus:border-sky-500,focus:outline,focus:outline-sky-500,focus:invalid:border-pink-500,focus:invalid:outline-pink-500,disabled:border-gray-200,disabled:bg-gray-50,disabled:text-gray-500,disabled:shadow-none,dark:disabled:border-gray-700,dark:disabled:bg-gray-800/20] --> | |
<input | |
type="text" | |
value="tbone" | |
disabled | |
class="invalid:border-pink-500 invalid:text-pink-600 focus:border-sky-500 focus:outline focus:outline-sky-500 focus:invalid:border-pink-500 focus:invalid:outline-pink-500 disabled:border-gray-200 disabled:bg-gray-50 disabled:text-gray-500 disabled:shadow-none dark:disabled:border-gray-700 dark:disabled:bg-gray-800/20 ..." | |
/> | |
``` | |
</Figure> | |
Using variants for this sort of thing can reduce the amount of conditional logic in your templates, letting you use the same set of classes regardless of what state an input is in and letting the browser apply the right styles for you. | |
Tailwind also includes variants for other form states like `:read-only`, `:indeterminate`, `:checked`, and more. | |
See the [pseudo-class reference](#pseudo-class-reference) for a complete list of available pseudo-class variants. | |
### :has() | |
Use the `has-*` variant to style an element based on the state or content of its descendants: | |
<Figure> | |
<Example className="py-0"> | |
{ | |
<div className="mx-auto max-w-md border-x border-x-gray-200 px-4 py-6 text-gray-700 dark:border-x-gray-800 dark:bg-gray-950/10 dark:text-gray-200"> | |
<fieldset> | |
<legend className="text-base font-semibold text-gray-900 dark:text-white">Payment method</legend> | |
<div className="mt-4 space-y-2"> | |
<label | |
htmlFor="apple" | |
className="grid grid-cols-[24px_1fr_auto] items-center gap-6 rounded-lg p-4 ring-1 ring-transparent hover:bg-gray-100 has-checked:bg-indigo-50 has-checked:text-indigo-800 has-checked:ring-indigo-200 dark:hover:bg-white/5 dark:has-checked:bg-indigo-950 dark:has-checked:text-indigo-200 dark:has-checked:ring-indigo-900" | |
> | |
<svg className="w-8" fill="currentColor" viewBox="0 0 24 13"> | |
<path d="M3.96299 1.735C3.22833 1.73504 2.50814 1.9393 1.88285 2.32497C1.25756 2.71063 0.751781 3.26252 0.42199 3.919C0.144511 4.47115 0 5.08054 0 5.6985C0 6.31645 0.144511 6.92584 0.42199 7.478C0.751781 8.13447 1.25756 8.68636 1.88285 9.07202C2.50814 9.45769 3.22833 9.66195 3.96299 9.662C5.03299 9.662 5.93299 9.31 6.58999 8.705C7.33799 8.015 7.76999 6.995 7.76999 5.789C7.76976 5.51882 7.74634 5.24916 7.69999 4.983H3.96399V6.509H6.10399C6.06043 6.75276 5.96798 6.98519 5.83221 7.19228C5.69644 7.39937 5.52016 7.57684 5.31399 7.714C4.95799 7.955 4.49999 8.093 3.96399 8.093C2.92999 8.093 2.05299 7.396 1.73899 6.457C1.57315 5.96493 1.57315 5.43207 1.73899 4.94C2.05299 4 2.92999 3.304 3.96399 3.304C4.52899 3.29475 5.07496 3.50811 5.48399 3.898L6.61599 2.768C5.89873 2.09384 4.94728 1.72362 3.96299 1.735ZM10.464 2.285V9.185H11.35V6.39H12.815C13.418 6.39 13.925 6.194 14.337 5.802C14.5421 5.61815 14.705 5.39214 14.8146 5.13945C14.9242 4.88676 14.9779 4.61337 14.972 4.338C14.9762 4.06405 14.9216 3.79238 14.8121 3.54125C14.7026 3.29011 14.5406 3.06533 14.337 2.882C14.1354 2.68674 13.897 2.53337 13.6358 2.43073C13.3746 2.32809 13.0956 2.27822 12.815 2.284L10.464 2.285ZM12.891 3.135C13.0456 3.13769 13.1981 3.17139 13.3395 3.23408C13.4808 3.29678 13.6082 3.3872 13.714 3.5C13.8267 3.60959 13.9162 3.74065 13.9774 3.88544C14.0385 4.03024 14.07 4.18582 14.07 4.343C14.07 4.50017 14.0385 4.65576 13.9774 4.80055C13.9162 4.94534 13.8267 5.07641 13.714 5.186C13.6007 5.30328 13.4642 5.39562 13.3132 5.45709C13.1622 5.51857 13 5.54783 12.837 5.543H11.35V3.135H12.837C12.855 3.13458 12.873 3.13458 12.891 3.135ZM17.015 4.31C16.173 4.31 15.538 4.618 15.108 5.235L15.889 5.726C16.177 5.309 16.569 5.1 17.064 5.1C17.3798 5.09612 17.6855 5.21145 17.92 5.423C18.0354 5.51846 18.1282 5.63844 18.1915 5.77423C18.2548 5.91001 18.2871 6.05818 18.286 6.208V6.41C17.946 6.217 17.512 6.121 16.986 6.121C16.369 6.121 15.876 6.266 15.507 6.555C15.137 6.843 14.953 7.232 14.953 7.72C14.949 7.9396 14.994 8.15734 15.0848 8.35733C15.1757 8.55732 15.31 8.73451 15.478 8.876C15.828 9.184 16.263 9.339 16.783 9.339C17.393 9.339 17.881 9.069 18.248 8.529H18.286V9.184H19.134V6.275C19.134 5.665 18.944 5.185 18.566 4.835C18.186 4.485 17.67 4.31 17.015 4.31ZM19.278 4.464L21.224 8.886L20.126 11.266H21.041L24 4.463H23.035L21.667 7.854H21.647L20.241 4.464H19.278ZM17.132 6.832C17.626 6.832 18.012 6.942 18.288 7.162C18.288 7.534 18.141 7.858 17.848 8.135C17.5835 8.39951 17.225 8.54839 16.851 8.549C16.6011 8.55376 16.3573 8.47178 16.161 8.317C16.0697 8.25093 15.9954 8.16402 15.9445 8.06349C15.8935 7.96295 15.8673 7.85171 15.868 7.739C15.868 7.482 15.988 7.269 16.231 7.092C16.471 6.919 16.772 6.832 17.132 6.832Z" /> | |
</svg> | |
Google Pay | |
<input | |
name="payment_method" | |
id="apple" | |
value="google" | |
type="radio" | |
className="box-content h-1.5 w-1.5 appearance-none rounded-full border-[5px] border-white bg-white bg-clip-padding ring-1 ring-gray-950/20 outline-none checked:border-indigo-500 checked:ring-indigo-500" | |
defaultChecked | |
/> | |
</label> | |
<label | |
htmlFor="google" | |
className="grid grid-cols-[24px_1fr_auto] items-center gap-6 rounded-lg p-4 ring-1 ring-transparent hover:bg-gray-100 has-checked:bg-indigo-50 has-checked:text-indigo-800 has-checked:ring-indigo-200 dark:hover:bg-white/5 dark:has-checked:bg-indigo-950 dark:has-checked:text-indigo-200 dark:has-checked:ring-indigo-900" | |
> | |
<svg className="mt-1 w-8 fill-current" fill="currentColor" viewBox="0 0 24 13"> | |
<path d="M4.38526 1.86704C4.10401 2.19606 3.65392 2.45565 3.20387 2.41854C3.14762 1.97367 3.36793 1.50091 3.62579 1.20892C3.90704 0.870635 4.39932 0.62962 4.79781 0.611084C4.84468 1.07453 4.66182 1.52871 4.38526 1.86704ZM4.79312 2.50663C4.14146 2.46956 3.5836 2.87272 3.27418 2.87272C2.96012 2.87272 2.48659 2.52517 1.97092 2.53443C1.30056 2.5437 0.677025 2.91906 0.33479 3.51694C-0.368428 4.71265 0.151978 6.48308 0.831712 7.45632C1.16457 7.9383 1.56306 8.46662 2.0881 8.44809C2.58507 8.42955 2.78195 8.12834 3.38204 8.12834C3.98677 8.12834 4.16026 8.44809 4.68531 8.43882C5.2291 8.42955 5.57134 7.95688 5.9042 7.47485C6.28388 6.92799 6.43862 6.39499 6.44799 6.36718C6.43862 6.35791 5.3979 5.96402 5.38853 4.77753C5.37915 3.78576 6.20893 3.31304 6.24643 3.28524C5.77759 2.59931 5.04629 2.52517 4.79312 2.50663ZM8.55765 1.16258V8.38789H9.69212V5.91768H11.2626C12.6971 5.91768 13.7051 4.94445 13.7051 3.53552C13.7051 2.12664 12.7159 1.16262 11.3001 1.16262H8.5576L8.55765 1.16258ZM9.69212 2.10806H11.0001C11.9846 2.10806 12.5471 2.62711 12.5471 3.54011C12.5471 4.4531 11.9846 4.97684 10.9954 4.97684H9.69212V2.10806ZM15.7772 8.44345C16.4898 8.44345 17.1508 8.08664 17.4508 7.52119H17.4743V8.38785H18.5244V4.79143C18.5244 3.74868 17.6806 3.07666 16.3819 3.07666C15.1771 3.07666 14.2864 3.75795 14.2536 4.69412H15.2756C15.36 4.24921 15.7771 3.95722 16.3491 3.95722C17.043 3.95722 17.4321 4.27701 17.4321 4.86562V5.26415L16.0163 5.34756C14.6989 5.42634 13.9864 5.95934 13.9864 6.88629C13.9864 7.82245 14.7224 8.44345 15.7772 8.44345ZM16.0819 7.58607C15.4772 7.58607 15.0927 7.29876 15.0927 6.85844C15.0927 6.4043 15.4631 6.14012 16.171 6.09841L17.4321 6.01963V6.42743C17.4321 7.10408 16.8508 7.58607 16.0819 7.58607H16.0819ZM19.9261 10.3529C21.0325 10.3529 21.5529 9.93584 22.0076 8.67057L24 3.14617H22.8467L21.5107 7.41456H21.4872L20.1511 3.14617H18.9651L20.8871 8.40638L20.784 8.72618C20.6106 9.2684 20.3293 9.47698 19.8277 9.47698C19.7386 9.47698 19.5652 9.46771 19.4948 9.45844V10.3251C19.5604 10.3436 19.8417 10.3529 19.9261 10.3529Z" /> | |
</svg> | |
Apple Pay | |
<input | |
name="payment_method" | |
id="google" | |
value="apple" | |
type="radio" | |
className="box-content h-1.5 w-1.5 appearance-none rounded-full border-[5px] border-white bg-white bg-clip-padding ring-1 ring-gray-950/20 outline-none checked:border-indigo-500 checked:ring-indigo-500" | |
/> | |
</label> | |
<label | |
htmlFor="credit-card" | |
className="grid grid-cols-[24px_1fr_auto] items-center gap-6 rounded-lg p-4 ring-1 ring-transparent hover:bg-gray-100 has-checked:bg-indigo-50 has-checked:text-indigo-800 has-checked:ring-indigo-200 dark:hover:bg-white/5 dark:has-checked:bg-indigo-950 dark:has-checked:text-indigo-200 dark:has-checked:ring-indigo-900" | |
> | |
<svg className="w-8" viewBox="0 0 24 13" fill="none"> | |
<rect stroke="currentColor" x="0.5" y="0.5" width="23" height="11" rx="1.5" /> | |
<path | |
fill="currentColor" | |
d="M16.539 3.18591C16.0742 3.01652 15.5828 2.93152 15.088 2.93491C13.488 2.93491 12.358 3.74091 12.35 4.89791C12.34 5.74791 13.153 6.22691 13.768 6.51091C14.399 6.80291 14.61 6.98691 14.608 7.24791C14.604 7.64491 14.104 7.82491 13.639 7.82491C13 7.82491 12.651 7.73591 12.114 7.51291L11.915 7.41991L11.688 8.75191C12.077 8.91391 12.778 9.05291 13.502 9.06491C15.203 9.06491 16.315 8.26391 16.328 7.03291C16.342 6.35391 15.902 5.84091 14.976 5.41691C14.413 5.14191 14.064 4.95791 14.064 4.67891C14.064 4.43191 14.363 4.16791 14.988 4.16791C15.404 4.15785 15.8174 4.23589 16.201 4.39691L16.351 4.46391L16.578 3.17691L16.539 3.18591ZM20.691 3.04291H19.441C19.052 3.04291 18.759 3.14991 18.589 3.53591L16.185 8.98191H17.886L18.226 8.08891L20.302 8.09091C20.351 8.29991 20.501 8.98191 20.501 8.98191H22.001L20.691 3.04291ZM10.049 2.99291H11.67L10.656 8.93491H9.03705L10.049 2.99091V2.99291ZM5.93405 6.26791L6.10205 7.09291L7.68605 3.04291H9.40305L6.85205 8.97391H5.13905L3.73905 3.95191C3.71637 3.8691 3.66312 3.79798 3.59005 3.75291C3.08545 3.49225 2.55079 3.29444 1.99805 3.16391L2.02005 3.03891H4.62905C4.98305 3.05291 5.26805 3.16391 5.36305 3.54191L5.93305 6.27091L5.93405 6.26791ZM18.691 6.87391L19.337 5.21191C19.329 5.22991 19.47 4.86891 19.552 4.64591L19.663 5.15891L20.038 6.87291H18.69L18.691 6.87391Z" | |
/> | |
</svg> | |
Credit Card | |
<input | |
name="payment_method" | |
id="credit-card" | |
value="credit-card" | |
type="radio" | |
className="box-content h-1.5 w-1.5 appearance-none rounded-full border-[5px] border-white bg-white bg-clip-padding ring-1 ring-gray-950/20 outline-none checked:border-indigo-500 checked:ring-indigo-500" | |
/> | |
</label> | |
</div> | |
</fieldset> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:has-checked:bg-indigo-50,has-checked:text-indigo-900,has-checked:ring-indigo-200,dark:has-checked:bg-indigo-950,dark:has-checked:text-indigo-200,dark:has-checked:ring-indigo-900]--> | |
<label | |
class="has-checked:bg-indigo-50 has-checked:text-indigo-900 has-checked:ring-indigo-200 dark:has-checked:bg-indigo-950 dark:has-checked:text-indigo-200 dark:has-checked:ring-indigo-900 ..." | |
> | |
<svg fill="currentColor"> | |
<!-- ... --> | |
</svg> | |
Google Pay | |
<input type="radio" class="checked:border-indigo-500 ..." /> | |
</label> | |
``` | |
</Figure> | |
You can use `has-*` with a pseudo-class, like `has-[:focus]`, to style an element based on the state of its descendants. You can also use element selectors, like `has-[img]` or `has-[a]`, to style an element based on the content of its descendants. | |
#### Styling based on the descendants of a group | |
If you need to style an element based on the descendants of a parent element, you can mark the parent with the `group` class and use the `group-has-*` variant to style the target element: | |
<Figure> | |
<Example className="py-0"> | |
{ | |
<div className="mx-auto grid max-w-md divide-y divide-gray-100 border-x border-x-gray-200 text-gray-700 dark:divide-gray-800 dark:border-x-gray-800 dark:bg-gray-950/10 dark:text-gray-300"> | |
<div className="group grid grid-cols-[32px_1fr_auto] items-center gap-x-4 px-4 py-4 pt-6"> | |
<img | |
className="size-[32px] rounded-full" | |
src="https://spotlight.tailwindui.com/_next/image?url=%2F_next%2Fstatic%2Fmedia%2Favatar.51a13c67.jpg&w=128&q=80" | |
alt="" | |
/> | |
{/* This is not an h4 because we're converting h4's to links in MDX files */} | |
<div className="font-semibold text-gray-900 dark:text-white">Spencer Sharp</div> | |
<svg | |
fill="none" | |
viewBox="0 0 24 24" | |
strokeWidth="1.5" | |
stroke="currentColor" | |
className="hidden size-4 group-has-[a]:block" | |
> | |
<path strokeLinecap="round" strokeLinejoin="round" d="M4.5 19.5l15-15m0 0H8.25m11.25 0v11.25" /> | |
</svg> | |
<p className="col-start-2 text-sm"> | |
Product Designer at{" "} | |
<a href="#" className="dark;text-blue-400 text-blue-500 underline"> | |
planeteria.tech | |
</a> | |
</p> | |
</div> | |
<div className="group grid grid-cols-[32px_1fr_auto] items-center gap-x-4 px-4 py-4"> | |
<img | |
className="size-[32px] rounded-full" | |
src="https://images.unsplash.com/photo-1539571696357-5a69c17a67c6?q=80&w=256&h=256&auto=format&fit=crop&ixlib=rb-4.0.3&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D" | |
alt="" | |
/> | |
{/* This is not an h4 because we're converting h4's to links in MDX files */} | |
<div className="font-semibold text-gray-900 dark:text-white">Casey Jordan</div> | |
<svg | |
fill="none" | |
viewBox="0 0 24 24" | |
strokeWidth="1.5" | |
stroke="currentColor" | |
className="hidden size-4 group-has-[a]:block" | |
> | |
<path strokeLinecap="round" strokeLinejoin="round" d="M4.5 19.5l15-15m0 0H8.25m11.25 0v11.25" /> | |
</svg> | |
<p className="col-start-2 text-sm">Just happy to be here.</p> | |
</div> | |
<div className="group grid grid-cols-[32px_1fr_auto] items-center gap-x-4 px-4 py-4"> | |
<img | |
className="size-[32px] rounded-full" | |
src="https://images.unsplash.com/photo-1590895340509-793cb98788c9?q=80&w=256&h=256&&auto=format&fit=crop&ixlib=rb-4.0.3&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D" | |
alt="" | |
/> | |
{/* This is not an h4 because we're converting h4's to links in MDX files */} | |
<div className="font-semibold text-gray-900 dark:text-white">Alex Reed</div> | |
<svg | |
fill="none" | |
viewBox="0 0 24 24" | |
strokeWidth="1.5" | |
stroke="currentColor" | |
className="hidden size-4 group-has-[a]:block" | |
> | |
<path strokeLinecap="round" strokeLinejoin="round" d="M4.5 19.5l15-15m0 0H8.25m11.25 0v11.25" /> | |
</svg> | |
<p className="col-start-2 text-sm"> | |
A multidisciplinary designer, working at the intersection of art and technology. <br /> | |
<br /> | |
<a href="#" className="dark;text-blue-400 text-blue-500 underline"> | |
alex-reed.com | |
</a> | |
</p> | |
</div> | |
<div className="group grid grid-cols-[32px_1fr_auto] items-center gap-x-4 px-4 py-4 pb-6"> | |
<img | |
className="size-[32px] rounded-full" | |
src="https://images.unsplash.com/photo-1517841905240-472988babdf9?q=80&w=256&h=256&auto=format&fit=crop&ixlib=rb-4.0.3&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D" | |
alt="" | |
/> | |
{/* This is not an h4 because we're converting h4's to links in MDX files */} | |
<div className="font-semibold text-gray-900 dark:text-white">Taylor Bailey</div> | |
<svg | |
fill="none" | |
viewBox="0 0 24 24" | |
strokeWidth="1.5" | |
stroke="currentColor" | |
className="hidden size-4 group-has-[a]:block" | |
> | |
<path strokeLinecap="round" strokeLinejoin="round" d="M4.5 19.5l15-15m0 0H8.25m11.25 0v11.25" /> | |
</svg> | |
<p className="col-start-2 text-sm">Pushing pixels. Slinging divs.</p> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:group-has-[a]:block,group] --> | |
<div class="group ..."> | |
<img src="..." /> | |
<h4>Spencer Sharp</h4> | |
<svg class="hidden group-has-[a]:block ..."><!-- ... --></svg> | |
<p>Product Designer at <a href="...">planeteria.tech</a></p> | |
</div> | |
``` | |
</Figure> | |
#### Styling based on the descendants of a peer | |
If you need to style an element based on the descendants of a sibling element, you can mark the sibling with the `peer` class and use the `peer-has-*` variant to style the target element: | |
<Figure> | |
<Example className="py-0"> | |
{ | |
<div className="mx-auto max-w-md border-x border-x-gray-200 px-4 py-6 dark:border-x-gray-800 dark:bg-gray-950/10"> | |
<fieldset className="space-y-3"> | |
<legend className="text-base font-semibold text-gray-900 dark:text-white">Today</legend> | |
<div className="grid grid-cols-[1fr_24px] items-center gap-6"> | |
<label className="peer grid grid-cols-[auto_1fr] items-center gap-3 rounded-md px-2 hover:bg-gray-100 dark:hover:bg-white/5"> | |
<input | |
type="checkbox" | |
className="peer size-3.5 appearance-none rounded-sm border border-gray-300 accent-pink-500 checked:appearance-auto dark:border-gray-600 dark:accent-pink-600" | |
defaultChecked | |
/> | |
<span className="text-gray-700 select-none peer-checked:text-gray-400 peer-checked:line-through dark:text-gray-300"> | |
Create a to do list | |
</span> | |
</label> | |
<div className="size-[26px] rounded-md p-1 peer-has-checked:hidden hover:bg-red-50 hover:text-pink-500"> | |
<svg fill="none" viewBox="0 0 24 24" strokeWidth="1.5" stroke="currentColor"> | |
<path strokeLinecap="round" strokeLinejoin="round" d="M6 18L18 6M6 6l12 12" /> | |
</svg> | |
</div> | |
</div> | |
<div className="grid grid-cols-[1fr_24px] items-center gap-6"> | |
<label className="peer grid grid-cols-[auto_1fr] items-center gap-3 rounded-md px-2 hover:bg-gray-100 dark:hover:bg-white/5"> | |
<input | |
type="checkbox" | |
className="peer size-3.5 appearance-none rounded-sm border border-gray-300 accent-pink-500 checked:appearance-auto dark:border-gray-600 dark:accent-pink-600" | |
/> | |
<span className="text-gray-700 select-none peer-checked:text-gray-400 peer-checked:line-through dark:text-gray-300"> | |
Check off first item | |
</span> | |
</label> | |
<div className="size-[26px] rounded-md p-1 peer-has-checked:hidden hover:bg-red-50 hover:text-pink-500"> | |
<svg fill="none" viewBox="0 0 24 24" strokeWidth="1.5" stroke="currentColor"> | |
<path strokeLinecap="round" strokeLinejoin="round" d="M6 18L18 6M6 6l12 12" /> | |
</svg> | |
</div> | |
</div> | |
<div className="grid grid-cols-[1fr_24px] items-center gap-6"> | |
<label className="peer grid grid-cols-[auto_1fr] items-center gap-3 rounded-md px-2 hover:bg-gray-100 dark:hover:bg-white/5"> | |
<input | |
type="checkbox" | |
className="peer size-3.5 appearance-none rounded-sm border border-gray-300 accent-pink-500 checked:appearance-auto dark:border-gray-600 dark:accent-pink-600" | |
/> | |
<span className="text-gray-700 select-none peer-checked:text-gray-400 peer-checked:line-through dark:text-gray-300"> | |
Investigate race condition | |
</span> | |
</label> | |
<div className="block size-[26px] rounded-md p-1 peer-has-checked:hidden hover:bg-red-50 hover:text-pink-500"> | |
<svg fill="none" viewBox="0 0 24 24" strokeWidth="1.5" stroke="currentColor"> | |
<path strokeLinecap="round" strokeLinejoin="round" d="M6 18L18 6M6 6l12 12" /> | |
</svg> | |
</div> | |
</div> | |
</fieldset> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:peer-has-checked:hidden,peer] --> | |
<div> | |
<label class="peer ..."> | |
<input type="checkbox" name="todo[1]" checked /> | |
Create a to do list | |
</label> | |
<svg class="peer-has-checked:hidden ..."><!-- ... --></svg> | |
</div> | |
``` | |
</Figure> | |
### :not() | |
Use the `not-` variant to style an element when a condition is not true. | |
It's particularly powerful when combined with other pseudo-class variants, for example combining `not-focus:` with `hover:` to only apply hover styles when an element is not focused: | |
<Figure hint="Try focusing on the button and then hovering over it"> | |
<Example> | |
{ | |
<div className="grid place-items-center"> | |
<button | |
type="button" | |
className="rounded-full bg-indigo-600 px-5 py-2 text-sm leading-5 font-semibold text-white hover:not-focus:bg-indigo-700 focus:outline focus:outline-violet-300 active:bg-violet-700" | |
tabIndex="0" | |
> | |
Save changes | |
</button> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:hover:not-focus:bg-indigo-700] --> | |
<button class="bg-indigo-600 hover:not-focus:bg-indigo-700"> | |
<!-- ... --> | |
</button> | |
``` | |
</Figure> | |
You can also combine the `not-` variant with media query variants like `forced-colors` or `supports` to only style an element when something about the user's environment is not true: | |
```html | |
<!-- [!code classes:not-supports-[display:grid]:flex] --> | |
<div class="not-supports-[display:grid]:flex"> | |
<!-- ... --> | |
</div> | |
``` | |
### Styling based on parent state | |
When you need to style an element based on the state of some _parent_ element, mark the parent with the `group` class, and use `group-*` variants like `group-hover` to style the target element: | |
<Figure hint="Hover over the card to see both text elements change color"> | |
<Example> | |
{ | |
<a | |
href="#" | |
className="group mx-auto block max-w-xs space-y-3 rounded-lg bg-white p-4 shadow-lg ring-1 ring-gray-900/5 hover:bg-sky-500 hover:ring-sky-500 dark:bg-white/5 dark:ring-white/10" | |
> | |
<div className="flex items-center space-x-3"> | |
<svg className="h-6 w-6 stroke-sky-500 group-hover:stroke-white" fill="none" viewBox="0 0 24 24"> | |
<path | |
strokeLinecap="round" | |
strokeLinejoin="round" | |
strokeWidth="2" | |
d="M11 19H6.931A1.922 1.922 0 015 17.087V8h12.069C18.135 8 19 8.857 19 9.913V11" | |
/> | |
<path | |
strokeLinecap="round" | |
strokeLinejoin="round" | |
strokeWidth="2" | |
d="M14 7.64L13.042 6c-.36-.616-1.053-1-1.806-1H7.057C5.921 5 5 5.86 5 6.92V11M17 15v4M19 17h-4" | |
/> | |
</svg> | |
{/* This is not an h3 because we're converting h3's to links in MDX files */} | |
<div className="text-sm font-semibold text-gray-900 group-hover:text-white dark:text-white">New project</div> | |
</div> | |
<p className="text-sm text-gray-500 group-hover:text-white dark:text-gray-400"> | |
Create a new project from a variety of starting templates. | |
</p> | |
</a> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:group-hover:stroke-white] --> | |
<!-- [!code classes:group-hover:text-white] --> | |
<!-- [!code classes:group-hover:text-white] --> | |
<!-- [!code classes:group] --> | |
<a href="#" class="group ..."> | |
<div> | |
<svg class="stroke-sky-500 group-hover:stroke-white ..." fill="none" viewBox="0 0 24 24"> | |
<!-- ... --> | |
</svg> | |
<h3 class="text-gray-900 group-hover:text-white ...">New project</h3> | |
</div> | |
<p class="text-gray-500 group-hover:text-white ...">Create a new project from a variety of starting templates.</p> | |
</a> | |
``` | |
</Figure> | |
This pattern works with every pseudo-class variant, for example `group-focus`, `group-active`, or even `group-odd`. | |
#### Differentiating nested groups | |
When nesting groups, you can style something based on the state of a _specific_ parent group by giving that parent a unique group name using a `group/{name}` class, and including that name in variants using classes like `group-hover/{name}`: | |
<Figure> | |
<Example className="py-0"> | |
{ | |
<div className="px-4"> | |
<ul | |
role="list" | |
className="mx-auto max-w-md border-x border-x-gray-200 p-2 dark:border-x-gray-800 dark:bg-gray-950/10" | |
> | |
<li className="group/item relative flex items-center justify-between rounded-xl p-4 hover:bg-gray-100 dark:hover:bg-white/5"> | |
<div className="flex gap-4"> | |
<div className="flex-shrink-0"> | |
<img | |
className="h-12 w-12 rounded-full" | |
src="https://images.unsplash.com/photo-1494790108377-be9c29b29330?ixlib=rb-1.2.1&ixid=eyJhcHBfaWQiOjEyMDd9&auto=format&fit=facearea&facepad=2&w=256&h=256&q=80" | |
alt="" | |
/> | |
</div> | |
<div className="w-full text-sm leading-6"> | |
<a href="#" className="font-semibold text-gray-900 dark:text-white"> | |
<span className="absolute inset-0 rounded-xl" aria-hidden="true"></span>Leslie Abbott | |
</a> | |
<div className="text-gray-500">Co-Founder / CEO</div> | |
</div> | |
</div> | |
<a | |
href="#" | |
className="group/edit invisible relative flex items-center rounded-full py-1 pr-3 pl-4 text-sm whitespace-nowrap text-gray-500 transition group-hover/item:visible hover:bg-gray-200 dark:text-gray-400" | |
> | |
<span className="font-semibold transition group-hover/edit:text-gray-700">Call</span> | |
<svg | |
className="mt-px h-5 w-5 text-gray-400 transition group-hover/edit:translate-x-0.5 group-hover/edit:text-gray-500" | |
viewBox="0 0 20 20" | |
fill="currentColor" | |
> | |
<path | |
fillRule="evenodd" | |
d="M7.21 14.77a.75.75 0 01.02-1.06L11.168 10 7.23 6.29a.75.75 0 111.04-1.08l4.5 4.25a.75.75 0 010 1.08l-4.5 4.25a.75.75 0 01-1.06-.02z" | |
clipRule="evenodd" | |
/> | |
</svg> | |
</a> | |
</li> | |
<li className="group/item relative flex items-center justify-between rounded-xl p-4 hover:bg-gray-100 dark:hover:bg-white/5"> | |
<div className="flex gap-4"> | |
<div className="flex-shrink-0"> | |
<img | |
className="h-12 w-12 rounded-full" | |
src="https://images.unsplash.com/photo-1500648767791-00dcc994a43e?ixlib=rb-1.2.1&ixid=eyJhcHBfaWQiOjEyMDd9&auto=format&fit=facearea&facepad=2&w=256&h=256&q=80" | |
alt="" | |
/> | |
</div> | |
<div className="w-full text-sm leading-6"> | |
<a href="#" className="font-semibold text-gray-900 dark:text-white"> | |
<span className="absolute inset-0 rounded-xl" aria-hidden="true"></span>Hector Adams | |
</a> | |
<div className="text-gray-500">VP, Marketing</div> | |
</div> | |
</div> | |
<a | |
href="#" | |
className="group/edit invisible relative flex items-center rounded-full py-1 pr-3 pl-4 text-sm whitespace-nowrap text-gray-500 transition group-hover/item:visible hover:bg-gray-200 dark:text-gray-400" | |
> | |
<span className="font-semibold transition group-hover/edit:text-gray-700">Call</span> | |
<svg | |
className="mt-px h-5 w-5 text-gray-400 transition group-hover/edit:translate-x-0.5 group-hover/edit:text-gray-500" | |
viewBox="0 0 20 20" | |
fill="currentColor" | |
> | |
<path | |
fillRule="evenodd" | |
d="M7.21 14.77a.75.75 0 01.02-1.06L11.168 10 7.23 6.29a.75.75 0 111.04-1.08l4.5 4.25a.75.75 0 010 1.08l-4.5 4.25a.75.75 0 01-1.06-.02z" | |
clipRule="evenodd" | |
/> | |
</svg> | |
</a> | |
</li> | |
<li className="group/item relative flex items-center justify-between rounded-xl p-4 hover:bg-gray-100 dark:hover:bg-white/5"> | |
<div className="flex gap-4"> | |
<div className="flex-shrink-0"> | |
<img | |
className="h-12 w-12 rounded-full" | |
src="https://images.unsplash.com/photo-1507003211169-0a1dd7228f2d?ixlib=rb-1.2.1&ixid=eyJhcHBfaWQiOjEyMDd9&auto=format&fit=facearea&facepad=2&w=256&h=256&q=80" | |
alt="" | |
/> | |
</div> | |
<div className="w-full text-sm leading-6"> | |
<a href="#" className="font-semibold text-gray-900 dark:text-white"> | |
<span className="absolute inset-0 rounded-xl" aria-hidden="true"></span>Blake Alexander | |
</a> | |
<div className="text-gray-500">Account Coordinator</div> | |
</div> | |
</div> | |
<a | |
href="#" | |
className="group/edit invisible relative flex items-center rounded-full py-1 pr-3 pl-4 text-sm whitespace-nowrap text-gray-500 transition group-hover/item:visible hover:bg-gray-200 dark:text-gray-400" | |
> | |
<span className="font-semibold transition group-hover/edit:text-gray-700">Call</span> | |
<svg | |
className="mt-px h-5 w-5 text-gray-400 transition group-hover/edit:translate-x-0.5 group-hover/edit:text-gray-500" | |
viewBox="0 0 20 20" | |
fill="currentColor" | |
> | |
<path | |
fillRule="evenodd" | |
d="M7.21 14.77a.75.75 0 01.02-1.06L11.168 10 7.23 6.29a.75.75 0 111.04-1.08l4.5 4.25a.75.75 0 010 1.08l-4.5 4.25a.75.75 0 01-1.06-.02z" | |
clipRule="evenodd" | |
/> | |
</svg> | |
</a> | |
</li> | |
</ul> | |
</div> | |
} | |
</Example> | |
```svelte | |
<!-- [!code classes:group-hover/item:visible] --> | |
<!-- [!code classes:group-hover/edit:text-gray-700] --> | |
<!-- [!code classes:group-hover/edit:translate-x-0.5] --> | |
<!-- [!code classes:group-hover/edit:text-gray-500] --> | |
<!-- [!code classes:group/item] --> | |
<!-- [!code classes:group/edit] --> | |
<ul role="list"> | |
{#each people as person} | |
<li class="group/item ..."> | |
<!-- ... --> | |
<a class="group/edit invisible group-hover/item:visible ..." href="tel:{person.phone}"> | |
<span class="group-hover/edit:text-gray-700 ...">Call</span> | |
<svg class="group-hover/edit:translate-x-0.5 group-hover/edit:text-gray-500 ..."><!-- ... --></svg> | |
</a> | |
</li> | |
{/each} | |
</ul> | |
``` | |
</Figure> | |
Groups can be named however you like and don’t need to be configured in any way — just name your groups directly in your markup and Tailwind will automatically generate the necessary CSS. | |
#### Arbitrary groups | |
You can create one-off `group-*` variants on the fly by providing your own selector as an [arbitrary value](/docs/adding-custom-styles#using-arbitrary-values) between square brackets: | |
<CodeExampleGroup | |
filenames={["HTML", "Generated CSS"]} | |
> | |
<CodeBlock | |
example={html` | |
<!-- [!code classes:group-[.is-published]:block] --> | |
<div class="group is-published"> | |
<div class="hidden group-[.is-published]:block"> | |
Published | |
</div> | |
</div> | |
`} | |
/> | |
<CodeBlock | |
example={css` | |
.group-\[\.is-published\]\:block { | |
&:is(:where(.group):is(.is-published) *) { | |
display: block; | |
} | |
} | |
`} | |
/> | |
</CodeExampleGroup> | |
For more control, you can use the `&` character to mark where `.group` should end up in the final selector relative to the selector you are passing in: | |
<CodeExampleGroup | |
filenames={["HTML", "Generated CSS"]} | |
> | |
<CodeBlock | |
example={html` | |
<!-- [!code classes:_&] --> | |
<div class="group"> | |
<div class="group-[:nth-of-type(3)_&]:block"> | |
<!-- ... --> | |
</div> | |
</div> | |
`} | |
/> | |
<CodeBlock | |
example={css` | |
.group-\[\:nth-of-type\(3\)_\&\]\:block { | |
&:is(:nth-of-type(3) :where(.group) *) { | |
display: block; | |
} | |
} | |
`} | |
/> | |
</CodeExampleGroup> | |
#### Implicit groups | |
The `in-*` variant works similarly to `group` except you don't need to add `group` to the parent element: | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:in-focus:opacity-100] --> | |
<!-- [!code --:3] --> | |
<div tabindex="0" class="group"> | |
<div class="opacity-50 group-focus:opacity-100"> | |
<!-- [!code ++:3] --> | |
<div tabindex="0"> | |
<div class="opacity-50 in-focus:opacity-100"> | |
<!-- ... --> | |
</div> | |
</div> | |
``` | |
The `in-*` variant responds to state changes in any parent, so if you want more fine-grained control you'll need to use `group` instead. | |
### Styling based on sibling state | |
When you need to style an element based on the state of a _sibling_ element, mark the sibling with the `peer` class, and use `peer-*` variants like `peer-invalid` to style the target element: | |
<Figure hint="Try making the email address valid to see the warning disappear"> | |
<Example className="py-0"> | |
{ | |
<div className="mx-auto max-w-md border-x border-x-gray-200 px-6 pt-6 pb-5 dark:border-x-gray-800 dark:bg-gray-950/10"> | |
<form> | |
<div> | |
<label htmlFor="email-2" className="block text-sm font-medium text-gray-700 dark:text-gray-300"> | |
</label> | |
<div className="mt-1"> | |
<input | |
type="email" | |
name="email" | |
id="email-2" | |
className="peer block w-full rounded-md border border-gray-300 px-3 py-2 placeholder-gray-400 shadow-sm invalid:border-pink-500 invalid:text-pink-600 focus:border-sky-500 focus:outline focus:outline-sky-500 focus:invalid:border-pink-500 focus:invalid:outline-pink-500 disabled:border-gray-200 disabled:bg-gray-50 disabled:text-gray-500 disabled:shadow-none sm:text-sm" | |
defaultValue="george@krugerindustrial." | |
placeholder="[email protected]" | |
/> | |
<p className="invisible mt-2 text-sm text-pink-600 peer-invalid:visible"> | |
Please provide a valid email address. | |
</p> | |
</div> | |
</div> | |
</form> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:peer-invalid:visible] --> | |
<!-- [!code classes:peer] --> | |
<form> | |
<label class="block"> | |
<span class="...">Email</span> | |
<input type="email" class="peer ..." /> | |
<p class="invisible peer-invalid:visible ...">Please provide a valid email address.</p> | |
</label> | |
</form> | |
``` | |
</Figure> | |
This makes it possible to do all sorts of neat tricks, like [floating labels](https://www.youtube.com/watch?v=nJzKi6oIvBA) for example without any JS. | |
This pattern works with every pseudo-class variant, for example `peer-focus`, `peer-required`, and `peer-disabled`. | |
It's important to note that the `peer` marker can only be used on _previous_ siblings because of how the [subsequent-sibling combinator](https://developer.mozilla.org/en-US/docs/Web/CSS/Subsequent-sibling_combinator) works in CSS: | |
<TipBad>{<>Won't work, only previous siblings can be marked as peers</>}</TipBad> | |
```html | |
<!-- [!code classes:peer-invalid:text-red-500] --> | |
<!-- [!code classes:peer] --> | |
<label> | |
<span class="peer-invalid:text-red-500 ...">Email</span> | |
<input type="email" class="peer ..." /> | |
</label> | |
``` | |
#### Differentiating peers | |
When using multiple peers, you can style something on the state of a _specific_ peer by giving that peer a unique name using a `peer/{name}` class, and including that name in variants using classes like `peer-checked/{name}`: | |
<Figure> | |
<Example className="py-0"> | |
{ | |
<div className="px-4"> | |
<fieldset className="mx-auto max-w-md border-x border-x-gray-200 p-8 text-sm text-gray-700 dark:border-x-gray-800 dark:bg-gray-950/10 dark:text-gray-100"> | |
<div className="mb-6 border-b border-gray-200 pb-2 text-base font-semibold dark:border-gray-800"> | |
Published status | |
</div> | |
<input | |
id="draft" | |
className="peer/draft form-radio mr-2 mb-0.5 border-gray-300 text-sky-400 focus:ring-sky-400" | |
type="radio" | |
name="status" | |
defaultChecked | |
/> | |
<label className="font-medium peer-checked/draft:text-sky-500" htmlFor="draft"> | |
Draft | |
</label> | |
<input | |
id="published" | |
className="peer/published form-radio mr-2 mb-0.5 ml-4 border-gray-300 text-sky-400 focus:ring-sky-400" | |
type="radio" | |
name="status" | |
/> | |
<label className="font-medium peer-checked/published:text-sky-500" htmlFor="published"> | |
Published | |
</label> | |
<div className="mt-4 hidden text-gray-500 peer-checked/draft:block dark:text-gray-400"> | |
Drafts are only visible to administrators. | |
</div> | |
<div className="mt-4 hidden text-gray-500 peer-checked/published:block dark:text-gray-400"> | |
Your post will be publicly visible on your site. | |
</div> | |
</fieldset> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:peer-checked/draft:block] --> | |
<!-- [!code classes:peer-checked/draft:text-sky-500] --> | |
<!-- [!code classes:peer-checked/published:text-sky-500] --> | |
<!-- [!code classes:peer-checked/published:block] --> | |
<!-- [!code classes:peer/draft] --> | |
<!-- [!code classes:peer/published] --> | |
<fieldset> | |
<legend>Published status</legend> | |
<input id="draft" class="peer/draft" type="radio" name="status" checked /> | |
<label for="draft" class="peer-checked/draft:text-sky-500">Draft</label> | |
<input id="published" class="peer/published" type="radio" name="status" /> | |
<label for="published" class="peer-checked/published:text-sky-500">Published</label> | |
<div class="hidden peer-checked/draft:block">Drafts are only visible to administrators.</div> | |
<div class="hidden peer-checked/published:block">Your post will be publicly visible on your site.</div> | |
</fieldset> | |
``` | |
</Figure> | |
Peers can be named however you like and don’t need to be configured in any way — just name your peers directly in your markup and Tailwind will automatically generate the necessary CSS. | |
#### Arbitrary peers | |
You can create one-off `peer-*` variants on the fly by providing your own selector as an [arbitrary value](/docs/adding-custom-styles#using-arbitrary-values) between square brackets: | |
<CodeExampleGroup | |
filenames={["HTML", "Generated CSS"]} | |
> | |
<CodeBlock | |
example={html` | |
<!-- [!code classes:peer-[.is-dirty]] --> | |
<form> | |
<label for="email">Email:</label> | |
<input id="email" name="email" type="email" class="is-dirty peer" required /> | |
<div class="peer-[.is-dirty]:peer-required:block hidden">This field is required.</div> | |
<!-- ... --> | |
</form> | |
`} | |
/> | |
<CodeBlock | |
example={css` | |
.peer-\[\.is-dirty\]\:peer-required\:block { | |
&:is(:where(.peer):is(.is-dirty) ~ *) { | |
&:is(:where(.peer):required ~ *) { | |
display: block; | |
} | |
} | |
} | |
`} | |
/> | |
</CodeExampleGroup> | |
For more control, you can use the `&` character to mark where `.peer` should end up in the final selector relative to the selector you are passing in: | |
<CodeExampleGroup | |
filenames={["HTML", "Generated CSS"]} | |
> | |
<CodeBlock | |
filename="HTML" | |
example={html` | |
<!-- [!code classes:peer-[:nth-of-type(3)_&]:block] --> | |
<div> | |
<input type="text" class="peer" /> | |
<div class="hidden peer-[:nth-of-type(3)_&]:block"> | |
<!-- ... --> | |
</div> | |
</div> | |
`} | |
/> | |
<CodeBlock | |
filename="Generated CSS" | |
example={css` | |
.peer-\[\:nth-of-type\(3\)_\&\]\:block { | |
&:is(:nth-of-type(3) :where(.peer) ~ *) { | |
display: block; | |
} | |
} | |
`} | |
/> | |
</CodeExampleGroup> | |
## Pseudo-elements | |
### ::before and ::after | |
Style the `::before` and `::after` pseudo-elements using the `before` and `after` variants: | |
<Figure> | |
<Example className="py-0"> | |
{ | |
<div className="mx-auto max-w-sm border-x border-x-gray-200 px-6 pt-6 pb-5 dark:border-x-gray-800 dark:bg-gray-950/10"> | |
<form> | |
<label className="block"> | |
<span className="block text-sm font-medium text-gray-700 after:ml-0.5 after:text-red-500 after:content-['*'] dark:text-white"> | |
</span> | |
<input | |
type="email" | |
name="email" | |
id="email-3" | |
className="mt-1 block w-full rounded-md border border-gray-300 px-3 py-2 placeholder-gray-400 shadow-sm focus:border-sky-500 focus:outline focus:outline-sky-500 sm:text-sm" | |
placeholder="[email protected]" | |
/> | |
</label> | |
</form> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:after:content-['*']] --> | |
<!-- [!code classes:after:ml-0.5] --> | |
<!-- [!code classes:after:text-red-500] --> | |
<label> | |
<span class="text-gray-700 after:ml-0.5 after:text-red-500 after:content-['*'] ...">Email</span> | |
<input type="email" name="email" class="..." placeholder="[email protected]" /> | |
</label> | |
``` | |
</Figure> | |
When using these variants, Tailwind will automatically add `content: ''` by default so you don't have to specify it unless you want a different value: | |
<Figure> | |
<Example className="py-0"> | |
{ | |
<div className="px-6"> | |
<div className="mx-auto max-w-lg border-x border-x-gray-200 px-6 py-8 dark:border-x-gray-800 dark:bg-gray-950/10"> | |
<blockquote className="text-center text-2xl font-semibold text-gray-900 italic dark:text-white"> | |
When you look{" "} | |
<span className="relative inline-block before:absolute before:-inset-1 before:block before:-skew-y-3 before:bg-pink-500"> | |
<span className="relative text-white dark:text-gray-950">annoyed</span> | |
</span>{" "} | |
all the time, people think that you're busy. | |
</blockquote> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:before:block] --> | |
<!-- [!code classes:before:absolute] --> | |
<!-- [!code classes:before:-inset-1] --> | |
<!-- [!code classes:before:-skew-y-3] --> | |
<!-- [!code classes:before:bg-pink-500] --> | |
<blockquote class="text-center text-2xl font-semibold text-gray-900 italic dark:text-white"> | |
When you look | |
<span class="relative inline-block before:absolute before:-inset-1 before:block before:-skew-y-3 before:bg-pink-500"> | |
<span class="relative text-white dark:text-gray-950">annoyed</span> | |
</span> | |
all the time, people think that you're busy. | |
</blockquote> | |
``` | |
</Figure> | |
It's worth noting that you don't really need `::before` and `::after` pseudo-elements for most things in Tailwind projects — it's usually simpler to just use a real HTML element. | |
For example, here's the same design from above but using a `<span>` instead of the `::before` pseudo-element, which is a little easier to read and is actually less code: | |
```html | |
<blockquote class="text-center text-2xl font-semibold text-gray-900 italic"> | |
When you look | |
<span class="relative"> | |
<!-- [!code highlight:2] --> | |
<span class="absolute -inset-1 block -skew-y-3 bg-pink-500" aria-hidden="true"></span> | |
<span class="relative text-white">annoyed</span> | |
</span> | |
all the time, people think that you're busy. | |
</blockquote> | |
``` | |
Save `before` and `after` for situations where it's important that the content of the pseudo-element is not actually in the DOM and can't be selected by the user. | |
### ::placeholder | |
Style the placeholder text of any input or textarea using the `placeholder` variant: | |
<Figure> | |
<Example> | |
{ | |
<div className="mx-auto max-w-sm"> | |
<form> | |
<label className="relative block"> | |
<span className="absolute inset-y-0 left-0 flex items-center pl-2"> | |
<svg className="h-5 w-5 fill-gray-300" viewBox="0 0 20 20"> | |
<path | |
fillRule="evenodd" | |
d="M8 4a4 4 0 100 8 4 4 0 000-8zM2 8a6 6 0 1110.89 3.476l4.817 4.817a1 1 0 01-1.414 1.414l-4.816-4.816A6 6 0 012 8z" | |
clipRule="evenodd" | |
/> | |
</svg> | |
</span> | |
<span className="sr-only">Search</span> | |
<input | |
type="text" | |
name="search" | |
className="block w-full rounded-md border border-gray-300 py-2 pr-3 pl-9 text-gray-700 shadow-sm placeholder:text-gray-400 placeholder:italic focus:border-sky-500 focus:outline focus:outline-sky-500 sm:text-sm dark:border-gray-600 dark:text-white" | |
placeholder="Search for anything..." | |
/> | |
</label> | |
</form> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:placeholder:italic,placeholder:text-gray-500] --> | |
<input | |
class="placeholder:text-gray-500 placeholder:italic ..." | |
placeholder="Search for anything..." | |
type="text" | |
name="search" | |
/> | |
``` | |
</Figure> | |
### ::file | |
Style the button in file inputs using the `file` variant: | |
<Figure> | |
<Example className="py-0"> | |
{ | |
<div className="px-6"> | |
<div className="mx-auto max-w-sm border-x border-x-gray-200 px-6 py-8 dark:border-x-gray-800 dark:bg-gray-950/10"> | |
<form className="flex items-center space-x-6"> | |
<div className="shrink-0"> | |
<img | |
className="h-16 w-16 rounded-full object-cover" | |
src="https://images.unsplash.com/photo-1580489944761-15a19d654956?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=1361&q=80" | |
alt="Current profile photo" | |
/> | |
</div> | |
<label className="block"> | |
<span className="sr-only">Choose profile photo</span> | |
<input | |
type="file" | |
className="block w-full text-sm text-gray-500 file:mr-4 file:rounded-full file:border-0 file:bg-violet-50 file:px-4 file:py-2 file:text-sm file:font-semibold file:text-violet-700 hover:file:bg-violet-100 dark:file:bg-violet-600 dark:file:text-violet-100 dark:hover:file:bg-violet-500" | |
/> | |
</label> | |
</form> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:file:mr-4,file:rounded-full,file:border-0,file:bg-violet-50,file:px-4,file:py-2,file:text-sm,file:font-semibold,file:text-violet-700,hover:file:bg-violet-100,dark:file:bg-violet-600,dark:file:text-violet-100,dark:hover:file:bg-violet-500] --> | |
<input | |
type="file" | |
class="file:mr-4 file:rounded-full file:border-0 file:bg-violet-50 file:px-4 file:py-2 file:text-sm file:font-semibold file:text-violet-700 hover:file:bg-violet-100 dark:file:bg-violet-600 dark:file:text-violet-100 dark:hover:file:bg-violet-500 ..." | |
/> | |
``` | |
</Figure> | |
### ::marker | |
Style the counters or bullets in lists using the `marker` variant: | |
<Figure> | |
<Example className="py-0"> | |
{ | |
<div className="px-6"> | |
<div className="mx-auto max-w-sm border-x border-x-gray-200 px-8 py-8 dark:border-x-gray-800 dark:bg-gray-950/10"> | |
<h2 className="text-base font-semibold text-gray-900 dark:text-gray-200">Ingredients</h2> | |
<ul role="list" className="mt-3 list-disc space-y-3 pl-5 text-gray-500 marker:text-sky-400 dark:text-gray-400"> | |
<li>5 cups chopped Porcini mushrooms</li> | |
<li>1/2 cup of olive oil</li> | |
<li>3lb of celery</li> | |
</ul> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:marker:text-sky-400] --> | |
<ul role="list" class="list-disc marker:text-sky-400 ..."> | |
<li>5 cups chopped Porcini mushrooms</li> | |
<li>1/2 cup of olive oil</li> | |
<li>3lb of celery</li> | |
</ul> | |
``` | |
</Figure> | |
We've designed the `marker` variant to be inheritable, so although you can use it directly on an `<li>` element, you can also use it on a parent to avoid repeating yourself. | |
### ::selection | |
Style the active text selection using the `selection` variant: | |
<Figure hint="Try selecting some of this text with your mouse"> | |
<Example className="py-0"> | |
{ | |
<div className="px-6"> | |
<div className="mx-auto max-w-lg border-x border-x-gray-200 px-6 py-8 text-gray-700 selection:bg-fuchsia-300 selection:text-fuchsia-900 dark:border-x-gray-800 dark:bg-gray-950/10 dark:text-gray-300"> | |
<p> | |
So I started to walk into the water. I won't lie to you boys, I was terrified. But I pressed on, and as I made | |
my way past the breakers a strange calm came over me. I don't know if it was divine intervention or the | |
kinship of all living things but I tell you Jerry at that moment, I <em>was</em> a marine biologist. | |
</p> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:selection:bg-fuchsia-300] --> | |
<!-- [!code classes:selection:text-fuchsia-900] --> | |
<div class="selection:bg-fuchsia-300 selection:text-fuchsia-900"> | |
<p> | |
So I started to walk into the water. I won't lie to you boys, I was terrified. But I pressed on, and as I made my | |
way past the breakers a strange calm came over me. I don't know if it was divine intervention or the kinship of all | |
living things but I tell you Jerry at that moment, I <em>was</em> a marine biologist. | |
</p> | |
</div> | |
``` | |
</Figure> | |
We've designed the `selection` variant to be inheritable, so you can add it anywhere in the tree and it will be applied to all descendant elements. | |
This makes it easy to set the selection color to match your brand across your entire site: | |
```html | |
<!-- [!code classes:selection:bg-pink-300] --> | |
<html> | |
<head> | |
<!-- ... --> | |
</head> | |
<body class="selection:bg-pink-300"> | |
<!-- ... --> | |
</body> | |
</html> | |
``` | |
### ::first-line and ::first-letter | |
Style the first line in a block of content using the `first-line` variant, and the first letter using the `first-letter` variant: | |
<Figure> | |
<Example className="py-0"> | |
{ | |
<div className="px-6"> | |
<div className="mx-auto max-w-lg border-x border-x-gray-200 px-6 py-8 font-serif text-gray-700 dark:border-x-gray-800 dark:bg-gray-950/10 dark:text-gray-200"> | |
<p | |
className="first-letter:float-left first-letter:mr-3 first-letter:text-7xl first-letter:leading-none first-letter:font-bold first-letter:text-gray-900 first-line:tracking-widest first-line:uppercase dark:first-letter:text-white" | |
children={`Well, let me tell you something, funny boy. Y'know that little stamp, the one that says "New York Public Library"? Well that may not mean anything to you, but that means a lot to me. One whole hell of a lot.`} | |
/> | |
<p | |
className="mt-6" | |
children={`Sure, go ahead, laugh if you want to. I've seen your type before: Flashy, making the scene, flaunting convention. Yeah, I know what you're thinking. What's this guy making such a big stink about old library books? Well, let me give you a hint, junior.`} | |
/> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:first-line:uppercase] --> | |
<!-- [!code classes:first-line:tracking-widest] --> | |
<!-- [!code classes:first-letter:text-7xl] --> | |
<!-- [!code classes:first-letter:font-bold] --> | |
<!-- [!code classes:first-letter:text-gray-900] --> | |
<!-- [!code classes:first-letter:mr-3] --> | |
<!-- [!code classes:first-letter:float-left] --> | |
<!-- [!code classes:first-line:uppercase] --> | |
<!-- [!code classes:first-line:tracking-widest] --> | |
<!-- [!code classes:first-letter:text-7xl] --> | |
<!-- [!code classes:first-letter:font-bold] --> | |
<!-- [!code classes:first-letter:text-white] --> | |
<!-- [!code classes:first-letter:mr-3] --> | |
<!-- [!code classes:first-letter:float-left] --> | |
<div class="text-gray-700"> | |
<p | |
class="first-letter:float-left first-letter:mr-3 first-letter:text-7xl first-letter:font-bold first-letter:text-gray-900 first-line:tracking-widest first-line:uppercase" | |
> | |
Well, let me tell you something, funny boy. Y'know that little stamp, the one that says "New York Public Library"? | |
</p> | |
<p class="mt-6">Well that may not mean anything to you, but that means a lot to me. One whole hell of a lot.</p> | |
</div> | |
``` | |
</Figure> | |
### ::backdrop | |
Style the backdrop of a [native `<dialog>` element](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/dialog) using the `backdrop` variant: | |
```html | |
<!-- [!code classes:backdrop:bg-gray-50] --> | |
<dialog class="backdrop:bg-gray-50"> | |
<form method="dialog"> | |
<!-- ... --> | |
</form> | |
</dialog> | |
``` | |
If you're using native `<dialog>` elements in your project, you may also want to read about [styling open/closed states](/docs/hover-focus-and-other-states#openclosed-state) using the `open` variant. | |
## Media and feature queries | |
### Responsive breakpoints | |
To style an element at a specific breakpoint, use responsive variants like `md` and `lg`. | |
For example, this will render a 3-column grid on mobile, a 4-column grid on medium-width screens, and a 6-column grid on large-width screens: | |
```html | |
<!-- [!code classes:md:grid-cols-4,lg:grid-cols-6] --> | |
<div class="grid grid-cols-3 md:grid-cols-4 lg:grid-cols-6"> | |
<!-- ... --> | |
</div> | |
``` | |
To style an element based on the width of a parent element instead of the viewport, use variants like `@md` and `@lg`: | |
```html | |
<!-- [!code classes:@container,@md:flex-row] --> | |
<div class="@container"> | |
<div class="flex flex-col @md:flex-row"> | |
<!-- ... --> | |
</div> | |
</div> | |
``` | |
Check out the [Responsive design](/docs/responsive-design) documentation for an in-depth look at how these features work. | |
### prefers-color-scheme | |
The `prefers-color-scheme` media query tells you whether the user prefers a light theme or dark theme, and is usually configured at the operating system level. | |
Use utilities with no variant to target light mode, and use the `dark` variant to provide overrides for dark mode: | |
<Figure> | |
<Example padding={false} className="py-0"> | |
{ | |
<div className="grid grid-cols-1 sm:grid-cols-2"> | |
<div className="p-8 pt-7"> | |
<p className="mb-2 text-sm font-medium text-gray-500">Light mode</p> | |
<div className="rounded-lg bg-white px-6 py-8 shadow-xl ring-1 ring-gray-900/5"> | |
<div> | |
<span className="inline-flex items-center justify-center rounded-md bg-indigo-500 p-2 shadow-lg"> | |
<svg | |
className="h-6 w-6 text-white" | |
fill="none" | |
viewBox="0 0 24 24" | |
stroke="currentColor" | |
aria-hidden="true" | |
> | |
<path | |
strokeLinecap="round" | |
strokeLinejoin="round" | |
strokeWidth="2" | |
d="M11 5H6a2 2 0 00-2 2v11a2 2 0 002 2h11a2 2 0 002-2v-5m-1.414-9.414a2 2 0 112.828 2.828L11.828 15H9v-2.828l8.586-8.586z" | |
/> | |
</svg> | |
</span> | |
</div> | |
{/* This is not an h3 because we're converting h3's to links in MDX files */} | |
<div className="mt-5 text-base font-medium tracking-tight text-gray-900">Writes upside-down</div> | |
<p className="mt-2 text-sm text-gray-500"> | |
The Zero Gravity Pen can be used to write in any orientation, including upside-down. It even works in outer | |
space. | |
</p> | |
</div> | |
</div> | |
<div className="border-l border-l-transparent bg-black/90 p-8 pt-7 dark:border-l-white/10 dark:bg-transparent"> | |
<p className="mb-2 text-sm font-medium text-gray-400">Dark mode</p> | |
<div className="rounded-lg bg-gray-800 px-6 py-8 shadow-xl ring-1 ring-gray-900/5"> | |
<div> | |
<span className="inline-flex items-center justify-center rounded-md bg-indigo-500 p-2 shadow-lg"> | |
<svg | |
className="h-6 w-6 text-white" | |
fill="none" | |
viewBox="0 0 24 24" | |
stroke="currentColor" | |
aria-hidden="true" | |
> | |
<path | |
strokeLinecap="round" | |
strokeLinejoin="round" | |
strokeWidth="2" | |
d="M11 5H6a2 2 0 00-2 2v11a2 2 0 002 2h11a2 2 0 002-2v-5m-1.414-9.414a2 2 0 112.828 2.828L11.828 15H9v-2.828l8.586-8.586z" | |
/> | |
</svg> | |
</span> | |
</div> | |
{/* This is not an h3 because we're converting h3's to links in MDX files */} | |
<div className="mt-5 text-base font-medium tracking-tight text-white">Writes upside-down</div> | |
<p className="mt-2 text-sm text-gray-400"> | |
The Zero Gravity Pen can be used to write in any orientation, including upside-down. It even works in outer | |
space. | |
</p> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:dark:bg-gray-900] --> | |
<!-- [!code classes:dark:text-white] --> | |
<!-- [!code classes:dark:text-gray-400] --> | |
<div class="bg-white dark:bg-gray-900 ..."> | |
<!-- ... --> | |
<h3 class="text-gray-900 dark:text-white ...">Writes upside-down</h3> | |
<p class="text-gray-500 dark:text-gray-400 ..."> | |
The Zero Gravity Pen can be used to write in any orientation, including upside-down. It even works in outer space. | |
</p> | |
</div> | |
``` | |
</Figure> | |
Check out the [Dark Mode](/docs/dark-mode) documentation for an in-depth look at how this feature works. | |
### prefers-reduced-motion | |
The `prefers-reduced-motion` media query tells you if the user has requested that you minimize non-essential motion. | |
Use the `motion-reduce` variant to conditionally add styles when the user has requested reduced motion: | |
<Figure hint="Try emulating `prefers-reduced-motion: reduce` in your developer tools to hide the spinner"> | |
<Example> | |
{ | |
<div className="flex items-center justify-center"> | |
<button | |
type="button" | |
className="inline-flex items-center rounded-md bg-indigo-500 px-4 py-2 text-sm leading-6 font-semibold text-white shadow" | |
disabled | |
> | |
<svg | |
className="mr-3 -ml-1 h-5 w-5 animate-spin text-white motion-reduce:hidden" | |
fill="none" | |
viewBox="0 0 24 24" | |
> | |
<circle className="opacity-25" cx="12" cy="12" r="10" stroke="currentColor" strokeWidth="4"></circle> | |
<path | |
className="opacity-75" | |
fill="currentColor" | |
d="M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z" | |
></path> | |
</svg> | |
Processing... | |
</button> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:motion-reduce:hidden] --> | |
<button type="button" class="bg-indigo-500 ..." disabled> | |
<svg class="animate-spin motion-reduce:hidden ..." viewBox="0 0 24 24"><!-- ... --></svg> | |
Processing... | |
</button> | |
``` | |
</Figure> | |
Tailwind also includes a `motion-safe` variant that only adds styles when the user has _not_ requested reduced motion. This can be useful when using the `motion-reduce` helper would mean having to "undo" a lot of styles: | |
```html | |
<!-- [!code classes:motion-reduce:hover:translate-y-0] --> | |
<!-- [!code classes:motion-reduce:transition-none] --> | |
<!-- [!code classes:motion-safe:hover:-translate-x-0.5] --> | |
<!-- [!code classes:motion-safe:transition] --> | |
<!-- Using `motion-reduce` can mean lots of "undoing" styles --> | |
<button class="transition hover:-translate-y-0.5 motion-reduce:transition-none motion-reduce:hover:translate-y-0 ..."> | |
Save changes | |
</button> | |
<!-- Using `motion-safe` is less code in these situations --> | |
<button class="motion-safe:transition motion-safe:hover:-translate-x-0.5 ...">Save changes</button> | |
``` | |
### prefers-contrast | |
The `prefers-contrast` media query tells you if the user has requested more or less contrast. | |
Use the `contrast-more` variant to conditionally add styles when the user has requested more contrast: | |
<Figure hint="Try emulating `prefers-contrast: more` in your developer tools to see the changes"> | |
<Example className="py-0"> | |
{ | |
<div className="mx-auto max-w-sm border-x border-x-gray-200 px-6 pt-6 pb-4 dark:border-x-gray-800 dark:bg-gray-950/10"> | |
<form> | |
<div> | |
<label htmlFor="contrast-example" className="block text-sm font-medium text-gray-700 dark:text-white"> | |
Social Security Number | |
</label> | |
<div className="mt-1"> | |
<input | |
type="text" | |
name="contrast-example" | |
id="contrast-example" | |
className="block w-full rounded-md border border-gray-200 px-3 py-2 placeholder-gray-400 shadow-sm focus:border-sky-500 focus:outline focus:outline-sky-500 contrast-more:border-gray-400 contrast-more:placeholder-gray-500 sm:text-sm dark:border-gray-900 dark:contrast-more:border-gray-700 dark:contrast-more:placeholder-gray-300" | |
placeholder="000-00-0000" | |
/> | |
<p className="mt-2 text-sm text-gray-600 opacity-10 contrast-more:opacity-100 dark:text-gray-400"> | |
We need this to steal your identity. | |
</p> | |
</div> | |
</div> | |
</form> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:contrast-more:border-gray-400,contrast-more:placeholder-gray-500,contrast-more:opacity-100] --> | |
<label class="block"> | |
<span class="block text-sm font-medium text-gray-700">Social Security Number</span> | |
<input | |
class="border-gray-200 placeholder-gray-400 contrast-more:border-gray-400 contrast-more:placeholder-gray-500 ..." | |
/> | |
<p class="text-gray-600 opacity-10 contrast-more:opacity-100 ...">We need this to steal your identity.</p> | |
</label> | |
``` | |
</Figure> | |
Tailwind also includes a `contrast-less` variant you can use to conditionally add styles when the user has requested less contrast. | |
### forced-colors | |
The `forced-colors` media query indicates if the user is using a forced colors mode. These modes override your site's colors with a user defined palette for text, backgrounds, links and buttons. | |
Use the `forced-colors` variant to conditionally add styles when the user has enabled a forced color mode: | |
<Figure hint="Try emulating `forced-colors: active` in your developer tools to see the changes"> | |
<Example className="py-0"> | |
{ | |
<div className="mx-auto max-w-sm border-x border-x-gray-200 px-6 pt-6 pb-4 text-gray-900 dark:border-x-gray-800 dark:bg-gray-950/10 dark:text-white"> | |
<form> | |
<legend> Choose a theme: </legend> | |
<div className="mt-4 grid grid-flow-col"> | |
<label htmlFor="theme-1" className="text-sm font-medium text-gray-700 dark:text-white"> | |
<div className="relative grid h-16 w-16 items-center justify-center rounded-xl border border-transparent bg-transparent text-white hover:bg-gray-50 has-checked:border-cyan-500 has-checked:bg-cyan-50 has-checked:text-cyan-50 dark:text-gray-800 dark:hover:bg-gray-800 dark:has-checked:bg-cyan-950 dark:has-checked:text-cyan-950 forced-colors:border-0"> | |
<input | |
type="radio" | |
name="themes" | |
id="theme-1" | |
className="appearance-none forced-colors:appearance-auto" | |
defaultChecked | |
/> | |
<p className="hidden forced-colors:block">Cyan</p> | |
<div className="absolute top-3 left-3 h-6 w-6 rounded-full bg-cyan-200 forced-colors:hidden"></div> | |
<div className="absolute right-3 bottom-3 h-6 w-6 rounded-full bg-cyan-500 ring-2 ring-current forced-colors:hidden"></div> | |
</div> | |
</label> | |
<label htmlFor="theme-2" className="text-sm font-medium text-gray-700 dark:text-white"> | |
<div className="relative grid h-16 w-16 items-center justify-center rounded-xl border border-transparent bg-transparent text-white hover:bg-gray-50 has-checked:border-blue-500 has-checked:bg-blue-50 has-checked:text-blue-50 dark:text-gray-800 dark:hover:bg-gray-800 dark:has-checked:bg-blue-950 dark:has-checked:text-blue-950 forced-colors:border-0"> | |
<input | |
type="radio" | |
name="themes" | |
id="theme-2" | |
className="appearance-none forced-colors:appearance-auto" | |
/> | |
<p className="hidden forced-colors:block">Blue</p> | |
<div className="absolute top-3 left-3 h-6 w-6 rounded-full bg-blue-200 forced-colors:hidden"></div> | |
<div className="absolute right-3 bottom-3 h-6 w-6 rounded-full bg-blue-500 ring-2 ring-current forced-colors:hidden"></div> | |
</div> | |
</label> | |
<label htmlFor="theme-3" className="text-sm font-medium text-gray-700 dark:text-white"> | |
<div className="relative grid h-16 w-16 items-center justify-center rounded-xl border border-transparent bg-transparent text-white hover:bg-gray-50 has-checked:border-indigo-500 has-checked:bg-indigo-50 has-checked:text-indigo-50 dark:text-gray-800 dark:hover:bg-gray-800 dark:has-checked:bg-indigo-950 dark:has-checked:text-indigo-950 forced-colors:border-0"> | |
<input | |
type="radio" | |
name="themes" | |
id="theme-3" | |
className="appearance-none forced-colors:appearance-auto" | |
/> | |
<p className="hidden forced-colors:block">Indigo</p> | |
<div className="absolute top-3 left-3 h-6 w-6 rounded-full bg-indigo-200 forced-colors:hidden"></div> | |
<div className="absolute right-3 bottom-3 h-6 w-6 rounded-full bg-indigo-500 ring-2 ring-current forced-colors:hidden"></div> | |
</div> | |
</label> | |
<label htmlFor="theme-4" className="text-sm font-medium text-gray-700 dark:text-white"> | |
<div className="relative grid h-16 w-16 items-center justify-center rounded-xl border border-transparent bg-transparent text-white hover:bg-gray-50 has-checked:border-purple-500 has-checked:bg-purple-50 has-checked:text-purple-50 dark:text-gray-800 dark:hover:bg-gray-800 dark:has-checked:bg-purple-950 dark:has-checked:text-purple-950 forced-colors:border-0"> | |
<input | |
type="radio" | |
name="themes" | |
id="theme-4" | |
className="appearance-none forced-colors:appearance-auto" | |
/> | |
<p className="hidden forced-colors:block">Purple</p> | |
<div className="absolute top-3 left-3 h-6 w-6 rounded-full bg-purple-200 forced-colors:hidden"></div> | |
<div className="absolute right-3 bottom-3 h-6 w-6 rounded-full bg-purple-500 ring-2 ring-current forced-colors:hidden"></div> | |
</div> | |
</label> | |
</div> | |
</form> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:forced-colors:appearance-auto] --> | |
<!-- [!code classes:forced-colors:block] --> | |
<!-- [!code classes:forced-colors:hidden] --> | |
<!-- [!code classes:forced-colors:hidden] --> | |
<label> | |
<input type="radio" class="appearance-none forced-colors:appearance-auto" /> | |
<p class="hidden forced-colors:block">Cyan</p> | |
<div class="bg-cyan-200 forced-colors:hidden ..."></div> | |
<div class="bg-cyan-500 forced-colors:hidden ..."></div> | |
</label> | |
``` | |
</Figure> | |
Use the `not-forced-colors` variant to apply styles based when the user is _not_ using a forced colors mode: | |
```html | |
<!-- [!code classes:not-forced-colors:appearance-none] --> | |
<div class="not-forced-colors:appearance-none ..."> | |
<!-- ... --> | |
</div> | |
``` | |
Tailwind also includes a [forced color adjust](/docs/forced-color-adjust) utilities to opt in and out of forced colors. | |
### inverted-colors | |
Use the `inverted-colors` variant to conditionally add styles when the user has enabled an inverted color scheme: | |
```html | |
<!-- [!code classes:inverted-colors:shadow-none] --> | |
<div class="shadow-xl inverted-colors:shadow-none ..."> | |
<!-- ... --> | |
</div> | |
``` | |
### pointer and any-pointer | |
The `pointer` media query tells you whether the user has a primary pointing device, like a mouse, and the accuracy of that pointing device. | |
Use the `pointer-fine` variant to target an accurate pointing device, like a mouse or trackpad, or the `pointer-coarse` variant to target a less accurate pointing device, like a touchscreen, which can be useful for providing larger click targets on touch devices: | |
<Figure hint="Try emulating a touch device in your developer tools to see the changes"> | |
<Example> | |
{ | |
<fieldset aria-label="Choose a memory option" className="mx-auto max-w-md"> | |
<div className="flex items-center justify-between"> | |
<div className="text-sm/6 font-medium text-gray-900 dark:text-white">RAM</div> | |
<a href="#" className="text-sm/6 font-medium text-indigo-600 hover:text-indigo-500 dark:text-indigo-400"> | |
See performance specs | |
</a> | |
</div> | |
<div className="mt-4 grid grid-cols-6 gap-2 max-sm:grid-cols-3 pointer-coarse:mt-6 pointer-coarse:grid-cols-3 pointer-coarse:gap-4"> | |
<label className="flex items-center justify-center rounded-md bg-white p-2 text-sm font-semibold text-gray-900 uppercase ring-1 ring-gray-300 not-data-focus:not-has-checked:ring-inset hover:bg-gray-50 has-checked:bg-indigo-600 has-checked:text-white has-checked:ring-0 has-checked:hover:bg-indigo-500 has-focus-visible:outline-2 has-focus-visible:outline-offset-2 has-focus-visible:outline-indigo-600 data-focus:ring-2 data-focus:ring-indigo-600 data-focus:ring-offset-2 data-focus:has-checked:ring-2 sm:flex-1 dark:bg-transparent dark:text-white dark:ring-white/20 dark:hover:bg-gray-950/50 pointer-coarse:p-4"> | |
<input type="radio" name="memory-option" value="4 GB" className="sr-only" /> | |
<span>4 GB</span> | |
</label> | |
<label className="flex items-center justify-center rounded-md bg-white p-2 text-sm font-semibold text-gray-900 uppercase ring-1 ring-gray-300 not-data-focus:not-has-checked:ring-inset hover:bg-gray-50 has-checked:bg-indigo-600 has-checked:text-white has-checked:ring-0 has-checked:hover:bg-indigo-500 has-focus-visible:outline-2 has-focus-visible:outline-offset-2 has-focus-visible:outline-indigo-600 data-focus:ring-2 data-focus:ring-indigo-600 data-focus:ring-offset-2 data-focus:has-checked:ring-2 sm:flex-1 dark:bg-transparent dark:text-white dark:ring-white/20 dark:hover:bg-gray-950/50 pointer-coarse:p-4"> | |
<input type="radio" name="memory-option" value="8 GB" className="sr-only" defaultChecked /> | |
<span>8 GB</span> | |
</label> | |
<label className="flex items-center justify-center rounded-md bg-white p-2 text-sm font-semibold text-gray-900 uppercase ring-1 ring-gray-300 not-data-focus:not-has-checked:ring-inset hover:bg-gray-50 has-checked:bg-indigo-600 has-checked:text-white has-checked:ring-0 has-checked:hover:bg-indigo-500 has-focus-visible:outline-2 has-focus-visible:outline-offset-2 has-focus-visible:outline-indigo-600 data-focus:ring-2 data-focus:ring-indigo-600 data-focus:ring-offset-2 data-focus:has-checked:ring-2 sm:flex-1 dark:bg-transparent dark:text-white dark:ring-white/20 dark:hover:bg-gray-950/50 pointer-coarse:p-4"> | |
<input type="radio" name="memory-option" value="16 GB" className="sr-only" /> | |
<span>16 GB</span> | |
</label> | |
<label className="flex items-center justify-center rounded-md bg-white p-2 text-sm font-semibold text-gray-900 uppercase ring-1 ring-gray-300 not-data-focus:not-has-checked:ring-inset hover:bg-gray-50 has-checked:bg-indigo-600 has-checked:text-white has-checked:ring-0 has-checked:hover:bg-indigo-500 has-focus-visible:outline-2 has-focus-visible:outline-offset-2 has-focus-visible:outline-indigo-600 data-focus:ring-2 data-focus:ring-indigo-600 data-focus:ring-offset-2 data-focus:has-checked:ring-2 sm:flex-1 dark:bg-transparent dark:text-white dark:ring-white/20 dark:hover:bg-gray-950/50 pointer-coarse:p-4"> | |
<input type="radio" name="memory-option" value="32 GB" className="sr-only" /> | |
<span>32 GB</span> | |
</label> | |
<label className="flex items-center justify-center rounded-md bg-white p-2 text-sm font-semibold text-gray-900 uppercase ring-1 ring-gray-300 not-data-focus:not-has-checked:ring-inset hover:bg-gray-50 has-checked:bg-indigo-600 has-checked:text-white has-checked:ring-0 has-checked:hover:bg-indigo-500 has-focus-visible:outline-2 has-focus-visible:outline-offset-2 has-focus-visible:outline-indigo-600 data-focus:ring-2 data-focus:ring-indigo-600 data-focus:ring-offset-2 data-focus:has-checked:ring-2 sm:flex-1 dark:bg-transparent dark:text-white dark:ring-white/20 dark:hover:bg-gray-950/50 pointer-coarse:p-4"> | |
<input type="radio" name="memory-option" value="64 GB" className="sr-only" /> | |
<span>64 GB</span> | |
</label> | |
<label className="flex items-center justify-center rounded-md bg-white p-2 text-sm font-semibold text-gray-900 uppercase ring-1 ring-gray-300 not-data-focus:not-has-checked:ring-inset hover:bg-gray-50 has-checked:bg-indigo-600 has-checked:text-white has-checked:ring-0 has-checked:hover:bg-indigo-500 has-focus-visible:outline-2 has-focus-visible:outline-offset-2 has-focus-visible:outline-indigo-600 data-focus:ring-2 data-focus:ring-indigo-600 data-focus:ring-offset-2 data-focus:has-checked:ring-2 sm:flex-1 dark:bg-transparent dark:text-white dark:ring-white/20 dark:hover:bg-gray-950/50 pointer-coarse:p-4"> | |
<input type="radio" name="memory-option" value="128 GB" className="sr-only" /> | |
<span>128 GB</span> | |
</label> | |
</div> | |
</fieldset> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:pointer-coarse:mt-6,pointer-coarse:grid-cols-3,pointer-coarse:gap-4,pointer-coarse:p-4] --> | |
<fieldset aria-label="Choose a memory option"> | |
<div class="flex items-center justify-between"> | |
<div>RAM</div> | |
<a href="#"> See performance specs </a> | |
</div> | |
<div class="mt-4 grid grid-cols-6 gap-2 pointer-coarse:mt-6 pointer-coarse:grid-cols-3 pointer-coarse:gap-4"> | |
<label class="p-2 pointer-coarse:p-4 ..."> | |
<input type="radio" name="memory-option" value="4 GB" className="sr-only" /> | |
<span>4 GB</span> | |
</label> | |
<!-- ... --> | |
</div> | |
</fieldset> | |
``` | |
</Figure> | |
While `pointer`only targets the primary pointing device, `any-pointer` is used to target any of the pointing devices that might be available. Use the `any-pointer-fine` and `any-pointer-coarse` variants to provide different styles if at least one connected pointing device meets the criteria. | |
You can use `pointer-none` and `any-pointer-none` to target the absence of a pointing device. | |
### orientation | |
Use the `portrait` and `landscape` variants to conditionally add styles when the viewport is in a specific orientation: | |
```html | |
<!-- [!code classes:portrait:hidden,landscape:hidden] --> | |
<div> | |
<div class="portrait:hidden"> | |
<!-- ... --> | |
</div> | |
<div class="landscape:hidden"> | |
<p>This experience is designed to be viewed in landscape. Please rotate your device to view the site.</p> | |
</div> | |
</div> | |
``` | |
### scripting | |
Use the `noscript` variant to conditionally add styles based on whether the user has scripting, such as JavaScript, enabled: | |
```html | |
<!-- [!code classes:noscript:block] --> | |
<div class="hidden noscript:block"> | |
<p>This experience requires JavaScript to function. Please enable JavaScript in your browser settings.</p> | |
</div> | |
``` | |
Use the `print` variant to conditionally add styles that only apply when the document is being printed: | |
```html | |
<!-- [!code classes:print:hidden] --> | |
<!-- [!code classes:print:block] --> | |
<div> | |
<article class="print:hidden"> | |
<h1>My Secret Pizza Recipe</h1> | |
<p>This recipe is a secret, and must not be shared with anyone</p> | |
<!-- ... --> | |
</article> | |
<div class="hidden print:block">Are you seriously trying to print this? It's secret!</div> | |
</div> | |
``` | |
### @supports | |
Use the `supports-[...]` variant to style things based on whether a certain feature is supported in the user's browser: | |
```html | |
<!-- [!code classes:supports-[display:grid]:grid] --> | |
<div class="flex supports-[display:grid]:grid ..."> | |
<!-- ... --> | |
</div> | |
``` | |
Under the hood the `supports-[...]` variant generates [`@supports rules`](https://developer.mozilla.org/en-US/docs/Web/CSS/@supports) and takes anything you’d use with `@supports (...)` between the square brackets, like a property/value pair, and even expressions using `and` and `or`. | |
For terseness, if you only need to check if a property is supported (and not a specific value), you can just specify the property name: | |
```html | |
<!-- [!code classes:supports-backdrop-filter:bg-black/25,supports-backdrop-filter:backdrop-blur] --> | |
<div class="bg-black/75 supports-backdrop-filter:bg-black/25 supports-backdrop-filter:backdrop-blur ..."> | |
<!-- ... --> | |
</div> | |
``` | |
Use the `not-supports-[...]` variant to style things based on whether a certain feature is not supported in the user's browser: | |
```html | |
<!-- [!code classes:not-supports-[display:grid]:flex] --> | |
<div class="not-supports-[display:grid]:flex"> | |
<!-- ... --> | |
</div> | |
``` | |
You can configure shortcuts for common `@supports` rules you're using in your project by creating a new variant in the `supports-*` namespace: | |
```css | |
@custom-variant supports-grid { | |
@supports (display: grid) { | |
@slot; | |
} | |
} | |
``` | |
You can then use these custom `supports-*` variants in your project: | |
```html | |
<!-- [!code classes:supports-grid:grid] --> | |
<div class="supports-grid:grid"> | |
<!-- ... --> | |
</div> | |
``` | |
### @starting-style | |
Use the `starting` variant to set the appearance of an element when it is first rendered in the DOM, or transitions from `display: none` to visible: | |
<Figure> | |
<Example className="flex py-0"> | |
{ | |
<Iframe className="h-[340px] w-full"> | |
<div className="grid h-full items-center justify-center"> | |
<button | |
popoverTarget="my-popover" | |
className="inline-flex w-full justify-center rounded-md bg-indigo-600 px-3 py-2 text-sm font-semibold text-white shadow-sm hover:bg-indigo-500 focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-indigo-600 sm:col-start-2" | |
> | |
Check for updates | |
</button> | |
<div | |
popover="auto" | |
id="my-popover" | |
className="relative inset-y-0 mx-auto my-auto transform overflow-hidden rounded-lg bg-white px-4 pt-5 pb-4 text-left opacity-0 shadow-xl transition-all [transition-behavior:allow-discrete] duration-500 sm:w-full sm:max-w-96 sm:p-6 dark:bg-gray-800 [&:is([open],:popover-open)]:opacity-100 [@starting-style]:[&:is([open],:popover-open)]:opacity-0" | |
> | |
<div> | |
<div className="mx-auto flex size-12 items-center justify-center rounded-full bg-indigo-50 dark:bg-indigo-600/10"> | |
<svg | |
className="size-5 text-indigo-400 dark:text-indigo-600" | |
viewBox="0 0 20 20" | |
fill="currentColor" | |
aria-hidden="true" | |
data-slot="icon" | |
> | |
<path | |
fillRule="evenodd" | |
d="M18 10a8 8 0 1 1-16 0 8 8 0 0 1 16 0Zm-7-4a1 1 0 1 1-2 0 1 1 0 0 1 2 0ZM9 9a.75.75 0 0 0 0 1.5h.253a.25.25 0 0 1 .244.304l-.459 2.066A1.75 1.75 0 0 0 10.747 15H11a.75.75 0 0 0 0-1.5h-.253a.25.25 0 0 1-.244-.304l.459-2.066A1.75 1.75 0 0 0 9.253 9H9Z" | |
clipRule="evenodd" | |
/> | |
</svg> | |
</div> | |
<div className="mt-3 text-center sm:mt-5"> | |
<h3 className="text-base font-semibold text-gray-900 dark:text-white" id="modal-title"> | |
Update available | |
</h3> | |
<div className="mt-2"> | |
<p className="text-sm text-gray-500 dark:text-gray-200"> | |
A new software update is available: <span className="font-semibold">v2.0.4.</span> | |
<br /> | |
Click the button below to install it. | |
</p> | |
</div> | |
</div> | |
</div> | |
<div className="mt-5"> | |
<button | |
type="button" | |
className="inline-flex w-full justify-center rounded-md bg-indigo-600 px-3 py-2 text-sm font-semibold text-white shadow-sm hover:bg-indigo-500 focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-indigo-600 sm:col-start-2" | |
> | |
Install | |
</button> | |
</div> | |
</div> | |
</div> | |
</Iframe> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:starting:open:opacity-0] --> | |
<div> | |
<button popovertarget="my-popover">Check for updates</button> | |
<div popover id="my-popover" class="opacity-0 starting:open:opacity-0 ..."> | |
<!-- ... --> | |
</div> | |
</div> | |
``` | |
</Figure> | |
## Attribute selectors | |
### ARIA states | |
Use the `aria-*` variant to conditionally style things based on [ARIA attributes](https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes). | |
For example, to apply the `bg-sky-700` class when the `aria-checked` attribute is set to `true`, use the `aria-checked:bg-sky-700` class: | |
```html | |
<!-- [!code classes:aria-checked:bg-sky-700] --> | |
<div aria-checked="true" class="bg-gray-600 aria-checked:bg-sky-700"> | |
<!-- ... --> | |
</div> | |
``` | |
By default we've included variants for the most common boolean ARIA attributes: | |
{ | |
<table> | |
<thead> | |
<tr> | |
<th>Variant</th> | |
<th>CSS</th> | |
</tr> | |
</thead> | |
<tbody> | |
<tr> | |
<td> | |
<code className="before:content-none after:content-none">aria-busy</code> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[aria-busy="true"] | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code className="before:content-none after:content-none">aria-checked</code> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[aria-checked="true"] | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code className="before:content-none after:content-none">aria-disabled</code> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[aria-disabled="true"] | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code className="before:content-none after:content-none">aria-expanded</code> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[aria-expanded="true"] | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code className="before:content-none after:content-none">aria-hidden</code> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[aria-hidden="true"] | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code className="before:content-none after:content-none">aria-pressed</code> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[aria-pressed="true"] | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code className="before:content-none after:content-none">aria-readonly</code> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[aria-readonly="true"] | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code className="before:content-none after:content-none">aria-required</code> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[aria-required="true"] | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<code className="before:content-none after:content-none">aria-selected</code> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[aria-selected="true"] | |
</code> | |
</td> | |
</tr> | |
</tbody> | |
</table> | |
} | |
You can customize which `aria-*` variants are available by creating a new variant: | |
```css | |
@custom-variant aria-asc (&[aria-sort="ascending"]); | |
@custom-variant aria-desc (&[aria-sort="descending"]); | |
``` | |
If you need to use a one-off `aria` variant that doesn’t make sense to include in your project, or for more complex ARIA attributes that take specific values, use square brackets to generate a property on the fly using any arbitrary value: | |
<Figure> | |
<Example padding={false} className="py-0"> | |
{ | |
<div className="py-8"> | |
<table className="w-full border-collapse border-y border-gray-400 bg-white text-sm dark:border-white/10 dark:bg-transparent"> | |
<thead className="bg-gray-50 dark:bg-white/5"> | |
<tr> | |
<th | |
className="group border border-gray-300 px-4 py-3 text-left font-semibold text-gray-900 first:border-l-0 last:border-r-0 dark:border-white/10 dark:text-gray-200" | |
aria-sort="ascending" | |
> | |
<span className="flex w-full items-center justify-between gap-2"> | |
Invoice # | |
<svg | |
viewBox="0 0 20 20" | |
className="h-5 w-5 fill-gray-500 group-aria-[sort=ascending]:rotate-0 group-aria-[sort=descending]:rotate-180" | |
> | |
<path | |
fillRule="evenodd" | |
d="M10 5a.75.75 0 01.75.75v6.638l1.96-2.158a.75.75 0 111.08 1.04l-3.25 3.5a.75.75 0 01-1.08 0l-3.25-3.5a.75.75 0 111.08-1.04l1.96 2.158V5.75A.75.75 0 0110 5z" | |
clipRule="evenodd" | |
/> | |
</svg> | |
</span> | |
</th> | |
<th className="border border-gray-300 px-4 py-3 text-left font-semibold text-gray-900 first:border-l-0 last:border-r-0 dark:border-white/10 dark:text-gray-200"> | |
Client | |
</th> | |
<th className="border border-gray-300 px-4 py-3 text-right font-semibold text-gray-900 first:border-l-0 last:border-r-0 dark:border-white/10 dark:text-gray-200"> | |
Amount | |
</th> | |
</tr> | |
</thead> | |
<tbody> | |
<tr> | |
<td className="border border-gray-300 px-4 py-3 text-gray-500 first:border-l-0 last:border-r-0 dark:border-white/10 dark:text-gray-400"> | |
#100 | |
</td> | |
<td className="border border-gray-300 px-4 py-3 text-gray-500 first:border-l-0 last:border-r-0 dark:border-white/10 dark:text-gray-400"> | |
Pendant Publishing | |
</td> | |
<td className="border border-gray-300 px-4 py-3 text-right text-gray-500 tabular-nums first:border-l-0 last:border-r-0 dark:border-white/10 dark:text-gray-400"> | |
$2,000.00 | |
</td> | |
</tr> | |
<tr> | |
<td className="border border-gray-300 px-4 py-3 text-gray-500 first:border-l-0 last:border-r-0 dark:border-white/10 dark:text-gray-400"> | |
#101 | |
</td> | |
<td className="border border-gray-300 px-4 py-3 text-gray-500 first:border-l-0 last:border-r-0 dark:border-white/10 dark:text-gray-400"> | |
Kruger Industrial Smoothing | |
</td> | |
<td className="border border-gray-300 px-4 py-3 text-right text-gray-500 tabular-nums first:border-l-0 last:border-r-0 dark:border-white/10 dark:text-gray-400"> | |
$545.00 | |
</td> | |
</tr> | |
<tr> | |
<td className="border border-gray-300 px-4 py-3 text-gray-500 first:border-l-0 last:border-r-0 dark:border-white/10 dark:text-gray-400"> | |
#102 | |
</td> | |
<td className="border border-gray-300 px-4 py-3 text-gray-500 first:border-l-0 last:border-r-0 dark:border-white/10 dark:text-gray-400"> | |
J. Peterman | |
</td> | |
<td className="border border-gray-300 px-4 py-3 text-right text-gray-500 tabular-nums first:border-l-0 last:border-r-0 dark:border-white/10 dark:text-gray-400"> | |
$10,000.25 | |
</td> | |
</tr> | |
</tbody> | |
</table> | |
</div> | |
} | |
</Example> | |
<CodeExampleGroup | |
filenames={["HTML", "Generated CSS"]} | |
> | |
<CodeBlock | |
example={html` | |
<!-- [!code classes:aria-[sort=ascending]:bg-[url('/img/down-arrow.svg')],aria-[sort=descending]:bg-[url('/img/up-arrow.svg')]] --> | |
<table> | |
<thead> | |
<tr> | |
<th | |
aria-sort="ascending" | |
class="aria-[sort=ascending]:bg-[url('/img/down-arrow.svg')] aria-[sort=descending]:bg-[url('/img/up-arrow.svg')]" | |
> | |
Invoice # | |
</th> | |
<!-- ... --> | |
</tr> | |
</thead> | |
<!-- ... --> | |
</table> | |
`} | |
/> | |
<CodeBlock | |
example={css` | |
.aria-\[sort\=ascending\]\:bg-\[url\(\'\/img\/down-arrow\.svg\'\)\] { | |
&[aria-sort="ascending"] { | |
background-image: url('/img/down-arrow.svg'); | |
} | |
} | |
.aria-\[sort\=descending\]\:bg-\[url\(\'\/img\/up-arrow\.svg\'\)\] { | |
&[aria-sort="descending"] { | |
background-image: url('/img/up-arrow.svg'); | |
} | |
} | |
`} | |
/> | |
</CodeExampleGroup> | |
</Figure> | |
ARIA state variants can also target parent and sibling elements using the `group-aria-*` and `peer-aria-*` variants: | |
<CodeExampleGroup | |
filenames={["HTML", "Generated CSS"]} | |
> | |
<CodeBlock | |
example={html` | |
<!-- [!code classes:group-aria-[sort=ascending]:rotate-0,group-aria-[sort=descending]:rotate-180] --> | |
<table> | |
<thead> | |
<tr> | |
<th aria-sort="ascending" class="group"> | |
Invoice # | |
<svg class="group-aria-[sort=ascending]:rotate-0 group-aria-[sort=descending]:rotate-180"><!-- ... --></svg> | |
</th> | |
<!-- ... --> | |
</tr> | |
</thead> | |
<!-- ... --> | |
</table> | |
`} | |
/> | |
<CodeBlock | |
example={css` | |
.group-aria-\[sort\=ascending\]\:rotate-0 { | |
&:is(:where(.group)[aria-sort="ascending"] *) { | |
rotate: 0deg; | |
} | |
} | |
.group-aria-\[sort\=descending\]\:rotate-180 { | |
&:is(:where(.group)[aria-sort="descending"] *) { | |
rotate: 180deg; | |
} | |
} | |
`} | |
/> | |
</CodeExampleGroup> | |
### Data attributes | |
Use the `data-*` variant to conditionally apply styles based on [data attributes](https://developer.mozilla.org/en-US/docs/Learn/HTML/Howto/Use_data_attributes). | |
To check if a data attribute exists (and not a specific value), you can just specify the attribute name: | |
```html | |
<!-- Will apply --> | |
<!-- [!code classes:data-active:border-purple-500] --> | |
<div data-active class="border border-gray-300 data-active:border-purple-500"> | |
<!-- ... --> | |
</div> | |
<!-- Will not apply --> | |
<div class="border border-gray-300 data-active:border-purple-500"> | |
<!-- ... --> | |
</div> | |
``` | |
If you need to check for a specific value you may use an arbitrary value: | |
```html | |
<!-- Will apply --> | |
<!-- [!code classes:data-[size=large]:p-8] --> | |
<div data-size="large" class="data-[size=large]:p-8"> | |
<!-- ... --> | |
</div> | |
<!-- Will not apply --> | |
<div data-size="medium" class="data-[size=large]:p-8"> | |
<!-- ... --> | |
</div> | |
``` | |
Alternatively, you can configure shortcuts for common data attributes you're using in your project by creating a new variant in the `data-*` namespace: | |
```css | |
<!-- [!code filename:app.css] --> | |
@import "tailwindcss"; | |
@custom-variant data-checked (&[data-ui~="checked"]); | |
``` | |
You can then use these custom `data-*` variants in your project: | |
```html | |
<!-- [!code classes:data-checked:underline] --> | |
<div data-ui="checked active" class="data-checked:underline"> | |
<!-- ... --> | |
</div> | |
``` | |
### RTL support | |
Use the `rtl` and `ltr` variants to conditionally add styles in right-to-left and left-to-right modes respectively when building multi-directional layouts: | |
<Figure> | |
<Example> | |
{ | |
<div className="mx-auto grid max-w-lg grid-cols-1 gap-x-6 gap-y-10 sm:grid-cols-2"> | |
<div dir="ltr"> | |
<p className="mb-4 text-sm font-medium">Left-to-right</p> | |
<div className="group flex items-center"> | |
<img | |
className="h-12 w-12 shrink-0 rounded-full" | |
src="https://images.unsplash.com/photo-1472099645785-5658abf4ff4e?ixlib=rb-1.2.1&ixid=eyJhcHBfaWQiOjEyMDd9&auto=format&fit=facearea&facepad=2&w=256&h=256&q=80" | |
alt="" | |
/> | |
<div className="ml-3 rtl:mr-3 rtl:ml-0"> | |
<p className="text-sm font-medium text-gray-700 group-hover:text-gray-900 dark:text-gray-300 dark:group-hover:text-white"> | |
Tom Cook | |
</p> | |
<p className="text-sm font-medium text-gray-500 group-hover:text-gray-700 dark:group-hover:text-gray-300"> | |
Director of Operations | |
</p> | |
</div> | |
</div> | |
</div> | |
<div dir="rtl"> | |
<p className="mb-4 text-sm font-medium">Right-to-left</p> | |
<div className="group flex items-center"> | |
<img | |
className="h-12 w-12 shrink-0 rounded-full" | |
src="https://images.unsplash.com/photo-1563833717765-00462801314e?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=facearea&facepad=2&w=256&h=256&q=80" | |
alt="" | |
/> | |
<div className="ml-3 rtl:mr-3 rtl:ml-0"> | |
<p className="text-sm font-medium text-gray-700 group-hover:text-gray-900 dark:text-gray-300 dark:group-hover:text-white"> | |
تامر كرم | |
</p> | |
<p className="text-sm font-medium text-gray-500 group-hover:text-gray-700 dark:group-hover:text-gray-300"> | |
الرئيس التنفيذي | |
</p> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:ltr:ml-3,rtl:mr-3] --> | |
<div class="group flex items-center"> | |
<img class="h-12 w-12 shrink-0 rounded-full" src="..." alt="" /> | |
<div class="ltr:ml-3 rtl:mr-3"> | |
<p class="text-gray-700 group-hover:text-gray-900 ...">...</p> | |
<p class="text-gray-500 group-hover:text-gray-700 ...">...</p> | |
</div> | |
</div> | |
``` | |
</Figure> | |
Remember, these variants are only useful if you are building a site that needs to support _both_ left-to-right and right-to-left layouts. If you're building a site that only needs to support a single direction, you don't need these variants — just apply the styles that make sense for your content. | |
### Open/closed state | |
Use the `open` variant to conditionally add styles when a `<details>` or `<dialog>` element is in an open state: | |
<Figure hint="Try toggling the disclosure to see the styles change"> | |
<Example> | |
{ | |
<div className="mx-auto max-w-lg"> | |
<details | |
className="rounded-lg border border-transparent p-6 open:border-black/10 open:bg-gray-100 dark:open:border-gray-700/50 dark:open:bg-gray-950/50" | |
open | |
> | |
<summary className="text-sm leading-6 font-semibold text-gray-900 select-none dark:text-white"> | |
Why do they call it Ovaltine? | |
</summary> | |
<div className="mt-3 text-sm leading-6 text-gray-600 dark:text-gray-400"> | |
<p>The mug is round. The jar is round. They should call it Roundtine.</p> | |
</div> | |
</details> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:open:border-black/10,open:bg-gray-100] --> | |
<details class="border border-transparent open:border-black/10 open:bg-gray-100 ..." open> | |
<summary class="text-sm leading-6 font-semibold text-gray-900 select-none">Why do they call it Ovaltine?</summary> | |
<div class="mt-3 text-sm leading-6 text-gray-600"> | |
<p>The mug is round. The jar is round. They should call it Roundtine.</p> | |
</div> | |
</details> | |
``` | |
</Figure> | |
This variant also targets the `:popover-open` pseudo-class for popovers: | |
```html | |
<!-- [!code classes:open:opacity-100] --> | |
<div> | |
<button popovertarget="my-popover">Open Popover</button> | |
<div popover id="my-popover" class="opacity-0 open:opacity-100 ..."> | |
<!-- ... --> | |
</div> | |
</div> | |
``` | |
### Styling inert elements | |
The `inert` variant lets you style elements marked with the `inert` attribute: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<form className="mx-auto max-w-md space-y-6 border-x border-x-gray-200 p-8 dark:border-x-gray-800"> | |
<legend>Notification preferences</legend> | |
<fieldset name="resale" defaultValue="permit"> | |
<div className="flex items-center gap-x-3"> | |
<input | |
readOnly | |
id="push-everything" | |
name="push-notifications" | |
type="radio" | |
className="relative size-4 appearance-none rounded-full border border-gray-300 bg-white before:absolute before:inset-1 before:rounded-full before:bg-white not-checked:before:hidden checked:border-indigo-600 checked:bg-indigo-600 focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-indigo-600 disabled:border-gray-300 disabled:bg-gray-100 disabled:before:bg-gray-400 dark:border-gray-700 dark:bg-gray-950 forced-colors:appearance-auto forced-colors:before:hidden" | |
/> | |
<label htmlFor="push-everything" className="block text-sm/6 font-medium text-gray-900 dark:text-white"> | |
Custom | |
</label> | |
</div> | |
<fieldset className="mt-6 space-y-6 pl-8 inert:opacity-25" inert> | |
<div className="flex gap-3"> | |
<div className="flex h-6 shrink-0 items-center"> | |
<div className="group grid size-4 grid-cols-1"> | |
<input | |
defaultChecked | |
id="comments" | |
name="comments" | |
type="checkbox" | |
aria-describedby="comments-description" | |
className="col-start-1 row-start-1 appearance-none rounded-sm border border-gray-300 bg-white checked:border-indigo-600 checked:bg-indigo-600 indeterminate:border-indigo-600 indeterminate:bg-indigo-600 focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-indigo-600 disabled:border-gray-300 disabled:bg-gray-100 disabled:checked:bg-gray-100 dark:border-gray-700 dark:bg-gray-950 forced-colors:appearance-auto" | |
/> | |
<svg | |
fill="none" | |
viewBox="0 0 14 14" | |
className="pointer-events-none col-start-1 row-start-1 size-3.5 self-center justify-self-center stroke-white group-has-disabled:stroke-gray-950/25" | |
> | |
<path | |
d="M3 8L6 11L11 3.5" | |
strokeWidth={2} | |
strokeLinecap="round" | |
strokeLinejoin="round" | |
className="opacity-0 group-has-checked:opacity-100" | |
/> | |
<path | |
d="M3 7H11" | |
strokeWidth={2} | |
strokeLinecap="round" | |
strokeLinejoin="round" | |
className="opacity-0 group-has-indeterminate:opacity-100" | |
/> | |
</svg> | |
</div> | |
</div> | |
<div className="text-sm/6"> | |
<label htmlFor="comments" className="font-medium text-gray-900 dark:text-white"> | |
Comments | |
</label> | |
<p id="comments-description" className="text-gray-500 dark:text-gray-400"> | |
Get notified when someones posts a comment on a post. | |
</p> | |
</div> | |
</div> | |
<div className="flex gap-3"> | |
<div className="flex h-6 shrink-0 items-center"> | |
<div className="group grid size-4 grid-cols-1"> | |
<input | |
defaultChecked | |
id="comments" | |
name="comments" | |
type="checkbox" | |
aria-describedby="comments-description" | |
className="col-start-1 row-start-1 appearance-none rounded-sm border border-gray-300 bg-white checked:border-indigo-600 checked:bg-indigo-600 indeterminate:border-indigo-600 indeterminate:bg-indigo-600 focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-indigo-600 disabled:border-gray-300 disabled:bg-gray-100 disabled:checked:bg-gray-100 dark:border-gray-700 dark:bg-gray-950 forced-colors:appearance-auto" | |
/> | |
<svg | |
fill="none" | |
viewBox="0 0 14 14" | |
className="pointer-events-none col-start-1 row-start-1 size-3.5 self-center justify-self-center stroke-white group-has-disabled:stroke-gray-950/25" | |
> | |
<path | |
d="M3 8L6 11L11 3.5" | |
strokeWidth={2} | |
strokeLinecap="round" | |
strokeLinejoin="round" | |
className="opacity-0 group-has-checked:opacity-100" | |
/> | |
<path | |
d="M3 7H11" | |
strokeWidth={2} | |
strokeLinecap="round" | |
strokeLinejoin="round" | |
className="opacity-0 group-has-indeterminate:opacity-100" | |
/> | |
</svg> | |
</div> | |
</div> | |
<div className="text-sm/6"> | |
<label htmlFor="comments" className="font-medium text-gray-900 dark:text-white"> | |
Mentions | |
</label> | |
<p id="comments-description" className="text-gray-500 dark:text-gray-400"> | |
Get notified when someones mentions you. | |
</p> | |
</div> | |
</div> | |
</fieldset> | |
<div className="mt-6 flex items-center gap-x-3"> | |
<input | |
readOnly | |
checked | |
id="push-everything" | |
name="push-notifications" | |
type="radio" | |
className="relative size-4 appearance-none rounded-full border border-gray-300 bg-white before:absolute before:inset-1 before:rounded-full before:bg-white not-checked:before:hidden checked:border-indigo-600 checked:bg-indigo-600 focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-indigo-600 disabled:border-gray-300 disabled:bg-gray-100 disabled:before:bg-gray-400 dark:border-gray-700 dark:bg-gray-950 forced-colors:appearance-auto forced-colors:before:hidden" | |
/> | |
<label htmlFor="push-everything" className="block text-sm/6 font-medium text-gray-900 dark:text-white"> | |
Everything | |
</label> | |
</div> | |
</fieldset> | |
</form> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:inert:opacity-50] --> | |
<form> | |
<legend>Notification preferences</legend> | |
<fieldset> | |
<input type="radio" /> | |
<label> Custom </label> | |
<fieldset inert class="inert:opacity-50"> | |
<!-- ... --> | |
</fieldset> | |
<input type="radio" /> | |
<label> Everything </label> | |
</fieldset> | |
</form> | |
``` | |
</Figure> | |
This is useful for adding visual cues that make it clear that sections of content aren't interactive. | |
## Child selectors | |
### Styling direct children | |
While it's generally preferable to put utility classes directly on child elements, you can use the `*` variant in situations where you need to style direct children that you don’t have control over: | |
<Figure> | |
<Example className="py-0"> | |
{ | |
<div className="mx-auto max-w-md border-x border-x-gray-200 p-6 dark:border-x-gray-800 dark:bg-gray-950/10"> | |
<h2 className="text-base font-semibold text-gray-900 dark:text-gray-200">Categories</h2> | |
<div className="flex flex-wrap gap-2 pt-4 text-sm text-sky-600 *:rounded-full *:border *:border-sky-100 *:bg-sky-50 *:px-2 *:py-0.5 dark:text-sky-300 dark:*:border-sky-500/15 dark:*:bg-sky-500/10"> | |
<div>Sales</div> | |
<div>Marketing</div> | |
<div>SEO</div> | |
<div>Analytics</div> | |
<div>Design</div> | |
<div>Strategy</div> | |
<div>Security</div> | |
<div>Growth</div> | |
<div>Mobile</div> | |
<div>UX/UI</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:*:rounded-full] --> | |
<!-- [!code classes:*:border] --> | |
<!-- [!code classes:*:border-sky-100] --> | |
<!-- [!code classes:*:bg-sky-50] --> | |
<!-- [!code classes:*:px-2] --> | |
<!-- [!code classes:*:py-0.5] --> | |
<!-- [!code classes:dark:text-sky-300] --> | |
<!-- [!code classes:dark:*:border-sky-500/15] --> | |
<!-- [!code classes:dark:*:bg-sky-500/10] --> | |
<div> | |
<h2>Categories<h2> | |
<ul class="*:rounded-full *:border *:border-sky-100 *:bg-sky-50 *:px-2 *:py-0.5 dark:text-sky-300 dark:*:border-sky-500/15 dark:*:bg-sky-500/10 ..."> | |
<li>Sales</li> | |
<li>Marketing</li> | |
<li>SEO</li> | |
<!-- ... --> | |
</ul> | |
</div> | |
``` | |
</Figure> | |
It's important to note that overriding a style with a utility directly on the child itself won't work due to the specificity of the generated child selector: | |
<TipBad>{<>Won't work, children can't override their own styling.</>}</TipBad> | |
```html | |
<!-- [!code classes:*:bg-sky-50] --> | |
<!-- [!code classes:bg-red-50] --> | |
<ul class="*:bg-sky-50 ..."> | |
<li class="bg-red-50 ...">Sales</li> | |
<li>Marketing</li> | |
<li>SEO</li> | |
<!-- ... --> | |
</ul> | |
``` | |
### Styling all descendants | |
Like `*`, the `**` variant can be used to style children of an element. The main difference is that `**` will apply styles to _all_ descendants, not just the direct children. This is especially useful when you combine it with another variant for narrowing the thing you're selecting: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="px-4"> | |
<ul | |
role="list" | |
className="mx-auto max-w-md border-x border-x-gray-200 p-2 **:data-avatar:size-12 **:data-avatar:rounded-full dark:border-x-gray-800 dark:bg-gray-950/10" | |
> | |
<li className="group/item relative flex items-center justify-between rounded-xl p-4 hover:bg-gray-100 dark:hover:bg-white/5"> | |
<div className="flex gap-4"> | |
<div className="flex-shrink-0"> | |
<img | |
data-avatar | |
src="https://images.unsplash.com/photo-1494790108377-be9c29b29330?ixlib=rb-1.2.1&ixid=eyJhcHBfaWQiOjEyMDd9&auto=format&fit=facearea&facepad=2&w=256&h=256&q=80" | |
alt="" | |
/> | |
</div> | |
<div className="w-full text-sm leading-6"> | |
<a href="#" className="font-semibold text-gray-900 dark:text-white"> | |
<span className="absolute inset-0 rounded-xl" aria-hidden="true"></span>Leslie Abbott | |
</a> | |
<div className="text-gray-500">Co-Founder / CEO</div> | |
</div> | |
</div> | |
</li> | |
<li className="group/item relative flex items-center justify-between rounded-xl p-4 hover:bg-gray-100 dark:hover:bg-white/5"> | |
<div className="flex gap-4"> | |
<div className="flex-shrink-0"> | |
<img | |
data-avatar | |
src="https://images.unsplash.com/photo-1500648767791-00dcc994a43e?ixlib=rb-1.2.1&ixid=eyJhcHBfaWQiOjEyMDd9&auto=format&fit=facearea&facepad=2&w=256&h=256&q=80" | |
alt="" | |
/> | |
</div> | |
<div className="w-full text-sm leading-6"> | |
<a href="#" className="font-semibold text-gray-900 dark:text-white"> | |
<span className="absolute inset-0 rounded-xl" aria-hidden="true"></span>Hector Adams | |
</a> | |
<div className="text-gray-500">VP, Marketing</div> | |
</div> | |
</div> | |
</li> | |
<li className="group/item relative flex items-center justify-between rounded-xl p-4 hover:bg-gray-100 dark:hover:bg-white/5"> | |
<div className="flex gap-4"> | |
<div className="flex-shrink-0"> | |
<img | |
data-avatar | |
src="https://images.unsplash.com/photo-1507003211169-0a1dd7228f2d?ixlib=rb-1.2.1&ixid=eyJhcHBfaWQiOjEyMDd9&auto=format&fit=facearea&facepad=2&w=256&h=256&q=80" | |
alt="" | |
/> | |
</div> | |
<div className="w-full text-sm leading-6"> | |
<a href="#" className="font-semibold text-gray-900 dark:text-white"> | |
<span className="absolute inset-0 rounded-xl" aria-hidden="true"></span>Blake Alexander | |
</a> | |
<div className="text-gray-500">Account Coordinator</div> | |
</div> | |
</div> | |
</li> | |
</ul> | |
</div> | |
} | |
</Example> | |
```svelte | |
<!-- [!code classes:**:data-avatar:rounded-full,**:data-avatar:size-12] --> | |
<ul class="**:data-avatar:size-12 **:data-avatar:rounded-full ..."> | |
{#each items as item} | |
<li> | |
<img src={item.src} data-avatar /> | |
<p>{item.name}</p> | |
</li> | |
{/each} | |
</ul> | |
``` | |
</Figure> | |
## Custom variants | |
### Using arbitrary variants | |
Just like [arbitrary values](/docs/adding-custom-styles#using-arbitrary-values) let you use custom values with your utility classes, arbitrary variants let you write custom selector variants directly in your HTML. | |
Arbitrary variants are just format strings that represent the selector, wrapped in square brackets. For example, this arbitrary variant changes the cursor to `grabbing` when the element has the `is-dragging` class: | |
<CodeExampleGroup | |
filenames={["HTML", "Generated CSS"]} | |
> | |
<CodeBlock | |
example={svelte` | |
<!-- [!code classes:[&.is-dragging]:cursor-grabbing] --> | |
<ul role="list"> | |
{#each items as item} | |
<li class="[&.is-dragging]:cursor-grabbing">{item}</li> | |
{/each} | |
</ul> | |
`} | |
/> | |
<CodeBlock | |
example={css` | |
.\[\&\.is-dragging\]\:cursor-grabbing { | |
&.is-dragging { | |
cursor: grabbing; | |
} | |
} | |
`} | |
/> | |
</CodeExampleGroup> | |
Arbitrary variants can be stacked with built-in variants or with each other, just like the rest of the variants in Tailwind: | |
<CodeExampleGroup | |
filenames={["HTML", "Generated CSS"]} | |
> | |
<CodeBlock | |
example={svelte` | |
<!-- [!code classes:[&.is-dragging]:active:cursor-grabbing] --> | |
<ul role="list"> | |
{#each items as item} | |
<li class="[&.is-dragging]:active:cursor-grabbing">{item}</li> | |
{/each} | |
</ul> | |
`} | |
/> | |
<CodeBlock | |
example={css` | |
.\[\&\.is-dragging\]\:active\:cursor-grabbing { | |
&.is-dragging { | |
&:active { | |
cursor: grabbing; | |
} | |
} | |
} | |
`} | |
/> | |
</CodeExampleGroup> | |
If you need spaces in your selector, you can use an underscore. For example, this arbitrary variant selects all `p` elements within the element where you've added the class: | |
<CodeExampleGroup | |
filenames={["HTML", "Generated CSS"]} | |
> | |
<CodeBlock | |
example={html` | |
<!-- [!code classes:[&_p]:mt-4] --> | |
<div class="[&_p]:mt-4"> | |
<p>Lorem ipsum...</p> | |
<ul> | |
<li> | |
<p>Lorem ipsum...</p> | |
</li> | |
<!-- ... --> | |
</ul> | |
</div> | |
`} | |
/> | |
<CodeBlock | |
example={css` | |
.\[\&_p\]\:mt-4 { | |
& p { | |
margin-top: calc(var(--spacing) * 4); | |
} | |
} | |
`} | |
/> | |
</CodeExampleGroup> | |
You can also use at-rules like `@media` or `@supports` in arbitrary variants: | |
<CodeExampleGroup | |
filenames={["HTML", "Generated CSS"]} | |
> | |
<CodeBlock | |
example={html` | |
<!-- [!code classes:[@supports(display:grid)]:grid] --> | |
<div class="flex [@supports(display:grid)]:grid"> | |
<!-- ... --> | |
</div> | |
`} | |
/> | |
<CodeBlock | |
example={css` | |
.\[\@supports\(display\:grid\)\]\:grid { | |
@supports (display:grid) { | |
display: grid; | |
} | |
} | |
`} | |
/> | |
</CodeExampleGroup> | |
With at-rule custom variants the `&` placeholder isn't necessary, just like when nesting with a preprocessor. | |
### Registering a custom variant | |
If you find yourself using the same arbitrary variant multiple times in your project, it might be worth creating a custom variant using the `@custom-variant` directive: | |
```css | |
@custom-variant theme-midnight (&:where([data-theme="midnight"] *)); | |
``` | |
Now you can use the `theme-midnight:<utility>` variant in your HTML: | |
```html | |
<!-- [!code classes:theme-midnight:bg-black] --> | |
<html data-theme="midnight"> | |
<button class="theme-midnight:bg-black ..."></button> | |
</html> | |
``` | |
Learn more about adding custom variants in the [adding custom variants documentation](/docs/adding-custom-styles#adding-custom-variants). | |
## Appendix | |
### Quick reference | |
A quick reference table of every single variant included in Tailwind by default. | |
{ | |
<div className="max-w-screen overflow-scroll"> | |
<table> | |
<thead> | |
<tr> | |
<th>Variant</th> | |
<th>CSS</th> | |
</tr> | |
</thead> | |
<tbody> | |
<tr> | |
<td> | |
<a href="#hover" className="whitespace-nowrap"> | |
hover | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@media (hover: hover) {"{ "} <span className="text-gray-400">&</span>:hover {" }"} | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#focus" className="whitespace-nowrap"> | |
focus | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:focus | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#focus-within" className="whitespace-nowrap"> | |
focus-within | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:focus-within | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#focus-visible" className="whitespace-nowrap"> | |
focus-visible | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:focus-visible | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#active" className="whitespace-nowrap"> | |
active | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:active | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#visited" className="whitespace-nowrap"> | |
visited | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:visited | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#target" className="whitespace-nowrap"> | |
target | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:target | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#styling-direct-children" className="whitespace-nowrap"> | |
* | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
:is(<span className="text-gray-400">&</span> {" > *"}) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#styling-all-descendants" className="whitespace-nowrap"> | |
** | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
:is(<span className="text-gray-400">&</span> {" *"}) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#has" className="whitespace-nowrap"> | |
has-[<span className="text-gray-400">...</span>] | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:has(<span className="text-gray-400">...</span>) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#styling-based-on-parent-state" className="whitespace-nowrap"> | |
group-[<span className="text-gray-400">...</span>] | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:is(:where(.group)<span className="text-gray-400">...</span> *) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#styling-based-on-sibling-state" className="whitespace-nowrap"> | |
peer-[<span className="text-gray-400">...</span>] | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:is(:where(.peer)<span className="text-gray-400">...</span> ~ *) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#implicit-groups" className="whitespace-nowrap"> | |
in-[<span className="text-gray-400">...</span>] | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
:where(<span className="text-gray-400">...</span>) <span className="text-gray-400">&</span> | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#not" className="whitespace-nowrap"> | |
not-[<span className="text-gray-400">...</span>] | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:not(<span className="text-gray-400">...</span>) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#styling-inert-elements" className="whitespace-nowrap"> | |
inert | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:is([inert], [inert] *) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#first" className="whitespace-nowrap"> | |
first | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:first-child | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#last" className="whitespace-nowrap"> | |
last | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:last-child | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#only" className="whitespace-nowrap"> | |
only | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:only-child | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#odd" className="whitespace-nowrap"> | |
odd | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:nth-child(odd) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#even" className="whitespace-nowrap"> | |
even | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:nth-child(even) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#first-of-type" className="whitespace-nowrap"> | |
first-of-type | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:first-of-type | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#last-of-type" className="whitespace-nowrap"> | |
last-of-type | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:last-of-type | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#only-of-type" className="whitespace-nowrap"> | |
only-of-type | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:only-of-type | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#nth" className="whitespace-nowrap"> | |
nth-[<span className="text-gray-400">...</span>] | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:nth-child(<span className="text-gray-400">...</span>) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#nth-last" className="whitespace-nowrap"> | |
nth-last-[<span className="text-gray-400">...</span>] | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:nth-last-child(<span className="text-gray-400">...</span>) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#nth-of-type" className="whitespace-nowrap"> | |
nth-of-type-[<span className="text-gray-400">...</span>] | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:nth-of-type(<span className="text-gray-400">...</span>) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#nth-last-of-type" className="whitespace-nowrap"> | |
nth-last-of-type-[<span className="text-gray-400">...</span>] | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:nth-last-of-type(<span className="text-gray-400">...</span>) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#empty" className="whitespace-nowrap"> | |
empty | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:empty | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#disabled" className="whitespace-nowrap"> | |
disabled | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:disabled | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#enabled" className="whitespace-nowrap"> | |
enabled | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:enabled | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#checked" className="whitespace-nowrap"> | |
checked | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:checked | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#indeterminate" className="whitespace-nowrap"> | |
indeterminate | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:indeterminate | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#default" className="whitespace-nowrap"> | |
default | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:default | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#optional" className="whitespace-nowrap"> | |
optional | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:optional | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#required" className="whitespace-nowrap"> | |
required | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:required | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#valid" className="whitespace-nowrap"> | |
valid | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:valid | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#invalid" className="whitespace-nowrap"> | |
invalid | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:invalid | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#user-valid" className="whitespace-nowrap"> | |
user-valid | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:user-valid | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#user-invalid" className="whitespace-nowrap"> | |
user-invalid | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:user-invalid | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#in-range" className="whitespace-nowrap"> | |
in-range | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:in-range | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#out-of-range" className="whitespace-nowrap"> | |
out-of-range | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:out-of-range | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#placeholder-shown" className="whitespace-nowrap"> | |
placeholder-shown | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:placeholder-shown | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#placeholder-shown" className="whitespace-nowrap"> | |
details-content | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:details-content | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#autofill" className="whitespace-nowrap"> | |
autofill | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:autofill | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#read-only" className="whitespace-nowrap"> | |
read-only | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:read-only | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#before-and-after" className="whitespace-nowrap"> | |
before | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>::before | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#before-and-after" className="whitespace-nowrap"> | |
after | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>::after | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#first-line-and-first-letter" className="whitespace-nowrap"> | |
first-letter | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>::first-letter | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#first-line-and-first-letter" className="whitespace-nowrap"> | |
first-line | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>::first-line | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#marker" className="whitespace-nowrap"> | |
marker | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>::marker, <span className="text-gray-400">&</span> *::marker | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#selection" className="whitespace-nowrap"> | |
selection | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>::selection | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#file" className="whitespace-nowrap"> | |
file | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>::file-selector-button | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#backdrop" className="whitespace-nowrap"> | |
backdrop | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>::backdrop | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#placeholder" className="whitespace-nowrap"> | |
placeholder | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>::placeholder | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
sm | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none">@media (width {">="} 40rem)</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
md | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none">@media (width {">="} 48rem)</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
lg | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none">@media (width {">="} 64rem)</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
xl | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none">@media (width {">="} 80rem)</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
2xl | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none">@media (width {">="} 96rem)</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
min-[<span className="text-gray-400">...</span>] | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@media (width {">= "} <span className="text-gray-400">...</span>) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
max-sm | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none">@media (width {"<"} 40rem)</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
max-md | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none">@media (width {"<"} 48rem)</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
max-lg | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none">@media (width {"<"} 64rem)</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
max-xl | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none">@media (width {"<"} 80rem)</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
max-2xl | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none">@media (width {"<"} 96rem)</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
max-[<span className="text-gray-400">...</span>] | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@media (width {"< "} <span className="text-gray-400">...</span>) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@3xs | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {">="} 16rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@2xs | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {">="} 18rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@xs | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {">="} 20rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@sm | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {">="} 24rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@md | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {">="} 28rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@lg | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {">="} 32rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@xl | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {">="} 36rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@2xl | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {">="} 42rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@3xl | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {">="} 48rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@4xl | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {">="} 56rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@5xl | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {">="} 64rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@6xl | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {">="} 72rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@7xl | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {">="} 80rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@min-[<span className="text-gray-400">...</span>] | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {">= "} <span className="text-gray-400">...</span>) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@max-3xs | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {"<"} 16rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@max-2xs | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {"<"} 18rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@max-xs | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {"<"} 20rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@max-sm | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {"<"} 24rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@max-md | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {"<"} 28rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@max-lg | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {"<"} 32rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@max-xl | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {"<"} 36rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@max-2xl | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {"<"} 42rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@max-3xl | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {"<"} 48rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@max-4xl | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {"<"} 56rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@max-5xl | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {"<"} 64rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@max-6xl | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {"<"} 72rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@max-7xl | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {"<"} 80rem) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#responsive-breakpoints" className="whitespace-nowrap"> | |
@max-[<span className="text-gray-400">...</span>] | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@container (width {"< "} <span className="text-gray-400">...</span>) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#prefers-color-scheme" className="whitespace-nowrap"> | |
dark | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@media (prefers-color-scheme: dark) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#prefers-reduced-motion" className="whitespace-nowrap"> | |
motion-safe | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@media (prefers-reduced-motion: no-preference) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#prefers-reduced-motion" className="whitespace-nowrap"> | |
motion-reduce | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@media (prefers-reduced-motion: reduce) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#prefers-contrast" className="whitespace-nowrap"> | |
contrast-more | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@media (prefers-contrast: more) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#prefers-contrast" className="whitespace-nowrap"> | |
contrast-less | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@media (prefers-contrast: less) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#forced-colors" className="whitespace-nowrap"> | |
forced-colors | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@media (forced-colors: active) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#inverted-colors" className="whitespace-nowrap"> | |
inverted-colors | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@media (inverted-colors: inverted) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#pointer-and-any-pointer" className="whitespace-nowrap"> | |
pointer-fine | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none">@media (pointer: fine)</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#pointer-and-any-pointer" className="whitespace-nowrap"> | |
pointer-coarse | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none">@media (pointer: coarse)</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#pointer-and-any-pointer" className="whitespace-nowrap"> | |
pointer-none | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none">@media (pointer: none)</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#pointer-and-any-pointer" className="whitespace-nowrap"> | |
any-pointer-fine | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none">@media (any-pointer: fine)</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#pointer-and-any-pointer" className="whitespace-nowrap"> | |
any-pointer-coarse | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none">@media (any-pointer: coarse)</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#pointer-and-any-pointer" className="whitespace-nowrap"> | |
any-pointer-none | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none">@media (any-pointer: none)</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#orientation" className="whitespace-nowrap"> | |
portrait | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@media (orientation: portrait) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#orientation" className="whitespace-nowrap"> | |
landscape | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@media (orientation: landscape) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#scripting" className="whitespace-nowrap"> | |
noscript | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none">@media (scripting: none)</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#print" className="whitespace-nowrap"> | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none">@media print</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#supports" className="whitespace-nowrap"> | |
supports-[<span className="text-gray-400">…</span>] | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
@supports (<span className="text-gray-400">…</span>) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#aria-states" className="whitespace-nowrap"> | |
aria-busy | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[aria-busy="true"] | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#aria-states" className="whitespace-nowrap"> | |
aria-checked | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[aria-checked="true"] | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#aria-states" className="whitespace-nowrap"> | |
aria-disabled | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[aria-disabled="true"] | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#aria-states" className="whitespace-nowrap"> | |
aria-expanded | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[aria-expanded="true"] | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#aria-states" className="whitespace-nowrap"> | |
aria-hidden | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[aria-hidden="true"] | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#aria-states" className="whitespace-nowrap"> | |
aria-pressed | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[aria-pressed="true"] | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#aria-states" className="whitespace-nowrap"> | |
aria-readonly | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[aria-readonly="true"] | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#aria-states" className="whitespace-nowrap"> | |
aria-required | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[aria-required="true"] | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#aria-states" className="whitespace-nowrap"> | |
aria-selected | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[aria-selected="true"] | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#aria-states" className="whitespace-nowrap"> | |
aria-[<span className="text-gray-400">…</span>] | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[aria-<span className="text-gray-400">…</span>] | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#data-attributes" className="whitespace-nowrap"> | |
data-[<span className="text-gray-400">…</span>] | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>[data-<span className="text-gray-400">…</span>] | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#rtl-support" className="whitespace-nowrap"> | |
rtl | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:where(:dir(rtl), [dir="rtl"], [dir="rtl"] *) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#rtl-support" className="whitespace-nowrap"> | |
ltr | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:where(:dir(ltr), [dir="ltr"], [dir="ltr"] *) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#openclosed-state" className="whitespace-nowrap"> | |
open | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none"> | |
<span className="text-gray-400">&</span>:is([open], :popover-open, :open) | |
</code> | |
</td> | |
</tr> | |
<tr> | |
<td> | |
<a href="#starting-style" className="whitespace-nowrap"> | |
starting | |
</a> | |
</td> | |
<td> | |
<code className="whitespace-nowrap before:content-none after:content-none">@starting-style</code> | |
</td> | |
</tr> | |
</tbody> | |
</table> | |
</div> | |
} | |
### Pseudo-class reference | |
This is a comprehensive list of examples for all the pseudo-class variants included in Tailwind to complement the [pseudo-classes documentation](/docs/hover-focus-and-other-states#pseudo-classes) at the beginning of this guide. | |
#### :hover | |
Style an element when the user hovers over it with the mouse cursor using the `hover` variant: | |
```html | |
<!-- [!code classes:hover:bg-white] --> | |
<div class="bg-black hover:bg-white ..."> | |
<!-- ... --> | |
</div> | |
``` | |
#### :focus | |
Style an element when it has focus using the `focus` variant: | |
```html | |
<!-- [!code classes:focus:border-blue-400] --> | |
<input class="border-gray-300 focus:border-blue-400 ..." /> | |
``` | |
#### :focus-within | |
Style an element when it or one of its descendants has focus using the `focus-within` variant: | |
```html | |
<!-- [!code classes:focus-within:shadow-lg] --> | |
<div class="focus-within:shadow-lg ..."> | |
<input type="text" /> | |
</div> | |
``` | |
#### :focus-visible | |
Style an element when it has been focused using the keyboard using the `focus-visible` variant: | |
```html | |
<!-- [!code classes:focus-visible:outline-2] --> | |
<button class="focus-visible:outline-2 ...">Submit</button> | |
``` | |
#### :active | |
Style an element when it is being pressed using the `active` variant: | |
```html | |
<!-- [!code classes:active:bg-blue-600] --> | |
<button class="bg-blue-500 active:bg-blue-600 ...">Submit</button> | |
``` | |
#### :visited | |
Style a link when it has already been visited using the `visited` variant: | |
```html | |
<!-- [!code classes:visited:text-purple-600] --> | |
<a href="https://seinfeldquotes.com" class="text-blue-600 visited:text-purple-600 ..."> Inspiration </a> | |
``` | |
#### :target | |
Style an element if its ID matches the current URL fragment using the `target` variant: | |
```html | |
<!-- [!code classes:target:shadow-lg] --> | |
<div id="about" class="target:shadow-lg ..."> | |
<!-- ... --> | |
</div> | |
``` | |
#### :first-child | |
Style an element if it's the first child using the `first` variant: | |
```svelte | |
<!-- [!code classes:first:pt-0] --> | |
<ul> | |
{#each people as person} | |
<li class="py-4 first:pt-0 ..."> | |
<!-- ... --> | |
</li> | |
{/each} | |
</ul> | |
``` | |
#### :last-child | |
Style an element if it's the last child using the `last` variant: | |
```svelte | |
<!-- [!code classes:last:pb-0] --> | |
<ul> | |
{#each people as person} | |
<li class="py-4 last:pb-0 ..."> | |
<!-- ... --> | |
</li> | |
{/each} | |
</ul> | |
``` | |
#### :only-child | |
Style an element if it's the only child using the `only` variant: | |
```svelte | |
<!-- [!code classes:only:py-0] --> | |
<ul> | |
{#each people as person} | |
<li class="py-4 only:py-0 ..."> | |
<!-- ... --> | |
</li> | |
{/each} | |
</ul> | |
``` | |
#### :nth-child(odd) | |
Style an element if it's an oddly numbered child using the `odd` variant: | |
```svelte | |
<!-- [!code classes:odd:bg-gray-100] --> | |
<table> | |
{#each people as person} | |
<tr class="bg-white odd:bg-gray-100 ..."> | |
<!-- ... --> | |
</tr> | |
{/each} | |
</table> | |
``` | |
#### :nth-child(even) | |
Style an element if it's an evenly numbered child using the `even` variant: | |
```svelte | |
<!-- [!code classes:even:bg-gray-100] --> | |
<table> | |
{#each people as person} | |
<tr class="bg-white even:bg-gray-100 ..."> | |
<!-- ... --> | |
</tr> | |
{/each} | |
</table> | |
``` | |
#### :first-of-type | |
Style an element if it's the first child of its type using the `first-of-type` variant: | |
```svelte | |
<!-- [!code classes:first-of-type:ml-6] --> | |
<nav> | |
<img src="/logo.svg" alt="Vandelay Industries" /> | |
{#each links as link} | |
<a href="#" class="ml-2 first-of-type:ml-6 ..."> | |
<!-- ... --> | |
</a> | |
{/each} | |
</nav> | |
``` | |
#### :last-of-type | |
Style an element if it's the last child of its type using the `last-of-type` variant: | |
```svelte | |
<!-- [!code classes:last-of-type:mr-6] --> | |
<nav> | |
<img src="/logo.svg" alt="Vandelay Industries" /> | |
{#each links as link} | |
<a href="#" class="mr-2 last-of-type:mr-6 ..."> | |
<!-- ... --> | |
</a> | |
{/each} | |
<button>More</button> | |
</nav> | |
``` | |
#### :only-of-type | |
Style an element if it's the only child of its type using the `only-of-type` variant: | |
```svelte | |
<!-- [!code classes:only-of-type:mx-6] --> | |
<nav> | |
<img src="/logo.svg" alt="Vandelay Industries" /> | |
{#each links as link} | |
<a href="#" class="mx-2 only-of-type:mx-6 ..."> | |
<!-- ... --> | |
</a> | |
{/each} | |
<button>More</button> | |
</nav> | |
``` | |
#### :nth-child() | |
Style an element at a specific position using the `nth` variant: | |
```svelte | |
<!-- [!code classes:nth-3:mx-6,nth-[3n+1]:mx-7] --> | |
<nav> | |
<img src="/logo.svg" alt="Vandelay Industries" /> | |
{#each links as link} | |
<a href="#" class="mx-2 nth-3:mx-6 nth-[3n+1]:mx-7 ..."> | |
<!-- ... --> | |
</a> | |
{/each} | |
<button>More</button> | |
</nav> | |
``` | |
#### :nth-last-child() | |
Style an element at a specific position from the end using the `nth-last` variant: | |
```svelte | |
<!-- [!code classes:nth-last-3:mx-6,nth-last-[3n+1]:mx-7] --> | |
<nav> | |
<img src="/logo.svg" alt="Vandelay Industries" /> | |
{#each links as link} | |
<a href="#" class="mx-2 nth-last-3:mx-6 nth-last-[3n+1]:mx-7 ..."> | |
<!-- ... --> | |
</a> | |
{/each} | |
<button>More</button> | |
</nav> | |
``` | |
#### :nth-of-type() | |
Style an element at a specific position, of the same type using the `nth-of-type` variant: | |
```svelte | |
<!-- [!code classes:nth-of-type-3:mx-6,nth-of-type-[3n+1]:mx-7] --> | |
<nav> | |
<img src="/logo.svg" alt="Vandelay Industries" /> | |
{#each links as link} | |
<a href="#" class="mx-2 nth-of-type-3:mx-6 nth-of-type-[3n+1]:mx-7 ..."> | |
<!-- ... --> | |
</a> | |
{/each} | |
<button>More</button> | |
</nav> | |
``` | |
#### :nth-last-of-type() | |
Style an element at a specific position from the end, of the same type using the `nth-last-of-type` variant: | |
```svelte | |
<!-- [!code classes:nth-last-of-type-3:mx-6,nth-last-of-type-[3n+1]:mx-7] --> | |
<nav> | |
<img src="/logo.svg" alt="Vandelay Industries" /> | |
{#each links as link} | |
<a href="#" class="mx-2 nth-last-of-type-3:mx-6 nth-last-of-type-[3n+1]:mx-7 ..."> | |
<!-- ... --> | |
</a> | |
{/each} | |
<button>More</button> | |
</nav> | |
``` | |
#### :empty | |
Style an element if it has no content using the `empty` variant: | |
```svelte | |
<!-- [!code classes:empty:hidden] --> | |
<ul> | |
{#each people as person} | |
<li class="empty:hidden ...">{person.hobby}</li> | |
{/each} | |
</ul> | |
``` | |
#### :disabled | |
Style an input when it's disabled using the `disabled` variant: | |
```html | |
<!-- [!code classes:disabled:opacity-75] --> | |
<input class="disabled:opacity-75 ..." /> | |
``` | |
#### :enabled | |
Style an input when it's enabled using the `enabled` variant, most helpful when you only want to apply another style when an element is not disabled: | |
```html | |
<!-- [!code classes:enabled:hover:border-gray-400] --> | |
<input class="enabled:hover:border-gray-400 disabled:opacity-75 ..." /> | |
``` | |
#### :checked | |
Style a checkbox or radio button when it's checked using the `checked` variant: | |
```html | |
<!-- [!code classes:checked:bg-blue-500] --> | |
<input type="checkbox" class="appearance-none checked:bg-blue-500 ..." /> | |
``` | |
#### :indeterminate | |
Style a checkbox or radio button in an indeterminate state using the `indeterminate` variant: | |
```html | |
<!-- [!code classes:indeterminate:bg-gray-300] --> | |
<input type="checkbox" class="appearance-none indeterminate:bg-gray-300 ..." /> | |
``` | |
#### :default | |
Style an option, checkbox or radio button that was the default value when the page initially loaded using the `default` variant: | |
```html | |
<!-- [!code classes:default:outline-2] --> | |
<input type="checkbox" class="default:outline-2 ..." /> | |
``` | |
#### :optional | |
Style an input when it's optional using the `optional` variant: | |
```html | |
<!-- [!code classes:optional:border-red-500] --> | |
<input class="border optional:border-red-500 ..." /> | |
``` | |
#### :required | |
Style an input when it's required using the `required` variant: | |
```html | |
<!-- [!code classes:required:border-red-500] --> | |
<input required class="border required:border-red-500 ..." /> | |
``` | |
#### :valid | |
Style an input when it's valid using the `valid` variant: | |
```html | |
<!-- [!code classes:valid:border-green-500] --> | |
<input required class="border valid:border-green-500 ..." /> | |
``` | |
#### :invalid | |
Style an input when it's invalid using the `invalid` variant: | |
```html | |
<!-- [!code classes:invalid:border-red-500] --> | |
<input required class="border invalid:border-red-500 ..." /> | |
``` | |
#### :user-valid | |
Style an input when it's valid and the user has interacted with it, using the `user-valid` variant: | |
```html | |
<!-- [!code classes:user-valid:border-green-500] --> | |
<input required class="border user-valid:border-green-500" /> | |
``` | |
#### :user-invalid | |
Style an input when it's invalid and the user has interacted with it, using the `user-invalid` variant: | |
```html | |
<!-- [!code classes:user-invalid:border-red-500] --> | |
<input required class="border user-invalid:border-red-500" /> | |
``` | |
#### :in-range | |
Style an input when its value is within a specified range limit using the `in-range` variant: | |
```html | |
<!-- [!code classes:in-range:border-green-500] --> | |
<input min="1" max="5" class="in-range:border-green-500 ..." /> | |
``` | |
#### :out-of-range | |
Style an input when its value is outside of a specified range limit using the `out-of-range` variant: | |
```html | |
<!-- [!code classes:out-of-range:border-red-500] --> | |
<input min="1" max="5" class="out-of-range:border-red-500 ..." /> | |
``` | |
#### :placeholder-shown | |
Style an input when the placeholder is shown using the `placeholder-shown` variant: | |
```html | |
<!-- [!code classes:placeholder-shown:border-gray-500] --> | |
<input class="placeholder-shown:border-gray-500 ..." placeholder="[email protected]" /> | |
``` | |
#### :details-content | |
Style the content of a `<details>` element using the `details-content` variant: | |
```html | |
<!-- [!code classes:details-content:bg-gray-100] --> | |
<details class="details-content:bg-gray-100 ..."> | |
<summary>Details</summary> | |
This is a secret. | |
</details> | |
``` | |
#### :autofill | |
Style an input when it has been autofilled by the browser using the `autofill` variant: | |
```html | |
<!-- [!code classes:autofill:bg-yellow-200] --> | |
<input class="autofill:bg-yellow-200 ..." /> | |
``` | |
#### :read-only | |
Style an input when it is read-only using the `read-only` variant: | |
```html | |
<!-- [!code classes:read-only:bg-gray-100] --> | |
<input class="read-only:bg-gray-100 ..." /> | |
``` | |
--- | |
File: /src/docs/hyphens.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "hyphens"; | |
export const description = "Utilities for controlling how words should be hyphenated."; | |
<ApiTable | |
rows={[ | |
["hyphens-none", "hyphens: none;"], | |
["hyphens-manual", "hyphens: manual;"], | |
["hyphens-auto", "hyphens: auto;"], | |
]} | |
/> | |
## Examples | |
### Preventing hyphenation | |
Use the `hyphens-none` utility to prevent words from being hyphenated even if the line break suggestion `­` is used: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<p className="mx-auto max-w-xs border-x border-x-pink-400/30 py-8 break-normal hyphens-none text-gray-900 dark:text-gray-200"> | |
Officially recognized by the Duden dictionary as the longest word in German,{" "} | |
<span className="font-bold" lang="de"> | |
Kraftfahrzeug­haftpflichtversicherung | |
</span>{" "} | |
is a 36 letter word for motor vehicle liability insurance. | |
</p> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:hyphens-none] --> | |
<!-- [!code word:­] --> | |
<!-- prettier-ignore --> | |
<p class="hyphens-none"> | |
... Kraftfahrzeug­haftpflichtversicherung is a ... | |
</p> | |
``` | |
</Figure> | |
### Manual hyphenation | |
Use the `hyphens-manual` utility to only set hyphenation points where the line break suggestion `­` is used: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<p className="mx-auto max-w-xs border-x border-x-pink-400/30 py-8 break-normal hyphens-manual text-gray-900 dark:text-gray-200"> | |
Officially recognized by the Duden dictionary as the longest word in German,{" "} | |
<span className="font-bold" lang="de"> | |
Kraftfahrzeug­haftpflichtversicherung | |
</span>{" "} | |
is a 36 letter word for motor vehicle liability insurance. | |
</p> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:hyphens-manual] --> | |
<!-- [!code word:­] --> | |
<!-- prettier-ignore --> | |
<p class="hyphens-manual"> | |
... Kraftfahrzeug­haftpflichtversicherung is a ... | |
</p> | |
``` | |
</Figure> | |
This is the default browser behavior. | |
### Automatic hyphenation | |
Use the `hyphens-auto` utility to allow the browser to automatically choose hyphenation points based on the language: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<p className="mx-auto max-w-xs border-x border-x-pink-400/30 py-8 break-normal hyphens-auto text-gray-900 dark:text-gray-200"> | |
Officially recognized by the Duden dictionary as the longest word in German,{" "} | |
<span className="font-bold" lang="de"> | |
Kraftfahrzeughaftpflichtversicherung | |
</span>{" "} | |
is a 36 letter word for motor vehicle liability insurance. | |
</p> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:hyphens-auto] --> | |
<!-- [!code word:lang="de"] --> | |
<!-- prettier-ignore --> | |
<p class="hyphens-auto" lang="de"> | |
... Kraftfahrzeughaftpflichtversicherung is a ... | |
</p> | |
``` | |
</Figure> | |
The line break suggestion `­` will be preferred over automatic hyphenation points. | |
### Responsive design | |
<ResponsiveDesign element="p" property="hyphens" defaultClass="hyphens-none" featuredClass="hyphens-auto" /> | |
--- | |
File: /src/docs/isolation.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "isolation"; | |
export const description = | |
"Utilities for controlling whether an element should explicitly create a new stacking context."; | |
<ApiTable | |
rows={[ | |
["isolate", "isolation: isolate;"], | |
["isolation-auto", "isolation: auto;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use the `isolate` and `isolation-auto` utilities to control whether an element should explicitly create a new stacking context: | |
```html | |
<!-- [!code classes:isolate] --> | |
<div class="isolate ..."> | |
<!-- ... --> | |
</div> | |
``` | |
### Responsive design | |
<ResponsiveDesign property="isolation" defaultClass="isolate" featuredClass="isolation-auto" /> | |
--- | |
File: /src/docs/justify-content.mdx | |
--- | |
import { CodeExampleStack } from "@/components/code-example"; | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "justify-content"; | |
export const description = | |
"Utilities for controlling how flex and grid items are positioned along a container's main axis."; | |
<ApiTable | |
rows={[ | |
["justify-start", "justify-content: flex-start;"], | |
["justify-end", "justify-content: flex-end;"], | |
["justify-end-safe", "justify-content: safe flex-end;"], | |
["justify-center", "justify-content: center;"], | |
["justify-center-safe", "justify-content: safe center;"], | |
["justify-between", "justify-content: space-between;"], | |
["justify-around", "justify-content: space-around;"], | |
["justify-evenly", "justify-content: space-evenly;"], | |
["justify-stretch", "justify-content: stretch;"], | |
["justify-baseline", "justify-content: baseline;"], | |
["justify-normal", "justify-content: normal;"], | |
]} | |
/> | |
## Examples | |
### Start | |
Use the `justify-start` utility to justify items against the start of the container's main axis: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex justify-start space-x-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-fuchsia-500">01</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-fuchsia-500">02</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-fuchsia-500">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:justify-start] --> | |
<div class="flex justify-start ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Center | |
Use the `justify-center` or `justify-center-safe` utilities to justify items along the center of the container's main axis: | |
<Figure hint="Resize the container to see the alignment behavior"> | |
<Example resizable> | |
{ | |
<div className="grid grid-cols-1 gap-8"> | |
<div> | |
<p className="text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">justify-center</p> | |
<div className="mt-4 grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex justify-center space-x-4 overflow-hidden rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-blue-500">01</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-blue-500">02</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-blue-500">03</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-blue-500">04</div> | |
</div> | |
</div> | |
</div> | |
<div> | |
<p className="text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
justify-center-safe | |
</p> | |
<div className="mt-4 grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex justify-center-safe space-x-4 overflow-hidden rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-indigo-500">01</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-indigo-500">02</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-indigo-500">03</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-indigo-500">04</div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
<CodeExampleStack> | |
```html | |
<!-- [!code filename:justify-center] --> | |
<!-- [!code classes:justify-center] --> | |
<div class="flex justify-center ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
<div>04</div> | |
</div> | |
``` | |
```html | |
<!-- [!code filename:justify-center-safe] --> | |
<!-- [!code classes:justify-center-safe] --> | |
<div class="flex justify-center-safe ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
<div>04</div> | |
</div> | |
``` | |
</CodeExampleStack> | |
</Figure> | |
When there is not enough space available, the `justify-center-safe` utility will align items to the start of the container instead of the center. | |
### End | |
Use the `justify-end` or `justify-end-safe` utilities to justify items against the end of the container's main axis: | |
<Figure hint="Resize the container to see the alignment behavior"> | |
<Example resizable> | |
{ | |
<div className="grid grid-cols-1 gap-8"> | |
<div> | |
<p className="text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">justify-end</p> | |
<div className="mt-4 grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex justify-end space-x-4 overflow-hidden rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-pink-500">01</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-pink-500">02</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-pink-500">03</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-pink-500">04</div> | |
</div> | |
</div> | |
</div> | |
<div> | |
<p className="text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">justify-end-safe</p> | |
<div className="mt-4 grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex justify-end-safe space-x-4 overflow-hidden rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-fuchsia-500">01</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-fuchsia-500">02</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-fuchsia-500">03</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-fuchsia-500">04</div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
<CodeExampleStack> | |
```html | |
<!-- [!code filename:justify-end] --> | |
<!-- [!code classes:justify-end] --> | |
<div class="flex justify-end ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
<div>03</div> | |
</div> | |
``` | |
```html | |
<!-- [!code filename:justify-end-safe] --> | |
<!-- [!code classes:justify-end-safe] --> | |
<div class="flex justify-end-safe ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
<div>03</div> | |
</div> | |
``` | |
</CodeExampleStack> | |
</Figure> | |
When there is not enough space available, the `justify-end-safe` utility will align items to the start of the container instead of the end. | |
### Space between | |
Use the `justify-between` utility to justify items along the container's main axis such that there is an equal amount of space between each item: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex justify-between space-x-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-cyan-500">01</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-cyan-500">02</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-cyan-500">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:justify-between] --> | |
<div class="flex justify-between ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Space around | |
Use the `justify-around` utility to justify items along the container's main axis such that there is an equal amount of space on each side of each item: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex justify-around space-x-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-purple-500">01</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-purple-500">02</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-purple-500">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:justify-around] --> | |
<div class="flex justify-around ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Space evenly | |
Use the `justify-evenly` utility to justify items along the container's main axis such that there is an equal amount of space around each item, but also accounting for the doubling of space you would normally see between each item when using `justify-around`: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex justify-evenly space-x-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-indigo-500">01</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-indigo-500">02</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-indigo-500">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:justify-evenly] --> | |
<div class="flex justify-evenly ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Stretch | |
Use the `justify-stretch` utility to allow content items to fill the available space along the container's main axis: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 grid grid-flow-col justify-stretch gap-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex h-14 items-center justify-center rounded-lg bg-fuchsia-500">01</div> | |
<div className="flex h-14 items-center justify-center rounded-lg bg-fuchsia-500">02</div> | |
<div className="flex h-14 items-center justify-center rounded-lg bg-fuchsia-500">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:justify-stretch] --> | |
<div class="flex justify-stretch ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Normal | |
Use the `justify-normal` utility to pack content items in their default position as if no `justify-content` value was set: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex justify-normal space-x-4 rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-blue-500">01</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-blue-500">02</div> | |
<div className="flex size-14 shrink-0 items-center justify-center rounded-lg bg-blue-500">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:justify-normal] --> | |
<div class="flex justify-normal ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="justify-content" defaultClass="flex justify-start" featuredClass="justify-between" /> | |
--- | |
File: /src/docs/justify-items.mdx | |
--- | |
import { CodeExampleStack } from "@/components/code-example"; | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "justify-items"; | |
export const description = "Utilities for controlling how grid items are aligned along their inline axis."; | |
<ApiTable | |
rows={[ | |
["justify-items-start", "justify-items: start;"], | |
["justify-items-end", "justify-items: end;"], | |
["justify-items-end-safe", "justify-items: safe end;"], | |
["justify-items-center", "justify-items: center;"], | |
["justify-items-center-safe", "justify-items: safe center;"], | |
["justify-items-stretch", "justify-items: stretch;"], | |
["justify-items-normal", "justify-items: normal;"], | |
]} | |
/> | |
## Examples | |
### Start | |
Use the `justify-items-start` utility to justify grid items against the start of their inline axis: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-3 gap-4 font-mono text-sm leading-6 font-bold text-white"> | |
<div className="grid rounded-lg"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex size-14 items-center justify-center justify-self-start rounded-lg bg-sky-500"> | |
01 | |
</div> | |
</div> | |
<div className="grid rounded-lg"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex size-14 items-center justify-center justify-self-start rounded-lg bg-sky-500"> | |
02 | |
</div> | |
</div> | |
<div className="grid rounded-lg"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex size-14 items-center justify-center justify-self-start rounded-lg bg-sky-500"> | |
03 | |
</div> | |
</div> | |
<div className="grid rounded-lg"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex size-14 items-center justify-center justify-self-start rounded-lg bg-sky-500"> | |
04 | |
</div> | |
</div> | |
<div className="grid rounded-lg"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex size-14 items-center justify-center justify-self-start rounded-lg bg-sky-500"> | |
05 | |
</div> | |
</div> | |
<div className="grid rounded-lg"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 flex size-14 items-center justify-center justify-self-start rounded-lg bg-sky-500"> | |
06 | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:justify-items-start] --> | |
<div class="grid justify-items-start ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
<div>04</div> | |
<div>05</div> | |
<div>06</div> | |
</div> | |
``` | |
</Figure> | |
### End | |
Use the `justify-items-end` or `justify-items-end-safe` utilities to justify grid items against the end of their inline axis: | |
<Figure hint="Resize the container to see the alignment behavior"> | |
<Example resizable> | |
{ | |
<div className="grid grid-cols-1 gap-8"> | |
<div> | |
<p className="text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">justify-items-end</p> | |
<div className="mt-4 grid auto-rows-fr grid-cols-3 justify-items-stretch gap-10 text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="grid grid-cols-1 justify-items-end"> | |
<Stripes border className="col-start-1 row-start-1 justify-self-stretch rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 rounded-lg bg-blue-500 p-4">01</div> | |
</div> | |
<div className="grid grid-cols-1 justify-items-end"> | |
<Stripes border className="col-start-1 row-start-1 justify-self-stretch rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 rounded-lg bg-blue-500 p-4">02</div> | |
</div> | |
<div className="grid grid-cols-1 justify-items-end"> | |
<Stripes border className="col-start-1 row-start-1 justify-self-stretch rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 rounded-lg bg-blue-500 p-4">03</div> | |
</div> | |
</div> | |
</div> | |
<div> | |
<p className="text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
justify-items-end-safe | |
</p> | |
<div className="mt-4 grid auto-rows-fr grid-cols-3 justify-items-stretch gap-10 text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="grid grid-cols-1 justify-items-end-safe"> | |
<Stripes border className="col-start-1 row-start-1 justify-self-stretch rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 rounded-lg bg-purple-500 p-4">01</div> | |
</div> | |
<div className="grid grid-cols-1 justify-items-end-safe"> | |
<Stripes border className="col-start-1 row-start-1 justify-self-stretch rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 rounded-lg bg-purple-500 p-4">02</div> | |
</div> | |
<div className="grid grid-cols-1 justify-items-end-safe"> | |
<Stripes border className="col-start-1 row-start-1 justify-self-stretch rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 rounded-lg bg-purple-500 p-4">03</div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
<CodeExampleStack> | |
```html | |
<!-- [!code filename:justify-items-end] --> | |
<!-- [!code classes:justify-items-end] --> | |
<div class="grid grid-flow-col justify-items-end ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
```html | |
<!-- [!code filename:justify-items-end-safe] --> | |
<!-- [!code classes:justify-items-end-safe] --> | |
<div class="grid grid-flow-col justify-items-end-safe ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</ CodeExampleStack> | |
</Figure> | |
When there is not enough space available, the `justify-items-end-safe` utility will align items to the start of the container instead of the end. | |
### Center | |
Use the `justify-items-center` or `justify-items-center-safe` utilities to justify grid items against the end of their inline axis: | |
<Figure hint="Resize the container to see the alignment behavior"> | |
<Example resizable> | |
{ | |
<div className="grid grid-cols-1 gap-8"> | |
<div> | |
<p className="text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
justify-items-center | |
</p> | |
<div className="mt-4 grid auto-rows-fr grid-cols-3 justify-items-stretch gap-10 text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="grid grid-cols-1 justify-items-center"> | |
<Stripes border className="col-start-1 row-start-1 justify-self-stretch rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 rounded-lg bg-indigo-500 p-4">01</div> | |
</div> | |
<div className="grid grid-cols-1 justify-items-center"> | |
<Stripes border className="col-start-1 row-start-1 justify-self-stretch rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 rounded-lg bg-indigo-500 p-4">02</div> | |
</div> | |
<div className="grid grid-cols-1 justify-items-center"> | |
<Stripes border className="col-start-1 row-start-1 justify-self-stretch rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 rounded-lg bg-indigo-500 p-4">03</div> | |
</div> | |
</div> | |
</div> | |
<div> | |
<p className="text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
justify-items-center-safe | |
</p> | |
<div className="mt-4 grid auto-rows-fr grid-cols-3 justify-items-stretch gap-10 text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="grid grid-cols-1 justify-items-center-safe"> | |
<Stripes border className="col-start-1 row-start-1 justify-self-stretch rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 rounded-lg bg-fuchsia-500 p-4">01</div> | |
</div> | |
<div className="grid grid-cols-1 justify-items-center-safe"> | |
<Stripes border className="col-start-1 row-start-1 justify-self-stretch rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 rounded-lg bg-fuchsia-500 p-4">02</div> | |
</div> | |
<div className="grid grid-cols-1 justify-items-center-safe"> | |
<Stripes border className="col-start-1 row-start-1 justify-self-stretch rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 rounded-lg bg-fuchsia-500 p-4">03</div> | |
</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
<CodeExampleStack> | |
```html | |
<!-- [!code filename:justify-items-center] --> | |
<!-- [!code classes:justify-items-center] --> | |
<div class="grid grid-flow-col justify-items-center ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
```html | |
<!-- [!code filename:justify-items-center-safe] --> | |
<!-- [!code classes:justify-items-center-safe] --> | |
<div class="grid grid-flow-col justify-items-center-safe ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</CodeExampleStack> | |
</Figure> | |
When there is not enough space available, the `justify-items-center-safe` utility will align items to the start of the container instead of the center. | |
### Stretch | |
Use the `justify-items-stretch` utility to stretch items along their inline axis: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 grid grid-cols-3 justify-items-stretch gap-4 font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex h-14 items-center justify-center rounded-lg bg-blue-500">01</div> | |
<div className="flex h-14 items-center justify-center rounded-lg bg-blue-500">02</div> | |
<div className="flex h-14 items-center justify-center rounded-lg bg-blue-500">03</div> | |
<div className="flex h-14 items-center justify-center rounded-lg bg-blue-500">04</div> | |
<div className="flex h-14 items-center justify-center rounded-lg bg-blue-500">05</div> | |
<div className="flex h-14 items-center justify-center rounded-lg bg-blue-500">06</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:justify-items-stretch] --> | |
<div class="grid justify-items-stretch ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
<div>04</div> | |
<div>05</div> | |
<div>06</div> | |
</div> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign | |
property="justify-items" | |
defaultClass="grid justify-items-start" | |
featuredClass="justify-items-center" | |
/> | |
--- | |
File: /src/docs/justify-self.mdx | |
--- | |
import { CodeExampleStack } from "@/components/code-example"; | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "justify-self"; | |
export const description = "Utilities for controlling how an individual grid item is aligned along its inline axis."; | |
<ApiTable | |
rows={[ | |
["justify-self-auto", "justify-self: auto;"], | |
["justify-self-start", "justify-self: start;"], | |
["justify-self-center", "justify-self: center;"], | |
["justify-self-center-safe", "justify-self: safe center;"], | |
["justify-self-end", "justify-self: end;"], | |
["justify-self-end-safe", "justify-self: safe end;"], | |
["justify-self-stretch", "justify-self: stretch;"], | |
]} | |
/> | |
## Examples | |
### Auto | |
Use the `justify-self-auto` utility to align an item based on the value of the grid's `justify-items` property: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 grid auto-rows-fr grid-cols-3 justify-items-stretch gap-4 text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="rounded-lg bg-purple-300 p-4 dark:bg-purple-800 dark:text-purple-400">01</div> | |
<div className="justify-self-auto rounded-lg bg-purple-500 p-4">02</div> | |
<div className="rounded-lg bg-purple-300 p-4 dark:bg-purple-800 dark:text-purple-400">03</div> | |
<div className="rounded-lg bg-purple-300 p-4 dark:bg-purple-800 dark:text-purple-400">04</div> | |
<div className="rounded-lg bg-purple-300 p-4 dark:bg-purple-800 dark:text-purple-400">05</div> | |
<div className="rounded-lg bg-purple-300 p-4 dark:bg-purple-800 dark:text-purple-400">06</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:justify-self-auto] --> | |
<div class="grid justify-items-stretch ..."> | |
<!-- ... --> | |
<div class="justify-self-auto ...">02</div> | |
<!-- ... --> | |
</div> | |
``` | |
</Figure> | |
### Start | |
Use the `justify-self-start` utility to align a grid item to the start of its inline axis: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid auto-rows-fr grid-cols-3 justify-items-stretch gap-4 text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="rounded-lg bg-pink-300 p-4 dark:bg-pink-800 dark:text-pink-400">01</div> | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 justify-self-start rounded-lg bg-pink-500 p-4">02</div> | |
</div> | |
<div className="rounded-lg bg-pink-300 p-4 dark:bg-pink-800 dark:text-pink-400">03</div> | |
<div className="rounded-lg bg-pink-300 p-4 dark:bg-pink-800 dark:text-pink-400">04</div> | |
<div className="rounded-lg bg-pink-300 p-4 dark:bg-pink-800 dark:text-pink-400">05</div> | |
<div className="rounded-lg bg-pink-300 p-4 dark:bg-pink-800 dark:text-pink-400">06</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:justify-self-start] --> | |
<div class="grid justify-items-stretch ..."> | |
<!-- ... --> | |
<div class="justify-self-start ...">02</div> | |
<!-- ... --> | |
</div> | |
``` | |
</Figure> | |
### Center | |
Use the `justify-self-center` or `justify-self-center-safe` utilities to align a grid item along the center of its inline axis: | |
<Figure hint="Resize the container to see the alignment behavior"> | |
<Example resizable> | |
{ | |
<div className="grid grid-cols-1 gap-8"> | |
<div> | |
<p className="text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">justify-self-center</p> | |
<div className="mt-4 grid auto-rows-fr grid-cols-3 justify-items-stretch gap-10 text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="rounded-lg bg-indigo-300 p-4 dark:bg-indigo-800 dark:text-indigo-500">01</div> | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 justify-self-center rounded-lg bg-indigo-500 p-4">02</div> | |
</div> | |
<div className="rounded-lg bg-indigo-300 p-4 dark:bg-indigo-800 dark:text-indigo-500">03</div> | |
</div> | |
</div> | |
<div> | |
<p className="text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
justify-self-center-safe | |
</p> | |
<div className="mt-4 grid auto-rows-fr grid-cols-3 justify-items-stretch gap-10 text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="rounded-lg bg-sky-300 p-4 dark:bg-sky-800 dark:text-sky-500">01</div> | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 justify-self-center-safe rounded-lg bg-sky-500 p-4">02</div> | |
</div> | |
<div className="rounded-lg bg-sky-300 p-4 dark:bg-sky-800 dark:text-sky-500">03</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
<CodeExampleStack> | |
```html | |
<!-- [!code filename:justify-self-center] --> | |
<!-- [!code classes:justify-self-center] --> | |
<div class="grid justify-items-stretch ..."> | |
<!-- ... --> | |
<div class="justify-self-center ...">02</div> | |
<!-- ... --> | |
</div> | |
``` | |
```html | |
<!-- [!code filename:justify-self-center-safe] --> | |
<!-- [!code classes:justify-self-center-safe] --> | |
<div class="grid justify-items-stretch ..."> | |
<!-- ... --> | |
<div class="justify-self-center-safe ...">02</div> | |
<!-- ... --> | |
</div> | |
``` | |
</CodeExampleStack> | |
</Figure> | |
When there is not enough space available, the `justify-self-center-safe` utility will align the item to the start of the container instead of the end. | |
### End | |
Use the `justify-self-end` or `justify-self-end-safe` utilities to align a grid item to the end of its inline axis: | |
<Figure hint="Resize the container to see the alignment behavior"> | |
<Example resizable> | |
{ | |
<div className="grid grid-cols-1 gap-8"> | |
<div> | |
<p className="text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">justify-self-end</p> | |
<div className="mt-4 grid auto-rows-fr grid-cols-3 justify-items-stretch gap-10 text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="rounded-lg bg-blue-300 p-4 dark:bg-blue-800 dark:text-blue-500">01</div> | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 justify-self-end rounded-lg bg-blue-500 p-4">02</div> | |
</div> | |
<div className="rounded-lg bg-blue-300 p-4 dark:bg-blue-800 dark:text-blue-500">03</div> | |
</div> | |
</div> | |
<div> | |
<p className="text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
justify-self-end-safe | |
</p> | |
<div className="mt-4 grid auto-rows-fr grid-cols-3 justify-items-stretch gap-10 text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="rounded-lg bg-purple-300 p-4 dark:bg-purple-800 dark:text-purple-500">01</div> | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 justify-self-end-safe rounded-lg bg-purple-500 p-4">02</div> | |
</div> | |
<div className="rounded-lg bg-purple-300 p-4 dark:bg-purple-800 dark:text-purple-500">03</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
<CodeExampleStack> | |
```html | |
<!-- [!code filename:justify-self-end] --> | |
<!-- [!code classes:justify-self-end] --> | |
<div class="grid justify-items-stretch ..."> | |
<!-- ... --> | |
<div class="justify-self-end ...">02</div> | |
<!-- ... --> | |
</div> | |
``` | |
```html | |
<!-- [!code filename:justify-self-end-safe] --> | |
<!-- [!code classes:justify-self-end-safe] --> | |
<div class="grid justify-items-stretch ..."> | |
<!-- ... --> | |
<div class="justify-self-end-safe ...">02</div> | |
<!-- ... --> | |
</div> | |
``` | |
</CodeExampleStack> | |
</Figure> | |
When there is not enough space available, the `justify-self-end-safe` utility will align the item to the start of the container instead of the end. | |
### Stretch | |
Use the `justify-self-stretch` utility to stretch a grid item to fill the grid area on its inline axis: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid auto-rows-fr grid-cols-3 justify-items-stretch gap-4 text-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 rounded-lg bg-fuchsia-300 p-4 dark:bg-fuchsia-800 dark:text-fuchsia-400"> | |
01 | |
</div> | |
</div> | |
<div className="bg-stripes-fuchsia grid w-full justify-self-stretch rounded-lg"> | |
<div className="justify-self-stretch rounded-lg bg-fuchsia-500 p-4">02</div> | |
</div> | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 rounded-lg bg-fuchsia-300 p-4 dark:bg-fuchsia-800 dark:text-fuchsia-400"> | |
03 | |
</div> | |
</div> | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 rounded-lg bg-fuchsia-300 p-4 dark:bg-fuchsia-800 dark:text-fuchsia-400"> | |
04 | |
</div> | |
</div> | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 rounded-lg bg-fuchsia-300 p-4 dark:bg-fuchsia-800 dark:text-fuchsia-400"> | |
05 | |
</div> | |
</div> | |
<div className="grid grid-cols-1"> | |
<Stripes border className="col-start-1 row-start-1 rounded-lg" /> | |
<div className="col-start-1 row-start-1 size-14 rounded-lg bg-fuchsia-300 p-4 dark:bg-fuchsia-800 dark:text-fuchsia-400"> | |
06 | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:justify-self-stretch] --> | |
<div class="grid justify-items-start ..."> | |
<!-- ... --> | |
<div class="justify-self-stretch ...">02</div> | |
<!-- ... --> | |
</div> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="justify-self" defaultClass="justify-self-start" featuredClass="justify-self-end" /> | |
--- | |
File: /src/docs/letter-spacing.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourTheme, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
export const title = "letter-spacing"; | |
export const description = "Utilities for controlling the tracking, or letter spacing, of an element."; | |
<ApiTable | |
rows={[ | |
["tracking-tighter", "letter-spacing: var(--tracking-tighter); /* -0.05em */"], | |
["tracking-tight", "letter-spacing: var(--tracking-tight); /* -0.025em */"], | |
["tracking-normal", "letter-spacing: var(--tracking-normal); /* 0em */"], | |
["tracking-wide", "letter-spacing: var(--tracking-wide); /* 0.025em */"], | |
["tracking-wider", "letter-spacing: var(--tracking-wider); /* 0.05em */"], | |
["tracking-widest", "letter-spacing: var(--tracking-widest); /* 0.1em */"], | |
["tracking-(<custom-property>)", "letter-spacing: var(<custom-property>);"], | |
["tracking-[<value>]", "letter-spacing: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `tracking-tight` and `tracking-wide` to set the letter spacing of an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col gap-8"> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">tracking-tight</span> | |
<p className="text-lg font-medium tracking-tight text-gray-900 dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">tracking-normal</span> | |
<p className="text-lg font-medium tracking-normal text-gray-900 dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">tracking-wide</span> | |
<p className="text-lg font-medium tracking-wide text-gray-900 dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:tracking-tight,tracking-normal,tracking-wide] --> | |
<p class="tracking-tight ...">The quick brown fox ...</p> | |
<p class="tracking-normal ...">The quick brown fox ...</p> | |
<p class="tracking-wide ...">The quick brown fox ...</p> | |
``` | |
</Figure> | |
### Using negative values | |
Using negative values doesn't make a ton of sense with the named letter spacing scale Tailwind includes out of the box, but if you've customized your scale to use numbers it can be useful: | |
```css | |
@theme { | |
--tracking-1: 0em; | |
--tracking-2: 0.025em; | |
--tracking-3: 0.05em; | |
--tracking-4: 0.1em; | |
} | |
``` | |
To use a negative letter spacing value, prefix the class name with a dash to convert it to a negative value: | |
```html | |
<!-- [!code classes:-tracking-2] --> | |
<p class="-tracking-2">The quick brown fox ...</p> | |
``` | |
### Using a custom value | |
<UsingACustomValue element="p" utility="tracking" name="letter spacing" value=".25em" /> | |
### Responsive design | |
<ResponsiveDesign element="p" property="letter-spacing" defaultClass="tracking-tight" featuredClass="tracking-wide" /> | |
## Customizing your theme | |
<CustomizingYourTheme | |
element="p" | |
utility="tracking" | |
name="letter spacing" | |
customValue="-0.075em" | |
customName="tightest" | |
/> | |
--- | |
File: /src/docs/line-clamp.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "line-clamp"; | |
export const description = "Utilities for clamping text to a specific number of lines."; | |
<ApiTable | |
rows={[ | |
[ | |
"line-clamp-<number>", | |
"overflow: hidden;\ndisplay: -webkit-box;\n-webkit-box-orient: vertical;\n-webkit-line-clamp: <number>;", | |
], | |
[ | |
"line-clamp-none", | |
"overflow: visible;\ndisplay: block;\n-webkit-box-orient: horizontal;\n-webkit-line-clamp: unset;", | |
], | |
[ | |
"line-clamp-(<custom-property>)", | |
"overflow: hidden;\ndisplay: -webkit-box;\n-webkit-box-orient: vertical;\n-webkit-line-clamp: var(<custom-property>);", | |
], | |
[ | |
"line-clamp-[<value>]", | |
"overflow: hidden;\ndisplay: -webkit-box;\n-webkit-box-orient: vertical;\n-webkit-line-clamp: <value>;", | |
], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use `line-clamp-<number>` utilities like `line-clamp-2` and `line-clamp-3` to truncate multi-line text after a specific number of lines: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="px-4 sm:px-0"> | |
<article className="mx-auto max-w-sm p-8 text-gray-700 dark:text-gray-400"> | |
<time dateTime="2020-03-16" className="block text-sm leading-6 text-gray-500 dark:text-gray-400"> | |
Mar 10, 2020 | |
</time> | |
<div className="mt-2 text-lg font-semibold text-gray-900 dark:text-gray-200">Boost your conversion rate</div> | |
<p className="mt-4 line-clamp-3 text-sm leading-6 text-gray-500 dark:text-gray-400"> | |
Nulla dolor velit adipisicing duis excepteur esse in duis nostrud occaecat mollit incididunt deserunt sunt. Ut | |
ut sunt laborum ex occaecat eu tempor labore enim adipisicing minim ad. Est in quis eu dolore occaecat | |
excepteur fugiat dolore nisi aliqua fugiat enim ut cillum. Labore enim duis nostrud eu. Est ut eiusmod | |
consequat irure quis deserunt ex. Enim laboris dolor magna pariatur. Dolor et ad sint voluptate sunt elit | |
mollit officia ad enim sit consectetur enim. | |
</p> | |
<div className="mt-4 flex gap-x-2.5 text-sm leading-6 font-semibold text-gray-900 dark:text-gray-200"> | |
<img | |
className="h-6 w-6 flex-none rounded-full bg-gray-50 dark:bg-gray-900" | |
src="https://images.unsplash.com/photo-1517841905240-472988babdf9?ixlib=rb-1.2.1&ixid=eyJhcHBfaWQiOjEyMDd9&auto=format&fit=facearea&facepad=2&w=256&h=256&q=80" | |
alt="" | |
/> | |
Lindsay Walton | |
</div> | |
</article> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:line-clamp-3] --> | |
<article> | |
<time>Mar 10, 2020</time> | |
<h2>Boost your conversion rate</h2> | |
<p class="line-clamp-3"> | |
Nulla dolor velit adipisicing duis excepteur esse in duis nostrud occaecat mollit incididunt deserunt sunt. Ut ut | |
sunt laborum ex occaecat eu tempor labore enim adipisicing minim ad. Est in quis eu dolore occaecat excepteur fugiat | |
dolore nisi aliqua fugiat enim ut cillum. Labore enim duis nostrud eu. Est ut eiusmod consequat irure quis deserunt | |
ex. Enim laboris dolor magna pariatur. Dolor et ad sint voluptate sunt elit mollit officia ad enim sit consectetur | |
enim. | |
</p> | |
<div> | |
<img src="/img/lindsay.jpg" /> | |
Lindsay Walton | |
</div> | |
</article> | |
``` | |
</Figure> | |
### Undoing line clamping | |
Use `line-clamp-none` to undo a previously applied line clamp utility: | |
```html | |
<!-- [!code classes:lg:line-clamp-none] --> | |
<p class="line-clamp-3 lg:line-clamp-none"> | |
<!-- ... --> | |
</p> | |
``` | |
### Using a custom value | |
<UsingACustomValue | |
element="p" | |
utility="line-clamp" | |
name="number of lines" | |
variable="line-count" | |
value="calc(var(--characters)/100)" | |
/> | |
### Responsive design | |
<ResponsiveDesign property="line-clamp" defaultClass="line-clamp-3" featuredClass="line-clamp-4" /> | |
--- | |
File: /src/docs/line-height.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourSpacingScale, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
export const title = "line-height"; | |
export const description = "Utilities for controlling the leading, or line height, of an element."; | |
<ApiTable | |
rows={[ | |
["text-<size>/<number>", "font-size: <size>;\nline-height: calc(var(--spacing) * <number>);"], | |
["text-<size>/(<custom-property>)", "font-size: <size>;\nline-height: var(<custom-property>);"], | |
["text-<size>/[<value>]", "font-size: <size>;\nline-height: <value>;"], | |
["leading-none", "line-height: 1;"], | |
["leading-<number>", "line-height: calc(var(--spacing) * <number>)"], | |
["leading-(<custom-property>)", "line-height: var(<custom-property>);"], | |
["leading-[<value>]", "line-height: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use font size utilities like `text-sm/6` and `text-lg/7` to set the font size and line-height of an element at the same time: | |
<Figure> | |
<Example>{ | |
<div className="flex flex-col gap-8"> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">text-sm/6</span> | |
<p className="text-sm/6 text-gray-900 dark:text-gray-200"> | |
So I started to walk into the water. I won't lie to you boys, I was terrified. But I pressed on, and as I made | |
my way past the breakers a strange calm came over me. I don't know if it was divine intervention or the kinship | |
of all living things but I tell you Jerry at that moment, I <em>was</em> a marine biologist. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">text-sm/7</span> | |
<p className="text-sm/7 text-gray-900 dark:text-gray-200"> | |
So I started to walk into the water. I won't lie to you boys, I was terrified. But I pressed on, and as I made | |
my way past the breakers a strange calm came over me. I don't know if it was divine intervention or the kinship | |
of all living things but I tell you Jerry at that moment, I <em>was</em> a marine biologist. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">text-sm/8</span> | |
<p className="text-sm/8 text-gray-900 dark:text-gray-200"> | |
So I started to walk into the water. I won't lie to you boys, I was terrified. But I pressed on, and as I made | |
my way past the breakers a strange calm came over me. I don't know if it was divine intervention or the kinship | |
of all living things but I tell you Jerry at that moment, I <em>was</em> a marine biologist. | |
</p> | |
</div> | |
</div> | |
}</Example> | |
```html | |
<!-- [!code classes:text-base/6,text-base/7,text-base/8] --> | |
<p class="text-base/6 ...">So I started to walk into the water...</p> | |
<p class="text-base/7 ...">So I started to walk into the water...</p> | |
<p class="text-base/8 ...">So I started to walk into the water...</p> | |
``` | |
</Figure> | |
Each font size utility also sets a default line height when one isn't provided. You can learn more about these values and how to customize them in the [font-size documentation](/docs/font-size). | |
### Setting independently | |
Use `leading-<number>` utilities like `leading-6` and `leading-7` to set the line height of an element independent of the font-size: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col gap-8"> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">leading-6</span> | |
<p className="leading-6 text-gray-900 dark:text-gray-200"> | |
So I started to walk into the water. I won't lie to you boys, I was terrified. But I pressed on, and as I made | |
my way past the breakers a strange calm came over me. I don't know if it was divine intervention or the | |
kinship of all living things but I tell you Jerry at that moment, I <em>was</em> a marine biologist. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">leading-7</span> | |
<p className="leading-7 text-gray-900 dark:text-gray-200"> | |
So I started to walk into the water. I won't lie to you boys, I was terrified. But I pressed on, and as I made | |
my way past the breakers a strange calm came over me. I don't know if it was divine intervention or the | |
kinship of all living things but I tell you Jerry at that moment, I <em>was</em> a marine biologist. | |
</p> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">leading-8</span> | |
<p className="leading-8 text-gray-900 dark:text-gray-200"> | |
So I started to walk into the water. I won't lie to you boys, I was terrified. But I pressed on, and as I made | |
my way past the breakers a strange calm came over me. I don't know if it was divine intervention or the | |
kinship of all living things but I tell you Jerry at that moment, I <em>was</em> a marine biologist. | |
</p> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:leading-6,leading-7,leading-8] --> | |
<p class="text-sm leading-6">So I started to walk into the water...</p> | |
<p class="text-sm leading-7">So I started to walk into the water...</p> | |
<p class="text-sm leading-8">So I started to walk into the water...</p> | |
``` | |
</Figure> | |
### Removing the leading | |
Use the `leading-none` utility to set the line height of an element equal to its font size: | |
<Figure> | |
<Example> | |
{ | |
<p className="mx-auto max-w-2xs text-2xl leading-none text-gray-900 dark:text-gray-200"> | |
The quick brown fox jumps over the lazy dog. | |
</p> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:leading-none] --> | |
<p class="text-2xl leading-none ...">The quick brown fox...</p> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue element="p" utility="leading" name="line height" variable="line-height" value="1.5" /> | |
### Responsive design | |
<ResponsiveDesign element="p" property="line-height" defaultClass="leading-5" featuredClass="leading-6" /> | |
## Customizing your theme | |
<CustomizingYourSpacingScale utility="leading" /> | |
--- | |
File: /src/docs/list-style-image.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "list-style-image"; | |
export const description = "Utilities for controlling the marker images for list items."; | |
<ApiTable | |
rows={[ | |
["list-image-[<value>]", "list-style-image: <value>;"], | |
["list-image-(<custom-property>)", "list-style-image: var(<custom-property>);"], | |
["list-image-none", "list-style-image: none;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use the `list-image-[<value>]` syntax to control the marker image for list items: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="px-4 sm:px-0"> | |
<div className="mx-auto max-w-sm p-8 text-gray-700 sm:text-base sm:leading-7 dark:text-gray-400"> | |
<ul className="list-image-[url('')] pl-4 text-gray-900 dark:text-gray-200"> | |
<li className="pl-2">5 cups chopped Porcini mushrooms</li> | |
<li className="pl-2">1/2 cup of olive oil</li> | |
<li className="pl-2">3lb of celery</li> | |
</ul> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:list-image-[url(/img/checkmark.png)]] --> | |
<ul class="list-image-[url(/img/checkmark.png)]"> | |
<li>5 cups chopped Porcini mushrooms</li> | |
<!-- ... --> | |
</ul> | |
``` | |
</Figure> | |
### Using a CSS variable | |
Use the <code>list-image-{'(<custom-property>)'}</code> syntax to control the marker image for list items using a CSS variable: | |
```html | |
<!-- [!code classes:list-image-(--my-list-image)] --> | |
<ul class="list-image-(--my-list-image)"> | |
<!-- ... --> | |
</ul> | |
``` | |
This is just a shorthand for <code>list-image-{'[var(<custom-property>)]'}</code> that adds the `var()` function for you automatically. | |
### Removing a marker image | |
Use the `list-image-none` utility to remove an existing marker image from list items: | |
```html | |
<!-- [!code classes:list-image-none] --> | |
<ul class="list-image-none"> | |
<!-- ... --> | |
</ul> | |
``` | |
### Responsive design | |
<ResponsiveDesign | |
property="list-style-image" | |
defaultClass="list-image-none" | |
featuredClass="list-image-[url(/img/checkmark.png)]" | |
/> | |
--- | |
File: /src/docs/list-style-position.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "list-style-position"; | |
export const description = "Utilities for controlling the position of bullets and numbers in lists."; | |
<ApiTable | |
rows={[ | |
["list-inside", "list-style-position: inside;"], | |
["list-outside", "list-style-position: outside;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `list-inside` and `list-outside` to control the position of the markers and text indentation in a list: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col gap-8 sm:flex-row"> | |
<div className="relative"> | |
<div className="absolute -top-8 -bottom-8 left-8 w-px bg-pink-400/40 dark:bg-pink-400/30"></div> | |
<p className="mb-3 ml-8 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">list-inside</p> | |
<ul className="list-inside list-disc rounded-xl p-4 pl-8 text-gray-900 dark:text-gray-200"> | |
<li>5 cups chopped Porcini mushrooms</li> | |
<li>1/2 cup of olive oil</li> | |
<li>3lb of celery</li> | |
</ul> | |
</div> | |
<div className="relative"> | |
<div className="absolute -top-0 -bottom-8 left-8 w-px bg-pink-400/40 sm:-top-8 dark:bg-pink-400/30"></div> | |
<p className="mb-3 ml-8 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">list-outside</p> | |
<ul className="list-outside list-disc rounded-xl p-4 pl-8 text-gray-900 dark:text-gray-200"> | |
<li>5 cups chopped Porcini mushrooms</li> | |
<li>1/2 cup of olive oil</li> | |
<li>3lb of celery</li> | |
</ul> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:list-inside] --> | |
<ul class="list-inside"> | |
<li>5 cups chopped Porcini mushrooms</li> | |
<!-- ... --> | |
</ul> | |
<!-- [!code classes:list-outside] --> | |
<ul class="list-outside"> | |
<li>5 cups chopped Porcini mushrooms</li> | |
<!-- ... --> | |
</ul> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign element="ul" property="list-style-position" defaultClass="list-outside" featuredClass="list-inside" /> | |
--- | |
File: /src/docs/list-style-type.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
export const title = "list-style-type"; | |
export const description = "Utilities for controlling the marker style of a list."; | |
<ApiTable | |
rows={[ | |
["list-disc", "list-style-type: disc;"], | |
["list-decimal", "list-style-type: decimal;"], | |
["list-none", "list-style-type: none;"], | |
["list-(<custom-property>)", "list-style-type: var(<custom-property>);"], | |
["list-[<value>]", "list-style-type: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `list-disc` and `list-decimal` to control the style of the markers in a list: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col gap-8"> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">list-disc</span> | |
<ul className="list-inside list-disc text-gray-900 dark:text-gray-200"> | |
<li>Now this is a story all about how, my life got flipped-turned upside down</li> | |
<li>And I'd like to take a minute just sit right there</li> | |
<li>I'll tell you how I became the prince of a town called Bel-Air</li> | |
</ul> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">list-decimal</span> | |
<ul className="list-inside list-decimal text-gray-900 dark:text-gray-200"> | |
<li>Now this is a story all about how, my life got flipped-turned upside down</li> | |
<li>And I'd like to take a minute just sit right there</li> | |
<li>I'll tell you how I became the prince of a town called Bel-Air</li> | |
</ul> | |
</div> | |
<div> | |
<span className="mb-3 font-mono text-xs font-medium text-gray-500 dark:text-gray-400">list-none</span> | |
<ul className="list-inside list-none text-gray-900 dark:text-gray-200"> | |
<li>Now this is a story all about how, my life got flipped-turned upside down</li> | |
<li>And I'd like to take a minute just sit right there</li> | |
<li>I'll tell you how I became the prince of a town called Bel-Air</li> | |
</ul> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:list-disc] --> | |
<ul class="list-disc"> | |
<li>Now this is a story all about how, my life got flipped-turned upside down</li> | |
<!-- ... --> | |
</ul> | |
<!-- [!code classes:list-decimal] --> | |
<ol class="list-decimal"> | |
<li>Now this is a story all about how, my life got flipped-turned upside down</li> | |
<!-- ... --> | |
</ol> | |
<!-- [!code classes:list-none] --> | |
<ul class="list-none"> | |
<li>Now this is a story all about how, my life got flipped-turned upside down</li> | |
<!-- ... --> | |
</ul> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue element="ol" utility="list" name="marker" value="upper-roman" variable="marker" /> | |
### Responsive design | |
<ResponsiveDesign element="ul" property="list-style-type" defaultClass="list-none" featuredClass="list-disc" /> | |
--- | |
File: /src/docs/margin.mdx | |
--- | |
import dedent from "dedent"; | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourSpacingScale, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "margin"; | |
export const description = "Utilities for controlling an element's margin."; | |
<ApiTable | |
rows={[ | |
...[ | |
["m", "margin"], | |
["mx", "margin-inline"], | |
["my", "margin-block"], | |
["ms", "margin-inline-start"], | |
["me", "margin-inline-end"], | |
["mt", "margin-top"], | |
["mr", "margin-right"], | |
["mb", "margin-bottom"], | |
["ml", "margin-left"], | |
].flatMap(([prefix, property]) => [ | |
[`${prefix}-<number>`, `${property}: calc(var(--spacing) * <number>);`], | |
[`-${prefix}-<number>`, `${property}: calc(var(--spacing) * -<number>);`], | |
[`${prefix}-auto`, `${property}: auto;`], | |
[`${prefix}-px`, `${property}: 1px;`], | |
[`-${prefix}-px`, `${property}: -1px;`], | |
[`${prefix}-(<custom-property>)`, `${property}: var(<custom-property>);`], | |
[`${prefix}-[<value>]`, `${property}: <value>;`], | |
]), | |
...[ | |
["space-x", "margin-inline"], | |
["space-y", "margin-block"], | |
].flatMap(([prefix, property]) => [ | |
[ | |
`${prefix}-<number>`, | |
dedent`& > :not(:last-child) { | |
--tw-${prefix}-reverse: 0; | |
${property}-start: calc(calc(var(--spacing) * <number>) * var(--tw-${prefix}-reverse)); | |
${property}-end: calc(calc(var(--spacing) * <number>) * calc(1 - var(--tw-${prefix}-reverse))); | |
};`, | |
], | |
[ | |
`-${prefix}-<number>`, | |
dedent`& > :not(:last-child) { | |
--tw-${prefix}-reverse: 0; | |
${property}-start: calc(calc(var(--spacing) * -<number>) * var(--tw-${prefix}-reverse)); | |
${property}-end: calc(calc(var(--spacing) * -<number>) * calc(1 - var(--tw-${prefix}-reverse))); | |
};`, | |
], | |
[ | |
`${prefix}-px`, | |
dedent`& > :not(:last-child) { | |
--tw-${prefix}-reverse: 0; | |
${property}-start: calc(1px * var(--tw-${prefix}-reverse)); | |
${property}-end: calc(1px * calc(1 - var(--tw-${prefix}-reverse))); | |
};`, | |
], | |
[ | |
`-${prefix}-px`, | |
dedent`& > :not(:last-child) { | |
--tw-${prefix}-reverse: 0; | |
${property}-start: calc(-1px * var(--tw-${prefix}-reverse)); | |
${property}-end: calc(-1px * calc(1 - var(--tw-${prefix}-reverse))); | |
};`, | |
], | |
[ | |
`${prefix}-(<custom-property>)`, | |
dedent`& > :not(:last-child) { | |
--tw-${prefix}-reverse: 0; | |
${property}-start: calc(var(<custom-property>) * var(--tw-${prefix}-reverse)); | |
${property}-end: calc(var(<custom-property>) * calc(1 - var(--tw-${prefix}-reverse))); | |
};`, | |
], | |
[ | |
`${prefix}-[<value>]`, | |
dedent`& > :not(:last-child) { | |
--tw-${prefix}-reverse: 0; | |
${property}-start: calc(<value> * var(--tw-${prefix}-reverse)); | |
${property}-end: calc(<value> * calc(1 - var(--tw-${prefix}-reverse))); | |
};`, | |
], | |
]), | |
[ | |
"space-x-reverse", | |
dedent`& > :not(:last-child)) { | |
--tw-space-x-reverse: 1; | |
}`, | |
], | |
[ | |
"space-y-reverse", | |
dedent`& > :not(:last-child)) { | |
--tw-space-y-reverse: 1; | |
}`, | |
], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use `m-<number>` utilities like `m-4` and `m-8` to control the margin on all sides of an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex justify-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="relative flow-root rounded-lg"> | |
<div className="absolute inset-0"> | |
<Stripes border className="h-full rounded-lg" /> | |
</div> | |
<div className="relative m-8 rounded-lg bg-blue-500 p-4">m-8</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:m-8] --> | |
<div class="m-8 ...">m-8</div> | |
``` | |
</Figure> | |
### Adding margin to a single side | |
Use `mt-<number>`, `mr-<number>`, `mb-<number>`, and `ml-<number>` utilities like `ml-2` and `mt-6` to control the margin on one side of an element: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="relative h-56 font-mono text-sm leading-6 font-bold text-white"> | |
<div className="absolute top-0 left-1/2 -translate-x-1/2 md:-ml-24"> | |
<div className="relative pt-6"> | |
<Stripes border="x" className="absolute inset-0 rounded-b-lg" /> | |
<div className="relative rounded-lg bg-purple-500 p-4">mt-6</div> | |
</div> | |
</div> | |
<div className="absolute top-1/2 right-0 -translate-y-1/2"> | |
<div className="relative pr-4"> | |
<Stripes border="y" className="absolute inset-0 rounded-l-lg" /> | |
<div className="relative rounded-lg bg-purple-500 p-4">mr-4</div> | |
</div> | |
</div> | |
<div className="absolute bottom-0 left-1/2 -translate-x-1/2 md:ml-24"> | |
<div className="relative pb-8"> | |
<Stripes border="x" className="absolute inset-0 rounded-t-lg" /> | |
<div className="relative rounded-lg bg-purple-500 p-4">mb-8</div> | |
</div> | |
</div> | |
<div className="absolute top-1/2 left-0 -translate-y-1/2"> | |
<div className="relative pl-2"> | |
<Stripes border="y" className="absolute inset-0 rounded-r-lg" /> | |
<div className="relative rounded-lg bg-purple-500 p-4">ml-2</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:mt-6,mr-4,mb-8,ml-2] --> | |
<div class="mt-6 ...">mt-6</div> | |
<div class="mr-4 ...">mr-4</div> | |
<div class="mb-8 ...">mb-8</div> | |
<div class="ml-2 ...">ml-2</div> | |
``` | |
</Figure> | |
### Adding horizontal margin | |
Use `mx-<number>` utilities like `mx-4` and `mx-8` to control the horizontal margin of an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex justify-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="relative rounded-lg"> | |
<div className="absolute inset-0"> | |
<Stripes border className="h-full rounded-lg" /> | |
</div> | |
<div className="relative mx-8 rounded-lg bg-indigo-500 p-4">mx-8</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:mx-8] --> | |
<div class="mx-8 ...">mx-8</div> | |
``` | |
</Figure> | |
### Adding vertical margin | |
Use `my-<number>` utilities like `my-4` and `my-8` to control the vertical margin of an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex justify-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="relative flow-root rounded-lg"> | |
<div className="absolute inset-0"> | |
<Stripes border className="h-full rounded-lg" /> | |
</div> | |
<div className="relative my-8 rounded-lg bg-pink-500 p-4">my-8</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:my-8] --> | |
<div class="my-8 ...">my-8</div> | |
``` | |
</Figure> | |
### Using negative values | |
To use a negative margin value, prefix the class name with a dash to convert it to a negative value: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex justify-center font-mono text-sm leading-6 font-bold text-white"> | |
<div className="flex flex-col items-center"> | |
<div className="relative h-16 w-36 overflow-hidden rounded-md border border-sky-700/10 bg-sky-400/20"></div> | |
<div className="relative -mt-8 flex items-center justify-center rounded-md bg-sky-500 p-4">-mt-8</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:-mt-8] --> | |
<div class="h-16 w-36 bg-sky-400 opacity-20 ..."></div> | |
<div class="-mt-8 bg-sky-300 ...">-mt-8</div> | |
``` | |
</Figure> | |
### Using logical properties | |
Use `ms-<number>` or `me-<number>` utilities like `ms-4` and `me-8` to set the `margin-inline-start` and `margin-inline-end` logical properties: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-2 place-items-center gap-x-4"> | |
<div className="flex flex-col items-start gap-y-4" dir="ltr"> | |
<p className="text-sm font-medium">Left-to-right</p> | |
<div className="relative flex rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<Stripes border className="absolute min-h-full w-full rounded-lg" /> | |
<div className="relative ms-8 rounded-lg bg-indigo-500 p-4">ms-8</div> | |
</div> | |
<div className="relative mt-4 flex rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<Stripes border className="absolute min-h-full w-full rounded-lg" /> | |
<div className="relative me-8 rounded-lg bg-indigo-500 p-4">me-8</div> | |
</div> | |
</div> | |
<div className="flex flex-col items-start gap-y-4" dir="rtl"> | |
<p className="text-sm font-medium">Right-to-left</p> | |
<div className="relative flex rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<Stripes border className="absolute min-h-full w-full rounded-lg" /> | |
<div className="relative ms-8 rounded-lg bg-indigo-500 p-4">ms-8</div> | |
</div> | |
<div className="relative mt-4 flex rounded-lg font-mono text-sm leading-6 font-bold text-white"> | |
<Stripes border className="absolute min-h-full w-full rounded-lg" /> | |
<div className="relative me-8 rounded-lg bg-indigo-500 p-4">me-8</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:ms-8,me-8] --> | |
<!-- [!code word:dir="ltr"] --> | |
<!-- [!code word:dir="rtl"] --> | |
<div> | |
<div dir="ltr"> | |
<div class="ms-8 ...">ms-8</div> | |
<div class="me-8 ...">me-8</div> | |
</div> | |
<div dir="rtl"> | |
<div class="ms-8 ...">ms-8</div> | |
<div class="me-8 ...">me-8</div> | |
</div> | |
</div> | |
``` | |
</Figure> | |
### Adding space between children | |
Use `space-x-<number>` or `space-y-<number>` utilities like `space-x-4` and `space-y-8` to control the space between elements: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex justify-start font-mono text-sm leading-6 font-bold text-white"> | |
<div className="relative flex space-x-4 rounded-lg"> | |
<div className="absolute inset-0"> | |
<Stripes border="y" className="h-full rounded-lg" /> | |
</div> | |
<div className="relative flex h-14 w-14 items-center justify-center rounded-lg bg-fuchsia-500">01</div> | |
<div className="relative flex h-14 w-14 items-center justify-center rounded-lg bg-fuchsia-500">02</div> | |
<div className="relative flex h-14 w-14 items-center justify-center rounded-lg bg-fuchsia-500">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:space-x-4] --> | |
<div class="flex space-x-4 ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
#### Reversing children order | |
If your elements are in reverse order (using say `flex-row-reverse` or `flex-col-reverse`), use the `space-x-reverse` or `space-y-reverse` utilities to ensure the space is added to the correct side of each element: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex justify-end font-mono text-sm leading-6 font-bold text-white"> | |
<div className="relative flex flex-row-reverse space-x-4 space-x-reverse rounded-lg"> | |
<div className="absolute inset-0"> | |
<Stripes border="y" className="h-full rounded-lg" /> | |
</div> | |
<div className="relative flex h-14 w-14 items-center justify-center rounded-lg bg-cyan-500">01</div> | |
<div className="relative flex h-14 w-14 items-center justify-center rounded-lg bg-cyan-500">02</div> | |
<div className="relative flex h-14 w-14 items-center justify-center rounded-lg bg-cyan-500">03</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:flex-row-reverse,space-x-4,space-x-reverse] --> | |
<div class="flex flex-row-reverse space-x-4 space-x-reverse ..."> | |
<div>01</div> | |
<div>02</div> | |
<div>03</div> | |
</div> | |
``` | |
</Figure> | |
#### Limitations | |
The space utilities are really just a shortcut for adding margin to all-but-the-last-item in a group, and aren't designed to handle complex cases like grids, layouts that wrap, or situations where the children are rendered in a complex custom order rather than their natural DOM order. | |
For those situations, it's better to use the [gap utilities](/docs/gap) when possible, or add margin to every element with a matching negative margin on the parent. | |
Additionally, the space utilities are not designed to work together with the [divide utilities](/docs/border-width#between-children). For those situations, consider adding margin/padding utilities to the children instead. | |
### Using a custom value | |
<UsingACustomValue utilities={["m", "mx", "mb"]} name="margin" variable="margin" value="5px" /> | |
### Responsive design | |
<ResponsiveDesign property="margin" defaultClass="mt-4" featuredClass="mt-8" /> | |
## Customizing your theme | |
<CustomizingYourSpacingScale utilities={["m", "mx", "my", "ms", "me", "mt", "mr", "mb", "ml"]} /> | |
--- | |
File: /src/docs/mask-clip.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "mask-clip"; | |
export const description = "Utilities for controlling the bounding box of an element's mask."; | |
<ApiTable | |
rows={[ | |
["mask-clip-border", "mask-clip: border-box;"], | |
["mask-clip-padding", "mask-clip: padding-box;"], | |
["mask-clip-content", "mask-clip: content-box;"], | |
["mask-clip-fill", "mask-clip: fill-box;"], | |
["mask-clip-stroke", "mask-clip: stroke-box;"], | |
["mask-clip-view", "mask-clip: view-box;"], | |
["mask-no-clip", "mask-clip: no-clip;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `mask-clip-border`, `mask-clip-padding`, and `mask-clip-content` to control the bounding box of an element's mask: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col items-center justify-center gap-y-10 text-center font-mono text-xs font-medium text-gray-500 sm:flex-row sm:space-y-0 sm:space-x-10 dark:text-gray-400"> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3">mask-clip-border</p> | |
<div className="relative size-24 rounded-lg border-3 border-dashed border-indigo-500/50 dark:border-indigo-400/75"> | |
<div className="absolute -inset-[3px] bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-[50%_50%] mask-radial-from-100% bg-cover bg-center mask-clip-border p-1.5"></div> | |
</div> | |
</div> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3">mask-clip-padding</p> | |
<div className="relative size-24 rounded-lg border-3 border-dashed border-indigo-500/50 dark:border-indigo-400/75"> | |
<div className="absolute -inset-[3px] rounded-lg border-3 bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-[50%_50%] mask-radial-from-100% bg-cover bg-center mask-clip-padding p-1.5"></div> | |
</div> | |
</div> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3">mask-clip-content</p> | |
<div className="relative size-24 rounded-lg border-3 border-dashed border-indigo-500/50 dark:border-indigo-400/75"> | |
<div className="absolute -inset-[3px] rounded-lg border-3 bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-[50%_50%] mask-radial-from-100% bg-cover bg-center mask-clip-content p-1.5"></div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-clip-border,mask-clip-padding,mask-clip-content] --> | |
<div class="mask-clip-border border-3 p-1.5 mask-[url(/img/circle.png)] bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-clip-padding border-3 p-1.5 mask-[url(/img/circle.png)] bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-clip-content border-3 p-1.5 mask-[url(/img/circle.png)] bg-[url(/img/mountains.jpg)] ..."></div> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="mask-clip" defaultClass="mask-clip-border" featuredClass="mask-clip-padding" /> | |
--- | |
File: /src/docs/mask-composite.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "mask-composite"; | |
export const description = "Utilities for controlling how multiple masks are combined together."; | |
<ApiTable | |
rows={[ | |
["mask-add", "mask-composite: add;"], | |
["mask-subtract", "mask-composite: subtract;"], | |
["mask-intersect", "mask-composite: intersect;"], | |
["mask-exclude", "mask-composite: exclude;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `mask-add` and `mask-intersect` to control how an element's masks are combined together: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-2 items-center justify-center justify-items-center gap-y-8 py-4 text-center font-mono text-xs font-medium text-gray-500 max-sm:grid-cols-1 dark:text-gray-400"> | |
<div className="relative grid justify-center"> | |
<div className="absolute -bottom-[2px] right-[calc(5%-2px)] box-content size-24 rounded-full border-2 border-dashed border-black/10 dark:border-white/20" /> | |
<div className="absolute -bottom-[2px] left-[calc(5%-2px)] box-content size-24 rounded-full border-2 border-dashed border-black/10 dark:border-white/20" /> | |
<p className="mb-3">mask-add</p> | |
<div className="h-24 w-48 bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-[radial-gradient(ellipse_25%_50%_at_30%_50%,_white_100%,transparent_100%),_radial-gradient(ellipse_25%_50%_at_70%_50%,_white_100%,transparent_100%)] bg-cover bg-center mask-add"></div> | |
</div> | |
<div className="relative grid justify-center"> | |
<div className="absolute -bottom-[2px] right-[calc(5%-2px)] box-content size-24 rounded-full border-2 border-dashed border-black/10 dark:border-white/20" /> | |
<div className="absolute -bottom-[2px] left-[calc(5%-2px)] box-content size-24 rounded-full border-2 border-dashed border-black/10 dark:border-white/20" /> | |
<p className="mb-3 text-center">mask-subtract</p> | |
<div className="h-24 w-48 bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-[radial-gradient(ellipse_25%_50%_at_30%_50%,_white_100%,transparent_100%),_radial-gradient(ellipse_25%_50%_at_70%_50%,_white_100%,transparent_100%)] bg-cover bg-center mask-subtract"></div> | |
</div> | |
<div className="relative grid justify-center"> | |
<div className="absolute -bottom-[2px] right-[calc(5%-2px)] box-content size-24 rounded-full border-2 border-dashed border-black/10 dark:border-white/20" /> | |
<div className="absolute -bottom-[2px] left-[calc(5%-2px)] box-content size-24 rounded-full border-2 border-dashed border-black/10 dark:border-white/20" /> | |
<p className="mb-3 text-center">mask-intersect</p> | |
<div className="h-24 w-48 bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-[radial-gradient(ellipse_25%_50%_at_30%_50%,_white_100%,transparent_100%),_radial-gradient(ellipse_25%_50%_at_70%_50%,_white_100%,transparent_100%)] bg-cover bg-center mask-intersect"></div> | |
</div> | |
<div className="relative grid justify-center"> | |
<div className="absolute -bottom-[2px] right-[calc(5%-2px)] box-content size-24 rounded-full border-2 border-dashed border-black/10 dark:border-white/20" /> | |
<div className="absolute -bottom-[2px] left-[calc(5%-2px)] box-content size-24 rounded-full border-2 border-dashed border-black/10 dark:border-white/20" /> | |
<p className="mb-3 text-center">mask-exclude</p> | |
<div className="h-24 w-48 bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-[radial-gradient(ellipse_25%_50%_at_30%_50%,_white_100%,transparent_100%),_radial-gradient(ellipse_25%_50%_at_70%_50%,_white_100%,transparent_100%)] bg-cover bg-center mask-exclude"></div> | |
</div> | |
</div> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-add,mask-subtract,mask-intersect,mask-exclude] --> | |
<div class="mask-add mask-[url(/img/circle.png),url(/img/circle.png)] mask-[position:30%_50%,70%_50%] bg-[url(/img/mountains.jpg)]"></div> | |
<div class="mask-subtract mask-[url(/img/circle.png),url(/img/circle.png)] mask-[position:30%_50%,70%_50%] bg-[url(/img/mountains.jpg)]"></div> | |
<div class="mask-intersect mask-[url(/img/circle.png),url(/img/circle.png)] mask-[position:30%_50%,70%_50%] bg-[url(/img/mountains.jpg)]"></div> | |
<div class="mask-exclude mask-[url(/img/circle.png),url(/img/circle.png)] mask-[position:30%_50%,70%_50%] bg-[url(/img/mountains.jpg)]"></div> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="mask-composite" defaultClass="mask-add" featuredClass="mask-subtract" /> | |
--- | |
File: /src/docs/mask-image.mdx | |
--- | |
import KeyboardLight from "@/docs/img/keyboard-light.png"; | |
import KeyboardDark from "@/docs/img/keyboard-dark.png"; | |
import maskImg from "@/docs/img/mask.png"; | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourThemeColors, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
import dedent from "dedent"; | |
export const title = "mask-image"; | |
export const description = "Utilities for controlling an element's mask image."; | |
<svg className="sr-only"> | |
<defs> | |
<pattern id="checkerboard" x="0.5" y="0" width="10" height="10" patternUnits="userSpaceOnUse"> | |
<rect x="0" y="0" width="5" height="5" fill="#fff" /> | |
<rect x="5" y="0" width="5" height="5" fill="#808080" /> | |
<rect x="0" y="5" width="5" height="5" fill="#808080" /> | |
<rect x="5" y="5" width="5" height="5" fill="#fff" /> | |
</pattern> | |
</defs> | |
</svg> | |
<svg className="hidden"> | |
<symbol id="gradient-color-stop" viewBox="0 0 32 34"> | |
<path | |
fill="url(#checkerboard)" | |
stroke="#000" | |
strokeOpacity=".05" | |
d="M5 .5h22A3.5 3.5 0 0 1 30.5 4v19.6a3.5 3.5 0 0 1-1.853 3.088L16 33.433 3.353 26.688A3.5 3.5 0 0 1 1.5 23.6V4A3.5 3.5 0 0 1 5 .5Z" | |
/> | |
<path | |
fill="currentColor" | |
d="M1 4a4 4 0 0 1 4-4h22a4 4 0 0 1 4 4v19.6a4 4 0 0 1-2.118 3.53L16 34 3.118 27.13A4 4 0 0 1 1 23.6V4Z" | |
/> | |
</symbol> | |
</svg> | |
<ApiTable | |
rows={[ | |
["mask-[<value>]", "mask-image: <value>;"], | |
["mask-(<custom-property>)", "mask-image: var(<custom-property>);"], | |
["mask-none", "mask-image: none;"], | |
[ | |
"mask-linear-<number>", | |
"mask-image: linear-gradient(<number>deg, black var(--tw-mask-linear-from)), transparent var(--tw-mask-linear-to));", | |
], | |
[ | |
"-mask-linear-<number>", | |
"mask-image: linear-gradient(calc(<number>deg * -1), black var(--tw-mask-linear-from)), transparent var(--tw-mask-linear-to));", | |
], | |
[ | |
"mask-linear-from-<number>", | |
"mask-image: linear-gradient(var(--tw-mask-linear-position), black calc(var(--spacing * <number>)), transparent var(--tw-mask-linear-to));", | |
], | |
[ | |
"mask-linear-from-<percentage>", | |
"mask-image: linear-gradient(var(--tw-mask-linear-position), black <percentage>, transparent var(--tw-mask-linear-to));", | |
], | |
[ | |
"mask-linear-from-<color>", | |
"mask-image: linear-gradient(var(--tw-mask-linear-position), <color> var(--tw-mask-linear-from), transparent var(--tw-mask-linear-to));", | |
], | |
[ | |
"mask-linear-from-(<custom-property>)", | |
"mask-image: linear-gradient(var(--tw-mask-linear-position), black <custom-property>, transparent var(--tw-mask-linear-to));", | |
], | |
[ | |
"mask-linear-from-[<value>]", | |
"mask-image: linear-gradient(var(--tw-mask-linear-position), black <value>, transparent var(--tw-mask-linear-to));", | |
], | |
[ | |
"mask-linear-to-<number>", | |
"mask-image: linear-gradient(var(--tw-mask-linear-position), black var(--tw-mask-linear-from), transparent calc(var(--spacing * <number>)));", | |
], | |
[ | |
"mask-linear-to-<percentage>", | |
"mask-image: linear-gradient(var(--tw-mask-linear-position), black var(--tw-mask-linear-from), transparent <percentage>);", | |
], | |
[ | |
"mask-linear-to-<color>", | |
"mask-image: linear-gradient(var(--tw-mask-linear-position), black var(--tw-mask-linear-from), <color> var(--tw-mask-linear-to));", | |
], | |
[ | |
"mask-linear-to-(<custom-property>)", | |
"mask-image: linear-gradient(var(--tw-mask-linear-position), black var(--tw-mask-linear-from), transparent var(<custom-property>));", | |
], | |
[ | |
"mask-linear-to-[<value>]", | |
"mask-image: linear-gradient(var(--tw-mask-linear-position), black var(--tw-mask-linear-from), transparent <value>);", | |
], | |
[ | |
"mask-t-from-<number>", | |
"mask-image: linear-gradient(to top, black calc(var(--spacing * <number>)), transparent var(--tw-mask-top-to));", | |
], | |
[ | |
"mask-t-from-<percentage>", | |
"mask-image: linear-gradient(to top, black <percentage>, transparent var(--tw-mask-top-to));", | |
], | |
[ | |
"mask-t-from-<color>", | |
"mask-image: linear-gradient(to top, <color> var(--tw-mask-top-from), transparent var(--tw-mask-top-to));", | |
], | |
[ | |
"mask-t-from-(<custom-property>)", | |
"mask-image: linear-gradient(to top, black var(<custom-property>), transparent var(--tw-mask-top-to));", | |
], | |
["mask-t-from-[<value>]", "mask-image: linear-gradient(to top, black <value>, transparent var(--tw-mask-top-to));"], | |
[ | |
"mask-t-to-<number>", | |
"mask-image: linear-gradient(to top, black var(--tw-mask-top-from), transparent calc(var(--spacing * <number>));", | |
], | |
[ | |
"mask-t-to-<percentage>", | |
"mask-image: linear-gradient(to top, black var(--tw-mask-top-from), transparent <percentage>);", | |
], | |
[ | |
"mask-t-to-<color>", | |
"mask-image: linear-gradient(to top, black var(--tw-mask-top-from), <color> var(--tw-mask-top-to));", | |
], | |
[ | |
"mask-t-to-(<custom-property>)", | |
"mask-image: linear-gradient(to top, black var(--tw-mask-top-from), transparent var(<custom-property>));", | |
], | |
["mask-t-to-[<value>]", "mask-image: linear-gradient(to top, black var(--tw-mask-top-from), transparent <value>);"], | |
[ | |
"mask-r-from-<number>", | |
"mask-image: linear-gradient(to right, black calc(var(--spacing * <number>)), transparent var(--tw-mask-right-to));", | |
], | |
[ | |
"mask-r-from-<percentage>", | |
"mask-image: linear-gradient(to right, black <percentage>, transparent var(--tw-mask-right-to));", | |
], | |
[ | |
"mask-r-from-<color>", | |
"mask-image: linear-gradient(to right, <color> var(--tw-mask-right-from), transparent var(--tw-mask-right-to));", | |
], | |
[ | |
"mask-r-from-(<custom-property>)", | |
"mask-image: linear-gradient(to right, black var(<custom-property>), transparent var(--tw-mask-right-to));", | |
], | |
[ | |
"mask-r-from-[<value>]", | |
"mask-image: linear-gradient(to right, black <value>, transparent var(--tw-mask-right-to));", | |
], | |
[ | |
"mask-r-to-<number>", | |
"mask-image: linear-gradient(to right, black var(--tw-mask-right-from), transparent calc(var(--spacing * <number>));", | |
], | |
[ | |
"mask-r-to-<percentage>", | |
"mask-image: linear-gradient(to right, black var(--tw-mask-right-from), transparent <percentage>);", | |
], | |
[ | |
"mask-r-to-<color>", | |
"mask-image: linear-gradient(to right, black var(--tw-mask-right-from), <color> var(--tw-mask-right-to));", | |
], | |
[ | |
"mask-r-to-(<custom-property>)", | |
"mask-image: linear-gradient(to right, black var(--tw-mask-right-from), transparent var(<custom-property>));", | |
], | |
[ | |
"mask-r-to-[<value>]", | |
"mask-image: linear-gradient(to right, black var(--tw-mask-right-from), transparent <value>);", | |
], | |
[ | |
"mask-b-from-<number>", | |
"mask-image: linear-gradient(to bottom, black calc(var(--spacing * <number>)), transparent var(--tw-mask-bottom-to));", | |
], | |
[ | |
"mask-b-from-<percentage>", | |
"mask-image: linear-gradient(to bottom, black <percentage>, transparent var(--tw-mask-bottom-to));", | |
], | |
[ | |
"mask-b-from-<color>", | |
"mask-image: linear-gradient(to bottom, <color> var(--tw-mask-bottom-from), transparent var(--tw-mask-bottom-to));", | |
], | |
[ | |
"mask-b-from-(<custom-property>)", | |
"mask-image: linear-gradient(to bottom, black var(<custom-property>), transparent var(--tw-mask-bottom-to));", | |
], | |
[ | |
"mask-b-from-[<value>]", | |
"mask-image: linear-gradient(to bottom, black <value>, transparent var(--tw-mask-bottom-to));", | |
], | |
[ | |
"mask-b-to-<number>", | |
"mask-image: linear-gradient(to bottom, black var(--tw-mask-bottom-from), transparent calc(var(--spacing * <number>));", | |
], | |
[ | |
"mask-b-to-<percentage>", | |
"mask-image: linear-gradient(to bottom, black var(--tw-mask-bottom-from), transparent <percentage>);", | |
], | |
[ | |
"mask-b-to-<color>", | |
"mask-image: linear-gradient(to bottom, black var(--tw-mask-bottom-from), <color> var(--tw-mask-bottom-to));", | |
], | |
[ | |
"mask-b-to-(<custom-property>)", | |
"mask-image: linear-gradient(to bottom, black var(--tw-mask-bottom-from), transparent var(<custom-property>));", | |
], | |
[ | |
"mask-b-to-[<value>]", | |
"mask-image: linear-gradient(to bottom, black var(--tw-mask-bottom-from), transparent <value>);", | |
], | |
[ | |
"mask-l-from-<number>", | |
"mask-image: linear-gradient(to left, black calc(var(--spacing * <number>)), transparent var(--tw-mask-left-to));", | |
], | |
[ | |
"mask-l-from-<percentage>", | |
"mask-image: linear-gradient(to left, black <percentage>, transparent var(--tw-mask-left-to));", | |
], | |
[ | |
"mask-l-from-<color>", | |
"mask-image: linear-gradient(to left, <color> var(--tw-mask-left-from), transparent var(--tw-mask-left-to));", | |
], | |
[ | |
"mask-l-from-(<custom-property>)", | |
"mask-image: linear-gradient(to left, black var(<custom-property>), transparent var(--tw-mask-left-to));", | |
], | |
[ | |
"mask-l-from-[<value>]", | |
"mask-image: linear-gradient(to left, black <value>, transparent var(--tw-mask-left-to));", | |
], | |
[ | |
"mask-l-to-<number>", | |
"mask-image: linear-gradient(to left, black var(--tw-mask-left-from), transparent calc(var(--spacing * <number>));", | |
], | |
[ | |
"mask-l-to-<percentage>", | |
"mask-image: linear-gradient(to bottom, black var(--tw-mask-left-from), transparent <percentage>);", | |
], | |
[ | |
"mask-l-to-<color>", | |
"mask-image: linear-gradient(to bottom, black var(--tw-mask-left-from), <color> var(--tw-mask-left-to));", | |
], | |
[ | |
"mask-l-to-(<custom-property>)", | |
"mask-image: linear-gradient(to left, black var(--tw-mask-left-from), transparent var(<custom-property>));", | |
], | |
[ | |
"mask-l-to-[<value>]", | |
"mask-image: linear-gradient(to left, black var(--tw-mask-left-from), transparent <value>);", | |
], | |
[ | |
"mask-y-from-<number>", | |
dedent` | |
mask-image: linear-gradient(to top, black calc(var(--spacing * <number>)), transparent var(--tw-mask-top-to)), linear-gradient(to bottom, black calc(var(--spacing * <number>)), transparent var(--tw-mask-bottom-to)); | |
mask-composite: intersect;`, | |
], | |
[ | |
"mask-y-from-<percentage>", | |
dedent` | |
mask-image: linear-gradient(to top, black <percentage>, transparent var(--tw-mask-top-to)), linear-gradient(to bottom, black <percentage>, transparent var(--tw-mask-bottom-to)); | |
mask-composite: intersect;`, | |
], | |
[ | |
"mask-y-from-<color>", | |
dedent` | |
mask-image: linear-gradient(to top, <color> var(--tw-mask-top-from), transparent var(--tw-mask-top-to)), linear-gradient(to bottom, <color> var(--tw-mask-bottom-from), transparent var(--tw-mask-bottom-to)); | |
mask-composite: intersect;`, | |
], | |
[ | |
"mask-y-from-(<custom-property>)", | |
dedent` | |
mask-image: linear-gradient(to top, black var(<custom-property>), transparent var(--tw-mask-top-to)), linear-gradient(to bottom, black var(<custom-property>), transparent var(--tw-mask-bottom-to)); | |
mask-composite: intersect;`, | |
], | |
[ | |
"mask-y-from-[<value>]", | |
dedent` | |
mask-image: linear-gradient(to top, black <value>, transparent var(--tw-mask-top-to)), linear-gradient(to bottom, black <value>, transparent var(--tw-mask-bottom-to)); | |
mask-composite: intersect;`, | |
], | |
[ | |
"mask-y-to-<number>", | |
dedent` | |
mask-image: linear-gradient(to top, black var(--tw-mask-top-from), transparent calc(var(--spacing * <number>)), linear-gradient(to bottom, black var(--tw-mask-bottom-from), transparent calc(var(--spacing * <number>)); | |
mask-composite: intersect;`, | |
], | |
[ | |
"mask-y-to-<percentage>", | |
dedent` | |
mask-image: linear-gradient(to bottom, black var(--tw-mask-top-from), transparent <percentage>), linear-gradient(to bottom, black var(--tw-mask-bottom-from), transparent <percentage>); | |
mask-composite: intersect;`, | |
], | |
[ | |
"mask-y-to-<color>", | |
dedent` | |
mask-image: linear-gradient(to bottom, black var(--tw-mask-top-from), <color> var(--tw-mask-top-to)), linear-gradient(to bottom, black var(--tw-mask-bottom-from), <color> var(--tw-mask-bottom-to)); | |
mask-composite: intersect;`, | |
], | |
[ | |
"mask-y-to-(<custom-property>)", | |
dedent` | |
mask-image: linear-gradient(to top, black var(--tw-mask-top-from), transparent var(<custom-property>)),linear-gradient(to bottom, black var(--tw-mask-bottom-from), transparent var(<custom-property>)); | |
mask-composite: intersect;`, | |
], | |
[ | |
"mask-y-to-[<value>]", | |
dedent` | |
mask-image: linear-gradient(to top, black var(--tw-mask-top-from), transparent <value>),linear-gradient(to bottom, black var(--tw-mask-bottom-from), transparent <value>); | |
mask-composite: intersect;`, | |
], | |
[ | |
"mask-x-from-<number>", | |
dedent` | |
mask-image: linear-gradient(to right, black calc(var(--spacing * <number>)), transparent var(--tw-mask-right-to)), linear-gradient(to left, black calc(var(--spacing * <number>)), transparent var(--tw-mask-left-to)); | |
mask-composite: intersect;`, | |
], | |
[ | |
"mask-x-from-<percentage>", | |
dedent` | |
mask-image: linear-gradient(to right, black <percentage>, transparent var(--tw-mask-right-to)), linear-gradient(to left, black <percentage>, transparent var(--tw-mask-left-to)); | |
mask-composite: intersect;`, | |
], | |
[ | |
"mask-x-from-<color>", | |
dedent` | |
mask-image: linear-gradient(to right, <color> var(--tw-mask-right-from), transparent var(--tw-mask-right-to)), linear-gradient(to left, <color> var(--tw-mask-left-from), transparent var(--tw-mask-left-to)); | |
mask-composite: intersect;`, | |
], | |
[ | |
"mask-x-from-(<custom-property>)", | |
dedent` | |
mask-image: linear-gradient(to right, black var(<custom-property>), transparent var(--tw-mask-right-to)), linear-gradient(to left, black var(<custom-property>), transparent var(--tw-mask-left-to)); | |
mask-composite: intersect;`, | |
], | |
[ | |
"mask-x-from-[<value>]", | |
dedent` | |
mask-image: linear-gradient(to right, black <value>, transparent var(--tw-mask-right-to)), linear-gradient(to left, black <value>, transparent var(--tw-mask-left-to)); | |
mask-composite: intersect;`, | |
], | |
[ | |
"mask-x-to-<number>", | |
dedent` | |
mask-image: linear-gradient(to right, black var(--tw-mask-right-from), transparent calc(var(--spacing * <number>)), linear-gradient(to left, black var(--tw-mask-left-from), transparent calc(var(--spacing * <number>)); | |
mask-composite: intersect;`, | |
], | |
[ | |
"mask-x-to-<percentage>", | |
dedent` | |
mask-image: linear-gradient(to left, black var(--tw-mask-right-from), transparent <percentage>), linear-gradient(to left, black var(--tw-mask-left-from), transparent <percentage>); | |
mask-composite: intersect;`, | |
], | |
[ | |
"mask-x-to-<color>", | |
dedent` | |
mask-image: linear-gradient(to left, black var(--tw-mask-right-from), <color> var(--tw-mask-right-to)), linear-gradient(to left, black var(--tw-mask-left-from), <color> var(--tw-mask-left-to)); | |
mask-composite: intersect;`, | |
], | |
[ | |
"mask-x-to-(<custom-property>)", | |
dedent` | |
mask-image: linear-gradient(to right, black var(--tw-mask-right-from), transparent var(<custom-property>)),linear-gradient(to left, black var(--tw-mask-left-from), transparent var(<custom-property>)); | |
mask-composite: intersect;`, | |
], | |
[ | |
"mask-x-to-[<value>]", | |
dedent` | |
mask-image: linear-gradient(to right, black var(--tw-mask-right-from), transparent <value>),linear-gradient(to left, black var(--tw-mask-left-from), transparent <value>); | |
mask-composite: intersect;`, | |
], | |
["mask-radial-[<value>]", "mask-image: radial-gradient(<value>);"], | |
["mask-radial-[<size>]", "--tw-mask-radial-size: <size>;"], | |
["mask-radial-[<size>_<size>]", "--tw-mask-radial-size: <size> <size>;"], | |
[ | |
"mask-radial-from-<number>", | |
"mask-image: radial-gradient(var(--tw-mask-radial-shape) var(--tw-mask-radial-size) at var(--tw-mask-radial-position), black calc(var(--spacing * <number>)), transparent var(--tw-mask-radial-to));", | |
], | |
[ | |
"mask-radial-from-<percentage>", | |
"mask-image: radial-gradient(var(--tw-mask-radial-shape) var(--tw-mask-radial-size) at var(--tw-mask-radial-position), black <percentage>, transparent var(--tw-mask-radial-to));", | |
], | |
[ | |
"mask-radial-from-<color>", | |
"mask-image: radial-gradient(var(--tw-mask-radial-shape) var(--tw-mask-radial-size) at var(--tw-mask-radial-position), <color> var(--tw-mask-radial-from), transparent var(--tw-mask-radial-to));", | |
], | |
[ | |
"mask-radial-from-(<custom-property>)", | |
"mask-image: radial-gradient(var(--tw-mask-radial-shape) var(--tw-mask-radial-size) at var(--tw-mask-radial-position), black var(<custom-property>), transparent var(--tw-mask-radial-to));", | |
], | |
[ | |
"mask-radial-from-[<value>]", | |
"mask-image: radial-gradient(var(--tw-mask-radial-shape) var(--tw-mask-radial-size) at var(--tw-mask-radial-position), black <value>, transparent var(--tw-mask-radial-to));", | |
], | |
[ | |
"mask-radial-to-<number>", | |
"mask-image: radial-gradient(var(--tw-mask-radial-shape) var(--tw-mask-radial-size) at var(--tw-mask-radial-position), black var(--tw-mask-radial-from), transparent calc(var(--spacing * <number>)));", | |
], | |
[ | |
"mask-radial-to-<percentage>", | |
"mask-image: radial-gradient(var(--tw-mask-radial-shape) var(--tw-mask-radial-size) at var(--tw-mask-radial-position), black var(--tw-mask-radial-from), transparent <percentage>);", | |
], | |
[ | |
"mask-radial-to-<color>", | |
"mask-image: radial-gradient(var(--tw-mask-radial-shape) var(--tw-mask-radial-size) at var(--tw-mask-radial-position), black var(--tw-mask-radial-from), <color> var(--tw-mask-radial-to));", | |
], | |
[ | |
"mask-radial-to-(<custom-property>)", | |
"mask-image: radial-gradient(var(--tw-mask-radial-shape) var(--tw-mask-radial-size) at var(--tw-mask-radial-position), black var(--tw-mask-radial-from), transparent var(<custom-property>));", | |
], | |
[ | |
"mask-radial-to-[<value>]", | |
"mask-image: radial-gradient(var(--tw-mask-radial-shape) var(--tw-mask-radial-size) at var(--tw-mask-radial-position), black var(--tw-mask-radial-from), transparent <value>);", | |
], | |
["mask-radial-circle", "--tw-mask-radial-shape: circle;"], | |
["mask-radial-ellipse", "--tw-mask-radial-shape: ellipse;"], | |
["mask-radial-closest-corner", "--tw-mask-radial-size: closest-corner;"], | |
["mask-radial-closest-side", "--tw-mask-radial-size: closest-side;"], | |
["mask-radial-farthest-corner", "--tw-mask-radial-size: farthest-corner;"], | |
["mask-radial-farthest-side", "--tw-mask-radial-size: farthest-side;"], | |
["mask-radial-at-top-left", "--tw-mask-radial-position: top left;"], | |
["mask-radial-at-top", "--tw-mask-radial-position: top;"], | |
["mask-radial-at-top-right", "--tw-mask-radial-position: top right;"], | |
["mask-radial-at-left", "--tw-mask-radial-position: left;"], | |
["mask-radial-at-center", "--tw-mask-radial-position:center;"], | |
["mask-radial-at-right", "--tw-mask-radial-position: right;"], | |
["mask-radial-at-bottom-left", "--tw-mask-radial-position: bottom left;"], | |
["mask-radial-at-bottom", "--tw-mask-radial-position: bottom;"], | |
["mask-radial-at-bottom-right", "--tw-mask-radial-position: bottom right;"], | |
[ | |
"mask-conic-<number>", | |
"mask-image: conic-gradient(from <number>deg, black var(--tw-mask-conic-from), transparent var(--tw-mask-conic-to));", | |
], | |
[ | |
"-mask-conic-<number>", | |
"mask-image: conic-gradient(from calc(<number>deg * -1), black var(--tw-mask-conic-from), transparent var(--tw-mask-conic-to));", | |
], | |
[ | |
"mask-conic-from-<number>", | |
"mask-image: conic-gradient(from var(--tw-mask-conic-position), black calc(var(--spacing * <number>)), transparent var(--tw-mask-conic-to));", | |
], | |
[ | |
"mask-conic-from-<percentage>", | |
"mask-image: conic-gradient(from var(--tw-mask-conic-position), black <percentage>, transparent var(--tw-mask-conic-to));", | |
], | |
[ | |
"mask-conic-from-<color>", | |
"mask-image: conic-gradient(from var(--tw-mask-conic-position), <color> var(--tw-mask-conic-from), transparent var(--tw-mask-conic-to));", | |
], | |
[ | |
"mask-conic-from-(<custom-property>)", | |
"mask-image: conic-gradient(from var(--tw-mask-conic-position), black var(<custom-property>), transparent var(--tw-mask-conic-to));", | |
], | |
[ | |
"mask-conic-from-[<value>]", | |
"mask-image: conic-gradient(from var(--tw-mask-conic-position), black <value>, transparent var(--tw-mask-conic-to));", | |
], | |
[ | |
"mask-conic-to-<number>", | |
"mask-image: conic-gradient(from var(--tw-mask-conic-position), black var(--tw-mask-conic-from), transparent calc(var(--spacing * <number>));", | |
], | |
[ | |
"mask-conic-to-<percentage>", | |
"mask-image: conic-gradient(from var(--tw-mask-conic-position), black var(--tw-mask-conic-from), transparent <percentage>);", | |
], | |
[ | |
"mask-conic-to-<color>", | |
"mask-image: conic-gradient(from var(--tw-mask-conic-position), black var(--tw-mask-conic-from), <color> var(--tw-mask-conic-to);", | |
], | |
[ | |
"mask-conic-to-(<custom-property>)", | |
"mask-image: conic-gradient(from var(--tw-mask-conic-position), black var(--tw-mask-conic-from), transparent var(<custom-property>);", | |
], | |
[ | |
"mask-conic-to-[<value>]", | |
"mask-image: conic-gradient(from var(--tw-mask-conic-position), black var(--tw-mask-conic-from), transparent <value>);", | |
], | |
]} | |
/> | |
## Examples | |
### Using an image mask | |
Use the `mask-[<value>]` syntax to set the mask image of an element: | |
<Figure> | |
<Example> | |
{ | |
<Stripes | |
border | |
className="relative mx-auto flex h-48 w-full max-w-96 items-center justify-center overflow-hidden rounded-lg sm:w-96" | |
> | |
<div | |
className="h-full w-full bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] bg-cover bg-center bg-no-repeat mask-size-[110%_90%] mask-center mask-no-repeat" | |
style={{ maskImage: `url(${maskImg.src})` }} | |
></div> | |
</Stripes> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-[url(/img/scribble.png)]] --> | |
<div class="mask-[url(/img/scribble.png)] bg-[url(/img/mountains.jpg)] ..."> | |
<!-- ... --> | |
</div> | |
``` | |
</Figure> | |
### Masking edges | |
Use utilities like `mask-b-from-<value>` and `mask-t-to-<value>` to add a linear gradient mask to a single side of an element: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="grid grid-cols-1 items-end gap-x-2 gap-y-8 p-8 text-center font-mono text-xs font-medium text-gray-500 max-sm:justify-between max-sm:px-2 sm:grid-cols-2 dark:text-gray-400"> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-t-from-50%</p> | |
<div className="grid aspect-3/2 w-48 grid-cols-1"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-t-from-50% bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-r-from-30%</p> | |
<div className="grid aspect-3/2 w-48 grid-cols-1"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-r-from-30% bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-l-from-50% mask-l-to-90%</p> | |
<div className="grid aspect-3/2 w-48 grid-cols-1"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-l-from-50% mask-l-to-90% bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-b-from-20% mask-b-to-80%</p> | |
<div className="grid aspect-3/2 w-48 grid-cols-1"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-b-from-20% mask-b-to-80% bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-t-from-50%,mask-r-from-30%,mask-l-from-50%,mask-l-to-90%,mask-b-from-20%,mask-b-to-80%] --> | |
<div class="mask-t-from-50% bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-r-from-30% bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-l-from-50% mask-l-to-90% bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-b-from-20% mask-b-to-80% bg-[url(/img/mountains.jpg)] ..."></div> | |
``` | |
</Figure> | |
Additionally, use utilities like `mask-x-from-70%` and `mask-y-to-90%` to apply a mask to two sides of an element at the same time: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="grid grid-cols-1 items-end gap-x-2 gap-y-8 p-8 text-center font-mono text-xs font-medium text-gray-500 max-sm:justify-between max-sm:px-2 sm:grid-cols-2 dark:text-gray-400"> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-x-from-70% mask-x-to-90%</p> | |
<div className="grid aspect-3/2 w-48 grid-cols-1"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-x-from-70% mask-x-to-90% bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-y-from-70% mask-y-to-90%</p> | |
<div className="grid aspect-3/2 w-48 grid-cols-1"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-y-from-70% mask-y-to-90% bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-x-from-70%,mask-x-to-90%,mask-y-from-70%,mask-y-to-90%] --> | |
<div class="mask-x-from-70% mask-x-to-90% bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-y-from-70% mask-y-to-90% bg-[url(/img/mountains.jpg)] ..."></div> | |
``` | |
</Figure> | |
By default, linear gradient masks transition from black to transparent, but you can customize the gradient colors using the `mask-<side>-from-<color>` and `mask-<side>-to-<color>` utilities. | |
### Adding an angled linear mask | |
Use utilities like `mask-linear-<angle>`, `mask-linear-from-20`, and `mask-linear-to-40` to add a custom linear gradient mask to an element: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="grid grid-cols-1 items-end gap-x-2 gap-y-8 p-8 text-center font-mono text-xs font-medium text-gray-500 max-sm:justify-between max-sm:px-2 sm:grid-cols-2 dark:text-gray-400"> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-linear-50</p> | |
<div className="grid aspect-3/2 w-48 grid-cols-1"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-linear-50 mask-linear-from-60% mask-linear-to-80% bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
<div className="flex flex-col items-center gap-3"> | |
<p>-mask-linear-50</p> | |
<div className="grid aspect-3/2 w-48 grid-cols-1"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] -mask-linear-50 mask-linear-from-60% mask-linear-to-80% bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-linear-50,mask-linear-from-60%,mask-linear-to-80%,-mask-linear-50] --> | |
<div class="mask-linear-50 mask-linear-from-60% mask-linear-to-80% bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="-mask-linear-50 mask-linear-from-60% mask-linear-to-80% bg-[url(/img/mountains.jpg)] ..."></div> | |
``` | |
</Figure> | |
### Adding a radial mask | |
Use the `mask-radial-from-<value>` and `mask-radial-to-<value>` utilities to add a radial gradient mask to an element: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="mx-auto flex items-center p-16 max-sm:p-6"> | |
<img | |
src={KeyboardLight.src} | |
className="aspect-square max-h-72 w-full mask-radial-[100%_200%] mask-radial-from-transparent mask-radial-from-15% mask-radial-to-black mask-radial-to-60% mask-radial-at-right object-cover object-top-left dark:hidden" | |
alt="" | |
/> | |
<img | |
src={KeyboardDark.src} | |
className="hidden aspect-square max-h-72 w-full mask-radial-[100%_200%] mask-radial-from-transparent mask-radial-from-15% mask-radial-to-black mask-radial-to-60% mask-radial-at-right object-cover object-top-left dark:block" | |
alt="" | |
/> | |
<div className="font-medium max-sm:-mx-3"> | |
<p className="font-mono text-xs text-blue-500 uppercase dark:text-blue-400">Speed</p> | |
<p className="mt-2 text-base whitespace-nowrap text-gray-700 dark:text-gray-300">Built for power users</p> | |
<p className="mt-1 text-sm leading-relaxed text-balance text-gray-500"> | |
Work faster than ever with our keyboard shortcuts | |
</p> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:mask-radial-from-75%] --> | |
<div class="flex items-center gap-4"> | |
<img class="mask-radial-[100%_100%] mask-radial-from-75% mask-radial-at-left ..." src="/img/keyboard.png" /> | |
<div class="font-medium"> | |
<p class="font-mono text-xs text-blue-500 uppercase dark:text-blue-400">Speed</p> | |
<p class="mt-2 text-base text-gray-700 dark:text-gray-300">Built for power users</p> | |
<p class="mt-1 text-sm leading-relaxed text-balance text-gray-500"> | |
Work faster than ever with customizable keyboard shortcuts | |
</p> | |
</div> | |
</div> | |
``` | |
</Figure> | |
By default, radial gradient masks transition from black to transparent, but you can customize the gradient colors using the `mask-radial-from-<color>` and `mask-radial-to-<color>` utilities. | |
#### Setting the radial position | |
Use utilities like `mask-radial-at-bottom-left` and `mask-radial-at-[35%_35%]` to set the position of the center of the radial gradient mask: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="grid grid-cols-1 items-end gap-x-2 gap-y-8 p-8 text-center font-mono text-xs font-medium text-gray-500 max-sm:justify-between max-sm:px-2 sm:grid-cols-3 dark:text-gray-400"> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-radial-at-top-left</p> | |
<div className="grid size-28 grid-cols-1 max-sm:size-24"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-[33%_33%] mask-radial-from-100% mask-radial-at-top-left bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-radial-at-top</p> | |
<div className="grid size-28 grid-cols-1 max-sm:size-24"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-[33%_33%] mask-radial-from-100% mask-radial-at-top bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-radial-at-top-right</p> | |
<div className="grid size-28 grid-cols-1 max-sm:size-24"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-[33%_33%] mask-radial-from-100% mask-radial-at-top-right bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-radial-at-left</p> | |
<div className="grid size-28 grid-cols-1 max-sm:size-24"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-[33%_33%] mask-radial-from-100% mask-radial-at-left bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-radial-at-center</p> | |
<div className="grid size-28 grid-cols-1 max-sm:size-24"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-[33%_33%] mask-radial-from-100% mask-radial-at-center bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-radial-at-right</p> | |
<div className="grid size-28 grid-cols-1 max-sm:size-24"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-[33%_33%] mask-radial-from-100% mask-radial-at-right bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-radial-at-bottom-left</p> | |
<div className="grid size-28 grid-cols-1 max-sm:size-24"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-[33%_33%] mask-radial-from-100% mask-radial-at-bottom-left bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-radial-at-bottom</p> | |
<div className="grid size-28 grid-cols-1 max-sm:size-24"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-[33%_33%] mask-radial-from-100% mask-radial-at-bottom bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-radial-at-bottom-right</p> | |
<div className="grid size-28 grid-cols-1 max-sm:size-24"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-[33%_33%] mask-radial-from-100% mask-radial-at-bottom-right bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-radial-at-top-left,mask-radial-at-top,mask-radial-at-top-right,mask-radial-at-left,mask-radial-at-center,mask-radial-at-right,mask-radial-at-bottom,mask-radial-at-bottom-left,mask-radial-at-bottom-right] --> | |
<div class="mask-radial-at-top-left mask-radial-from-100% bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-radial-at-top mask-radial-from-100% bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-radial-at-top-right mask-radial-from-100% bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-radial-at-left mask-radial-from-100% bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-radial-at-center mask-radial-from-100% bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-radial-at-right mask-radial-from-100% bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-radial-at-bottom-left mask-radial-from-100% bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-radial-at-bottom mask-radial-from-100% bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-radial-at-bottom-right mask-radial-from-100% bg-[url(/img/mountains.jpg)] ..."></div> | |
``` | |
</Figure> | |
This is different from [`mask-position`](/docs/mask-position) which sets the position of the mask image itself, not the radial gradient. | |
#### Setting the radial size | |
Use utilities like `mask-radial-closest-corner` and `mask-radial-farthest-side` to set the size of the radial gradient mask: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="grid grid-cols-1 items-end gap-x-2 gap-y-8 p-8 text-center font-mono text-xs font-medium text-gray-500 max-sm:justify-between max-sm:px-2 sm:grid-cols-2 dark:text-gray-400"> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-radial-closest-side</p> | |
<div className="grid aspect-3/2 w-48 grid-cols-1"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-from-100% mask-radial-closest-side mask-radial-at-[30%_30%] bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-radial-closest-corner</p> | |
<div className="grid aspect-3/2 w-48 grid-cols-1"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-from-100% mask-radial-closest-corner mask-radial-at-[30%_30%] bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-radial-farthest-side</p> | |
<div className="grid aspect-3/2 w-48 grid-cols-1"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-from-100% mask-radial-farthest-side mask-radial-at-[30%_30%] bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
<div className="flex flex-col items-center gap-3"> | |
<p>mask-radial-farthest-corner</p> | |
<div className="grid aspect-3/2 w-48 grid-cols-1"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-from-100% mask-radial-farthest-corner mask-radial-at-[30%_30%] bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-radial-farthest-corner,mask-radial-farthest-side,mask-radial-closest-corner,mask-radial-closest-side] --> | |
<div class="mask-radial-closest-side mask-radial-from-100% mask-radial-at-[30%_30%] bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-radial-closest-corner mask-radial-from-100% mask-radial-at-[30%_30%] bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-radial-farthest-side mask-radial-from-100% mask-radial-at-[30%_30%] bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-radial-farthest-corner mask-radial-from-100% mask-radial-at-[30%_30%] bg-[url(/img/mountains.jpg)] ..."></div> | |
``` | |
</Figure> | |
When setting a custom radial gradient size, the units you can use depend on the `<ending-shape>` of the gradient which is set to `ellipse` by default. | |
With `mask-circle`, you can only use a single fixed length, like `mask-radial-[5rem]`. Whereas with `mask-ellipse`, you can specify each axis as a fixed length or percentage, like `mask-radial-[40%_80%]`. | |
### Adding a conic mask | |
Use the `mask-conic-from-<value>`, `mask-conic-to-<value>` and `mask-conic-<angle>` utilities to add a conic gradient mask to an element: | |
<Figure> | |
<Example> | |
{ | |
<div className="mx-auto flex w-full max-w-sm items-center gap-5 rounded-xl bg-white p-4 shadow-lg ring-1 ring-black/5 dark:bg-gray-800"> | |
<div className="grid grid-cols-1 grid-rows-1"> | |
<div className="col-start-1 row-start-1 size-12 rounded-full border-4 border-gray-100 dark:border-gray-700" /> | |
<div className="col-start-1 row-start-1 size-12 rounded-full border-4 border-amber-500 mask-conic-from-75% mask-conic-to-75% dark:border-amber-400" /> | |
</div> | |
<div className="w-0 flex-1 text-sm text-gray-950 dark:text-white"> | |
<p className="font-medium">Storage used: 75%</p> | |
<p className="mt-1 text-gray-500 dark:text-gray-400"> | |
<span className="font-medium">0.48 GB</span> out of 2 GB remaining | |
</p> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:mask-conic-from-75%,mask-conic-to-75%] --> | |
<div class="flex items-center gap-5 rounded-xl bg-white p-4 shadow-lg ring-1 ring-black/5 dark:bg-gray-800"> | |
<div class="grid grid-cols-1 grid-rows-1"> | |
<div class="border-4 border-gray-100 dark:border-gray-700 ..."></div> | |
<div class="border-4 border-amber-500 mask-conic-from-75% mask-conic-to-75% dark:border-amber-400 ..."></div> | |
</div> | |
<div class="w-0 flex-1 text-sm text-gray-950 dark:text-white"> | |
<p class="font-medium">Storage used: 75%</p> | |
<p class="mt-1 text-gray-500 dark:text-gray-400"><span class="font-medium">0.48 GB</span> out of 2 GB remaining</p> | |
</div> | |
</div> | |
``` | |
</Figure> | |
By default, conic gradient masks transition from black to transparent, but you can customize the gradient colors using the `mask-conic-from-<color>` and `mask-conic-to-<color>` utilities. | |
### Combining masks | |
Gradient mask utilities, like `mask-radial-from-<value>`, `mask-conic-to-<value>`, and `mask-l-from-<value>` can be combined to create more complex gradient masks: | |
<Figure> | |
<Example> | |
{ | |
<div className="grid grid-cols-1 items-end gap-x-2 gap-y-8 p-8 text-center font-mono text-xs font-medium text-gray-500 max-sm:justify-between max-sm:px-2 sm:grid-cols-2 dark:text-gray-400"> | |
<div className="flex flex-col items-center"> | |
<div className="grid aspect-3/2 w-48 grid-cols-1"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-b-from-50% mask-radial-[50%_90%] mask-radial-from-80% mask-radial-at-bottom bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
<div className="flex flex-col items-center"> | |
<div className="grid aspect-3/2 w-48 grid-cols-1"> | |
<Stripes className="col-start-1 row-start-1 rounded-lg" border /> | |
<div className="col-start-1 row-start-1 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-r-from-80% mask-b-from-80% mask-radial-from-70% mask-radial-to-85% mask-circle mask-radial-at-top-left bg-cover bg-center mask-no-repeat"></div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-b-from-50%,mask-radial-[50%_90%],mask-radial-from-80%,mask-r-from-80%,mask-b-from-80%,mask-radial-from-70%,mask-radial-to-85%] --> | |
<div class="mask-b-from-50% mask-radial-[50%_90%] mask-radial-from-80% bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-r-from-80% mask-b-from-80% mask-radial-from-70% mask-radial-to-85% bg-[url(/img/mountains.jpg)] ..."></div> | |
``` | |
</Figure> | |
This behavior relies on the fact that Tailwind sets the [`mask-composite` property](/docs/mask-composite) to `intersect` by default. Changing this property will affect how the gradient masks are combined. | |
### Removing mask images | |
Use the `mask-none` utility to remove an existing mask image from an element: | |
```html | |
<!-- [!code classes:mask-none] --> | |
<div class="mask-none"> | |
<!-- ... --> | |
</div> | |
``` | |
### Using a custom value | |
<UsingACustomValue | |
utilities={["mask-linear", "mask-radial"]} | |
name="mask image" | |
value="70deg,transparent_10%,black,transparent_80%" | |
variable="mask" | |
/> | |
### Responsive design | |
<ResponsiveDesign property="mask-image" defaultClass="mask-radial-from-70%" featuredClass="mask-radial-from-50%" /> | |
## Customizing your theme | |
<CustomizingYourThemeColors utilities={["mask-radial-from", "mask-conic-to", "mask-b-from"]} /> | |
--- | |
File: /src/docs/mask-mode.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "mask-mode"; | |
export const description = "Utilities for controlling an element's mask mode."; | |
<svg className="sr-only"> | |
<defs> | |
<pattern id="checkerboard" x="0.5" y="0" width="10" height="10" patternUnits="userSpaceOnUse"> | |
<rect x="0" y="0" width="5" height="5" fill="#fff" /> | |
<rect x="5" y="0" width="5" height="5" fill="#808080" /> | |
<rect x="0" y="5" width="5" height="5" fill="#808080" /> | |
<rect x="5" y="5" width="5" height="5" fill="#fff" /> | |
</pattern> | |
</defs> | |
</svg> | |
<svg className="hidden"> | |
<symbol id="gradient-color-stop" viewBox="0 0 32 34"> | |
<path | |
fill="url(#checkerboard)" | |
stroke="#000" | |
strokeOpacity=".05" | |
d="M5 .5h22A3.5 3.5 0 0 1 30.5 4v19.6a3.5 3.5 0 0 1-1.853 3.088L16 33.433 3.353 26.688A3.5 3.5 0 0 1 1.5 23.6V4A3.5 3.5 0 0 1 5 .5Z" | |
/> | |
<path | |
fill="currentColor" | |
d="M1 4a4 4 0 0 1 4-4h22a4 4 0 0 1 4 4v19.6a4 4 0 0 1-2.118 3.53L16 34 3.118 27.13A4 4 0 0 1 1 23.6V4Z" | |
/> | |
</symbol> | |
</svg> | |
<ApiTable | |
rows={[ | |
["mask-alpha", "mask-mode: alpha;"], | |
["mask-luminance", "mask-mode: luminance;"], | |
["mask-match", "mask-mode: match-source;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use the `mask-alpha`, `mask-luminance` and `mask-match` utilities to control the mode of an element's mask: | |
<Figure> | |
<Example> | |
{ | |
<div className="mx-5 grid gap-10 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
<div> | |
<div className="relative h-[3.625rem]"> | |
<div className="absolute top-0 left-[50%] -ml-3 flex h-12 flex-col items-center"> | |
<svg viewBox="0 0 32 34" className="w-7 flex-none text-black drop-shadow-sm dark:stroke-white/10"> | |
<use href="#gradient-color-stop" /> | |
</svg> | |
<div className="mt-2 h-2 w-0.5 bg-gray-900/30 dark:bg-white/30"></div> | |
</div> | |
<div className="absolute top-0 right-px -mr-3 flex h-12 flex-col items-center"> | |
<svg viewBox="0 0 32 34" className="w-7 flex-none text-transparent drop-shadow-sm dark:stroke-white/10"> | |
<use href="#gradient-color-stop" /> | |
</svg> | |
<div className="mt-2 h-2 w-0.5 bg-gray-900/30 dark:bg-white/30"></div> | |
</div> | |
</div> | |
<div className="relative"> | |
<div className="relative z-10 h-24 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-r-from-black mask-r-from-50% mask-r-to-transparent bg-cover bg-center mask-alpha"></div> | |
<Stripes className="absolute inset-0 rounded-lg" border /> | |
</div> | |
<p className="mt-3">mask-alpha</p> | |
</div> | |
<div> | |
<div className="relative h-[3.625rem]"> | |
<div className="absolute top-0 left-[50%] -ml-3 flex h-12 flex-col items-center"> | |
<svg viewBox="0 0 32 34" className="w-7 flex-none text-white drop-shadow-sm dark:stroke-white/10"> | |
<use href="#gradient-color-stop" /> | |
</svg> | |
<div className="mt-2 h-2 w-0.5 bg-gray-900/30 dark:bg-white/30"></div> | |
</div> | |
<div className="absolute top-0 right-px -mr-3 flex h-12 flex-col items-center"> | |
<svg viewBox="0 0 32 34" className="w-7 flex-none text-black drop-shadow-sm dark:stroke-white/10"> | |
<use href="#gradient-color-stop" /> | |
</svg> | |
<div className="mt-2 h-2 w-0.5 bg-gray-900/30 dark:bg-white/30"></div> | |
</div> | |
</div> | |
<div className="relative"> | |
<div className="relative z-10 h-24 rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-r-from-white mask-r-from-50% mask-r-to-black bg-cover bg-center mask-luminance"></div> | |
<Stripes className="absolute inset-0 rounded-lg" border /> | |
</div> | |
<p className="mt-3">mask-luminance</p> | |
</div> | |
</div> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-alpha,mask-luminance] --> | |
<div class="mask-alpha mask-r-from-black mask-r-from-50% mask-r-to-transparent bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-luminance mask-r-from-white mask-r-from-50% mask-r-to-black bg-[url(/img/mountains.jpg)] ..."></div> | |
``` | |
</Figure> | |
When using `mask-luminance` the luminance value of the mask determines visibility, so sticking with grayscale colors will produce the most predictable results. With `mask-alpha`, the opacity of the mask determines the visibility of the masked element. | |
### Responsive design | |
<ResponsiveDesign property="mask-mode" defaultClass="mask-alpha" featuredClass="mask-luminance" /> | |
--- | |
File: /src/docs/mask-origin.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
export const title = "mask-origin"; | |
export const description = | |
"Utilities for controlling how an element's mask image is positioned relative to borders, padding, and content."; | |
<ApiTable | |
rows={[ | |
["mask-origin-border", "mask-origin: border-box;"], | |
["mask-origin-padding", "mask-origin: padding-box;"], | |
["mask-origin-content", "mask-origin: content-box;"], | |
["mask-origin-fill", "mask-origin: fill-box;"], | |
["mask-origin-stroke", "mask-origin: stroke-box;"], | |
["mask-origin-view", "mask-origin: view-box;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `mask-origin-border`, `mask-origin-padding`, and `mask-origin-content` to control where an element's mask is rendered: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col gap-y-10 text-center font-mono text-xs font-medium text-gray-500 sm:flex-row sm:justify-between dark:text-gray-400"> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3">mask-origin-border</p> | |
<div className="relative size-24 rounded-lg border-3 border-dashed border-indigo-500/50 dark:border-indigo-400/75"> | |
<div className="absolute -inset-[3px] bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-[50%_50%] mask-radial-from-100% bg-cover bg-center mask-no-repeat mask-origin-border p-1.5"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3">mask-origin-padding</p> | |
<div className="relative size-24 rounded-lg border-3 border-dashed border-indigo-500/50 dark:border-indigo-400/75"> | |
<div className="absolute -inset-[3px] rounded-lg border-3 bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-[50%_50%] mask-radial-from-100% bg-cover bg-center mask-no-repeat mask-origin-padding p-1.5"></div> | |
</div> | |
</div> | |
<div className="flex shrink-0 flex-col items-center"> | |
<p className="mb-3">mask-origin-content</p> | |
<div className="relative size-24 rounded-lg border-3 border-dashed border-indigo-500/50 dark:border-indigo-400/75"> | |
<div className="absolute -inset-[3px] rounded-lg border-3 bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-[50%_50%] mask-radial-from-100% bg-cover bg-center mask-no-repeat mask-origin-content p-1.5"></div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-origin-border,mask-origin-padding,mask-origin-content] --> | |
<div class="mask-origin-border border-3 p-1.5 mask-[url(/img/circle.png)] bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-origin-padding border-3 p-1.5 mask-[url(/img/circle.png)] bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-origin-content border-3 p-1.5 mask-[url(/img/circle.png)] bg-[url(/img/mountains.jpg)] ..."></div> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="mask-origin" defaultClass="mask-origin-border" featuredClass="mask-origin-padding" /> | |
--- | |
File: /src/docs/mask-position.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "mask-position"; | |
export const description = "Utilities for controlling the position of an element's mask image."; | |
<ApiTable | |
rows={[ | |
["mask-top-left", "mask-position: top left;"], | |
["mask-top", "mask-position: top;"], | |
["mask-top-right", "mask-position: top right;"], | |
["mask-left", "mask-position: left;"], | |
["mask-center", "mask-position: center;"], | |
["mask-right", "mask-position: right;"], | |
["mask-bottom-left", "mask-position: bottom left;"], | |
["mask-bottom", "mask-position: bottom;"], | |
["mask-bottom-right", "mask-position: bottom right;"], | |
["mask-position-(<custom-property>)", "mask-position: var(<custom-property>);"], | |
["mask-position-[<value>]", "mask-position: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use utilities like `mask-center`, `mask-right`, and `mask-left-top` to control the position of an element's mask image: | |
<Figure> | |
<Example padding={false}> | |
{ | |
<div className="grid grid-cols-3 gap-y-8 p-8 text-center font-mono text-xs font-medium text-gray-500 max-sm:items-end max-sm:justify-between max-sm:px-2 dark:text-gray-400"> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3">mask-top-left</p> | |
<Stripes className="aspect-[1.333] w-32 rounded-lg max-sm:w-24" border> | |
<div className="h-full rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-from-70% mask-radial-to-70% bg-cover bg-center mask-size-[50%_66%] mask-top-left mask-no-repeat"></div> | |
</Stripes> | |
</div> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3">mask-top</p> | |
<Stripes className="aspect-[1.333] w-32 rounded-lg max-sm:w-24" border> | |
<div className="h-full rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-from-70% mask-radial-to-70% bg-cover bg-center mask-size-[50%_66%] mask-top mask-no-repeat"></div> | |
</Stripes> | |
</div> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3">mask-top-right</p> | |
<Stripes className="aspect-[1.333] w-32 rounded-lg max-sm:w-24" border> | |
<div className="h-full rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-from-70% mask-radial-to-70% bg-cover bg-center mask-size-[50%_66%] mask-top-right mask-no-repeat"></div> | |
</Stripes> | |
</div> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3">mask-left</p> | |
<Stripes className="aspect-[1.333] w-32 rounded-lg max-sm:w-24" border> | |
<div className="h-full rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-from-70% mask-radial-to-70% bg-cover bg-center mask-size-[50%_66%] mask-left mask-no-repeat"></div> | |
</Stripes> | |
</div> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3">mask-center</p> | |
<Stripes className="aspect-[1.333] w-32 rounded-lg max-sm:w-24" border> | |
<div className="h-full rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-from-70% mask-radial-to-70% bg-cover bg-center mask-size-[50%_66%] mask-center mask-no-repeat"></div> | |
</Stripes> | |
</div> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3">mask-right</p> | |
<Stripes className="aspect-[1.333] w-32 rounded-lg max-sm:w-24" border> | |
<div className="h-full rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-from-70% mask-radial-to-70% bg-cover bg-center mask-size-[50%_66%] mask-right mask-no-repeat"></div> | |
</Stripes> | |
</div> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3">mask-bottom-left</p> | |
<Stripes className="aspect-[1.333] w-32 rounded-lg max-sm:w-24" border> | |
<div className="h-full rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-from-70% mask-radial-to-70% bg-cover bg-center mask-size-[50%_66%] mask-bottom-left mask-no-repeat"></div> | |
</Stripes> | |
</div> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3">mask-bottom</p> | |
<Stripes className="aspect-[1.333] w-32 rounded-lg max-sm:w-24" border> | |
<div className="h-full rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-from-70% mask-radial-to-70% bg-cover bg-center mask-size-[50%_66%] mask-bottom mask-no-repeat"></div> | |
</Stripes> | |
</div> | |
<div className="flex flex-col items-center"> | |
<p className="mb-3">mask-bottom-right</p> | |
<Stripes className="aspect-[1.333] w-32 rounded-lg max-sm:w-24" border> | |
<div className="h-full rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-from-70% mask-radial-to-70% bg-cover bg-center mask-size-[50%_66%] mask-bottom-right mask-no-repeat"></div> | |
</Stripes> | |
</div> | |
</div> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-top-left,mask-top,mask-top-right,mask-left,mask-center,mask-right,mask-bottom-left,mask-bottom,mask-bottom-right] --> | |
<div class="mask-top-left mask-[url(/img/circle.png)] mask-size-[50%] bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-top mask-[url(/img/circle.png)] mask-size-[50%] bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-top-right mask-[url(/img/circle.png)] mask-size-[50%] bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-left mask-[url(/img/circle.png)] mask-size-[50%] bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-center mask-[url(/img/circle.png)] mask-size-[50%] bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-right mask-[url(/img/circle.png)] mask-size-[50%] bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-bottom-left mask-[url(/img/circle.png)] mask-size-[50%] bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-bottom mask-[url(/img/circle.png)] mask-size-[50%] bg-[url(/img/mountains.jpg)] ..."></div> | |
<div class="mask-bottom-right mask-[url(/img/circle.png)] mask-size-[50%] bg-[url(/img/mountains.jpg)] ..."></div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="mask-position" value="center_top_1rem" name="mask position" variable="mask-position" /> | |
### Responsive design | |
<ResponsiveDesign property="mask-position" defaultClass="mask-center" featuredClass="mask-top" /> | |
--- | |
File: /src/docs/mask-repeat.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "mask-repeat"; | |
export const description = "Utilities for controlling the repetition of an element's mask image."; | |
<ApiTable | |
rows={[ | |
["mask-repeat", "mask-repeat: repeat;"], | |
["mask-no-repeat", "mask-repeat: no-repeat;"], | |
["mask-repeat-x", "mask-repeat: repeat-x;"], | |
["mask-repeat-y", "mask-repeat: repeat-y;"], | |
["mask-repeat-space", "mask-repeat: space;"], | |
["mask-repeat-round", "mask-repeat: round;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use the `mask-repeat` utility to repeat the mask image both vertically and horizontally: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col py-8"> | |
<Stripes className="h-40 w-full rounded-lg" border> | |
<div className="h-full rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-from-100% mask-radial-closest-side bg-cover bg-center mask-size-[50px_50px] mask-center mask-repeat"></div> | |
</Stripes> | |
</div> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-repeat] --> | |
<div class="mask-repeat mask-[url(/img/circle.png)] mask-size-[50px_50px] bg-[url(/img/mountains.jpg)] ..."></div> | |
``` | |
</Figure> | |
### Repeating horizontally | |
Use the `mask-repeat-x` utility to only repeat the mask image horizontally: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col py-8"> | |
<Stripes className="h-40 w-full rounded-lg" border> | |
<div className="h-full rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-from-100% mask-radial-closest-side bg-cover bg-center mask-size-[50px_50px] mask-center mask-repeat-x"></div> | |
</Stripes> | |
</div> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-repeat-x] --> | |
<div class="mask-repeat-x mask-[url(/img/circle.png)] mask-size-[50px_50px] bg-[url(/img/mountains.jpg)]..."></div> | |
``` | |
</Figure> | |
### Repeating vertically | |
Use the `mask-repeat-y` utility to only repeat the mask image vertically: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col py-8"> | |
<Stripes className="h-40 w-full rounded-lg" border> | |
<div className="h-full rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-from-100% mask-radial-closest-side bg-cover bg-center mask-size-[50px_50px] mask-center mask-repeat-y"></div> | |
</Stripes> | |
</div> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-repeat-y] --> | |
<div class="mask-repeat-y mask-[url(/img/circle.png)] mask-size-[50px_50px] bg-[url(/img/mountains.jpg)]..."></div> | |
``` | |
</Figure> | |
### Preventing clipping | |
Use the `mask-repeat-space` utility to repeat the mask image without clipping: | |
<Figure> | |
<Example resizable> | |
{ | |
<div className="flex flex-col py-8"> | |
<Stripes className="h-40 w-full rounded-lg" border> | |
<div className="h-full rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-from-100% mask-radial-closest-side bg-cover bg-center mask-size-[50px_50px] mask-repeat-space"></div> | |
</Stripes> | |
</div> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-repeat-space] --> | |
<div class="mask-repeat-space mask-[url(/img/circle.png)] mask-size-[50px_50px] bg-[url(/img/mountains.jpg)] ..."></div> | |
``` | |
</Figure> | |
### Preventing clipping and gaps | |
Use the `mask-repeat-round` utility to repeat the mask image without clipping, stretching if needed to avoid gaps: | |
<Figure> | |
<Example resizable> | |
{ | |
<div className="flex flex-col py-8"> | |
<Stripes className="h-40 w-full rounded-lg" border> | |
<div className="h-full rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-from-100% mask-radial-closest-side bg-cover bg-center mask-size-[50px_50px] mask-repeat-round"></div> | |
</Stripes> | |
</div> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-repeat-round] --> | |
<div class="mask-repeat-round mask-[url(/img/circle.png)] mask-size-[50px_50px] bg-[url(/img/mountains.jpg)] ..."></div> | |
``` | |
</Figure> | |
### Disabling repeating | |
Use the `mask-no-repeat` utility to prevent a mask image from repeating: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex flex-col py-8"> | |
<Stripes className="h-40 w-full rounded-lg" border> | |
<div className="h-full rounded-lg bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] mask-radial-from-100% mask-radial-closest-side bg-cover bg-center mask-size-[50px_50px] mask-center mask-no-repeat"></div> | |
</Stripes> | |
</div> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-no-repeat] --> | |
<div class="mask-no-repeat mask-[url(/img/circle.png)] mask-size-[50px_50px] bg-[url(/img/mountains.jpg)] ..."></div> | |
``` | |
</Figure> | |
### Responsive design | |
<ResponsiveDesign property="mask-repeat" defaultClass="mask-repeat" featuredClass="mask-repeat-x" /> | |
--- | |
File: /src/docs/mask-size.mdx | |
--- | |
import maskImg from "@/docs/img/mask.png"; | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "mask-size"; | |
export const description = "Utilities for controlling the size of an element's mask image."; | |
<ApiTable | |
rows={[ | |
["mask-auto", "mask-size: auto;"], | |
["mask-cover", "mask-size: cover;"], | |
["mask-contain", "mask-size: contain;"], | |
["mask-size-(<custom-property>)", "mask-size: var(<custom-property>);"], | |
["mask-size-[<value>]", "mask-size: <value>;"], | |
]} | |
/> | |
## Examples | |
### Filling the container | |
Use the `mask-cover` utility to scale the mask image until it fills the mask layer, cropping the image if needed: | |
<Figure> | |
<Example> | |
{ | |
<Stripes border className="mx-auto h-48 w-96 overflow-hidden rounded-lg sm:w-96"> | |
<div | |
className="h-full w-full bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] bg-cover bg-center bg-no-repeat mask-cover mask-center" | |
style={{ maskImage: `url(${maskImg.src})` }} | |
></div> | |
</Stripes> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-cover] --> | |
<div class="mask-cover mask-[url(/img/scribble.png)] bg-[url(/img/mountains.jpg)] ..."></div> | |
``` | |
</Figure> | |
### Filling without cropping | |
Use the `mask-contain` utility to scale the mask image to the outer edges without cropping or stretching: | |
<Figure> | |
<Example> | |
{ | |
<Stripes border className="mx-auto h-48 w-96 overflow-hidden rounded-lg sm:w-96"> | |
<div | |
className="h-full w-full bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] bg-cover bg-center bg-no-repeat mask-contain mask-center mask-no-repeat" | |
style={{ maskImage: `url(${maskImg.src})` }} | |
></div> | |
</Stripes> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-contain] --> | |
<div class="mask-contain mask-[url(/img/scribble.png)] bg-[url(/img/mountains.jpg)] ..."></div> | |
``` | |
</Figure> | |
### Using the default size | |
Use the `mask-auto` utility to display the mask image at its default size: | |
<Figure> | |
<Example> | |
{ | |
<Stripes border className="mx-auto h-48 w-96 overflow-hidden rounded-lg sm:w-96"> | |
<div | |
className="h-full w-full bg-[url(https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80)] bg-cover bg-center bg-no-repeat mask-auto mask-center mask-no-repeat" | |
style={{ maskImage: `url(${maskImg.src})` }} | |
></div> | |
</Stripes> | |
} | |
</Example> | |
{/* prettier-ignore */} | |
```html | |
<!-- [!code classes:mask-auto] --> | |
<div class="mask-auto mask-[url(/img/scribble.png)] bg-[url(/img/mountains.jpg)] ..."></div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="mask-size" value="auto_100px" name="mask image size" variable="mask-size" /> | |
### Responsive design | |
<ResponsiveDesign property="mask-size" defaultClass="mask-auto" featuredClass="mask-contain" /> | |
--- | |
File: /src/docs/mask-type.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { ResponsiveDesign } from "@/components/content.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "mask-type"; | |
export const description = "Utilities for controlling how an SVG mask is interpreted."; | |
<ApiTable | |
rows={[ | |
["mask-type-alpha", "mask-type: alpha;"], | |
["mask-type-luminance", "mask-type: luminance;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use the `mask-type-alpha` and `mask-type-luminance` utilities to control the type of an SVG mask: | |
<Figure> | |
<Example> | |
{ | |
<div> | |
<Stripes | |
border | |
className="relative mx-auto flex h-48 max-w-96 items-center justify-center overflow-hidden rounded-lg sm:w-96" | |
> | |
<svg viewBox="0 0 384 192"> | |
<mask id="blob1" className="mask-type-alpha fill-gray-700/70"> | |
<path d="M138.25 45.9161c34.504 -4.0384 45.586 -8.2996 69.504 -26.7274c35.516 -27.35568 88.5 -27.47958 103.651 24.8472c11.65 40.2452 0.417 90.1771 -25.438 113.0701c-43.537 38.552 -124.113 45.445 -174.128 15.703c-43.1183 -25.637 -56.9741 -74.9589 -30.0882 -107.1019c9.1187 -10.902 23.4522 -15.924 56.4992 -19.791z" /> | |
</mask> | |
<image | |
href="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80" | |
height="100%" | |
width="100%" | |
preserveAspectRatio="xMaxYMid slice" | |
mask="url(#blob1)" | |
/> | |
</svg> | |
</Stripes> | |
<p className="mt-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400">mask-type-alpha</p> | |
<Stripes | |
border | |
className="relative mx-auto mt-8 flex h-48 max-w-96 items-center justify-center overflow-hidden rounded-lg sm:w-96" | |
> | |
<svg viewBox="0 0 384 192"> | |
<mask id="blob2" className="mask-type-luminance fill-gray-700/70"> | |
<path d="M138.25 45.9161c34.504 -4.0384 45.586 -8.2996 69.504 -26.7274c35.516 -27.35568 88.5 -27.47958 103.651 24.8472c11.65 40.2452 0.417 90.1771 -25.438 113.0701c-43.537 38.552 -124.113 45.445 -174.128 15.703c-43.1183 -25.637 -56.9741 -74.9589 -30.0882 -107.1019c9.1187 -10.902 23.4522 -15.924 56.4992 -19.791z" /> | |
</mask> | |
<image | |
href="https://images.unsplash.com/photo-1554629947-334ff61d85dc?ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&ixlib=rb-1.2.1&auto=format&fit=crop&w=1000&h=1000&q=80" | |
height="100%" | |
width="100%" | |
preserveAspectRatio="xMaxYMid slice" | |
mask="url(#blob2)" | |
/> | |
</svg> | |
</Stripes> | |
<p className="mt-3 text-center font-mono text-xs font-medium text-gray-500 dark:text-gray-400"> | |
mask-type-luminance | |
</p> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:mask-type-alpha,mask-type-luminance] --> | |
<svg> | |
<mask id="blob1" class="mask-type-alpha fill-gray-700/70"> | |
<path d="..."></path> | |
</mask> | |
<image href="/img/mountains.jpg" height="100%" width="100%" mask="url(#blob1)" /> | |
</svg> | |
<svg> | |
<mask id="blob2" class="mask-type-luminance fill-gray-700/70"> | |
<path d="..."></path> | |
</mask> | |
<image href="/img/mountains.jpg" height="100%" width="100%" mask="url(#blob2)" /> | |
</svg> | |
``` | |
</Figure> | |
When using `mask-type-luminance` the luminance value of the SVG mask determines visibility, so sticking with grayscale colors will produce the most predictable results. With `mask-alpha`, the opacity of the SVG mask determines the visibility of the masked element. | |
### Responsive design | |
<ResponsiveDesign | |
element="mask" | |
property="mask-type" | |
defaultClass="mask-type-alpha" | |
featuredClass="mask-type-luminance" | |
/> | |
--- | |
File: /src/docs/max-height.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourSpacingScale, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "max-height"; | |
export const description = "Utilities for setting the maximum height of an element."; | |
<ApiTable | |
rows={[ | |
["max-h-<number>", "max-height: calc(var(--spacing) * <number>);"], | |
["max-h-<fraction>", "max-height: calc(<fraction> * 100%);"], | |
["max-h-none", "max-height: none;"], | |
["max-h-px", "max-height: 1px;"], | |
["max-h-full", "max-height: 100%;"], | |
["max-h-screen", "max-height: 100vh;"], | |
["max-h-dvh", "max-height: 100dvh;"], | |
["max-h-dvw", "max-height: 100dvw;"], | |
["max-h-lvh", "max-height: 100lvh;"], | |
["max-h-lvw", "max-height: 100lvw;"], | |
["max-h-svh", "max-height: 100svh;"], | |
["max-h-svw", "max-height: 100svw;"], | |
["max-h-min", "max-height: min-content;"], | |
["max-h-max", "max-height: max-content;"], | |
["max-h-fit", "max-height: fit-content;"], | |
["max-h-lh", "max-height: 1lh;"], | |
["max-h-(<custom-property>)", "max-height: var(<custom-property>);"], | |
["max-h-[<value>]", "max-height: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use `max-h-<number>` utilities like `max-h-24` and `max-h-64` to set an element to a fixed maximum height based on the spacing scale: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex h-96 items-end justify-center space-x-4 text-center font-mono text-xs font-bold text-white"> | |
<div className="relative grid h-full w-8 items-end rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative h-full max-h-80 w-full rounded-lg bg-blue-500"> | |
<div className="absolute bottom-6 w-8 -rotate-90 text-nowrap">max-h-80</div> | |
</div> | |
</div> | |
<div className="relative grid h-full w-8 items-end rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative h-full max-h-64 w-full rounded-lg bg-blue-500"> | |
<div className="absolute bottom-6 w-8 -rotate-90 text-nowrap">max-h-64</div> | |
</div> | |
</div> | |
<div className="relative grid h-full w-8 items-end rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative h-full max-h-48 w-full rounded-lg bg-blue-500"> | |
<div className="absolute bottom-6 w-8 -rotate-90 text-nowrap">max-h-48</div> | |
</div> | |
</div> | |
<div className="relative grid h-full w-8 items-end rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative h-full max-h-40 w-full rounded-lg bg-blue-500"> | |
<div className="absolute bottom-6 w-8 -rotate-90 text-nowrap">max-h-40</div> | |
</div> | |
</div> | |
<div className="relative grid h-full w-8 items-end rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative h-full max-h-32 w-full rounded-lg bg-blue-500"> | |
<div className="absolute bottom-6 w-8 -rotate-90 text-nowrap">max-h-32</div> | |
</div> | |
</div> | |
<div className="relative grid h-full w-8 items-end rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative h-full max-h-24 w-full rounded-lg bg-blue-500"> | |
<div className="absolute bottom-6 w-8 -rotate-90 text-nowrap">max-h-24</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:max-h-80,max-h-64,max-h-48,max-h-40,max-h-32,max-h-24,max-h-full] --> | |
<div class="h-96 ..."> | |
<div class="h-full max-h-80 ...">max-h-80</div> | |
<div class="h-full max-h-64 ...">max-h-64</div> | |
<div class="h-full max-h-48 ...">max-h-48</div> | |
<div class="h-full max-h-40 ...">max-h-40</div> | |
<div class="h-full max-h-32 ...">max-h-32</div> | |
<div class="h-full max-h-24 ...">max-h-24</div> | |
</div> | |
``` | |
</Figure> | |
### Using a percentage | |
Use `max-h-full` or `max-h-<fraction>` utilities like `max-h-1/2` and `max-h-2/5` to give an element a percentage-based maximum height: | |
<Figure> | |
<Example> | |
{ | |
<div className="flex h-96 items-end justify-center space-x-4 text-center font-mono text-xs font-bold text-white"> | |
<div className="relative grid h-full w-8 items-end rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative h-full max-h-9/10 w-full rounded-lg bg-blue-500"> | |
<div className="absolute bottom-6 w-8 -rotate-90 text-nowrap">max-h-9/10</div> | |
</div> | |
</div> | |
<div className="relative grid h-full w-8 items-end rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative h-full max-h-3/4 w-full rounded-lg bg-blue-500"> | |
<div className="absolute bottom-6 w-8 -rotate-90 text-nowrap">max-h-3/4</div> | |
</div> | |
</div> | |
<div className="relative grid h-full w-8 items-end rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative h-full max-h-1/2 w-full rounded-lg bg-blue-500"> | |
<div className="absolute bottom-6 w-8 -rotate-90 text-nowrap">max-h-1/2</div> | |
</div> | |
</div> | |
<div className="relative grid h-full w-8 items-end rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative h-full max-h-1/4 w-full rounded-lg bg-blue-500"> | |
<div className="absolute bottom-6 w-8 -rotate-90 text-nowrap">max-h-1/4</div> | |
</div> | |
</div> | |
<div className="relative grid h-full w-8 items-end rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative h-full max-h-full w-full rounded-lg bg-blue-500"> | |
<div className="absolute bottom-6 w-8 -rotate-90 text-nowrap">max-h-full</div> | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:max-h-9/10,max-h-3/4,max-h-1/2,max-h-1/4,max-h-full] --> | |
<div class="h-96 ..."> | |
<div class="h-full max-h-9/10 ...">max-h-9/10</div> | |
<div class="h-full max-h-3/4 ...">max-h-3/4</div> | |
<div class="h-full max-h-1/2 ...">max-h-1/2</div> | |
<div class="h-full max-h-1/4 ...">max-h-1/4</div> | |
<div class="h-full max-h-full ...">max-h-full</div> | |
</div> | |
``` | |
</Figure> | |
### Using a custom value | |
<UsingACustomValue utility="max-h" value="220px" name="maximum height" variable="max-height" /> | |
### Responsive design | |
<ResponsiveDesign property="max-height" defaultClass="h-48 max-h-full" featuredClass="max-h-screen" /> | |
## Customizing your theme | |
<CustomizingYourSpacingScale utility="max-h" /> | |
--- | |
File: /src/docs/max-width.mdx | |
--- | |
import dedent from "dedent"; | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourSpacingScale, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "max-width"; | |
export const description = "Utilities for setting the maximum width of an element."; | |
<ApiTable | |
rows={[ | |
["max-w-<number>", "max-width: calc(var(--spacing) * <number>);"], | |
["max-w-<fraction>", "max-width: calc(<fraction> * 100%);"], | |
["max-w-3xs", "max-width: var(--container-3xs); /* 16rem (256px) */"], | |
["max-w-2xs", "max-width: var(--container-2xs); /* 18rem (288px) */"], | |
["max-w-xs", "max-width: var(--container-xs); /* 20rem (320px) */"], | |
["max-w-sm", "max-width: var(--container-sm); /* 24rem (384px) */"], | |
["max-w-md", "max-width: var(--container-md); /* 28rem (448px) */"], | |
["max-w-lg", "max-width: var(--container-lg); /* 32rem (512px) */"], | |
["max-w-xl", "max-width: var(--container-xl); /* 36rem (576px) */"], | |
["max-w-2xl", "max-width: var(--container-2xl); /* 42rem (672px) */"], | |
["max-w-3xl", "max-width: var(--container-3xl); /* 48rem (768px) */"], | |
["max-w-4xl", "max-width: var(--container-4xl); /* 56rem (896px) */"], | |
["max-w-5xl", "max-width: var(--container-5xl); /* 64rem (1024px) */"], | |
["max-w-6xl", "max-width: var(--container-6xl); /* 72rem (1152px) */"], | |
["max-w-7xl", "max-width: var(--container-7xl); /* 80rem (1280px) */"], | |
["max-w-none", "max-width: none;"], | |
["max-w-px", "max-width: 1px;"], | |
["max-w-full", "max-width: 100%;"], | |
["max-w-dvw", "max-width: 100dvw;"], | |
["max-w-dvh", "max-width: 100dvh;"], | |
["max-w-lvw", "max-width: 100lvw;"], | |
["max-w-lvh", "max-width: 100lvh;"], | |
["max-w-svw", "max-width: 100svw;"], | |
["max-w-svh", "max-width: 100svh;"], | |
["max-w-screen", "max-width: 100vw;"], | |
["max-w-min", "max-width: min-content;"], | |
["max-w-max", "max-width: max-content;"], | |
["max-w-fit", "max-width: fit-content;"], | |
[ | |
"container", | |
dedent` | |
width: 100%; | |
@media (width >= 40rem) { max-width: 40rem; } | |
@media (width >= 48rem) { max-width: 48rem; } | |
@media (width >= 64rem) { max-width: 64rem; } | |
@media (width >= 80rem) { max-width: 80rem; } | |
@media (width >= 96rem) { max-width: 96rem; } | |
`, | |
], | |
["max-w-(<custom-property>)", "max-width: var(<custom-property>);"], | |
["max-w-[<value>]", "max-width: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use `max-w-<number>` utilities like `max-w-24` and `max-w-64` to set an element to a fixed maximum width based on the spacing scale: | |
<Figure hint="Resize the example to see the expected behavior"> | |
<Example resizable> | |
{ | |
<div className="align-start grid gap-4 text-center font-mono text-xs font-bold text-white"> | |
<div className="relative grid w-full rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative max-w-96 rounded-lg bg-blue-500 px-4 py-2">max-w-96</div> | |
</div> | |
<div className="relative grid w-full rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative max-w-80 rounded-lg bg-blue-500 px-4 py-2">max-w-80</div> | |
</div> | |
<div className="relative grid w-full rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative max-w-64 rounded-lg bg-blue-500 px-4 py-2">max-w-64</div> | |
</div> | |
<div className="relative grid w-full rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative max-w-48 rounded-lg bg-blue-500 px-4 py-2">max-w-48</div> | |
</div> | |
<div className="relative grid w-full rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative max-w-40 rounded-lg bg-blue-500 px-4 py-2">max-w-40</div> | |
</div> | |
<div className="relative grid w-full rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative max-w-32 rounded-lg bg-blue-500 px-4 py-2">max-w-32</div> | |
</div> | |
<div className="relative grid w-full rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative max-w-24 rounded-lg bg-blue-500 px-4 py-2">max-w-24</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:max-w-96,max-w-80,max-w-64,max-w-48,max-w-40,max-w-32,max-w-24] --> | |
<div class="w-full max-w-96 ...">max-w-96</div> | |
<div class="w-full max-w-80 ...">max-w-80</div> | |
<div class="w-full max-w-64 ...">max-w-64</div> | |
<div class="w-full max-w-48 ...">max-w-48</div> | |
<div class="w-full max-w-40 ...">max-w-40</div> | |
<div class="w-full max-w-32 ...">max-w-32</div> | |
<div class="w-full max-w-24 ...">max-w-24</div> | |
``` | |
</Figure> | |
### Using a percentage | |
Use `max-w-full` or `max-w-<fraction>` utilities like `max-w-1/2` and `max-w-2/5` to give an element a percentage-based maximum width: | |
<Figure hint="Resize the example to see the expected behavior"> | |
<Example resizable> | |
{ | |
<div className="align-start grid gap-4 text-center font-mono text-xs font-bold text-white"> | |
<div className="relative grid w-full rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative max-w-9/10 truncate rounded-lg bg-indigo-500 px-4 py-2 text-nowrap">max-w-9/10</div> | |
</div> | |
<div className="relative grid w-full rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative max-w-3/4 truncate rounded-lg bg-indigo-500 px-4 py-2 text-nowrap">max-w-3/4</div> | |
</div> | |
<div className="relative grid w-full rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative max-w-1/2 truncate rounded-lg bg-indigo-500 px-4 py-2 text-nowrap">max-w-1/2</div> | |
</div> | |
<div className="relative grid w-full rounded-lg"> | |
<Stripes border className="absolute inset-0 h-full rounded-lg" /> | |
<div className="relative max-w-1/3 truncate rounded-lg bg-indigo-500 px-4 py-2 text-nowrap">max-w-1/3</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:max-w-3/4,max-w-9/10,max-w-1/2,max-w-1/3] --> | |
<div class="w-full max-w-9/10 ...">max-w-9/10</div> | |
<div class="w-full max-w-3/4 ...">max-w-3/4</div> | |
<div class="w-full max-w-1/2 ...">max-w-1/2</div> | |
<div class="w-full max-w-1/3 ...">max-w-1/3</div> | |
``` | |
</Figure> | |
### Using the container scale | |
Use utilities like `max-w-sm` and `max-w-xl` to set an element to a fixed maximum width based on the container scale: | |
<Figure hint="Resize the example to see the expected behavior"> | |
<Example resizable> | |
{ | |
<div className="dark:highlight-white/5 relative mx-auto flex max-w-md items-center gap-6 overflow-hidden rounded-xl bg-white shadow-lg ring-1 ring-black/5 dark:bg-gray-800"> | |
<img | |
className="absolute -left-6 h-28 w-28 rounded-full" | |
src="https://images.unsplash.com/photo-1501196354995-cbb51c65aaea?ixlib=rb-1.2.1&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=facearea&facepad=4&w=256&h=256&q=80" | |
/> | |
<div className="min-w-0 py-5 pr-5 pl-28"> | |
<div className="truncate text-sm font-medium text-gray-900 sm:text-base dark:text-gray-200">Andrew Alfred</div> | |
<div className="truncate text-sm leading-tight text-gray-500 sm:text-base dark:text-gray-400"> | |
Assistant to the Traveling Secretary | |
</div> | |
</div> | |
</div> | |
} | |
</Example> | |
```html | |
<!-- [!code classes:max-w-md] --> | |
<div class="max-w-md ..."> | |
<!-- ... --> | |
</div> | |
``` | |
</Figure> | |
### Using breakpoints container | |
Use the `container` utility to set the maximum width of an element to match the `min-width` of the current breakpoint. This is useful if you'd prefer to design for a fixed set of screen sizes instead of trying to accommodate a fully fluid viewport: | |
```html | |
<!-- [!code classes:container] --> | |
<div class="container"> | |
<!-- ... --> | |
</div> | |
``` | |
Note that unlike containers you might have used in other frameworks, Tailwind's container does not center itself automatically and does not have any built-in horizontal padding. Use `mx-auto` and the `px-<number>` utilities to add these: | |
```html | |
<!-- [!code classes:mx-auto,px-4] --> | |
<div class="container mx-auto px-4"> | |
<!-- ... --> | |
</div> | |
``` | |
### Using a custom value | |
<UsingACustomValue utility="max-w" value="220px" name="maximum width" variable="max-width" /> | |
### Responsive design | |
<ResponsiveDesign property="max-width" defaultClass="max-w-sm" featuredClass="max-w-lg" /> | |
## Customizing your theme | |
<CustomizingYourSpacingScale utility="max-w" /> | |
--- | |
File: /src/docs/min-height.mdx | |
--- | |
import { ApiTable } from "@/components/api-table.tsx"; | |
import { CustomizingYourSpacingScale, ResponsiveDesign, UsingACustomValue } from "@/components/content.tsx"; | |
import { Example } from "@/components/example.tsx"; | |
import { Figure } from "@/components/figure.tsx"; | |
import { Stripes } from "@/components/stripes.tsx"; | |
export const title = "min-height"; | |
export const description = "Utilities for setting the minimum height of an element."; | |
<ApiTable | |
rows={[ | |
["min-h-<number>", "min-height: calc(var(--spacing) * <number>);"], | |
["min-h-<fraction>", "min-height: calc(<fraction> * 100%);"], | |
["min-h-px", "min-height: 1px;"], | |
["min-h-full", "min-height: 100%;"], | |
["min-h-screen", "min-height: 100vh;"], | |
["min-h-dvh", "min-height: 100dvh;"], | |
["min-h-dvw", "min-height: 100dvw;"], | |
["min-h-lvh", "min-height: 100lvh;"], | |
["min-h-lvw", "min-height: 100lvw;"], | |
["min-h-svw", "min-height: 100svw;"], | |
["min-h-svh", "min-height: 100svh;"], | |
["min-h-auto", "min-height: auto;"], | |
["min-h-min", "min-height: min-content;"], | |
["min-h-max", "min-height: max-content;"], | |
["min-h-fit", "min-height: fit-content;"], | |
["min-h-lh", "min-height: 1lh;"], | |
["min-h-(<custom-property>)", "min-height: var(<custom-property>);"], | |
["min-h-[<value>]", "min-height: <value>;"], | |
]} | |
/> | |
## Examples | |
### Basic example | |
Use `min-h-<number>` utilities like `min-h-24` and `min-h-64` to set an element to a fixed minimum height based on the spacing scale: | |
<Figure> | |
<Example> | |
{ | |
<div className="mx-auto flex justify-center"> | |
<div className="relative flex items-end space-x-4 font-mono text-xs font-bold text-white"> | |
<Stripes border className="absolute -inset-x-[5%] h-20 w-[110%] rounded-lg" /> | |
<div className="relative flex h-96 w-8 items-end justify-center rounded-lg bg-blue-500"> | |
<div className="mb-8 -rotate-90 text-left text-nowrap">min-h-96</div> | |
</div> | |
<div className="relative flex h-80 w-8 items-end justify-center rounded-lg bg-blue-500"> | |
<div className="mb-8 -rotate-90 text-left text-nowrap">min-h-80</div> | |
</div> | |
<div className="relative flex h-64 w-8 items-end justify-center rounded-lg bg-blue-500"> | |
<div className="mb-8 -rotate-90 text-left text-nowrap">min-h-64</div> | |
</div> | |
<div className="relative flex h-48 w-8 items-end justify-center rounded-lg bg-blue-500"> | |
<div className="mb-8 -rotate-90 text-left text-nowrap">min-h-48</div> | |
</div> | |
<div className="relative flex h-40 w-8 items-end justify-center rounded-lg bg-blue-500"> | |
<div className="mb-8 -rotate-90 text-left text-nowrap">min-h-40</div> | |
</div> | |
<div className="relative flex h-32 w-8 items-end justify-center rounded-lg bg-blue-500"> | |
<div className="mb-8 -rotate-90 text-left text-nowrap">min-h-32</div> | |
</div> | |
<div className="relative flex h-24 w-8 items-end justify-center rounded-lg bg-blue-500"> | |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment