<div class="badge">
<div class="dotted">
<div class="bubble" data-icon="!"></div>
</div>
<div class="tail">
<div class="inner"></div>
</div>
</div>
@import compass
/* General Styles */
*, *:after, *:before
box-sizing: border-box
html
background: rgba(127, 127, 128, 1.0)
/* Mixins */
@mixin center-element-x
left: 50%
@include transform(translateX(-50%))
/* Variables */
$circle-dimension: 100px
$circle-radius: 50%
$main-color: rgba(41,137,216, 1) // dark blue
$secondary-color: rgba(67, 143, 194, 1) // light blue
$terciary-color: rgba(255,255,255, 1) // white
/* Bagde Styles */
.badge
position: relative
height: 166px
width: 100px
margin: 100px auto
//background: red
.dotted
@include center-element-x
position: absolute
z-index: 1
width: $circle-dimension
height: $circle-dimension
border-radius: $circle-radius
box-shadow: 0px 2px 10px 1px rgba(0,0,0,.5), inset 0px 0px 5px 1px rgba(0,0,0,.4)
background: $terciary-color
&:before, &:after
@include center-element-x
position: absolute
border-radius: $circle-radius
&:before
content: ''
z-index: 2
top: 5px
width: $circle-dimension - 10px
height: $circle-dimension - 10px
box-shadow: 0px 0px 2px 1px rgba(0,0,0,.8), inset 0px 0px 5px 1px rgba(0,0,0,.4)
background: $main-color
+filter-gradient(#7abcff, #4096ee, vertical)
+background-image(linear-gradient(top, lighten($main-color, 20%) 0%, lighten($main-color, 10%) 60%, $main-color 100%))
&:after
content: ''
z-index: 3
top: 10px
width: $circle-dimension - 20px
height: $circle-dimension - 20px
border: 1px dashed $terciary-color
font-size: 50px
color: white
text-align: center
text-shadow: 0px 0px 4px lighten(black, 15%)
padding:
top: 8px
right: 2px
.bubble
@include center-element-x
position: relative
z-index: 4
top: $circle-dimension - 75px
width: 50px
height: 50px
padding: 0px
background: $terciary-color
border-radius: $circle-radius
box-shadow: 0px 1px 2px 1px rgba(0,0,0,.4)
&:before
content: attr(data-icon)
text-align: center
font-size: 25px
color: $main-color
display: block
padding:
top: $circle-dimension - 89px
right: 2px
&:after
content: ''
display: block
position: absolute
bottom: -4px
left: 5px
width: 0
border-style: solid
border-width: 10px 4px 0
border-color: #FFFFFF transparent
z-index: 1
transform: rotate(35deg)
.tail
@include center-element-x
position: absolute
z-index: 0
top: $circle-dimension - 12px
height: 70px
width: 62px
background: $main-color
+filter-gradient(#2989d8, #2989d8, vertical)
+background-image(linear-gradient(top, lighten($main-color, 12%) 0%,lighten($main-color, 0%) 60%,$main-color 76%,lighten($main-color, 12%) 100%))
box-shadow: 0px 3px 10px 1px rgba(0,0,0,.4)
&:before, &:after
content: ''
position: absolute
z-index: 0
bottom: -15px
width: 0px
height: 0px
border-style: solid
&:before
border-width: 15px 31px 0 0
border-color: lighten($main-color, 12%) transparent transparent transparent
&:after
right: 0
border-width: 0 31px 15px 0
border-color: transparent lighten($main-color, 12%) transparent transparent
.inner
@include center-element-x
position: absolute
z-index: 1
height: 75px
width: 50px
border:
left: 1px dashed $terciary-color
right: 1px dashed $terciary-color
View Compiled
/*
Series
Name : IMG to CSS
Author : Eduardo Grigolo (@eduardoag)
Date : 22/MAY/2013
Number : 1
Version: 1.0a
PSD (UI)
Name : Badge
Description:
This is an exercise to improve my CSS skills.
I'll try to code one template a day based on the UI Designs from the site 365psd.com.
My choices may not alwyas be the bet alternative, so if you plan to use this code in
your project, please consider reviewing it before you do!
!! All the rights are reserved to the author of the design. !!
*/
This Pen doesn't use any external CSS resources.