I'm proud to announce my latest CSS experiment—The CSS Social Buttons. They are not another "pure CSS3" or "HTML5 canvas" icons. These icons use the basic traditional background-image technique. The purpose of these icons is to provide a cross-browser, consistent and versatile CSS that can be applied in any design, app or theme. Basically, it is one master stylesheet that contains various design styles. It allows you to display many different button styles by combining the CSS classes.

Implementation

To apply this CSS Social Icons to your site, download the demo zip and include the social-icons.css file to your site:

<link href="social-buttons.css" rel="stylesheet">

Option A: You need to add a .sb class (sb stands for social button) and the icon class (eg. twitter, facebook, rss, etc.) to the <a> link tag. Use this option if you want each button to have different style.

Option B: The .sb class can also be in the wrapping tag such as <p>, <div> or <ul> tag. The icon class (eg. twitter, facebook, rss) is required inside the <a> tag. Use this option if you want the buttons to have one consistent style.

Available CSS Classes

Below is a list of the classes available. You can specify as many classes as you want. It is very versatile. You can mix and match the styles to produce many possible results. For example, you can have "large blue gradient glossy embossed text thick-border" all in one button. Check the demo to see examples.

Sizes

default = 34px

small = 28px

large = 42px

Colors

blue

purple

red

green

orange

brown

black

gray

light-gray

light-blue

light-purple

pink

light-green

yellow

Styles

min = minimal style, no background or border

flat = no rounded corners and box shadows

circle = circle style

embossed = embossed style

pressed = pressed like style

thick-border = thicker border stroke

no-border = remove border

no-shadow = remove box-shadow

gradient = the gradient is applied to the :after element

glossy = the glossy overlay gradient is added to the :before element

text = display icon with text

Icons

twitter

facebook

heart

linkedin

pinterest

podcast

rss

share_this

star

vimeo

How to Add Your Own Icons

Because there are too many social networks, I've only included some basic icon classes in the demo to keep the social-icons.css file small. You can add more icon classes with the following sample CSS code (don't forget to add the .sb blass in your link tag <a href="#" class="sb youtube">):

Download More Icons

The icons used in the demo are from the free Mono Social Icons where you can download from IconDock. The vector EPS version is included in the set. The other matching icons are from the Rocky icon set.

How to Override the Button Size & Background Color

You can override the button size and backgound with the following CSS code:

a.sb {
width: 36px;
height: 36px;
background-color: #666;
}

How to Add Custom Gradients

The gradient background is applied to the :after pseudo element. You can generate more gradients using this Ultimate CSS Gradient Generator. Note that SVG gradient is required for Internet Explorer 9 as it does not support native CSS3 gradient.

How to Create Your Own Styles

You can also override the default social-icons.css to create your own styles. The following custom icon class uses the styles from the .gradient class but overrides the :after background-image with a custom image.

Browser Compatibility

The basic styles work on any browser. The CSS3 effects such as: rounded corners, gradient, glossy, pressed, and embossed styles work on any browser that supports CSS3 such as Chrome, Firefox, Safari, and IE9.