1. 核心概念
  2. 主题变量

核心概念

主题变量

使用工具类作为设计令牌的 API。

概述(Overview)

¥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?)

¥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:

app.css
@import "tailwindcss";@theme {  --color-mint-500: oklch(0.72 0.11 178);}

现在你可以在 HTML 中使用工具类,如 bg-mint-500text-mint-500fill-mint-500

¥Now you can use utility classes like bg-mint-500, text-mint-500, or fill-mint-500 in your HTML:

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:

HTML
<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?)

¥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.

当你想要定义一个不打算连接到工具类的变量时,使用 :root 定义常规 CSS 变量在 Tailwind 项目中仍然很有用。当你希望设计令牌直接映射到工具类时使用 @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)

¥Relationship to utility classes

Tailwind 中的一些工具类(如 flexobject-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:

./node_modules/tailwindcss/theme.css
@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-sansfont-seriffont-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:

app.css
@import "tailwindcss";@theme {  --font-poppins: Poppins, sans-serif;}
HTML
<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)

¥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:

app.css
@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:

HTML
<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)

¥Theme variable 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:

NamespaceUtility 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)

¥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:

node_modules/tailwindcss/index.css
@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:

node_modules/tailwindcss/theme.css
@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-200font-serifshadow-sm 这样的工具开箱即用的原因 - 它们由默认主题驱动,而不是像 flex-colpointer-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)

¥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)

¥Extending the default theme

使用 @theme 定义新主题变量并扩展默认主题:

¥Use @theme to define new theme variables and extend the default theme:

app.css
@import "tailwindcss";@theme {  --font-script: Great Vibes, cursive;}

这使得你可以在 HTML 中使用新的 font-script 工具类,就像默认的 font-sansfont-mono 工具一样:

¥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:

HTML
<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)

¥Overriding the default theme

通过在 @theme 中重新定义来覆盖默认主题变量值:

¥Override a default theme variable value by redefining it within @theme:

app.css
@import "tailwindcss";@theme {  --breakpoint-sm: 30rem;}

现在 sm:* 变体将在 30rem 而不是默认的 40rem 视口大小下触发:

¥Now the sm:* variant will trigger at 30rem instead of the default 40rem viewport size:

HTML
<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:

app.css
@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)

¥Using a custom theme

要完全禁用默认主题并仅使用自定义值,请将全局主题变量命名空间设置为 initial

¥To completely disable the default theme and use only custom values, set the global theme variable namespace to initial:

app.css
@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-bodytext-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)

¥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:

app.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);    }  }}

如果你希望即使不添加 --animate-* 主题变量也始终包含自定义 @keyframes 规则,请在 @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)

¥Referencing other variables

定义引用其他变量的主题变量时,请使用 inline 选项:

¥When defining theme variables that reference other variables, use the inline option:

app.css
@import "tailwindcss";@theme inline {  --font-sans: var(--font-inter);}

使用 inline 选项,工具类将使用主题变量值而不是引用实际主题变量:

¥Using the inline option, the utility class will use the theme variable value instead of referencing the actual theme variable:

dist.css
.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:

HTML
<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)

¥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:

app.css
@import "tailwindcss";@theme static {  --color-primary: var(--color-red-500);  --color-secondary: var(--color-blue-500);}

跨项目共享(Sharing across projects)

¥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:

./packages/brand/theme.css
@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:

./packages/admin/app.css
@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)

¥Using your theme variables

编译 CSS 时,所有主题变量都会转换为常规 CSS 变量:

¥All of your theme variables are turned into regular CSS variables when you compile your CSS:

dist.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)

¥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:

app.css
@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)

¥With arbitrary values

使用任意值的主题变量可能很有用,尤其是与 calc() 函数结合使用时。

¥Using theme variables in arbitrary values can be useful, especially in combination with the calc() function.

HTML
<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)

¥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 运动 库允许你为 CSS 变量值设置动画:

¥For example, the popular Motion library for React lets you animate to and from CSS variable values:

JSX
<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:

spaghetti.js
let styles = getComputedStyle(document.documentElement);let shadow = styles.getPropertyValue("--shadow-xl");

默认主题变量参考(Default theme variable reference)

¥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:

tailwindcss/theme.css
@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);  --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;  --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);  --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);    }  }}
TailwindCSS v4.1 中文网 - 粤ICP备13048890号