@dnb/eufemia
Version:
DNB Eufemia Design System UI Library
84 lines (59 loc) • 2.98 kB
Markdown
---
title: 'Importing CSS'
version: 10.104.0
generatedAt: 2026-04-17T18:46:12.806Z
checksum: 090b7d977ba4be5e2c4c04d199a30a4048416c59f443a56985df2f80629d9c40
---
# Importing the CSS
To include the packages `dnb-ui-core`, `ui-theme-basis` and `ui-theme-components` in a [Node.js](https://nodejs.org) based environment (given you have a CSS loader in place), do this:
**Style package structure:** The theme package `ui-theme-components` includes both [component](/uilib/components) and [Eufemia Forms](/uilib/extensions/forms) styles (Field, Value, Form layout, Wizard, etc.).
```js
// This includes the `dnb-ui-core`, `ui-theme-components` and `ui-theme-basis`
import '/eufemia/style'
```
## Select a theme
The above import is a shorthand for the DNB main theme. It is equivalent to the following import:
```js
// This is identical to `import '@dnb/eufemia/style'`
import '/eufemia/style/core'
import '/eufemia/style/themes/ui'
```
To import another theme, replace the second import:
```js
// This imports the sbanken theme instead
import '/eufemia/style/core'
import '/eufemia/style/themes/sbanken'
```
## Gatsby Plugin
The [gatsby-plugin-eufemia-theme-handler](https://github.com/dnbexperience/gatsby-plugin-eufemia-theme-handler) plugin makes it easy to add the needed styles and provides also a runtime style switch mechanism.
## Importing styles from within JavaScript
```tsx
import '/eufemia/style/dnb-ui-core.min.css'
import '/eufemia/style/themes/theme-ui/ui-theme-components.min.css'
import '/eufemia/style/themes/theme-ui/ui-theme-basis.min.css'
```
## Importing styles from within CSS
```css
url('/eufemia/style/dnb-ui-core.min.css');
url('/eufemia/style/themes/theme-ui/ui-theme-components.min.css');
url('/eufemia/style/themes/theme-ui/ui-theme-basis.min.css');
```
## Legacy import
The legacy import `import '/eufemia/style/basis'` scopes global css so it does not affect the whole page. But requires that
you place a wrapper element with class `.dnb-core-style` around all Eufemia elements. And may causes some css specificity issues.
If possible, it should be replaced with `import '/eufemia/style/core'` that attaches the same css to the `body` tag instead.
Read more about [how to deal with existing styles](/uilib/usage/customisation/styling#how-to-deal-with-existing-styles).
```js
import '/eufemia/style/basis' // replaced by '/eufemia/style/core'
import '/eufemia/style/themes/ui'
```
## Single Component only
It is possible to import a single CSS Style of a single component at once:
```js
// Imports the core css for the theme
import '/eufemia/style/dnb-ui-core.min.css'
import '/eufemia/style/themes/theme-ui/ui-theme-basis.min.css'
// Imports only the Button CSS and Main DNB Theme
import '/eufemia/components/button/style/dnb-button.min.css'
import '/eufemia/components/button/style/themes/dnb-button-theme-ui.min.css'
```