2018-09-30 23:01:58 +01:00
---
id: 5a9d7295424fe3d0e10cad14
2019-06-09 04:09:00 +02:00
title: Inherit CSS Variables
2018-09-30 23:01:58 +01:00
challengeType: 0
videoUrl: 'https://scrimba.com/c/cyLZZhZ'
2019-08-05 09:17:33 -07:00
forumTopicId: 301088
2021-01-13 03:31:00 +01:00
dashedName: inherit-css-variables
2018-09-30 23:01:58 +01:00
---
2020-11-27 19:02:05 +01:00
# --description--
2019-06-09 04:09:00 +02:00
When you create a variable, it is available for you to use inside the selector in which you create it. It also is available in any of that selector's descendants. This happens because CSS variables are inherited, just like ordinary properties.
2020-11-27 19:02:05 +01:00
2019-06-09 04:09:00 +02:00
To make use of inheritance, CSS variables are often defined in the < dfn > :root< / dfn > element.
2018-09-30 23:01:58 +01:00
2020-11-27 19:02:05 +01:00
`:root` is a < dfn > pseudo-class</ dfn > selector that matches the root element of the document, usually the `html` element. By creating your variables in `:root` , they will be available globally and can be accessed from any other selector in the style sheet.
2018-09-30 23:01:58 +01:00
2020-11-27 19:02:05 +01:00
# --instructions--
2018-09-30 23:01:58 +01:00
2020-11-27 19:02:05 +01:00
Define a variable named `--penguin-belly` in the `:root` selector and give it the value of `pink` . You can then see that the variable is inherited and that all the child elements which use it get pink backgrounds.
2018-09-30 23:01:58 +01:00
2020-11-27 19:02:05 +01:00
# --hints--
2018-09-30 23:01:58 +01:00
2020-11-27 19:02:05 +01:00
The `--penguin-belly` variable should be declared in the `:root` and assigned the value `pink` .
2018-09-30 23:01:58 +01:00
2020-11-27 19:02:05 +01:00
```js
assert(
code.match(/:root\s*?{[\s\S]*--penguin-belly\s*?:\s*?pink\s*?;[\s\S]*}/gi)
);
```
# --seed--
2018-09-30 23:01:58 +01:00
2020-11-27 19:02:05 +01:00
## --seed-contents--
2018-09-30 23:01:58 +01:00
```html
< style >
:root {
2020-02-27 07:20:46 -08:00
/* Only change code below this line */
2018-10-08 01:01:53 +01:00
2020-02-27 07:20:46 -08:00
/* Only change code above this line */
2018-09-30 23:01:58 +01:00
}
2018-10-08 01:01:53 +01:00
2018-09-30 23:01:58 +01:00
body {
background: var(--penguin-belly, #c6faf1 );
}
2018-10-08 01:01:53 +01:00
2018-09-30 23:01:58 +01:00
.penguin {
--penguin-skin: gray;
--penguin-beak: orange;
position: relative;
margin: auto;
display: block;
margin-top: 5%;
width: 300px;
height: 300px;
}
2018-10-08 01:01:53 +01:00
2018-09-30 23:01:58 +01:00
.right-cheek {
top: 15%;
left: 35%;
background: var(--penguin-belly, white);
width: 60%;
height: 70%;
border-radius: 70% 70% 60% 60%;
}
2018-10-08 01:01:53 +01:00
2018-09-30 23:01:58 +01:00
.left-cheek {
top: 15%;
left: 5%;
background: var(--penguin-belly, white);
width: 60%;
height: 70%;
border-radius: 70% 70% 60% 60%;
}
2018-10-08 01:01:53 +01:00
2018-09-30 23:01:58 +01:00
.belly {
top: 60%;
left: 2.5%;
background: var(--penguin-belly, white);
width: 95%;
height: 100%;
border-radius: 120% 120% 100% 100%;
}
2018-10-08 01:01:53 +01:00
2018-09-30 23:01:58 +01:00
.penguin-top {
top: 10%;
left: 25%;
background: var(--penguin-skin, gray);
width: 50%;
height: 45%;
border-radius: 70% 70% 60% 60%;
}
2018-10-08 01:01:53 +01:00
2018-09-30 23:01:58 +01:00
.penguin-bottom {
top: 40%;
left: 23.5%;
background: var(--penguin-skin, gray);
width: 53%;
height: 45%;
border-radius: 70% 70% 100% 100%;
}
2018-10-08 01:01:53 +01:00
2018-09-30 23:01:58 +01:00
.right-hand {
top: 0%;
left: -5%;
background: var(--penguin-skin, gray);
width: 30%;
height: 60%;
border-radius: 30% 30% 120% 30%;
transform: rotate(45deg);
z-index: -1;
}
2018-10-08 01:01:53 +01:00
2018-09-30 23:01:58 +01:00
.left-hand {
top: 0%;
left: 75%;
background: var(--penguin-skin, gray);
width: 30%;
height: 60%;
border-radius: 30% 30% 30% 120%;
transform: rotate(-45deg);
z-index: -1;
}
2018-10-08 01:01:53 +01:00
2018-09-30 23:01:58 +01:00
.right-feet {
top: 85%;
left: 60%;
background: var(--penguin-beak, orange);
width: 15%;
height: 30%;
border-radius: 50% 50% 50% 50%;
transform: rotate(-80deg);
z-index: -2222;
}
2018-10-08 01:01:53 +01:00
2018-09-30 23:01:58 +01:00
.left-feet {
top: 85%;
left: 25%;
background: var(--penguin-beak, orange);
width: 15%;
height: 30%;
border-radius: 50% 50% 50% 50%;
transform: rotate(80deg);
z-index: -2222;
}
2018-10-08 01:01:53 +01:00
2018-09-30 23:01:58 +01:00
.right-eye {
top: 45%;
left: 60%;
background: black;
width: 15%;
height: 17%;
border-radius: 50%;
}
2018-10-08 01:01:53 +01:00
2018-09-30 23:01:58 +01:00
.left-eye {
top: 45%;
left: 25%;
background: black;
width: 15%;
height: 17%;
border-radius: 50%;
}
2018-10-08 01:01:53 +01:00
2018-09-30 23:01:58 +01:00
.sparkle {
top: 25%;
left: 15%;
background: white;
width: 35%;
height: 35%;
border-radius: 50%;
}
2018-10-08 01:01:53 +01:00
2018-09-30 23:01:58 +01:00
.blush-right {
top: 65%;
left: 15%;
background: pink;
width: 15%;
height: 10%;
border-radius: 50%;
}
2018-10-08 01:01:53 +01:00
2018-09-30 23:01:58 +01:00
.blush-left {
top: 65%;
left: 70%;
background: pink;
width: 15%;
height: 10%;
border-radius: 50%;
}
2018-10-08 01:01:53 +01:00
2018-09-30 23:01:58 +01:00
.beak-top {
top: 60%;
left: 40%;
background: var(--penguin-beak, orange);
width: 20%;
height: 10%;
border-radius: 50%;
}
2018-10-08 01:01:53 +01:00
2018-09-30 23:01:58 +01:00
.beak-bottom {
top: 65%;
left: 42%;
background: var(--penguin-beak, orange);
width: 16%;
height: 10%;
border-radius: 50%;
}
2018-10-08 01:01:53 +01:00
2018-09-30 23:01:58 +01:00
.penguin * {
position: absolute;
}
< / style >
< div class = "penguin" >
< div class = "penguin-bottom" >
< div class = "right-hand" > < / div >
< div class = "left-hand" > < / div >
< div class = "right-feet" > < / div >
< div class = "left-feet" > < / div >
< / div >
< div class = "penguin-top" >
< div class = "right-cheek" > < / div >
< div class = "left-cheek" > < / div >
< div class = "belly" > < / div >
< div class = "right-eye" >
< div class = "sparkle" > < / div >
< / div >
< div class = "left-eye" >
< div class = "sparkle" > < / div >
< / div >
< div class = "blush-right" > < / div >
< div class = "blush-left" > < / div >
< div class = "beak-top" > < / div >
< div class = "beak-bottom" > < / div >
< / div >
< / div >
```
2020-11-27 19:02:05 +01:00
# --solutions--
2018-09-30 23:01:58 +01:00
2020-07-13 18:58:50 +02:00
```html
< style > : root { --penguin-belly : pink ; } < / style >
2018-09-30 23:01:58 +01:00
```