/* CSS Document */

@font-face {
    font-family: 'haettenschweilerregular';
    src: url('../fonts/hatten-webfont.eot');
    src: url('../fonts/hatten-webfont.eot?#iefix') format('embedded-opentype'),
         url('../fonts/hatten-webfont.woff') format('woff'),
         url('../fonts/hatten-webfont.ttf') format('truetype'),
         url('../fonts/hatten-webfont.svg#haettenschweilerregular') format('svg');
    font-weight: normal;
    font-style: normal;
}

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p,
a, em, img, strong, sub,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, tbody, tfoot, thead, tr, th, td {
	margin: 0;
	padding: 0;
	border: 0;
}

body {
	font-family: Arial, Helvetica, sans-serif;
	background: url(../img/body-bg2.jpg) repeat-x;
}

html, body {
	height: 100%;
}

ol, ul {
	list-style: none;
}

a {
	text-decoration: none;
}




/*  General   */

.bg {
	position: relative;
	width: 100%;
	background: url(../img/body-bg.jpg) center top no-repeat;
	overflow: hidden;
}

.bg-bottom {
	width: 100%;
	overflow: hidden;
	background: url(../img/bg-bottom.png) repeat-x bottom;
}

#container {
	width: 950px;
	margin: 0 auto;
}

.clear {
	clear: both;
}

.bold {
	font-weight: bold;
}



/*############################# HEADER #############################*/

#header {
	position: relative;
	width: 100%;
	padding: 30px 0 0 0;
	height: 166px;
	z-index: 99;
}

#header h1.logo a {
	float: left;
	display: block;
	width: 81px;
	height: 81px;
	background: url(../img/header-logo.jpg) no-repeat;
	text-indent: -9999em;
	overflow: hidden;
}

#header .banner {
	float: right;
	width: 856px;
	height: 81px;
	background: url(../img/header-banner.jpg) no-repeat;
	text-indent: -9999em;
	overflow: hidden;
}

#main-menu {
	position: absolute;
	bottom: 0;
	left: -180px;
	background: url(../img/header-main-menu.png) no-repeat;
	width: 1023px;
	height: 69px;
	padding: 0 146px;
}

#main-menu li {
	float: left;
}

#main-menu li a {
	float: left;
	display: block;
	height: 46px;
	text-transform: uppercase;
	color: #FFF;
	font-size: 13px;
	font-weight: bold;
	letter-spacing: -1px;
	line-height: 46px;
	text-align: center;
}

#main-menu li a:hover,
#main-menu li a.active {
	color: #404041;
}

#main-menu li a.link1 {
	width: 165px;
}

#main-menu li a.link1:hover,
#main-menu li a.link1.active {
	background: url(../img/header-main-menu.png) -147px -69px no-repeat;
}

#main-menu li a.link2 {
	width: 245px;
}

#main-menu li a.link2:hover,
#main-menu li a.link2.active {
	background: url(../img/header-main-menu.png) -247px -69px no-repeat;
}

#main-menu li a.link3 {
	width: 415px;
}

#main-menu li a.link3:hover,
#main-menu li a.link3.active {
	background: url(../img/header-main-menu.png) -247px -69px no-repeat;
}

#main-menu li a.link4 {
	width: 198px;
}

#main-menu li a.link4:hover,
#main-menu li a.link4.active {
	background: url(../img/header-main-menu.png) -970px -69px no-repeat;
}


/*############################# CONTENT #############################*/

#content {
	position: relative;
	width: 100%;
	background: url(../img/content-bg.jpg) no-repeat;
	margin: -23px 0 0 0;
	padding: 25px 0 0 0;
	z-index: 9;
	display: table;
}

#content .left-box {
	float: left;
	width: 255px;
	height: 426px;
	padding: 0 31px 0 25px;
	background: url(../img/content-left-box-bg.png) no-repeat;
}

#content .left-box h3 {
	margin: 0 auto;
	width: 237px;
	height: 176px;
	background: url(../img/content-left-box-title.png) no-repeat;
	text-indent: -9999em;
	overflow: hidden;
}

#content .left-box h2 {
	font-family: 'haettenschweilerregular';
	font-size: 34px;
	font-weight: normal;
	color: #f8b600;
	padding: 5px 0 0 20px;
}

#content .left-box p {
	color: #FFF;
	font-size: 14px;
	line-height: 18px;
	padding: 5px 20px 0 20px;
}

#content .left-box p strong {
	font-weight: normal;
}

#content .right-section {
	float: left;
	position: relative;
	width: 615px;
	height: 426px;
	margin: 1px 0 0 0;
	background: url(../img/content-slider-bg.png) no-repeat;
}

#content .slider-wrapper {
	position: absolute;
	width: 679px;
	height: 431px;
	top: 0;
	left: -31px;
	background: url(../img/content-slider-bg.png) no-repeat;
}

#boxes {
	position: relative;
	clear: both;
	background: url(../img/content-line-sep.png) center top no-repeat;
	overflow: hidden;
	padding: 20px 0 0 13px;
}

#boxes .box {
	float: left;
	position: relative;
	width: 171px;
	margin: 0 0 0 12px;
}

#boxes .box a.block {
	position: absolute;
	top: 27px;
	left: 0;
	right: 0;
	bottom: 0;
	display: block;
	z-index: 99;
	background: url(../img/blank.png);
}

#boxes .box a.block:hover {
	background: url(../img/content-box-link-bg.png) no-repeat;
}

#boxes .box h3 {
	color: #323232;
	font-size: 13px;
	line-height: 16px;
	letter-spacing: -1px;
	padding: 4px 0 7px 0;
}

#boxes .box h3 span {
	color: #f8b600;
}

#boxes .box img {
	float: left;
}

#boxes .box p {
	clear: both;
	width: 161px;
	height: 31px;
	background: url(../img/content-boxes-bg1.jpg) no-repeat;
	line-height: 31px;
	font-size: 11px;
	font-weight: bold;
	padding: 0 0 0 10px;
}

#block-links {
	clear: both;
	position: relative;
	margin: 19px 0 0 0;
	padding: 14px 0 0 0;
	background: url(../img/content-line-sep.png) center top no-repeat;
}

#block-links h3 {
	color: #f8b600;
	font-size: 17px;
	letter-spacing: -1px;
	font-weight: normal;
	text-transform: uppercase;
	padding: 0 0 0 25px;
}

#block-links img {
	float: left;
}



/*  About Us  /*/

.about #content .left-box {
	height: 273px;
	padding: 0 26px 0 25px;
	background: url(../img/about-left-box-bg.png) no-repeat;
}

.about #content .right-section {
	width: 347px;
	background: none;
	height: auto;
	padding: 15px 297px 25px 0;
	background: url(../img/about-right-box-bg.png) right top no-repeat;
}

.about #content .right-section h3 {
	color: #323232;
	text-transform: uppercase;
	font-size: 25px;
	padding: 0 0 7px 0;
}

.about #content .right-section h3 span {
	color: #f8b600;
}

.about #content .right-section p {
	color: #404041;
	font-size: 12px;
	line-height: 16px;
}


/*  Promo */

.promo #content .left-box {
	height: 387px;
	padding: 0 16px 0 25px;
	background: url(../img/promo-left-box-bg.png) no-repeat;
}

.promo #content .left-box h4 {
	font-family: 'haettenschweilerregular';
	font-size: 41px;
	line-height: 39px;
	color: #8a8a8c;
	text-transform: uppercase;
	font-weight: normal;
	text-align: center;
	text-shadow: 1px 1px 3px #000;
}

.promo #content .left-box p {
	color: #FFF;
	text-align: center;
	font-size: 17px;
	line-height: 18px;
	padding: 8px 0 0 0;
	letter-spacing: 1px;
	text-shadow: 1px 1px 3px #000;
}

.promo #content .right-section {
	width: 650px;
	background: none;
	height: auto;
	padding: 0 0 25px 0;
	margin: -10px 0 0 0;
	background: none;
}

.promo #content .right-section a.block {
	float: left;
	margin: 4px 2px 0 0;
}

#mask {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 9000;
  background-color: #000;
  display: none;
}
  
.window {
  position: absolute;
  left :0;
  top: 0;
  width: 410px;
  height: 330px;
  padding: 50px 255px 0 255px;
  display: none;
  z-index: 9999;
  background: #ffffff;
  text-align: center;
  border-radius: 10px; 
  -moz-border-radius: 10px; 
  -webkit-border-radius: 10px; 
}

.window .close {
	position: absolute;
	top: 10px;
	right: 10px;
	width: 24px;
	height: 24px;
	background: url(../img/close.png) no-repeat;
	text-indent: -9999em;
	overflow: hidden;
}

.window h1 {
	color: #000;
	font-size: 37px;
	line-height: 55px;
	font-weight: bold;
	text-transform: uppercase;
}

.window h1 span {
	font-size: 19px;
	line-height: 28px;
	display: block;
}

.window h2 {
	color: #febc00;
	font-size: 48px;
	line-height: 58px;
	font-family: 'haettenschweilerregular';
}

.window p {
	color: #000;
	font-size: 16px;
	line-height: 25px;
	text-transform: uppercase;
}

.window p.bottom {
	color: #000;
	font-size: 15px;
	line-height: 25px;
	text-transform: none;
	padding: 12px 0 0 0;
}

.window a.print {
	display: block;
	margin: 15px auto;
	width: 93px;
	height: 20px;
	background: url(../img/promo-print-button.png) no-repeat;
	text-indent: -9999em;
	overflow: hidden;
}



/*  Contact  /*/

.contact #content .left-box {
	height: 426px;
	padding: 0 19px 0 25px;
	background: url(../img/contact-left-box-bg.png) no-repeat;
}

.contact #content .left-box p {
	padding: 15px 20px 0;
}

.contact #content .right-section {
	position: relative;
	width: 590px;
	height: 373px;
	padding: 30px 20px 0 20px;
	background: url(../img/contact-form-bg.jpg) no-repeat;
}

.contact #content .right-section h3 {
	color: #bababa;
	font-size: 16px;
	line-height: 20px;
	text-transform: uppercase;
	text-shadow: 1px 1px 3px #000;
	letter-spacing: -1px;
}

.contact #content form {
	padding: 10px 0 0 0;
}

.contact #content form input,
.contact #content form textarea {
	float: left;
	clear: both;
	width: 560px;
	height: 24px;
	line-height: 24px;
	font-size: 12px;
	font-weight: bold;
	color: #bababa;
	padding: 0 10px;
	border: none;
	margin: 15px 0 0 0;
	background: none;
	font-family: Arial, Helvetica, sans-serif;
}

.contact #content form input.email {
	margin: 19px 0 0 0;
}

.contact #content form textarea {
	text-align: left;
	margin: 18px 0 0 0;
	height: 97px;
	overflow: auto; 
}

button::-moz-focus-inner { 
    border: 0;
    padding: 0;
}

input:focus,
textarea:focus {
	outline:0px;
}

.contact #content form button {
	position: absolute;
	right: 19px;
	bottom: 15px;
	border: none;
	width: 80px;
	height: 28px;
	text-align: center;
	background: url(../img/contact-form-button.png) no-repeat;
	text-indent: -9999em;
	overflow: hidden;
	cursor: pointer;
}

.contact #content form p {
	position: absolute;
	bottom: 27px;
	left: 30px;
	float: left;
	color: #bababa;
	font-size: 12px;
	font-style: italic;
}

.contact #content p.large {
	clear: both;
	width: 100%;
	font-size: 17px;
	padding: 0 0 15px 0;
	text-align: center;
	font-weight: bold;
}

.messagebox {
	position: absolute;
	width: 330px;
	bottom: 25px;
	right: 114px;
	font-size: 12px;
	text-align: right;
	color: #FFF;
}

.messageboxok {
	color: #00CC00;
}

.messageboxerror {
	color: #CC0000;
}






/* Nivo Slider */

.nivoSlider {
	position: relative;
	width: 584px;
	height: 369px;
	margin: 15px 0 0 48px;
}

.nivoSlider img {
	position: absolute;
	top: 0px;
	left: 0px;
	max-width: none;
}

.nivo-main-image {
	display: block !important;
	position: relative !important; 
	width: 100% !important;
}

.nivoSlider a.nivo-imageLink {
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	border: 0;
	padding: 0;
	margin: 0;
	z-index: 6;
	display: none;
	background: white; 
	filter: alpha(opacity=0); 
	opacity: 0;
}

.nivo-slice {
	display: block;
	position: absolute;
	z-index: 5;
	height: 100%;
	top: 0;
}

.nivo-box {
	display: block;
	position: absolute;
	z-index: 5;
	overflow: hidden;
}

.nivo-box img { 
	display: block;
}

.nivo-directionNav a {
	position: absolute;
	top: 153px;
	z-index: 9;
	cursor: pointer;
	width: 65px;
	height: 66px;
	z-index: 999;
	text-indent: -9999em;
	overflow: hidden;
}

.nivo-prevNav {
	left: -49px;
}

.nivo-nextNav {
	right: -49px;
}







/*############################# FOOTER #############################*/

#footer {
	position: relative;
	clear: both;
	margin: 7px 0 0 0;
}

#footer .text {
	background: #333334;
	overflow: hidden;
	height: 38px;
	color: #FFF;
	overflow: hidden;
}

#footer .text p.left {
	float: left;
	width: 430px;
	padding: 0 0 0 27px;
	font-size: 18px;
	line-height: 41px;
	letter-spacing: -1px;
}

#footer .text p.left span {
	float: left;
	font-size: 31px;
	line-height: 38px;
	font-family: 'haettenschweilerregular';
	letter-spacing: normal;
	padding: 0 5px 0 0;
}

#footer .text p.right {
	float: right;
	width: 467px;
	text-align: right;
	letter-spacing: -1px;
	font-size: 16px;
	line-height: 38px;
	padding: 0 25px 0 0;
}

#footer .text p.right span {
	font-size: 21px;
	font-weight: bold;
}

#footer .bottom {
	position: relative;
	padding: 10px 0;
	clear: both;
	font-size: 13px;
	color: #333334;
	line-height: 15px;
}

#footer .bottom p.left {
	float: left;
	width: 450px;
	padding: 0 0 15px 20px;
}

#footer .bottom p.right {
	float: right;
	width: 450px;
	text-align: right;
	padding: 0 20px 15px 0;
}

#footer .bottom p.right a {
	font-weight: bold;
	color: #333334;
}