#banner { 
	display: block;
	position: absolute;
	width: 40%;
	height: 85px;
	top: 0;
	right: 0;
	margin-top: 20px;
	margin-right:-100%;
	transition: margin-right 2000ms ease-in-out;
	border: 0 none;
	border-top: 2px solid #fff;
	border-bottom: 2px solid #fff;
}

#banner a {
	display: block;
	color: #fff;
	padding: 8px 20px 8px 70px;
	background: #7f8c8d;
	height: 100%;
	overflow: hidden;
}

#banner.load {
	margin-right: 0;
}

.banner-close {
	position: absolute;
	color: #fff;
	top: 0px;
	left: -70px;
	cursor: pointer;
}

.banner-circle {
	border-radius: 50%;
	border: 2px solid #7f8c8d; 
	background: #fff;
	width: 100px;
	height: 100px;
	position: absolute;
	left: -50px;
	top: -8px;
}

img.banner-icon {
	position: absolute;
	width: 100px;
	left: -50px;
	opacity: 1;
	top: 2px;
}

.banner-title {
	font-family: Impact, Verdana, sans-serif;
	text-transform: uppercase;
	font-size: 20px;
	line-height: normal;
	margin: 0;
}


.banner-actiontext {
	border-top: 1px solid #fff;
	font-size: .7em;
	margin-top: 100%;
	transition: margin 2.5s ease-in;
}

#banner.load .banner-actiontext {
	margin: 0;
}

#banner:hover a {
	background: #fff;
	color: #7f8c8d;
}

#banner:hover .banner-circle {
	border-color: #fff;
	background: #7f8c8d;
}


@media only screen and (max-width: 950px) {
	#banner { 
		width: 100%;
		height: 100%;
		border: 0 none;
		margin-top: 0;
		font-size: .9em;
	}

	#banner a {
		padding: 10px 20px;
	}

	.banner-close {
		position: absolute;
		font-size: 1.2em;
		top: 10px;
		left: 15px;
	}

	#banner:hover .banner-close {
		color: #222;
	}

	img.banner-icon,
	.banner-circle { 
		margin: 0 auto;
		left: 50%;
		top: auto;

	}

	.banner-circle {
		width: 70px;
		height: 70px;
		margin-left: -35px;
	}

	img.banner-icon {
		width: 50px;
		margin-left: -25px;
		margin-top: 10px;
	}

	.banner-bg { 
		width: 100%;
		text-align: center;
		margin-top: 75px;
		display: block;
	}
	.banner-subtitle,
	.banner-title {
		display: inline-block;
		text-align: center;
		margin: 0 auto;
	}
}
