| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  | --- | 
					
						
							|  |  |  | id: 5a9d725e424fe3d0e10cad10 | 
					
						
							|  |  |  | title: Use CSS Variables to change several elements at once | 
					
						
							|  |  |  | challengeType: 0 | 
					
						
							|  |  |  | videoUrl: 'https://scrimba.com/c/c6bDECm' | 
					
						
							| 
									
										
										
										
											2019-08-05 09:17:33 -07:00
										 |  |  | forumTopicId: 301093 | 
					
						
							| 
									
										
										
										
											2021-01-13 03:31:00 +01:00
										 |  |  | dashedName: use-css-variables-to-change-several-elements-at-once | 
					
						
							| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  | --- | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-27 19:02:05 +01:00
										 |  |  | # --description--
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  | <dfn>CSS Variables</dfn> are a powerful way to change many CSS style properties at once by changing only one value. | 
					
						
							| 
									
										
										
										
											2020-11-27 19:02:05 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  | Follow the instructions below to see how changing just three values can change the styling of many elements. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-27 19:02:05 +01:00
										 |  |  | # --instructions--
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | In the `penguin` class, change the `black` value to `gray`, the `gray` value to `white`, and the `yellow` value to `orange`. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # --hints--
 | 
					
						
							| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-27 19:02:05 +01:00
										 |  |  | `penguin` class should declare the `--penguin-skin` variable and assign it to `gray`. | 
					
						
							| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-27 19:02:05 +01:00
										 |  |  | ```js | 
					
						
							|  |  |  | assert( | 
					
						
							|  |  |  |   code.match(/.penguin\s*?{[\s\S]*--penguin-skin\s*?:\s*?gray\s*?;[\s\S]*}/gi) | 
					
						
							|  |  |  | ); | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | `penguin` class should declare the `--penguin-belly` variable and assign it to `white`. | 
					
						
							| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-27 19:02:05 +01:00
										 |  |  | ```js | 
					
						
							|  |  |  | assert( | 
					
						
							|  |  |  |   code.match(/.penguin\s*?{[\s\S]*--penguin-belly\s*?:\s*?white\s*?;[\s\S]*}/gi) | 
					
						
							|  |  |  | ); | 
					
						
							| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-27 19:02:05 +01:00
										 |  |  | `penguin` class should declare the `--penguin-beak` variable and assign it to `orange`. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ```js | 
					
						
							|  |  |  | assert( | 
					
						
							|  |  |  |   code.match(/.penguin\s*?{[\s\S]*--penguin-beak\s*?:\s*?orange\s*?;[\s\S]*}/gi) | 
					
						
							|  |  |  | ); | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-27 19:02:05 +01:00
										 |  |  | # --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> | 
					
						
							|  |  |  |   .penguin { | 
					
						
							| 
									
										
										
										
											2018-10-08 01:01:53 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-27 07:20:46 -08:00
										 |  |  |     /* Only change code below this line */ | 
					
						
							| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  |     --penguin-skin: black; | 
					
						
							|  |  |  |     --penguin-belly: gray; | 
					
						
							|  |  |  |     --penguin-beak: yellow; | 
					
						
							| 
									
										
										
										
											2020-02-27 07:20:46 -08:00
										 |  |  |     /* Only change code above this line */ | 
					
						
							| 
									
										
										
										
											2018-10-08 01:01:53 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  |     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
										 |  |  |   .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-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
										 |  |  |   .right-feet { | 
					
						
							|  |  |  |     top: 85%; | 
					
						
							|  |  |  |     left: 60%; | 
					
						
							|  |  |  |     background: var(--penguin-beak, orange); | 
					
						
							|  |  |  |     width: 15%; | 
					
						
							|  |  |  |     height: 30%; | 
					
						
							|  |  |  |     border-radius: 50% 50% 50% 50%; | 
					
						
							|  |  |  |     transform: rotate(-80deg); | 
					
						
							| 
									
										
										
										
											2018-10-08 01:01:53 +01:00
										 |  |  |     z-index: -2222; | 
					
						
							| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											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); | 
					
						
							| 
									
										
										
										
											2018-10-08 01:01:53 +01:00
										 |  |  |     z-index: -2222; | 
					
						
							| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											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%; | 
					
						
							| 
									
										
										
										
											2018-10-08 01:01:53 +01:00
										 |  |  |     border-radius: 50%; | 
					
						
							| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											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%; | 
					
						
							| 
									
										
										
										
											2018-10-08 01:01:53 +01:00
										 |  |  |     border-radius: 50%; | 
					
						
							| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											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%; | 
					
						
							| 
									
										
										
										
											2018-10-08 01:01:53 +01:00
										 |  |  |     border-radius: 50%; | 
					
						
							| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											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%; | 
					
						
							| 
									
										
										
										
											2018-10-08 01:01:53 +01:00
										 |  |  |     border-radius: 50%; | 
					
						
							| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											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%; | 
					
						
							| 
									
										
										
										
											2018-10-08 01:01:53 +01:00
										 |  |  |     border-radius: 50%; | 
					
						
							| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											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%; | 
					
						
							| 
									
										
										
										
											2018-10-08 01:01:53 +01:00
										 |  |  |     border-radius: 50%; | 
					
						
							| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											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%; | 
					
						
							| 
									
										
										
										
											2018-10-08 01:01:53 +01:00
										 |  |  |     border-radius: 50%; | 
					
						
							| 
									
										
										
										
											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:#c6faf1; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											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>.penguin {--penguin-skin: gray; --penguin-belly: white; --penguin-beak: orange;}</style> | 
					
						
							| 
									
										
										
										
											2018-09-30 23:01:58 +01:00
										 |  |  | ``` |