---
layout: docs
title: Grid system
description: Use our powerful mobile-first flexbox grid to build layouts of all shapes and sizes thanks to a twelve column system, five default responsive tiers, Sass variables and mixins, and dozens of predefined classes.
group: layout
toc: true
---
## How it works
Bootstrap's grid system uses a series of containers, rows, and columns to layout and align content. It's built with flexbox and is fully responsive. Below is an example and an in-depth look at how the grid comes together.
  
    
      One of three columns
    
    
      One of three columns
    
    
      One of three columns
    
   
 
 
The above example creates three equal-width columns on small, medium, large, and extra large devices using our predefined grid classes. Those columns are centered in the page with the parent `.container`.
Breaking it down, here's how it works:
- Containers provide a means to center your site's contents. Use `.container` for fixed width or `.container-fluid` for full width.
- Rows are horizontal groups of columns that ensure your columns are lined up properly. We use the negative margin method on `.row` to ensure all your content is aligned properly down the left side.
- Content should be placed within columns, and only columns may be immediate children of rows.
- Thanks to flexbox, grid columns without a set width will automatically layout with equal widths. For example, four instances of `.col-sm` will each automatically be 25% wide for small breakpoints.
- Column classes indicate the number of columns you'd like to use out of the possible 12 per row. So, if you want three equal-width columns, you can use `.col-sm-4`.
- Column `width`s are set in percentages, so they're always fluid and sized relative to their parent element.
- Columns have horizontal `padding` to create the gutters between individual columns, however, you can remove the `margin` from rows and `padding` from columns with `.no-gutters` on the `.row`.
- There are five grid tiers, one for each [responsive breakpoint]({{ site.baseurl }}/docs/{{ site.docs_version }}/layout/overview/#responsive-breakpoints): all breakpoints (extra small), small, medium, large, and extra large.
- Grid tiers are based on minimum widths, meaning they apply to that one tier and all those above it (e.g., `.col-sm-4` applies to small, medium, large, and extra large devices).
- You can use predefined grid classes or Sass mixins for more semantic markup.
Be aware of the limitations and [bugs around flexbox](https://github.com/philipwalton/flexbugs), like the [inability to use some HTML elements as flex containers](https://github.com/philipwalton/flexbugs#9-some-html-elements-cant-be-flex-containers).
Sounds good? Great, let's move on to seeing all that in an example.
## Grid options
While Bootstrap uses `em`s or `rem`s for defining most sizes, `px`s are used for grid breakpoints and container widths. This is because the viewport width is in pixels and does not change with the [font size](https://drafts.csswg.org/mediaqueries-3/#units).
See how aspects of the Bootstrap grid system work across multiple devices with a handy table.
  
    
      |  | Extra small <576px
 | Small ≥576px
 | Medium ≥768px
 | Large ≥992px
 | Extra large ≥1200px
 | 
  
  
    
      | Grid behavior | Horizontal at all times | Collapsed to start, horizontal above breakpoints | 
    
      | Max container width | None (auto) | 540px | 720px | 960px | 1140px | 
    
      | Class prefix | .col- | .col-sm- | .col-md- | .col-lg- | .col-xl- | 
    
      | # of columns | 12 | 
    
      | Gutter width | 30px (15px on each side of a column) | 
    
      | Nestable | Yes | 
    
      | Offsets | Yes | 
    
      | Column ordering | Yes | 
  
## Auto-layout columns
Utilize breakpoint-specific column classes for easy column sizing without an explicit numbered class like `.col-sm-6`.
### Equal-width
For example, here are two grid layouts that apply to every device and viewport, from `xs` to `xl`. Add any number of unit-less classes for each breakpoint you need and every column will be the same width.
{% example html %}
{% endexample %}
{% example html %}
  
    Column
    Column
    
    Column
    Column
   
 
{% endexample %}
{% example html %}
  
    
      1 of 3
    
    
      2 of 3 (wider)
    
    
      3 of 3
    
   
  
    
      1 of 3
    
    
      2 of 3 (wider)
    
    
      3 of 3
    
   
 
{% endexample %}
{% example html %}
  
    
      1 of 3
    
    
      Variable width content
    
    
      3 of 3
    
   
  
    
      1 of 3
    
    
      Variable width content
    
    
      3 of 3
    
   
 
{% endexample %}
{% example html %}
{% endexample %}
{% example html %}
{% endexample %}
{% example html %}
{% endexample %}
{% example html %}
  .col-12 .col-md-8
  .col-6 .col-md-4
 
  .col-6 .col-md-4
  .col-6 .col-md-4
  .col-6 .col-md-4
 
{% endexample %}
{% example html %}
  
    
      One of three columns
    
    
      One of three columns
    
    
      One of three columns
    
   
  
    
      One of three columns
    
    
      One of three columns
    
    
      One of three columns
    
   
  
    
      One of three columns
    
    
      One of three columns
    
    
      One of three columns
    
   
 
{% endexample %}
{% example html %}
  
    
      One of three columns
    
    
      One of three columns
    
    
      One of three columns
    
   
 
{% endexample %}
{% example html %}
  
    
      One of two columns
    
    
      One of two columns
    
   
  
    
      One of two columns
    
    
      One of two columns
    
   
  
    
      One of two columns
    
    
      One of two columns
    
   
  
    
      One of two columns
    
    
      One of two columns
    
   
  
    
      One of two columns
    
    
      One of two columns
    
   
 
{% endexample %}
{% example html %}
  .col-12 .col-sm-6 .col-md-8
  .col-6 .col-md-4
 
{% endexample %}
{% example html %}
  .col-9
  .col-4
Since 9 + 4 = 13 > 12, this 4-column-wide div gets wrapped onto a new line as one contiguous unit.
  .col-6
Subsequent columns continue along the new line.
 
{% endexample %}
{% example html %}
  .col-6 .col-sm-3
  .col-6 .col-sm-3
  
  
  .col-6 .col-sm-3
  .col-6 .col-sm-3
 
{% endexample %}
{% example html %}
  .col-sm-5 .col-md-6
  .col-sm-5 .offset-sm-2 .col-md-6 .offset-md-0
 
  .col.col-sm-6.col-md-5.col-lg-6
  .col-sm-6 .col-md-5 .offset-md-2 .col-lg-6 .offset-lg-0
 
{% endexample %}
{% example html %}
  
    
      First, but unordered
    
    
      Second, but last
    
    
      Third, but first
    
   
 
{% endexample %}
{% example html %}
  .col-md-4
  .col-md-4 .offset-md-4
 
  .col-md-3 .offset-md-3
  .col-md-3 .offset-md-3
 
{% endexample %}
{% example html %}
  .col-md-9 .push-md-3
  .col-md-3 .pull-md-9
 
{% endexample %}
{% example html %}
  
    Level 1: .col-sm-9
    
      
        Level 2: .col-8 .col-sm-6
      
      
        Level 2: .col-4 .col-sm-6
      
     
   
{% endexample %}
  
    Main content
    Secondary content
   
 
{% endexample %}
## Customizing the grid
Using our built-in grid Sass variables and maps, it's possible to completely customize the predefined grid classes. Change the number of tiers, the media query dimensions, and the container widths—then recompile.
### Columns and gutters
The number of grid columns and their horizontal padding (aka, gutters) can be modified via Sass variables. `$grid-columns` is used to generate the widths (in percent) of each individual column while `$grid-gutter-widths` allows breakpoint-specific widths that are divided evenly across `padding-left` and `padding-right` for the column gutters.
{% highlight scss %}
$grid-columns:               12 !default;
$grid-gutter-width-base:     30px !default;
$grid-gutter-widths: (
  xs: $grid-gutter-width-base,
  sm: $grid-gutter-width-base,
  md: $grid-gutter-width-base,
  lg: $grid-gutter-width-base,
  xl: $grid-gutter-width-base
) !default;
{% endhighlight %}
### Grid tiers
Moving beyond the columns themselves, you may also customize the number of grid tiers. If you wanted just four grid tiers, you'd update the `$grid-breakpoints` and `$container-max-widths` to something like this:
{% highlight scss %}
$grid-breakpoints: (
  xs: 0,
  sm: 480px,
  md: 768px,
  lg: 1024px
);
$container-max-widths: (
  sm: 420px,
  md: 720px,
  lg: 960px
);
{% endhighlight %}
When making any changes to the Sass variables or maps, you'll need to save your changes and recompile. Doing so will out a brand new set of predefined grid classes for column widths, offsets, pushes, and pulls. Responsive visibility utilities will also be updated to use the custom breakpoints.