How to use CSS in your application
Learn about the different ways to add CSS to your application, including CSS Modules, Global CSS, Tailwind CSS, and more.
Next.js provides several ways to use CSS in your application, including:
This page will guide you through how to use each of these approaches.
CSS Modules
CSS Modules locally scope CSS by generating unique class names. This allows you to use the same class in different files without worrying about collisions.
To start using CSS Modules, create a new file with the extension .module.css
and import it into any component inside the app
directory:
Global CSS
You can use global CSS to apply styles across your application.
To use global styles, create a new CSS file, for example app/global.css
:
Import the file in the root layout (app/layout.js
) to apply the styles to every route in your application:
Good to know: Global styles can be imported into any layout, page, or component inside the app
directory. However, since Next.js uses React's built-in support for stylesheets to integrate with Suspense. This built-in support currently does not remove stylesheets as you navigate between routes. Therefore, we recommend using global styles for truly global CSS, and CSS Modules for scoped CSS.
Tailwind CSS
Tailwind CSS is a utility-first CSS framework that integrates seamlessly with Next.js.
Installing Tailwind
To start using Tailwind, install the Tailwind CSS packages and run the init
command to generate both the tailwind.config.js
and postcss.config.js
files:
Configuring Tailwind
Inside your Tailwind configuration file, add paths to the files that will use the Tailwind class names:
Using Tailwind
Add the Tailwind directives to your Global Stylesheet:
Then, import the styles in the root layout:
Lastly, you can start writing Tailwind's utility classes in your application.
Sass
Next.js integrates with Sass using both the .scss
and .sass
extensions and syntax.
You can also use component-level Sass via CSS Modules and the .module.scss
or .module.sass
extension.
Installing Sass
To start using Sass, install the sass
package:
Customizing Sass options
If you want to configure your Sass options, use the sassOptions
option in next.config.js
.
CSS-in-JS
Warning: CSS-in-JS libraries which require runtime JavaScript are not currently supported in React Server Components. Using CSS-in-JS with newer React features like Server Components and Streaming requires library authors to support the latest version of React.
The following libraries are supported in Client Components in the app
directory (alphabetical):
ant-design
chakra-ui
@fluentui/react-components
kuma-ui
@mui/material
@mui/joy
pandacss
styled-jsx
styled-components
stylex
tamagui
tss-react
vanilla-extract
The following are currently working on support:
If you want to style Server Components, we recommend using CSS Modules or other solutions that output CSS files, like Tailwind CSS.
Configuring CSS-in-JS
To configure CSS-in-JS, you need to:
- Create a style registry to collect all CSS rules in a render.
- Use the
useServerInsertedHTML
hook to inject rules before any content that might use them. - Create a Client Component that wraps your app with the style registry during initial server-side rendering.
styled-jsx
To configure styled-jsx
for your application, create a new registry:
Then, wrap your root layout with the registry:
styled-components
To use styled-components
, enable it in next.config.js
:
Then, use the styled-components
API to create a global registry component to collect all CSS style rules generated during a render, and a function to return those rules. Then use the useServerInsertedHTML
hook to inject the styles collected in the registry into the <head>
HTML tag in the root layout.
Wrap the children
of the root layout with the style registry component:
External stylesheets
Stylesheets published by external packages can be imported anywhere in the app
directory, including colocated components:
External stylesheets must be directly imported from an npm package or downloaded and colocated with your codebase. You cannot use <link rel="stylesheet" />
.