Lesson 8: The CSS Box Model

/en/basic-css/organization-and-sizing-in-css/content/

The CSS Box Model

Throughout our HTML Basics tutorial, we referred to HTML elements as "containers," because most of them are meant to hold things like content or other HTML elements. However, CSS takes that concept a step further. When it comes to CSS, every HTML element is considered to be a box with distinct layers. This concept is called the box model.

labeled diagram of box model, showing margins, borders, and padding

What is the box model?

Every block-level HTML element you put on a webpage is a box, even if it doesn't ordinarily look like it. For example, if you add a <p> element to your webpage and load it, it initially looks like it's just loose text. If you add some CSS colors, though, you can see the square box shape:

A paragraph with colors

The box model defines the different parts of that shape, which are broken up into four pieces, or sub-boxes:

  • Content: the inner content of your HTML element. In a <p> element, for example, this is the area where text would be displayed. In the image above, it's the entire area made visible with the background color. 
  • Padding: a box that surrounds an HTML element's inner content. In the image below, it's the extra space around the content that also shares the background color: 
    A paragraph with padding
  • Border: a box that surrounds an HTML element's padding. In the image below, it's the darker space around the padding: 
    A paragraph with padding and a border
  • Margin: a functionally invisible box that surrounds an HTML element's border. The margin is meant to act as white space to separate HTML elements from each other. In the image below, it's the white spaces between and around the two paragraphs: 
    Two paragraphs with padding and borders

You may not always style all four of these sub-boxes, so they may not always be visible. Regardless, they are part of the make-up of every block-level HTML element.

Inline HTML elements are still boxes, but they don't respect all of the box model behavior and aren't as flexible. You'll get a feel for the differences over time, but in general, inline elements are incompatible with any CSS that would disrupt the basic flow of a line of text.

Most of the CSS we've worked with so far has been concerned with the content of HTML elements, so that is most of what you've seen. However, it's important to recognize that the content is only part of the series of boxes that makes up each HTML element. 

In particular, let's consider the height and width declarations you can use to resize HTML elements. While at first glance they may appear to resize an element as a whole, they are actually only resizing an element's content. The padding, border, and margin boxes can be resized separately from the content. Take this paragraph as an example:

paragraph with no height

 It has been styled to add to the padding and border and make them visible. Now let's add a height: 50px; declaration to it:

paragraph with height

Notice that while the content box has increased in size, the padding and border boxes have remained the same.

Try this!

We'll talk about margins, borders, and padding in more detail in the following lessons, but try adding each of these declarations, one by one, to the input below:

background-color: #15AAD7;
color: white;
padding: 10px;
border: solid 3px #0F7391;
margin: 10px;

The selector for the ruleset is already defined for you, and targets the paragraph to its right. Once you've tried those declarations, try changing some of the values yourself. For example, try using different values for the padding and margin values, or try changing the "solid" value in your border declaration to "dashed" or "dotted". Remember to click Update CSS to apply the changes.

Congratulations, you've explored the box model on your webpage!

/en/basic-css/margins-in-css/content/