CSS box-shadow

The box-shadow property in CSS

In this tutorial, the Apple logo is used to display without using any image. The demo in the following section uses pure CSS where the box-shadow CSS property is used along with other properties for making the Apple logo.

Before showing you the example, FYI, the box-shadow property is used to attach shadows in the specified HTML elements like div. You may attach one or more shadows by using the box-shadow.

The simple syntax of using the box-shadow property is:

box-shadow: 20px 20px 3px #92A5DE inset;

Where,

Value Description
h-offset The first value specifies the horizontal shadow length. This is the required value when using the box-shadow property.
v-offset The second value is the vertical distance of the shadow. This is also required.
blur The ‘3px’ value is for the blur radius. This is optional. If you want a larger and lighter shadow, use a higher value.
shadow color After that, the color of the shadow is given. This is also optional. If left blank, the default black color will be applied.
inset You may also use the “inset” keyword. If used, it creates an inner shadow. The default is an outer shadow. If you do not use this, the drop shadow is assumed.
  • Have a look at the following section to see the live demos and code for using the box-shadow property.

A demo of using box-shadow in a div tag

In this demo, a simple box shadow is created for illustration purposes. There, I only used the horizontal, vertical, and blur lengths along with the color of the shadow. No “inset” keyword is used:

CSS box shadow

The CSS:

.box-shadow-demo {

    width: 200px;

    height: 150px;

    background-color: #FFB3B3;

    box-shadow: 10px 10px 15px #92A5DE;

    text-align:center;

    font-size:20px;


}
</head>
<body>
<div class="box-shadow-demo">Box-shadow demo</div>
</body>

A demo with inset keyword in box-shadow

Using the same example as above except the inset keyword is added. Have a look and see the difference:

CSS box shadow inset

CSS:

.box-shadow-demo {

    width: 200px;

    height: 150px;

    background-color: #FFB3B3;

    box-shadow: 10px 10px 15px #92A5DE inset;

    text-align:center;

    font-size:20px;

}

You can see the difference between the two demos; in the first example, the drop shadow was created without using the inset keyword.

An example of attaching multiple shadows to a single element

You may attach multiple shadows separated by commas in a single declaration. There, you may specify (for example), one drop shadow and another as the inset. That way, you may create shadows in the top, bottom, and other directions separately and use different colors and blur lengths. See the following demo with multiple shadows:

CSS box shadow multiple shadows

The CSS:

.box-shadow-demo {

    width: 200px;

    height: 150px;

    background-color: #FFB3B3;

    box-shadow: 10px 10px 10px #92A5DE, 10px -10px 20px #400040, 10px 10px 10px #FF8000 inset;

    text-align:center;

    font-size:20px;

 

}

In that demo, you can see the first drop shadow is created with positive values while the next one is with negative vertical value. The last shadow is given the inset keyword.

Creating the Apple logo by using the box-shadow property

Now, taste the real example by using the CSS box-shadow property. In this demo, the Apple logo is created purely based on CSS. Many other properties are also used, however, the main is box-shadow with multiple shadows:

CSS apple logo

HTML and CSS

<!DOCTYPE html>
<html>
<head>

<style>
body{
  width: 200px;
  margin: 0 auto;
  padding: 80px;
}
.box-shadow-apple-logo{
  background: #000;
  width: 208px;
  height: 198px;
  position: absolute;
  border-radius: 36% 36% 41% 41% / 42% 42% 75% 75%;
}

.box-shadow-apple-logo:before{
  background: #000;
  content: "";
    width: 55px;
  height: 55px;
  position: absolute;
  margin: -51px 0 0 100px;
  border-radius: 100px 0;
  z-index: 5;
}

.box-shadow-apple-logo:after{
  background: #fff;
  content: "";
  width: 90px;
  height: 90px;
  position: absolute;
  margin: 28px 0 0 174px;
  border-radius: 50%;
  transform: rotate(-53deg);
  z-index: 4;
  box-shadow: 
    24px -154px 0 #fff,
    10px -175px 0 #fff,
    11px -171px 0 #fff,
    12px -160px 0 #fff,
    -215px -7px 0 #fff,
    -195px 17px 0 #fff,
    -198px 3px 0 #fff,
    -198px 13px 0 #fff;
}

</style> 

</head>
<body>

<div class="box-shadow-apple-logo"></div>


</body>
</html>

 

Credit for this example: samarkandiy