Breakpoints


    You define your project’s breakpoints in the section of your tailwind.config.js file. The keys are your screen names (used as the prefix for the responsive utility variants Tailwind generates, like md:text-center), and the values are the min-width where that breakpoint should start.

    The default breakpoints are inspired by common device resolutions:

    Feel free to have as few or as many screens as you want, naming them in whatever way you’d prefer for your project.

    For example, you could use device names instead of sizes:

    1. // tailwind.config.js
    2. module.exports = {
    3. theme: {
    4. screens: {
    5. 'tablet': '640px',
    6. // => @media (min-width: 640px) { ... }
    7. 'laptop': '1024px',
    8. // => @media (min-width: 1024px) { ... }
    9. 'desktop': '1280px',
    10. // => @media (min-width: 1280px) { ... }
    11. },
    12. }
    13. }

    These screen names will be reflected in your utilities, so your text-center utilities would now look like this:

    1. .text-center { text-align: center }
    2. @media (min-width: 640px) {
    3. .tablet\:text-center { text-align: center }
    4. @media (min-width: 1024px) {
    5. .laptop\:text-center { text-align: center }
    6. }
    7. @media (min-width: 1280px) {
    8. .desktop\:text-center { text-align: center }
    9. }

    You can even create breakpoints with both min-width and max-width definitions if necessary, for example:

    1. // tailwind.config.js
    2. module.exports = {
    3. theme: {
    4. screens: {
    5. 'sm': {'min': '640px', 'max': '767px'},
    6. 'md': {'min': '768px', 'max': '1023px'},
    7. 'lg': {'min': '1024px', 'max': '1279px'},
    8. 'xl': {'min': '1280px'},
    9. },
    10. }
    11. }

    Sometimes it can be useful to have a single breakpoint definition apply in multiple ranges.

    For example, say you have a sidebar and want your breakpoints to be based on the content-area width rather than the entire viewport. You can simulate this having one of your breakpoints fall back to a smaller breakpoint when the sidebar becomes visible and shrinks the content area:

    1. // tailwind.config.js
    2. module.exports = {
    3. theme: {
    4. screens: {
    5. 'sm': '500px',
    6. 'md': [
    7. // and 868px, after which the main content area is wide enough again to
    8. // apply the `md:` styles.
    9. {'min': '668px', 'max': '767px'},
    10. {'min': '868px'}
    11. 'lg': '1100px',
    12. 'xl': '1400px',
    13. }
    14. }
    15. }

    If you need to provide a completely custom media query for a breakpoint, you can do so using an object with a raw key:

    The raw option can be particularly useful if you need to apply different styles specifically for print.

    1. // tailwind.config.js
    2. module.exports = {
    3. theme: {
    4. extend: {
    5. screens: {
    6. 'print': {'raw': 'print'},
    7. // => @media print { ... }
    8. }
    9. }
    10. }
    11. }

    Then you can use classes like print:text-black to specify styles that should only be applied when someone tries to print the page you’re working on:

    1. <div class="text-gray-700 print:text-black">
    2. <!-- ... -->
    3. </div>

    Dark mode

    The raw option can even be used to implement a “dark mode” screen:

    Then you can style elements differently in dark mode using the dark: prefix:

    1. <div class="text-gray-700 dark:text-gray-200">

    Note that because of how these screen variants are implemented in Tailwind you can’t combine breakpoints with dark mode using this approach, for example md:dark:text-gray-300 won’t work. This is something we’re hoping to address with official dark mode support in a future release.


      Colors →