/*
        NOTE - The CSS here is very verbose, and could probably be cleaned up a lot
    (eg., hover states only modifying color and so on.) Verbosity was chosen so
        code could be moved around independently in blocks - at least, in theory.
*/

.demo-button {
    position:relative;
    display:inline-block;
    width:40em;
    padding:0.25em 0.5em 0.3em 0.5em;
    text-align:center;
    cursor:pointer;
    border:2px solid #999;
    background-color:#666;
    background-color:rgba(128,128,128,0.75);
    -moz-border-radius:16px;
    -webkit-border-radius:16px;
    -opera-border-radius:16px;
    -khtml-border-radius:16px;
    border-radius:16px;
    font-size:1.5em;
    color:#fff;
    font-weight:bold;
    text-shadow:1px 1px 3px rgba(0,0,0,0.5);
    border-color:#aa7777;
    background-color:rgba(255,0,0,1);
    background-image:-webkit-gradient(linear, 0% 0%, 0% 90%, from(rgba(128,64,64,0.75)), to(rgba(256,128,128,0.9)));
    background-image:-moz-linear-gradient(top,bottom,from(rgba(128,64,64,0.75)), to(rgba(192,128,128,0.9)));
    -khtml-box-shadow:rgba(256,128,128,0.5) 0px 8px 8px;
    -moz-box-shadow:rgba(256,128,128,0.5) 0px 8px 8px;
    box-shadow:rgba(256,128,128,0.5) 0px 8px 8px;
}

.demo-button span {
    position:absolute;
    display:block;
    width:94%;
    left:3.5%;
    top:0px;
    height:50%;
    -webkit-border-radius:8px;
    -moz-border-radius:8px;
    background-color:rgba(255,255,255,0.25);
    background-image:-webkit-gradient(linear, 0% 0%, 0% 100%, from(rgba(255,255,255,0.75)), to(rgba(255,255,255,0)));
    background-image:-moz-linear-gradient(top,bottom,from(rgba(255,255,255,0.75)), to(rgba(255,255,255,0)));		
}

#shiny {
    margin-right:1.5em;
    margin-right:1.5em;
}
