---
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](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Flexible_Box_Layout/Using_CSS_flexible_boxes) and is fully responsive. Below is an example and an in-depth look at how the grid comes together.
**New to or unfamiliar with flexbox?** [Read this CSS Tricks flexbox guide](https://css-tricks.com/snippets/css/a-guide-to-flexbox/#flexbox-background) for background, terminology, guidelines, and code snippets.
{% example html %}
  
    
      One of three columns
    
    
      One of three columns
    
    
      One of three columns
    
   
 
{% endexample %}
  
    
      |  | Extra small <576px
 | Small ≥576px
 | Medium ≥768px
 | Large ≥992px
 | Extra large ≥1200px
 | 
  
  
    
      | 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 | 
    
      | 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-6 .col-sm-4
  .col-6 .col-sm-4
  
  
  .col-6 .col-sm-4
  .col-6 .col-sm-4
 
{% endexample %}
{% example html %}
  
    
      First, but unordered
    
    
      Second, but last
    
    
      Third, but first
    
   
 
{% endexample %}
{% example html %}
  
    
      First, but unordered
    
    
      Second, but unordered
    
    
      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-sm-5 .col-md-6
  .col-sm-5 .offset-sm-2 .col-md-6 .offset-md-0
 
  .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 %}
  .col-md-4
  .col-md-4 .ml-auto
 
  .col-md-3 .ml-md-auto
  .col-md-3 .ml-md-auto
 
  .col-auto .mr-auto
  .col-auto
 
{% 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 can be modified via Sass variables. `$grid-columns` is used to generate the widths (in percent) of each individual column while `$grid-gutter-width` 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: 30px !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 output a brand new set of predefined grid classes for column widths, offsets, and ordering. Responsive visibility utilities will also be updated to use the custom breakpoints. Make sure to set grid values in `px` (not `rem`, `em`, or `%`).