Bootstrap 
api/framework developed by Twitter for mobile first, responsive (to changing devices it is displayed on) web sites/applications.
Setup on Webstorm or command line
If you don’t use the Webstorm IDE you have to go through the steps of downloading bootstrap and manually setting up (see appendix B of the Getting MEAN book)
RESPONSIVE = Bootstrap will rearrange the columns depending on size of the screen
Say we have 12 content areas we want to layout such that as shown in the previous image we have
- lg device = each div(item) takes up to 3 columns (hence 12/3 = 4 items in a row)--> this is specified by the col-lg-3 class attribute below
- md device =each div(item) takes up to 4 columns (hence 12/4 = 3 items in a row)--> this is specified by the col-md-4 class attribute below
- sm device =each div(item) takes up to 6 columns (hence 12/6 = 2 tiems in a row) --> this is specified by col-sm-6 class attribute below
*******CLICK HERE TO SEE THE CODE BELOW********
<div class="container">
<div class="row">
<div class="col-sm-6 col-md-4 col-lg-3"><p>Box 1</p></div>
<div class="col-sm-6 col-md-4 col-lg-3"><p>Box 2</p></div>
<div class="clearfix visible-sm-block"></div>
<div class="col-sm-6 col-md-4 col-lg-3"><p>Box 3</p></div>
<div class="clearfix visible-md-block"></div>
<div class="col-sm-6 col-md-4 col-lg-3"><p>Box 4</p></div>
<div class="clearfix visible-sm-block"></div>
<div class="clearfix visible-lg-block"></div>
<div class="col-sm-6 col-md-4 col-lg-3"><p>Box 5</p></div>
<div class="col-sm-6 col-md-4 col-lg-3"><p>Box 6</p></div>
<div class="clearfix visible-sm-block"></div>
<div class="clearfix visible-md-block"></div>
<div class="col-sm-6 col-md-4 col-lg-3"><p>Box 7</p></div>
<div class="col-sm-6 col-md-4 col-lg-3"><p>Box 8</p></div>
<div class="clearfix visible-sm-block"></div>
<div class="clearfix visible-lg-block"></div>
<div class="col-sm-6 col-md-4 col-lg-3"><p>Box 9</p></div>
<div class="clearfix visible-md-block"></div>
<div class="col-sm-6 col-md-4 col-lg-3"><p>Box 10</p></div>
<div class="clearfix visible-sm-block"></div>
<div class="col-sm-6 col-md-4 col-lg-3"><p>Box 11</p></div>
<div class="col-sm-6 col-md-4 col-lg-3"><p>Box 12</p></div>
</div>
</div>