From our sponsor: Meco is a distraction-free space for reading and discovering newsletters, separate from the inbox.
There are so many great things we can do with the additional properties and possibilities that CSS3 brings along. Today I want to show you how to experiment with text shadows and with transitions in order to achieve a blur effect that we’ll apply to a menu on hovering over the elements. The main idea is to blur the other items while enhancing the one we are currently hovering.
The images in the demos are by fabulous Mark Sebastian and they are licensed under the Attribution-ShareAlike 2.0 Generic (CC BY-SA 2.0) License. Visit Mark’s Flickr Photostream or his website to discover some beautiful photography.
Please note that this will only work properly in modern browsers and unfortunately Internet Explorer does not belong to that category yet since it does not support transitions (and many other suggested CSS3 properties that others do support). It also does not support text-shadows, so I’ve added a additional stylesheet for IE which will at least show the menu elements.
Tiny break: 📬 Want to stay up to date with frontend and trends in web design? Subscribe and get our Collective newsletter twice a tweek.
The Markup
Let’s create the HTML structure for our menu first. We’ll add it to a container with a fixed width. The menu is going to look as follows:
<ul class="bmenu"> <li><a href="#">About</a></li> <li><a href="#">Illustrations</a></li> <li><a href="#">Photography</a></li> <li><a href="#">Web Design</a></li> <li><a href="#">Personal Projects</a></li> <li><a href="#">Contact</a></li> </ul>
Now we’ll add some style!
The CSS
In almost all of our examples we’ll have the same style for the ul and for the list elements. Just the link element will be modified. So, the common style for the unordered list is the following:
.bmenu{ padding: 0px; margin: 0 0 10px 0; position: relative; } .bmenu li{ font-size: 50px; display: block; }
Now, let’s take a look at each of the seven examples.
Example 1
In the first example we want to show the menu items slightly blurred initially. For that, we’ll give the link elements transparent color and a white text-shadow. We’ll also add the transitions for all properties:
.bmenu li a{ color: transparent; display: block; text-transform: uppercase; text-shadow: 0px 0px 5px #fff; letter-spacing: 1px; -webkit-transition: all 0.3s ease-in-out; -moz-transition: all 0.3s ease-in-out; -o-transition: all 0.3s ease-in-out; -ms-transition: all 0.3s ease-in-out; transition: all 0.3s ease-in-out; }
When hovering over a link element, we want it to become “clear” and all the others should become blurry. Now, we cannot say “on hover of a particular element do x to all the siblings” in CSS because the sibling selector is not really a sibling selector, it will just give you the next siblings in the HTML.
Anyway, we can do a little trick here. Since we have all our items nicely laid out as block elements, we can simply say, make everything blurry when we hover the whole menu (the unordered list) and then when hovering over a specific item we’ll crisp it up:
.bmenu:hover li a{ text-shadow: 0px 0px 5px #0d1a3a; } .bmenu li a:hover{ color: #fff; text-shadow: 0px 0px 1px #fff; padding-left: 10px; }
By adding a padding left, we’ll animate the currently hovered item a bit to the right.
Example 2
In the second example, we’ll show the items in the menu a bit skewed initially. We’ll do that with the 2D transforms property skew. The value will be -12 degrees which is the skewing angle along the x axis. The link s will have a semi-transparent background that we’ll achieve by using an rgba value. We’ll also add a slighty transparent text-shadow using rgba:
.bmenu li a{ display: block; text-transform: uppercase; text-shadow: 1px 1px 2px rgba(89,22,20,0.3); color: #581514; padding: 5px 20px; margin: 2px; background: rgba(255,255,255,0.2); letter-spacing: 1px; -webkit-transform: skew(-12deg); -moz-transform: skew(-12deg); -o-transform: skew(-12deg); -ms-transform: skew(-12deg); transform: skew(-12deg); -webkit-transition: all 0.4s ease-in-out; -moz-transition: all 0.4s ease-in-out; -o-transition: all 0.4s ease-in-out; -ms-transition: all 0.4s ease-in-out; transition: all 0.4s ease-in-out; }
Hovering over the menu, we’ll change the skew angle to 0 and make them appear blurry with a semi-transparent background. The currently hovered link will have no background:
.bmenu:hover li a{ color: transparent; text-shadow: 0px 0px 10px #fff; background: rgba(88,22,22,0.2); -webkit-transform: skew(0deg); -moz-transform: skew(0deg); -o-transform: skew(0deg); -ms-transform: skew(0deg); transform: skew(0deg); } .bmenu li a:hover{ background: transparent; text-shadow: 1px 1px 10px rgba(89,22,20,0.6); color: #581514; }
Example 3
In the third example we will play a bit with the sizes of the elements. We’ll initially scale them down and blur them. We’ll use a fairly slow linear transition:
.bmenu li a{ white-space: nowrap; color: transparent; display: block; text-transform: uppercase; text-align: center; text-shadow: 0px 0px 6px #fff; letter-spacing: 1px; -moz-transform: scale(0.5); -ms-transform: scale(0.5); -o-transform: scale(0.5); -webkit-transform: scale(0.5); transform: scale(0.5); -webkit-transition: all 0.6s linear; -moz-transition: all 0.6s linear; -o-transition: all 0.6s linear; -ms-transition: all 0.6s linear; transition: all 0.6s linear; }
Hovering over the menu, well blur the items even more and the currently hovered element will be sharpened up and scaled to the original size:
.bmenu:hover li a{ text-shadow: 0px 0px 15px #fff; } .bmenu li a:hover{ text-shadow: 0px 0px 1px #fff; -moz-transform: scale(1); -ms-transform: scale(1); -o-transform: scale(1); -webkit-transform: scale(1); transform: scale(1); }
Example 4
In this variation, we’ll give the link elements a semi-transparent black background and a vibrant orange text color. We’ll use the linear timing transition function here:
.bmenu li a{ display: block; text-transform: uppercase; text-shadow: 0px 0px 2px #eeb213; color: #eeb213; padding: 5px 20px; margin: 2px; background: rgba(0,0,0,0.7); letter-spacing: 1px; -webkit-transition: all 0.2s linear; -moz-transition: all 0.2s linear; -o-transition: all 0.2s linear; -ms-transition: all 0.2s linear; transition: all 0.2s linear; }
When we hover, we want the menu items to blur and and also to make their backgrounds more transparent. A single hovered item will become more opaque:
.bmenu:hover li a{ text-shadow: 0px 0px 10px #eeb213; color: transparent; background: rgba(0,0,0,0.2); } .bmenu li a:hover{ background: rgba(0,0,0,1.0); text-shadow: 0px 0px 1px #eeb213; }
Example 5
The fifth example will be a subtle one: we’ll use only white for the text-shadows and font colors and just blur the elements slightly:
.bmenu li a{ color: transparent; display: block; text-transform: uppercase; text-shadow: 0px 0px 4px #fff; letter-spacing: 1px; -webkit-transition: all 0.2s ease-in-out; -moz-transition: all 0.2s ease-in-out; -o-transition: all 0.2s ease-in-out; -ms-transition: all 0.2s ease-in-out; transition: all 0.2s ease-in-out; }
On hover we’ll blur a little more and crisp up and move the currently hovered link element a bit:
.bmenu:hover li a{ text-shadow: 0px 0px 6px #fff; } .bmenu li a:hover{ color: #fff; text-shadow: 0px 0px 1px #fff; padding-left: 10px; }
Example 6
In this example we’ll give the elements a semi-transparent white background and leave them crisp initially:
.bmenu li a{ white-space: nowrap; display: block; text-transform: uppercase; text-shadow: 1px 1px 2px rgba(71,80,23,0.3); color: #fff; padding: 5px 20px; margin: 2px; background: rgba(255,255,255,0.2); letter-spacing: 1px; -webkit-transition: all 0.4s ease-in-out; -moz-transition: all 0.4s ease-in-out; -o-transition: all 0.4s ease-in-out; -ms-transition: all 0.4s ease-in-out; transition: all 0.4s ease-in-out; }
We want to give the first and last element some rounded borders so that the menu looks like a neat unit. We’ll target our desired elements with the first-child and last-child selectors:
.bmenu li:first-child a{ -webkit-border-radius: 15px 15px 0px 0px; -moz-border-radius: 15px 15px 0px 0px; border-radius: 15px 15px 0px 0px; } .bmenu li:last-child a{ -webkit-border-radius: 0px 0px 15px 15px; -moz-border-radius: 0px 0px 15px 15px; border-radius: 0px 0px 15px 15px; }
On hover, we want the elements to look blurry and the currently hovered element to change colors and have a transparent background:
.bmenu:hover li a{ text-shadow: 0px 0px 10px #fff; color: transparent; } .bmenu li a:hover{ background: transparent; text-shadow: 1px 1px 10px rgba(71,80,23,0.6); color: #c4d85a; }
Example 7
In the last experiment we’ll make the whole menu look like a circle by adding a border radius with the value of half of the menus width/height:
.bmenu{ padding: 50px 0px; margin: 0 auto; position: relative; background: rgba(0,0,0,0.7); width: 500px; height: 400px; -webkit-border-radius: 250px; -moz-border-radius: 250px; border-radius: 250px; -webkit-transition: background-color 0.5s ease-in-out; -moz-transition: background-color 0.5s ease-in-out; -o-transition: background-color 0.5s ease-in-out; -ms-transition: background-color 0.5s ease-in-out; transition: background-color 0.5s ease-in-out; }
We’ll add the transitions here because we want to animate the background color when we enter into the menu. We’ll make it more transparent by using rgba values:
.bmenu:hover{ background: rgba(0,0,0,0.2); }
We’ll adjust the font size and the line height of the list element a bit:
.bmenu li{ font-size: 40px; display: block; line-height: 66px; }
The elements will be scaled down and blurred:
.bmenu li a{ white-space: nowrap; color: transparent; display: block; text-align: center; text-transform: uppercase; text-shadow: 0px 0px 3px #fff; letter-spacing: 1px; -moz-transform: scale(0.8); -ms-transform: scale(0.8); -o-transform: scale(0.8); -webkit-transform: scale(0.8); transform: scale(0.8); -webkit-transition: all 0.4s linear; -moz-transition: all 0.4s linear; -o-transition: all 0.4s linear; -ms-transition: all 0.4s linear; transition: all 0.4s linear; }
Hovering over the menu will also make the elements more blurry and give the currently hovered one a nice background color while crisping it up and scaling it to its original size:
.bmenu:hover li a{ text-shadow: 0px 0px 10px #fff; } .bmenu li a:hover{ text-shadow: none; color: #fff; background: rgba(129,6,29,0.8); -moz-transform: scale(1); -ms-transform: scale(1); -o-transform: scale(1); -webkit-transform: scale(1); transform: scale(1); }
Remember, IE is the party pooper here, but if you’d like to try your luck and use IE’s proprietary shadows, check out the following resources and go wild:
CSS Blurred Text-Shadow in IE β Part I
IE Visual Filters and Transitions Reference: Static Filters
And that’s it! What’s your favorite one? I hope you like these experiments and find them inspiring!
gosh, beautiful!
works smooth on my latest version of chrome. there’s a little rough transition on my firefox 6.0.2. and fail on my dinosaur IE 9 :))
Very nicely done Mary. Love the effects!
Once again – absolutely gorgeous and unique. I really admire your creativity that you combine with functionality. Thank you for sharing it all with us!
jesus, lovelly as always !
what a wonderful things you keep doing !!
I have spent 5 years of my life in technology and never came up with such interest in just 1 single blog, you all guys doing solid job. Thanks for your beauty of mind.
amazing.
Wow,so creative.I’ve learned various things about CSS3 but still cant make anything close to it on my own.
Awfully great. You’re really the best Mary Lou.
Thanks a lot
now we can do it, used CSS…
ty ?
Nice effects always good to see the different things people can do using CSS animation.
Great job i like it a lot! Thank you for your work and sharing with the whole world for free! *
Just Great Mary as usual , thanks a lot …
a little difficult if we want to use it in website with the white background!
I added this on The CSS
.bmenu span{
color: #333;
}
.bmenu span:hover{
color: #AA0000;
}
In The markup to be
<li><a href="#"><span>About</span></a></li>
sorry if me wrong, just try otodidac ways π π
Cheers^^
IE9…fail
answsome, good job Mary!!
Thank you all for your great feedback!! Beben, you have to set the text shadows to black and then it will work nicely with a white background. Here, just for you π : http://tympanus.net/Tutorials/BlurMenu/index8.html
Hope it helps, cheers, ML
Awesome! I Love CSS3
Really impressive tutorials, must have taken a decent amount of time to put those together.
Unlike a lot of css3 animation tutorials, some of these could actually realistically be used today on sites, without being used ‘just for the sake of using css3 transitions’. I really like the #3 demo.
Nice job!
Interesting experiment Manoela π
It’s weird though that, in my case, even in Chrome the animations were hanging π
But I have to admit, you two have some pretty wicked ideas, love how you push the boundaries of today’s tech π
ic ic…can do it too
i dont try change there…hihihi
ty ty
creative more π
cheers
I’m sure glad I found this site a year or so ago. Other web design sites come up with the occasional cool technique but Codrops just continues to crank stuff out. The fact that you guys make it all freely available is icing on the cake.
Thanks so much to all of you!
Una pena que no funcione en IE.
just……… WOW
You Guys are the biggest inspirations over the Net….keep doing your great job!
Thanks a lot!
Excellent Work
Hey, stop complaining about IE failing with that – does it really surprise you after all that time?? Go on hoping for the next IE to do it right… or the one after the next one… π
GREAT work and style as always, Mary Lou! Thanks again for sharing!
oh lovely!
Perfect … I love the effects .. thanks Mary
Sweet Like You ^_^
I Love U Mary =Β€
Thanks a lot, i love this!
I use it on my blog now π
http://hickone.blogspot.com/
Incredible. Technical mastery, amazing creativity. Just perfect.
cool I just needed this effect for a single project
thanx!
I’d like to know how can I create submenu with this style.
Thanks a lot.
Sorry for my bad English
A great demo that uses no javascript, which is refreshing.
Do you think there are any usability issues here? A navigation menu is a core feature in a website after all. I can’t help but think that making the links blurry would detract from a UX perspective.
Perfect presentation of CSS3 capabilities!
Awesome! Thanks!
Thank you very much.
<3 i love u
Delicious…
Great thanks for sharing Mary
just a bit tune for the example 7:
.bmenu {
overflow: hidden;
}
in FF7, there is a lag, and for a second, no round corners for the li, but it looks nicer in overall, i think:)
Simply awesome and sparkly as usual folks.
this effect in jquery is posible? great very nice…congratulations!!!
nice !
π
what is the name of the font that is being used in this demo??
It doesn’t work so well on chrome on my site π the text turns black for less than a second…..
you can see it here http://www.zenodriesen.com/test I really need it to work. When I don’t put a href for the link just a # it does work as it should….
Can anyone help me?
Thanks
Hi Zeno,
I opened your site and it looks fine and smooth in my Chrome which is version 15.0.874.121 m.
Which version do you have?
Cheers, ML
This is great! I really love this and your work! Just curious if you ever figured anything out with the black flash in Chrome. I have found that it occurs even on your hosted examples. (the easiest to see it is example 6). and it only begins after you click on a link. It also seems to flash black for any page that is linked and already in the browser history. It resets to not being black after you delete any browsing data tied to it. My chrome is 17.0.963.46.
Thanks!
Hello! Nice work, but on Opera is a disaster, anyone noticed it ?
P.S: I have the latest version .
Why is there 10 Example Demo’s but only 7 examples shown how to create?
Gracias, Mary
Soy nueva en esto de CSS y realmente agradezco que personas como tu que teneis conocimientos los compartais con el resto
de la gente.
Great tutorial, thanks!