Preflight


    Built on top of normalize.css, Preflight is a set of base styles for Tailwind projects that are designed to smooth over cross-browser inconsistencies and make it easier for you to work within the constraints of your design system.

    Tailwind automatically injects these styles when you include in your CSS:

    While most of the styles in Preflight are meant to go unnoticed — they simply make things behave more like you’d expect them to — some are more opinionated and can be surprising when you first encounter them.

    For a complete reference of all the styles applied by Preflight, .


    Default margins are removed

    Preflight removes all of the default margins from elements like headings, blockquotes, paragraphs, etc.

    1. blockquote,
    2. dl,
    3. dd,
    4. h1,
    5. h2,
    6. h3,
    7. h4,
    8. h5,
    9. h6,
    10. figure,
    11. p,
    12. pre {
    13. margin: 0;

    This makes it harder to accidentally rely on margin values applied by the user-agent stylesheet that are not part of your spacing scale.


    All heading elements are completely unstyled by default, and have the same font-size and font-weight as normal text.

    1. h1,
    2. h2,
    3. h3,
    4. h4,
    5. h5,
    6. h6 {
    7. font-size: inherit;
    8. font-weight: inherit;
    9. }
    • It helps you avoid accidentally deviating from your type scale. By default, the browsers assigns sizes to headings that don’t exist in Tailwind’s default type scale, and aren’t guaranteed to exist in your own type scale.
    • In UI development, headings should often be visually de-emphasized. Making headings unstyled by default means any styling you apply to headings happens consciously and deliberately.

    You can always add default header styles to your project by .

    If you’d like to selectively introduce sensible default heading styles into article-style parts of a page, we recommend the @tailwindcss/typography plugin.


    Lists are unstyled

    Ordered and unordered lists are unstyled by default, with no bullets/numbers and no margin or padding.

    If you’d like to style a list, you can do so using the list-style-type and utilities:

    1. <li>One</li>
    2. <li>Two</li>
    3. <li>Three</li>
    4. </ul>

    You can always add default list styles to your project by adding your own base styles.

    If you’d like to selectively introduce default list styles into article-style parts of a page, we recommend the .


    Images and other replaced elements (like svg, video, canvas, and others) are display: block by default.

    1. img,
    2. svg,
    3. video,
    4. canvas,
    5. audio,
    6. embed,
    7. object {
    8. display: block;
    9. vertical-align: middle;
    10. }

    If you ever need to make one of these elements inline instead of block, simply use the inline utility:


    Border styles are reset globally

    In order to make it easy to add a border by simply adding the class, Tailwind overrides the default border styles for all elements with the following rules:

    1. *,
    2. *::before,
    3. *::after {
    4. border-width: 0;
    5. border-style: solid;
    6. border-color: theme('borderColor.default', currentColor);
    7. }

    Since the border class only sets the border-width property, this reset ensures that adding that class always adds a solid 1px border using your configured default border color.

    This can cause some unexpected results when integrating certain third-party libraries, like for example.

    When you run into situations like this, you can work around them by overriding the Preflight styles with your own custom CSS:

    1. .google-map * {
    2. border-style: none;
    3. }

    If you’d like to add your own base styles on top of Preflight, simply add them to your CSS after @tailwind base:

    Learn more in the adding base styles documentation.


    Disabling Preflight

    1. // tailwind.config.js
    2. module.exports = {
    3. corePlugins: {
    4. + preflight: false,
    5. }
    6. }

    ← Writing Plugins