Movatterモバイル変換


[0]ホーム

URL:


  1. Core concepts
  2. Theme variables

Core concepts

Theme variables

Using utility classes as an API for your design tokens.

Overview

Tailwind is a framework for building custom designs, and different designs need different typography, colors, shadows, breakpoints, and more.

These low-level design decisions are often calleddesign tokens, and in Tailwind projects you store those values intheme variables.

What are theme variables?

Theme variables are special CSS variables defined using the@theme directive that influence which utility classes exist in your project.

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

Now you can use utility classes likebg-mint-500,text-mint-500, orfill-mint-500 in your HTML:

HTML
<div class="bg-mint-500">  <!-- ... --></div>

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 thetheme variable namespaces documentation.

Why@theme instead of:root?

Theme variables aren'tjust CSS variables — they also instruct Tailwind to create new utility classes that you can use in your HTML.

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.

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

Some utility classes in Tailwind likeflex andobject-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.

For example, theme variables defined in the--font-* namespace determine all of thefont-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;  /* ... */}

Thefont-sans,font-serif, andfont-mono utilities only exist by default because Tailwind's default theme defines the--font-sans,--font-serif, and--font-mono theme variables.

If another theme variable like--font-poppins were defined, afont-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>

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

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;}

Now you can use the3xl:* 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 thetheme variable namespaces documentation.

Theme variable namespaces

Theme variables are defined innamespaces 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 likebg-red-500,text-sky-300, and many more
--font-*Font family utilities likefont-sans
--text-*Font size utilities liketext-xl
--font-weight-*Font weight utilities likefont-bold
--tracking-*Letter spacing utilities liketracking-wide
--leading-*Line height utilities likeleading-tight
--breakpoint-*Responsive breakpoint variants likesm:*
--container-*Container query variants like@sm:* and size utilities likemax-w-md
--spacing-*Spacing and sizing utilities likepx-4,max-h-16, and many more
--radius-*Border radius utilities likerounded-sm
--shadow-*Box shadow utilities likeshadow-md
--inset-shadow-*Inset box shadow utilities likeinset-shadow-xs
--drop-shadow-*Drop shadow filter utilities likedrop-shadow-md
--blur-*Blur filter utilities likeblur-md
--perspective-*Perspective utilities likeperspective-near
--aspect-*Aspect ratio utilities likeaspect-video
--ease-*Transition timing function utilities likeease-out
--animate-*Animation utilities likeanimate-spin

For a list of all of the default theme variables, see thedefault theme variable reference.

Default theme variables

When you importtailwindcss at the top of your CSS file, it includes a set of default theme variables to get you started.

Here's what you're actually importing when you importtailwindcss:

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

Thattheme.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 0rgb(0 0 0 / 0.05);  --shadow-sm:0 1px 3px 0rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);  /* ... */}

This is why utilities likebg-red-200,font-serif, andshadow-sm exist out of the box — they're driven by the default theme, not hardcoded into the framework likeflex-col orpointer-events-none.

For a list of all of the default theme variables, see thedefault 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

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

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

This makes a newfont-script utility class available that you can use in your HTML, just like the defaultfont-sans orfont-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 thetheme variable namespaces documentation.

Overriding the default theme

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

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

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

HTML
<div class="grid grid-cols-1sm:grid-cols-3">  <!-- ... --></div>

To completely override an entire namespace in the default theme, set the entire namespace toinitial 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;}

When you do this, all of the default utilities that use that namespace(likebg-red-500) will be removed, and only your custom values(likebg-midnight) will be available.

Learn more about how theme variables map to different utility classes and variants in thetheme variable namespaces documentation.

Using a custom theme

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

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

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 likefont-body andtext-dusk.

Defining animation keyframes

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

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

When defining theme variables that reference other variables, use theinline option:

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

Using theinline option, the utility class will use the theme variablevalue instead of referencing the actual theme variable:

dist.css
.font-sans {  font-family:var(--font-inter);}

Without usinginline, your utility classes might resolve to unexpected values because of how variables are resolved in CSS.

For example, this text will fall back tosans-serif instead of usingInter 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>

This happens becausevar(--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).

Generating all CSS variables

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 thestatic theme option:

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

Sharing across projects

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

Then you can use@import to include your theme variables in other projects:

./packages/admin/app.css
@import "tailwindcss";@import "../brand/theme.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

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 0rgb(0 0 0 / 0.05);  --shadow-sm:0 1px 3px 0rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);  /* ... */}

This makes it easy to reference all of your design tokens in any of your custom CSS or inline styles.

With custom 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);    }  }}

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

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

HTML
<div class="relativerounded-xl">  <div class="absolute inset-pxrounded-[calc(var(--radius-xl)-1px)]">    <!-- ... -->  </div>  <!-- ... --></div>

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.

Referencing in JavaScript

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.

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

JSX
<motion.div animate={{ backgroundColor: "var(--color-blue-500)" }} />

If you need access to a resolved CSS variable value in JS, you can usegetComputedStyle 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

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(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 0rgb(0 0 0 / 0.05);  --shadow-sm:0 1px 3px 0rgb(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);    }  }}
Copyright © 2025 Tailwind Labs Inc.·Trademark Policy

[8]ページ先頭

©2009-2025 Movatter.jp