核心概念
主题变量
将工具类用作设计令牌的 API。
概述(Overview)
Tailwind 是一个用于构建自定义设计的框架,不同的设计需要不同的排版、颜色、阴影、断点等。
🌐 Tailwind is a framework for building custom designs, and different designs need different typography, colors, shadows, breakpoints, and more.
这些低层次的设计决策通常被称为_设计令牌_,在 Tailwind 项目中,你可以将这些数值存储在_主题变量_中。
🌐 These low-level design decisions are often called design tokens, and in Tailwind projects you store those values in theme variables.
什么是主题变量?(What are theme variables?)
主题变量是使用 @theme 指令定义的特殊 CSS 变量,它们会影响项目中存在哪些实用类。
🌐 Theme variables are special CSS variables defined using the @theme directive that influence which utility classes exist in your project.
例如,你可以通过定义一个主题变量如 --color-mint-500 来为你的项目添加一种新颜色:
🌐 For example, you can add a new color to your project by defining a theme variable like --color-mint-500:
@import "tailwindcss";@theme { --color-mint-500: oklch(0.72 0.11 178);}现在你可以在你的 HTML 中使用像 bg-mint-500、text-mint-500 或 fill-mint-500 这样的实用类:
🌐 Now you can use utility classes like bg-mint-500, text-mint-500, or fill-mint-500 in your HTML:
<div class="bg-mint-500"> <!-- ... --></div>Tailwind 还会为你的主题变量生成常规 CSS 变量,以便你可以在任意值或内联样式中引用你的设计令牌:
🌐 Tailwind also generates regular CSS variables for your theme variables so you can reference your design tokens in arbitrary values or inline styles:
<div style="background-color: var(--color-mint-500)"> <!-- ... --></div>了解更多关于主题变量如何映射到不同实用程序类的信息,请参阅 主题变量命名空间 文档。
🌐 Learn more about how theme variables map to different utility classes in the theme variable namespaces documentation.
为什么选择 @theme 而不是 :root?(Why @theme instead of :root?)
主题变量不仅仅是 CSS 变量——它们还指示 Tailwind 创建新的实用类,你可以在 HTML 中使用这些类。
🌐 Theme variables aren't just CSS variables — they also instruct Tailwind to create new utility classes that you can use in your HTML.
由于它们的功能超出了常规 CSS 变量,Tailwind 使用特殊语法,因此定义主题变量总是明确的。主题变量也必须在顶层定义,不能嵌套在其他选择器或媒体查询下,而使用特殊语法可以实现这一要求。
🌐 Since they do more than regular CSS variables, Tailwind uses special syntax so that defining theme variables is always explicit. Theme variables are also required to be defined top-level and not nested under other selectors or media queries, and using a special syntax makes it possible to enforce that.
在 Tailwind 项目中,当你想定义一个不打算与工具类关联的变量时,使用 :root 定义普通 CSS 变量仍然是有用的。当你希望设计标记直接映射到工具类时,使用 @theme;而使用 :root 来定义不应有对应工具类的普通 CSS 变量。
🌐 Defining regular CSS variables with :root can still be useful in Tailwind projects when you want to define a variable that isn't meant to be connected to a utility class. Use @theme when you want a design token to map directly to a utility class, and use :root for defining regular CSS variables that shouldn't have corresponding utility classes.
与工具类的关系(Relationship to utility classes)
Tailwind 中的一些工具类,如 flex 和 object-cover 是静态的,在不同项目中总是相同的。但许多其他类则由主题变量驱动,只有在你定义了主题变量后才会存在。
🌐 Some utility classes in Tailwind like flex and object-cover are static, and are always the same from project to project. But many others are driven by theme variables, and only exist because of the theme variables you've defined.
例如,在 --font-* 命名空间中定义的主题变量决定了项目中存在的所有 font-family 工具:
🌐 For example, theme variables defined in the --font-* namespace determine all of the font-family utilities that exist in a project:
@theme { --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; --font-serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif; --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; /* ... */}font-sans、font-serif 和 font-mono 工具之所以默认存在,仅仅是因为 Tailwind 的默认主题定义了 --font-sans、--font-serif 和 --font-mono 主题变量。
🌐 The font-sans, font-serif, and font-mono utilities only exist by default because Tailwind's default theme defines the --font-sans, --font-serif, and --font-mono theme variables.
如果定义了另一个主题变量如 --font-poppins,则会有一个与之配套的 font-poppins 工具类可用:
🌐 If another theme variable like --font-poppins were defined, a font-poppins utility class would become available to go with it:
@import "tailwindcss";@theme { --font-poppins: Poppins, sans-serif;}<h1 class="font-poppins">This headline will use Poppins.</h1>你可以在这些命名空间中随意命名主题变量,并且具有相同名称的相应工具将可用于你的 HTML。
🌐 You can name your theme variables whatever you want within these namespaces, and a corresponding utility with the same name will become available to use in your HTML.
与变体(Relationship to variants)
某些主题变量用于定义变体而不是工具。例如,--breakpoint-* 命名空间中的主题变量决定了项目中存在哪些响应式断点变体:
🌐 Some theme variables are used to define variants rather than utilities. For example theme variables in the --breakpoint-* namespace determine which responsive breakpoint variants exist in your project:
@import "tailwindcss";@theme { --breakpoint-3xl: 120rem;}现在你可以使用 3xl:* 变体,仅在视口宽度达到 120rem 或更宽时触发一个工具:
🌐 Now you can use the 3xl:* variant to only trigger a utility when the viewport is 120rem or wider:
<div class="3xl:grid-cols-6 grid grid-cols-2 md:grid-cols-4"> <!-- ... --></div>了解更多关于主题变量如何映射到不同实用程序类和变体的信息,请参阅 主题变量命名空间 文档。
🌐 Learn more about how theme variables map to different utility classes and variants in the theme variable namespaces documentation.
主题变量命名空间(Theme variable namespaces)
主题变量在 namespaces 中定义,每个命名空间对应一个或多个实用程序类或变体 API。
🌐 Theme variables are defined in namespaces and each namespace corresponds to one or more utility class or variant APIs.
在这些命名空间中定义新的主题变量将使新的相应工具和变体在你的项目中可用:
🌐 Defining new theme variables in these namespaces will make new corresponding utilities and variants available in your project:
| Namespace | Utility classes |
|---|---|
--color-* | Color utilities like bg-red-500, text-sky-300, and many more |
--font-* | Font family utilities like font-sans |
--text-* | Font size utilities like text-xl |
--font-weight-* | Font weight utilities like font-bold |
--tracking-* | Letter spacing utilities like tracking-wide |
--leading-* | Line height utilities like leading-tight |
--breakpoint-* | Responsive breakpoint variants like sm:* |
--container-* | Container query variants like @sm:* and size utilities like max-w-md |
--spacing-* | Spacing and sizing utilities like px-4, max-h-16, and many more |
--radius-* | Border radius utilities like rounded-sm |
--shadow-* | Box shadow utilities like shadow-md |
--inset-shadow-* | Inset box shadow utilities like inset-shadow-xs |
--drop-shadow-* | Drop shadow filter utilities like drop-shadow-md |
--blur-* | Blur filter utilities like blur-md |
--perspective-* | Perspective utilities like perspective-near |
--aspect-* | Aspect ratio utilities like aspect-video |
--ease-* | Transition timing function utilities like ease-out |
--animate-* | Animation utilities like animate-spin |
有关所有默认主题变量的列表,请参见默认主题变量参考。
🌐 For a list of all of the default theme variables, see the default theme variable reference.
默认主题变量(Default theme variables)
当你在 CSS 文件顶部导入 tailwindcss 时,它会包含一组默认的主题变量,帮助你快速入门。
🌐 When you import tailwindcss at the top of your CSS file, it includes a set of default theme variables to get you started.
当你导入 tailwindcss 时,实际上导入的是以下内容:
🌐 Here's what you're actually importing when you import tailwindcss:
@layer theme, base, components, utilities;@import "./theme.css" layer(theme);@import "./preflight.css" layer(base);@import "./utilities.css" layer(utilities);那个 theme.css 文件包含默认的颜色调色板、字体尺度、阴影、字体等内容:
🌐 That theme.css file includes the default color palette, type scale, shadows, fonts, and more:
@theme { --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; --font-serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif; --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; --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); /* ... */ --shadow-2xs: 0 1px rgb(0 0 0 / 0.05); --shadow-xs: 0 1px 2px 0 rgb(0 0 0 / 0.05); --shadow-sm: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1); /* ... */}这就是为什么像 bg-red-200、font-serif 和 shadow-sm 这样的工具能够开箱即用——它们由默认主题驱动,而不是像 flex-col 或 pointer-events-none 那样硬编码在框架中。
🌐 This is why utilities like bg-red-200, font-serif, and shadow-sm exist out of the box — they're driven by the default theme, not hardcoded into the framework like flex-col or pointer-events-none.
有关所有默认主题变量的列表,请参见默认主题变量参考。
🌐 For a list of all of the default theme variables, see the default theme variable reference.
自定义主题(Customizing your theme)
默认的主题变量用途非常广泛,适合构建风格迥异的设计,但它们仍然只是一个起点。通常会自定义颜色调色板、字体和阴影,以打造完全符合你设想的设计。
🌐 The default theme variables are very general purpose and suitable for building dramatically different designs, but they are still just a starting point. It's very common to customize things like the color palette, fonts, and shadows to build exactly the design you have in mind.
扩展默认主题(Extending the default theme)
使用 @theme 来定义新的主题变量并扩展默认主题:
🌐 Use @theme to define new theme variables and extend the default theme:
@import "tailwindcss";@theme { --font-script: Great Vibes, cursive;}这会提供一个新的 font-script 工具类,你可以像使用默认的 font-sans 或 font-mono 工具类一样在 HTML 中使用它:
🌐 This makes a new font-script utility class available that you can use in your HTML, just like the default font-sans or font-mono utilities:
<p class="font-script">This will use the Great Vibes font family.</p>了解更多关于主题变量如何映射到不同实用程序类和变体的信息,请参阅 主题变量命名空间 文档。
🌐 Learn more about how theme variables map to different utility classes and variants in the theme variable namespaces documentation.
覆盖默认主题(Overriding the default theme)
通过在 @theme 中重新定义来覆盖默认主题变量值:
🌐 Override a default theme variable value by redefining it within @theme:
@import "tailwindcss";@theme { --breakpoint-sm: 30rem;}现在 sm:* 变体将在 30rem 而不是默认的 40rem 视口大小触发:
🌐 Now the sm:* variant will trigger at 30rem instead of the default 40rem viewport size:
<div class="grid grid-cols-1 sm:grid-cols-3"> <!-- ... --></div>要在默认主题中完全覆盖整个命名空间,请使用特殊的星号语法将整个命名空间设置为 initial:
🌐 To completely override an entire namespace in the default theme, set the entire namespace to initial using the special asterisk syntax:
@import "tailwindcss";@theme { --color-*: initial; --color-white: #fff; --color-purple: #3f3cbb; --color-midnight: #121063; --color-tahiti: #3ab7bf; --color-bermuda: #78dcca;}当你这样做时,使用该命名空间的所有默认工具(如 bg-red-500)将被移除,只有你的自定义值(如 bg-midnight)可用。
🌐 When you do this, all of the default utilities that use that namespace (like bg-red-500) will be removed, and only your custom values (like bg-midnight) will be available.
了解更多关于主题变量如何映射到不同实用程序类和变体的信息,请参阅 主题变量命名空间 文档。
🌐 Learn more about how theme variables map to different utility classes and variants in the theme variable namespaces documentation.
使用自定义主题(Using a custom theme)
要完全禁用默认主题并仅使用自定义值,请将全局主题变量命名空间设置为 initial:
🌐 To completely disable the default theme and use only custom values, set the global theme variable namespace to initial:
@import "tailwindcss";@theme { --*: initial; --spacing: 4px; --font-body: Inter, sans-serif; --color-lagoon: oklch(0.72 0.11 221.19); --color-coral: oklch(0.74 0.17 40.24); --color-driftwood: oklch(0.79 0.06 74.59); --color-tide: oklch(0.49 0.08 205.88); --color-dusk: oklch(0.82 0.15 72.09);}现在,由主题变量驱动的默认实用类将不可用,你只能使用与你的自定义主题变量匹配的实用类,例如 font-body 和 text-dusk。
🌐 Now none of the default utility classes that are driven by theme variables will be available, and you'll only be able to use utility classes matching your custom theme variables like font-body and text-dusk.
定义动画关键帧(Defining animation keyframes)
在 @theme 中为你的 --animate-* 主题变量定义 @keyframes 规则,以便将它们包含在生成的 CSS 中:
🌐 Define the @keyframes rules for your --animate-* theme variables within @theme to include them in your generated CSS:
@import "tailwindcss";@theme { --animate-fade-in-scale: fade-in-scale 0.3s ease-out; @keyframes fade-in-scale { 0% { opacity: 0; transform: scale(0.95); } 100% { opacity: 1; transform: scale(1); } }}如果你希望自定义的 @keyframes 规则即使在没有添加 --animate-* 主题变量的情况下也始终被包含,请将它们定义在 @theme 之外。
🌐 If you want your custom @keyframes rules to always be included even when not adding an --animate-* theme variable, define them outside of @theme instead.
引用其他变量(Referencing other variables)
在定义引用其他变量的主题变量时,使用 inline 选项:
🌐 When defining theme variables that reference other variables, use the inline option:
@import "tailwindcss";@theme inline { --font-sans: var(--font-inter);}使用 inline 选项时,实用程序类将使用主题变量 value,而不是引用实际的主题变量:
🌐 Using the inline option, the utility class will use the theme variable value instead of referencing the actual theme variable:
.font-sans { font-family: var(--font-inter);}如果不使用 inline,你的工具类可能会解析为意外的值,因为 CSS 中变量的解析方式会影响结果。
🌐 Without using inline, your utility classes might resolve to unexpected values because of how variables are resolved in CSS.
例如,这段文本将回退到 sans-serif,而不会像你可能预期的那样使用 Inter:
🌐 For example, this text will fall back to sans-serif instead of using Inter like you might expect:
<div id="parent" style="--font-sans: var(--font-inter, sans-serif);"> <div id="child" style="--font-inter: Inter; font-family: var(--font-sans);"> This text will use the sans-serif font, not Inter. </div></div>这是因为 var(--font-sans) 在 --font-sans 定义的地方(在 #parent 上)被解析,而 --font-inter 在那里没有值,因为它直到树的更深处(在 #child 上)才被定义。
🌐 This happens because var(--font-sans) is resolved where --font-sans is defined (on #parent), and --font-inter has no value there since it's not defined until deeper in the tree (on #child).
生成所有 CSS 变量(Generating all CSS variables)
默认情况下,最终的 CSS 输出中只会生成使用到的 CSS 变量。如果你想始终生成所有的 CSS 变量,可以使用 static 主题选项:
🌐 By default only used CSS variables will be generated in the final CSS output. If you want to always generate all CSS variables, you can use the static theme option:
@import "tailwindcss";@theme static { --color-primary: var(--color-red-500); --color-secondary: var(--color-blue-500);}跨项目共享(Sharing across projects)
由于主题变量是在 CSS 中定义的,因此在项目之间共享它们只需将它们放入你可以在每个项目中导入的自己的 CSS 文件中:
🌐 Since theme variables are defined in CSS, sharing them across projects is just a matter of throwing them into their own CSS file that you can import in each project:
@theme { --*: initial; --spacing: 4px; --font-body: Inter, sans-serif; --color-lagoon: oklch(0.72 0.11 221.19); --color-coral: oklch(0.74 0.17 40.24); --color-driftwood: oklch(0.79 0.06 74.59); --color-tide: oklch(0.49 0.08 205.88); --color-dusk: oklch(0.82 0.15 72.09);}然后你可以使用 @import 将你的主题变量包含到其他项目中:
🌐 Then you can use @import to include your theme variables in other projects:
@import "tailwindcss";@import "../brand/theme.css";你可以将这样的共享主题变量放在 monorepo 设置中的自己的包中,甚至可以将它们发布到 NPM 并像任何其他第三方 CSS 文件一样导入它们。
🌐 You can put shared theme variables like this in their own package in monorepo setups or even publish them to NPM and import them just like any other third-party CSS files.
使用主题变量(Using your theme variables)
编译 CSS 时,所有主题变量都会转换为常规 CSS 变量:
🌐 All of your theme variables are turned into regular CSS variables when you compile your CSS:
:root { --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; --font-serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif; --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; --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); /* ... */ --shadow-2xs: 0 1px rgb(0 0 0 / 0.05); --shadow-xs: 0 1px 2px 0 rgb(0 0 0 / 0.05); --shadow-sm: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1); /* ... */}这使得在任何自定义 CSS 或内联样式中引用所有设计标记变得容易。
🌐 This makes it easy to reference all of your design tokens in any of your custom CSS or inline styles.
使用自定义 CSS(With custom CSS)
在编写需要使用相同值的自定义 CSS 时,使用主题变量来访问设计令牌:
🌐 Use your theme variables to get access to your design tokens when you're writing custom CSS that needs to use the same values:
@import "tailwindcss";@layer components { .typography { p { font-size: var(--text-base); color: var(--color-gray-700); } h1 { font-size: var(--text-2xl--line-height); font-weight: var(--font-weight-semibold); color: var(--color-gray-950); } h2 { font-size: var(--text-xl); font-weight: var(--font-weight-semibold); color: var(--color-gray-950); } }}这在设置你无法控制的 HTML 样式时通常很有用,例如来自数据库或 API 并渲染为 HTML 的 Markdown 内容。
🌐 This is often useful when styling HTML you don't control, like Markdown content coming from a database or API and rendered to HTML.
使用任意值(With arbitrary values)
在任意值中使用主题变量可能非常有用,尤其是与 calc() 函数结合使用时。
🌐 Using theme variables in arbitrary values can be useful, especially in combination with the calc() function.
<div class="relative rounded-xl"> <div class="absolute inset-px rounded-[calc(var(--radius-xl)-1px)]"> <!-- ... --> </div> <!-- ... --></div>在上面的例子中,我们从嵌套内嵌元素的 --radius-xl 值中减去 1px,以确保它具有同心的圆角。
🌐 In the above example, we're subtracting 1px from the --radius-xl value on a nested inset element to make sure it has a concentric border radius.
在 JavaScript 中引用(Referencing in JavaScript)
大多数情况下,当你需要在 JS 中引用主题变量时,你可以直接使用 CSS 变量,就像任何其他 CSS 值一样。
🌐 Most of the time when you need to reference your theme variables in JS you can just use the CSS variables directly, just like any other CSS value.
例如,流行的 React 库 Motion 允许你在 CSS 变量值之间进行动画:
🌐 For example, the popular Motion library for React lets you animate to and from CSS variable values:
<motion.div animate={{ backgroundColor: "var(--color-blue-500)" }} />如果你需要在 JS 中访问已解析的 CSS 变量值,你可以使用 getComputedStyle 来获取文档根元素上的主题变量值:
🌐 If you need access to a resolved CSS variable value in JS, you can use getComputedStyle to get the value of a theme variable on the document root:
let styles = getComputedStyle(document.documentElement);let shadow = styles.getPropertyValue("--shadow-xl");默认主题变量参考(Default theme variable reference)
作为参考,以下是将 Tailwind CSS 导入项目时默认包含的主题变量的完整列表:
🌐 For reference, here's a complete list of the theme variables included by default when you import Tailwind CSS into your project:
@theme { --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; --font-serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif; --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; --color-red-50: oklch(97.1% 0.013 17.38); --color-red-100: oklch(93.6% 0.032 17.717); --color-red-200: oklch(88.5% 0.062 18.334); --color-red-300: oklch(80.8% 0.114 19.571); --color-red-400: oklch(70.4% 0.191 22.216); --color-red-500: oklch(63.7% 0.237 25.331); --color-red-600: oklch(57.7% 0.245 27.325); --color-red-700: oklch(50.5% 0.213 27.518); --color-red-800: oklch(44.4% 0.177 26.899); --color-red-900: oklch(39.6% 0.141 25.723); --color-red-950: oklch(25.8% 0.092 26.042); --color-orange-50: oklch(98% 0.016 73.684); --color-orange-100: oklch(95.4% 0.038 75.164); --color-orange-200: oklch(90.1% 0.076 70.697); --color-orange-300: oklch(83.7% 0.128 66.29); --color-orange-400: oklch(75% 0.183 55.934); --color-orange-500: oklch(70.5% 0.213 47.604); --color-orange-600: oklch(64.6% 0.222 41.116); --color-orange-700: oklch(55.3% 0.195 38.402); --color-orange-800: oklch(47% 0.157 37.304); --color-orange-900: oklch(40.8% 0.123 38.172); --color-orange-950: oklch(26.6% 0.079 36.259); --color-amber-50: oklch(98.7% 0.022 95.277); --color-amber-100: oklch(96.2% 0.059 95.617); --color-amber-200: oklch(92.4% 0.12 95.746); --color-amber-300: oklch(87.9% 0.169 91.605); --color-amber-400: oklch(82.8% 0.189 84.429); --color-amber-500: oklch(76.9% 0.188 70.08); --color-amber-600: oklch(66.6% 0.179 58.318); --color-amber-700: oklch(55.5% 0.163 48.998); --color-amber-800: oklch(47.3% 0.137 46.201); --color-amber-900: oklch(41.4% 0.112 45.904); --color-amber-950: oklch(27.9% 0.077 45.635); --color-yellow-50: oklch(98.7% 0.026 102.212); --color-yellow-100: oklch(97.3% 0.071 103.193); --color-yellow-200: oklch(94.5% 0.129 101.54); --color-yellow-300: oklch(90.5% 0.182 98.111); --color-yellow-400: oklch(85.2% 0.199 91.936); --color-yellow-500: oklch(79.5% 0.184 86.047); --color-yellow-600: oklch(68.1% 0.162 75.834); --color-yellow-700: oklch(55.4% 0.135 66.442); --color-yellow-800: oklch(47.6% 0.114 61.907); --color-yellow-900: oklch(42.1% 0.095 57.708); --color-yellow-950: oklch(28.6% 0.066 53.813); --color-lime-50: oklch(98.6% 0.031 120.757); --color-lime-100: oklch(96.7% 0.067 122.328); --color-lime-200: oklch(93.8% 0.127 124.321); --color-lime-300: oklch(89.7% 0.196 126.665); --color-lime-400: oklch(84.1% 0.238 128.85); --color-lime-500: oklch(76.8% 0.233 130.85); --color-lime-600: oklch(64.8% 0.2 131.684); --color-lime-700: oklch(53.2% 0.157 131.589); --color-lime-800: oklch(45.3% 0.124 130.933); --color-lime-900: oklch(40.5% 0.101 131.063); --color-lime-950: oklch(27.4% 0.072 132.109); --color-green-50: oklch(98.2% 0.018 155.826); --color-green-100: oklch(96.2% 0.044 156.743); --color-green-200: oklch(92.5% 0.084 155.995); --color-green-300: oklch(87.1% 0.15 154.449); --color-green-400: oklch(79.2% 0.209 151.711); --color-green-500: oklch(72.3% 0.219 149.579); --color-green-600: oklch(62.7% 0.194 149.214); --color-green-700: oklch(52.7% 0.154 150.069); --color-green-800: oklch(44.8% 0.119 151.328); --color-green-900: oklch(39.3% 0.095 152.535); --color-green-950: oklch(26.6% 0.065 152.934); --color-emerald-50: oklch(97.9% 0.021 166.113); --color-emerald-100: oklch(95% 0.052 163.051); --color-emerald-200: oklch(90.5% 0.093 164.15); --color-emerald-300: oklch(84.5% 0.143 164.978); --color-emerald-400: oklch(76.5% 0.177 163.223); --color-emerald-500: oklch(69.6% 0.17 162.48); --color-emerald-600: oklch(59.6% 0.145 163.225); --color-emerald-700: oklch(50.8% 0.118 165.612); --color-emerald-800: oklch(43.2% 0.095 166.913); --color-emerald-900: oklch(37.8% 0.077 168.94); --color-emerald-950: oklch(26.2% 0.051 172.552); --color-teal-50: oklch(98.4% 0.014 180.72); --color-teal-100: oklch(95.3% 0.051 180.801); --color-teal-200: oklch(91% 0.096 180.426); --color-teal-300: oklch(85.5% 0.138 181.071); --color-teal-400: oklch(77.7% 0.152 181.912); --color-teal-500: oklch(70.4% 0.14 182.503); --color-teal-600: oklch(60% 0.118 184.704); --color-teal-700: oklch(51.1% 0.096 186.391); --color-teal-800: oklch(43.7% 0.078 188.216); --color-teal-900: oklch(38.6% 0.063 188.416); --color-teal-950: oklch(27.7% 0.046 192.524); --color-cyan-50: oklch(98.4% 0.019 200.873); --color-cyan-100: oklch(95.6% 0.045 203.388); --color-cyan-200: oklch(91.7% 0.08 205.041); --color-cyan-300: oklch(86.5% 0.127 207.078); --color-cyan-400: oklch(78.9% 0.154 211.53); --color-cyan-500: oklch(71.5% 0.143 215.221); --color-cyan-600: oklch(60.9% 0.126 221.723); --color-cyan-700: oklch(52% 0.105 223.128); --color-cyan-800: oklch(45% 0.085 224.283); --color-cyan-900: oklch(39.8% 0.07 227.392); --color-cyan-950: oklch(30.2% 0.056 229.695); --color-sky-50: oklch(97.7% 0.013 236.62); --color-sky-100: oklch(95.1% 0.026 236.824); --color-sky-200: oklch(90.1% 0.058 230.902); --color-sky-300: oklch(82.8% 0.111 230.318); --color-sky-400: oklch(74.6% 0.16 232.661); --color-sky-500: oklch(68.5% 0.169 237.323); --color-sky-600: oklch(58.8% 0.158 241.966); --color-sky-700: oklch(50% 0.134 242.749); --color-sky-800: oklch(44.3% 0.11 240.79); --color-sky-900: oklch(39.1% 0.09 240.876); --color-sky-950: oklch(29.3% 0.066 243.157); --color-blue-50: oklch(97% 0.014 254.604); --color-blue-100: oklch(93.2% 0.032 255.585); --color-blue-200: oklch(88.2% 0.059 254.128); --color-blue-300: oklch(80.9% 0.105 251.813); --color-blue-400: oklch(70.7% 0.165 254.624); --color-blue-500: oklch(62.3% 0.214 259.815); --color-blue-600: oklch(54.6% 0.245 262.881); --color-blue-700: oklch(48.8% 0.243 264.376); --color-blue-800: oklch(42.4% 0.199 265.638); --color-blue-900: oklch(37.9% 0.146 265.522); --color-blue-950: oklch(28.2% 0.091 267.935); --color-indigo-50: oklch(96.2% 0.018 272.314); --color-indigo-100: oklch(93% 0.034 272.788); --color-indigo-200: oklch(87% 0.065 274.039); --color-indigo-300: oklch(78.5% 0.115 274.713); --color-indigo-400: oklch(67.3% 0.182 276.935); --color-indigo-500: oklch(58.5% 0.233 277.117); --color-indigo-600: oklch(51.1% 0.262 276.966); --color-indigo-700: oklch(45.7% 0.24 277.023); --color-indigo-800: oklch(39.8% 0.195 277.366); --color-indigo-900: oklch(35.9% 0.144 278.697); --color-indigo-950: oklch(25.7% 0.09 281.288); --color-violet-50: oklch(96.9% 0.016 293.756); --color-violet-100: oklch(94.3% 0.029 294.588); --color-violet-200: oklch(89.4% 0.057 293.283); --color-violet-300: oklch(81.1% 0.111 293.571); --color-violet-400: oklch(70.2% 0.183 293.541); --color-violet-500: oklch(60.6% 0.25 292.717); --color-violet-600: oklch(54.1% 0.281 293.009); --color-violet-700: oklch(49.1% 0.27 292.581); --color-violet-800: oklch(43.2% 0.232 292.759); --color-violet-900: oklch(38% 0.189 293.745); --color-violet-950: oklch(28.3% 0.141 291.089); --color-purple-50: oklch(97.7% 0.014 308.299); --color-purple-100: oklch(94.6% 0.033 307.174); --color-purple-200: oklch(90.2% 0.063 306.703); --color-purple-300: oklch(82.7% 0.119 306.383); --color-purple-400: oklch(71.4% 0.203 305.504); --color-purple-500: oklch(62.7% 0.265 303.9); --color-purple-600: oklch(55.8% 0.288 302.321); --color-purple-700: oklch(49.6% 0.265 301.924); --color-purple-800: oklch(43.8% 0.218 303.724); --color-purple-900: oklch(38.1% 0.176 304.987); --color-purple-950: oklch(29.1% 0.149 302.717); --color-fuchsia-50: oklch(97.7% 0.017 320.058); --color-fuchsia-100: oklch(95.2% 0.037 318.852); --color-fuchsia-200: oklch(90.3% 0.076 319.62); --color-fuchsia-300: oklch(83.3% 0.145 321.434); --color-fuchsia-400: oklch(74% 0.238 322.16); --color-fuchsia-500: oklch(66.7% 0.295 322.15); --color-fuchsia-600: oklch(59.1% 0.293 322.896); --color-fuchsia-700: oklch(51.8% 0.253 323.949); --color-fuchsia-800: oklch(45.2% 0.211 324.591); --color-fuchsia-900: oklch(40.1% 0.17 325.612); --color-fuchsia-950: oklch(29.3% 0.136 325.661); --color-pink-50: oklch(97.1% 0.014 343.198); --color-pink-100: oklch(94.8% 0.028 342.258); --color-pink-200: oklch(89.9% 0.061 343.231); --color-pink-300: oklch(82.3% 0.12 346.018); --color-pink-400: oklch(71.8% 0.202 349.761); --color-pink-500: oklch(65.6% 0.241 354.308); --color-pink-600: oklch(59.2% 0.249 0.584); --color-pink-700: oklch(52.5% 0.223 3.958); --color-pink-800: oklch(45.9% 0.187 3.815); --color-pink-900: oklch(40.8% 0.153 2.432); --color-pink-950: oklch(28.4% 0.109 3.907); --color-rose-50: oklch(96.9% 0.015 12.422); --color-rose-100: oklch(94.1% 0.03 12.58); --color-rose-200: oklch(89.2% 0.058 10.001); --color-rose-300: oklch(81% 0.117 11.638); --color-rose-400: oklch(71.2% 0.194 13.428); --color-rose-500: oklch(64.5% 0.246 16.439); --color-rose-600: oklch(58.6% 0.253 17.585); --color-rose-700: oklch(51.4% 0.222 16.935); --color-rose-800: oklch(45.5% 0.188 13.697); --color-rose-900: oklch(41% 0.159 10.272); --color-rose-950: oklch(27.1% 0.105 12.094); --color-slate-50: oklch(98.4% 0.003 247.858); --color-slate-100: oklch(96.8% 0.007 247.896); --color-slate-200: oklch(92.9% 0.013 255.508); --color-slate-300: oklch(86.9% 0.022 252.894); --color-slate-400: oklch(70.4% 0.04 256.788); --color-slate-500: oklch(55.4% 0.046 257.417); --color-slate-600: oklch(44.6% 0.043 257.281); --color-slate-700: oklch(37.2% 0.044 257.287); --color-slate-800: oklch(27.9% 0.041 260.031); --color-slate-900: oklch(20.8% 0.042 265.755); --color-slate-950: oklch(12.9% 0.042 264.695); --color-gray-50: oklch(98.5% 0.002 247.839); --color-gray-100: oklch(96.7% 0.003 264.542); --color-gray-200: oklch(92.8% 0.006 264.531); --color-gray-300: oklch(87.2% 0.01 258.338); --color-gray-400: oklch(70.7% 0.022 261.325); --color-gray-500: oklch(55.1% 0.027 264.364); --color-gray-600: oklch(44.6% 0.03 256.802); --color-gray-700: oklch(37.3% 0.034 259.733); --color-gray-800: oklch(27.8% 0.033 256.848); --color-gray-900: oklch(21% 0.034 264.665); --color-gray-950: oklch(13% 0.028 261.692); --color-zinc-50: oklch(98.5% 0 0); --color-zinc-100: oklch(96.7% 0.001 286.375); --color-zinc-200: oklch(92% 0.004 286.32); --color-zinc-300: oklch(87.1% 0.006 286.286); --color-zinc-400: oklch(70.5% 0.015 286.067); --color-zinc-500: oklch(55.2% 0.016 285.938); --color-zinc-600: oklch(44.2% 0.017 285.786); --color-zinc-700: oklch(37% 0.013 285.805); --color-zinc-800: oklch(27.4% 0.006 286.033); --color-zinc-900: oklch(21% 0.006 285.885); --color-zinc-950: oklch(14.1% 0.005 285.823); --color-neutral-50: oklch(98.5% 0 0); --color-neutral-100: oklch(97% 0 0); --color-neutral-200: oklch(92.2% 0 0); --color-neutral-300: oklch(87% 0 0); --color-neutral-400: oklch(70.8% 0 0); --color-neutral-500: oklch(55.6% 0 0); --color-neutral-600: oklch(43.9% 0 0); --color-neutral-700: oklch(37.1% 0 0); --color-neutral-800: oklch(26.9% 0 0); --color-neutral-900: oklch(20.5% 0 0); --color-neutral-950: oklch(14.5% 0 0); --color-stone-50: oklch(98.5% 0.001 106.423); --color-stone-100: oklch(97% 0.001 106.424); --color-stone-200: oklch(92.3% 0.003 48.717); --color-stone-300: oklch(86.9% 0.005 56.366); --color-stone-400: oklch(70.9% 0.01 56.259); --color-stone-500: oklch(55.3% 0.013 58.071); --color-stone-600: oklch(44.4% 0.011 73.639); --color-stone-700: oklch(37.4% 0.01 67.558); --color-stone-800: oklch(26.8% 0.007 34.298); --color-stone-900: oklch(21.6% 0.006 56.043); --color-stone-950: oklch(14.7% 0.004 49.25); --color-black: #000; --color-white: #fff; --spacing: 0.25rem; --breakpoint-sm: 40rem; --breakpoint-md: 48rem; --breakpoint-lg: 64rem; --breakpoint-xl: 80rem; --breakpoint-2xl: 96rem; --container-3xs: 16rem; --container-2xs: 18rem; --container-xs: 20rem; --container-sm: 24rem; --container-md: 28rem; --container-lg: 32rem; --container-xl: 36rem; --container-2xl: 42rem; --container-3xl: 48rem; --container-4xl: 56rem; --container-5xl: 64rem; --container-6xl: 72rem; --container-7xl: 80rem; --text-xs: 0.75rem; --text-xs--line-height: calc(1 / 0.75); --text-sm: 0.875rem; --text-sm--line-height: calc(1.25 / 0.875); --text-base: 1rem; --text-base--line-height: calc(1.5 / 1); --text-lg: 1.125rem; --text-lg--line-height: calc(1.75 / 1.125); --text-xl: 1.25rem; --text-xl--line-height: calc(1.75 / 1.25); --text-2xl: 1.5rem; --text-2xl--line-height: calc(2 / 1.5); --text-3xl: 1.875rem; --text-3xl--line-height: calc(2.25 / 1.875); --text-4xl: 2.25rem; --text-4xl--line-height: calc(2.5 / 2.25); --text-5xl: 3rem; --text-5xl--line-height: 1; --text-6xl: 3.75rem; --text-6xl--line-height: 1; --text-7xl: 4.5rem; --text-7xl--line-height: 1; --text-8xl: 6rem; --text-8xl--line-height: 1; --text-9xl: 8rem; --text-9xl--line-height: 1; --font-weight-thin: 100; --font-weight-extralight: 200; --font-weight-light: 300; --font-weight-normal: 400; --font-weight-medium: 500; --font-weight-semibold: 600; --font-weight-bold: 700; --font-weight-extrabold: 800; --font-weight-black: 900; --tracking-tighter: -0.05em; --tracking-tight: -0.025em; --tracking-normal: 0em; --tracking-wide: 0.025em; --tracking-wider: 0.05em; --tracking-widest: 0.1em; --leading-tight: 1.25; --leading-snug: 1.375; --leading-normal: 1.5; --leading-relaxed: 1.625; --leading-loose: 2; --radius-xs: 0.125rem; --radius-sm: 0.25rem; --radius-md: 0.375rem; --radius-lg: 0.5rem; --radius-xl: 0.75rem; --radius-2xl: 1rem; --radius-3xl: 1.5rem; --radius-4xl: 2rem; --shadow-2xs: 0 1px rgb(0 0 0 / 0.05); --shadow-xs: 0 1px 2px 0 rgb(0 0 0 / 0.05); --shadow-sm: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1); --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1); --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1); --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1); --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / 0.25); --inset-shadow-2xs: inset 0 1px rgb(0 0 0 / 0.05); --inset-shadow-xs: inset 0 1px 1px rgb(0 0 0 / 0.05); --inset-shadow-sm: inset 0 2px 4px rgb(0 0 0 / 0.05); --drop-shadow-xs: 0 1px 1px rgb(0 0 0 / 0.05); --drop-shadow-sm: 0 1px 2px rgb(0 0 0 / 0.15); --drop-shadow-md: 0 3px 3px rgb(0 0 0 / 0.12); --drop-shadow-lg: 0 4px 4px rgb(0 0 0 / 0.15); --drop-shadow-xl: 0 9px 7px rgb(0 0 0 / 0.1); --drop-shadow-2xl: 0 25px 25px rgb(0 0 0 / 0.15); --text-shadow-2xs: 0px 1px 0px rgb(0 0 0 / 0.15); --text-shadow-xs: 0px 1px 1px rgb(0 0 0 / 0.2); --text-shadow-sm: 0px 1px 0px rgb(0 0 0 / 0.075), 0px 1px 1px rgb(0 0 0 / 0.075), 0px 2px 2px rgb(0 0 0 / 0.075); --text-shadow-md: 0px 1px 1px rgb(0 0 0 / 0.1), 0px 1px 2px rgb(0 0 0 / 0.1), 0px 2px 4px rgb(0 0 0 / 0.1); --text-shadow-lg: 0px 1px 2px rgb(0 0 0 / 0.1), 0px 3px 2px rgb(0 0 0 / 0.1), 0px 4px 8px rgb(0 0 0 / 0.1); --blur-xs: 4px; --blur-sm: 8px; --blur-md: 12px; --blur-lg: 16px; --blur-xl: 24px; --blur-2xl: 40px; --blur-3xl: 64px; --perspective-dramatic: 100px; --perspective-near: 300px; --perspective-normal: 500px; --perspective-midrange: 800px; --perspective-distant: 1200px; --aspect-video: 16 / 9; --ease-in: cubic-bezier(0.4, 0, 1, 1); --ease-out: cubic-bezier(0, 0, 0.2, 1); --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1); --animate-spin: spin 1s linear infinite; --animate-ping: ping 1s cubic-bezier(0, 0, 0.2, 1) infinite; --animate-pulse: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite; --animate-bounce: bounce 1s infinite; @keyframes spin { to { transform: rotate(360deg); } } @keyframes ping { 75%, 100% { transform: scale(2); opacity: 0; } } @keyframes pulse { 50% { opacity: 0.5; } } @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); } }}