input, textarea, select { 
	padding: 8px;
	border: solid 1px #ccc;
	outline: 0;
	background: #fff url('bg.png') left top repeat-x;
	background: -webkit-gradient(linear, left top, left 25, from(#fff), color-stop(4%, #f0f0f0), to(#fff));
	background: -moz-linear-gradient(top, #fff, #f0f0f0 1px, #fff 25px);
	box-shadow: rgba(0,0,0, 0.1) 0px 0px 1px;
	-moz-box-shadow: rgba(0,0,0, 0.1) 0px 0px 1px;
	-webkit-box-shadow: rgba(0,0,0, 0.1) 0px 0px 1px;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	}
	
select {
	padding: 7px;
}
select:disabled {
	border: solid 1px #ddd;
	background: #f6f6f6 url('');
	opacity: 0.4;
}

textarea {
	line-height: 150%;
	}

input:hover, textarea:hover, select:hover,
input:focus, textarea:focus, select:focus {
	border-color: #bbb;
	-webkit-box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 3px;
	}
input:disabled {
	border: solid 1px #ddd;
	background: #f6f6f6 url('');
	opacity: 0.4;
}

.form label {
	margin-left: 10px;
	color: #999;
	}

.submit input {
	padding: 9px 15px;
	background: #360;
	border: 0;
	color: #fff;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	cursor: pointer;
	}
.submit input:hover {
	background: #390;
	}
.submit input:disabled {
	background: #ccc;
	cursor: default;
	}
	
/* #### input file #### */
	
input[type="file"] {
	padding: 7px;
	cursor: pointer;
	text-indent: -99999px;
	color: #fff;
	background: #999;
	border: 0;
	box-shadow: none;
}
input[type="file"]:hover {
	background: #aaa;
	box-shadow: none;
}

/* #### checkbox buttons #### */

input[type="checkbox"] {
    display:none;
}
input[type="checkbox"] + label span{
    display: inline-block;
    width: 20px;
    height: 20px;
	margin: 5px;
    vertical-align: middle;
	border: 1px solid #ccc;
    cursor: pointer;
	box-shadow: rgba(0,0,0, 0.1) 0px 0px 1px;
	-moz-box-shadow: rgba(0,0,0, 0.1) 0px 0px 1px;
	-webkit-box-shadow: rgba(0,0,0, 0.1) 0px 0px 1px;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	background: #fff url('bg.png') left center repeat-x;
}
input[type="checkbox"]:checked + label span{
    background:url(checked.png) no-repeat;
	background-position: center, center;
}
input[type="checkbox"]:hover + label span{
	border-color: #bbb;
	-webkit-box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 3px;
}

/* #### radio buttons #### */

input[type="radio"] {
    display:none;
}
input[type="radio"] + label span{
    display: inline-block;
    width: 20px;
    height: 20px;
	margin: 5px;
    vertical-align: middle;
	border: 1px solid #ccc;
    cursor: pointer;
	box-shadow: rgba(0,0,0, 0.1) 0px 0px 1px;
	-moz-box-shadow: rgba(0,0,0, 0.1) 0px 0px 1px;
	-webkit-box-shadow: rgba(0,0,0, 0.1) 0px 0px 1px;
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;
	background: #fff url('bg.png') left center repeat-x;
}
input[type="radio"]:checked + label span{
    background:url(dot.png) no-repeat;
	background-position: center, center;
}
input[type="radio"]:hover + label span{
	border-color: #bbb;
	-webkit-box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 3px;
}