/* -----------------------------------------
Site: 			Black Forest Restaurant
Author: 		Sean Langlands
Updated: 		May.3.2010
Updated By: 	Sean Langlands
--------------------------------------------
TABLE OF CONTENTS
--------------------------------------------
Reset:
Body:
Wrapper:
Typography:
Header Section:
Navigation Section:
Content Section:
Footer Section:
Hacks/Fixes:
--------------------------------------------
STYLE RULES
--------------------------------------------
Box
			hieght
			width
			background
			border
			margin
			padding
			display

Position
			position
			top
			left
			float
			clear
			z-index

Font
			color
			font family
			font size
			line hieght
----------------------------------------- */

/* CSS Constants (works in IE6+, FF2+, Opera, Safari and CSS1+)
 * ------------------------------------------------------------
 * Variables like: $variable = 'value';
 * Import this css as:
 * <style type="text/css">
 *		@import '{path-to-cssconst.php}cssconst.php?c={path-to-this-css-file}&{var1}={value1}...';
 * </style>
 * Comment out constants: replace $ with #

#colour2 = '#2f9a9e';

*/

/*----------------- Reset --------------- */

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend {
	margin: 				0px;
	padding:                0px;
	border: 				0px;
	outline: 				0px;
	font-size: 				100%;
	vertical-align: 		baseline;
	background: 			transparent;
}
body {
	line-height: 			1;
}
ol, ul {
	list-style: 			none;
}
blockquote, q {
	quotes: 				none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: 				'';
	content: 				none;
}

/* remember to define focus styles! */
:focus {
	outline: 				0;
}

/* remember to highlight inserts somehow! */
ins {
	text-decoration: 		none;
}
del {
	text-decoration: 		line-through;
}

/*----------------- Body ---------------- */

body {
	background:				url(../../images/interface/main_bg_tiled.png) repeat;
	margin: 				0px;
	padding: 	    	  	0px;
	font: 					12px/16px Verdana, Helvetica, sans-serif;
}

/*-------------- Wrapper ---------------- */

#top_wrapper {
	width:					1200px;
	background:				url(../../images/interface/top_header_bg_tiled.jpg) repeat;
	margin:         		0px auto;
	padding:          	    0px;
	padding-bottom: 		15px;
	position:       		relative;
	z-index:				5;
	border-bottom:			3px solid #5a0c02;

}

#bottom_wrapper {
	width:					1200px;
	background:				url(../../images/interface/footer_bottom_bg.png) bottom center repeat-x;
	background-size: cover;
	margin:         		0px auto;
	padding:          	    0px;
	position:       		relative;
	z-index:				5;
}
@media (min-width: 1200px) {
	#top_wrapper {
	width:					100%;
}
	#bottom_wrapper {
	width:					100%;}

}

div.content {
	width:					100%;
	margin:         		0px auto;
	padding:          	    0px;
	position:       		relative;
	z-index:				10;
}

div.text {
	width:					900px;
	margin:         		0px auto;
	padding:          	    0px;
	position:       		relative;
	z-index:				10;
	color:					#f6e3b5;
	font-size:				12px;
	line-height:			20px;
}

div.top_shading {
	background:				url(../../images/interface/top_shading.png) repeat-x;
	height: 				53px;
	width: 					100%;
	position: 				absolute;
	top: 					0;
	left: 					0;
}

/*-------------- Typography ------------- */

a:link, a:visited {
	color: #fbde05;
}

a:hover, a:active {
	color: #fff;
}
h1 span, h2 span, h3 span {
	display: 				none;
}

h1 {
	font-size:				22px;
	margin-bottom:			12px;
}

h1.welcome {
	background:				url(../../images/titles/welcome.png) no-repeat;
	width: 					596px;
	height: 				50px;
}

h1.restaurant {
	background:				url(../../images/titles/invermere_restaurant.png) no-repeat;
	width: 					227px;
	height: 				50px;
}

h1.menu {
	background:				url(../../images/titles/bavarian_menu.png) no-repeat;
	width: 					167px;
	height: 				50px;
}

h1.gallery {
	background:				url(../../images/titles/bavarian_restaurant_gallery.png) no-repeat;
	width: 					218px;
	height: 				50px;
}

h1.specials {
	background:				url(../../images/titles/specials.png) no-repeat;
	width: 					192px;
	height: 				50px;
}

h1.contact {
	background:				url(../../images/titles/contact_us.png) no-repeat;
	width: 					166px;
	height: 				50px;
}

h1.thank_you {
	background:				url(../../images/titles/thank_you.png) no-repeat;
	width: 					463px;
	height: 				50px;
}

h1.employment {
	background:				url(../../images/titles/human_recources.png) no-repeat;
	width: 					264px;
	height: 				50px;
}

h1.friends {
	background:				url(../../images/titles/friends_links.png) no-repeat;
	width: 					238px;
	height: 				50px;
}

h2 {
	margin-bottom:			14px;
	font-size:				18px;
	font-weight:			bold;
}

p {
	margin-bottom:			15px;
}

a span { display: none; }

a.book_reserve {
	background:				url(../../images/titles/book_reservation.png) no-repeat;
	width: 					596px;
	height:					80px;
	display: 				block;
}

a.book_reserve:hover {
	background-position: 	-596px 0;
}

span.required_field {
	color: #F00;
}

/*-------------- Header Section --------- */

#header {
	height:					358px;
	width:					661px;
	margin: 				0 auto;
	display:				block;
	position:				relative;
	z-index:				20;
}

div.header_img {
	z-index:				10;
	position:				absolute;
	top: 					25px;
	left:					50px;
}

div.header_frame {
	background: 			url(../../images/interface/main_header_comp.png) no-repeat;
	z-index:				50;
	height:					358px;
	width:					661px;
	position:				absolute;
	overflow:				hidden;
}

#logo {
	height:					153px;
	width:					203px;
	position:				absolute;
	top:					150px;
	left:					12%;
}

@media (max-width: 1344px) {
	#logo {
		left:					7%;
	}
}

@media (max-width: 1170px) {
	#logo {
		left:					4%;
	}
}

#header .search {
	height:					12px;
	width:					467px;
	border:					1px solid #292929;
	padding:	        	10px;
	position:				absolute;
	top:					16px;
	right:					41px;
	font-size:				11px;
	font-weight:			bold;
}
#header .search-button {
	height:					17px;
	width:					80px;
	background:				url(../../images/interface/search-button.png) no-repeat;
	border:					none;
	cursor:					pointer;
	position:				absolute;
	top:					56px;
	right:					41px;
}
#facebook {
	height:					14px;
	width:					133px;
	position:				absolute;
	bottom:					10px;
	right:					181px;
}
#twitter {
	height:					14px;
	width:					114px;
	position:				absolute;
	bottom:					10px;
	right:					41px;
}

/*----------------- Main Navigation --------------- */

#navigation {
	width:					685px;
	height:					45px;
	padding: 				0;
	margin: 				0 auto;
	background:				url(../../images/interface/main_navigation.png) no-repeat;
	z-index:				40;
	margin-bottom: 			30px;
	position: 				relative;
}

#navigation span { display:	none; }

#navigation li {
	list-style-type:		none;
	margin-left:			0px;
	padding:				0px;
	position:				relative;
	height:					45px;
	float: 					left;
}

#navigation li a {
	height:					45px;
	display: 				block;
	margin:					0px;
	padding:				0px;
	width:					113px;
}

.home {
	left:					0px;
	width:					113px;
}

.restaurant {
	left:					0px;
	width:					113px;
}

.menu {
	left:					0px;
	width:					113px;
}

.specials {
	left:					0px;
	width:					113px;
}

.gallery {
	left:					0px;
	width:					113px;
}

.contact {
	left:					0px;
	width:					113px;
}

.home a:hover, .home .selected  {
	color:					#FFF;
	background:				transparent url(../../images/interface/main_navigation.png) 0px -52px no-repeat;
}

.restaurant a:hover, .restaurant .selected  {
	color:					#FFF;
	background:				transparent url(../../images/interface/main_navigation.png) -113px -52px no-repeat;
}

.menu a:hover, .menu .selected  {
	color:					#FFF;
	background:				transparent url(../../images/interface/main_navigation.png) -226px -52px no-repeat;
}

.gallery a:hover, .gallery .selected  {
	color:					#FFF;
	background:				transparent url(../../images/interface/main_navigation.png) -339px -52px no-repeat;
}

.contact a:hover, .contact .selected  {
	color:					#FFF;
	background:				transparent url(../../images/interface/main_navigation.png) -452px -52px no-repeat;
    width:                  103% !important;
}

/*------------- Menu Section ---------- */

#menu_bg {
	background: #fff;
	border: 3px solid #f3d39f;
	padding: 20px;
	color: #200e08;
	-moz-box-shadow: 0 0 8px #000;
	-webkit-box-shadow: 3px 3px 3px #666;
	box-shadow: 3px 3px 3px #666;
	width: 600px;
	margin-left: -20px;
	text-align: center;
}

#menu_bg h2 {
	text-decoration: underline;
}

#menu_bg a:link, #menu_bg a:visited {
	color: #5a0c02;
	font-weight: bold;
}

#menu_bg a:hover, #menu_bg a:active {
	color: #200e08;
	font-weight: bold;
}

div.section {
	text-align: center;
	margin: 30px 0;
}

div.col_1, div.col_2, div.col_3 {
	width: 175px;
	float: left;
	text-align: center;
}

div.col_1 { margin-left: 35px; }

div.col_2_1, div.col_2_2 {
	width: 200px;
	float: left;
	text-align: left;
}

div.col_2_1 img, div.col_2_2 img {
	border: 3px solid #f3d39f;
	margin: 10px 0;
}

ul li {
	color: #5a3729;
}
dl {

}

dt {
	font-weight: bold;
	color: #3d1c13;

}

dd {
	margin-bottom: 15px;
	color: #5a3729;
}

hr {
	border: 1px	solid #f3d39f;
}

p.menu_nav {
	color: #ccc;
	float: right;
	margin-top: -30px;
	margin-right: -20px;
}

p.menu_nav a {
	background: url(../../images/interface/arrow_down.png) right center no-repeat;
	padding-right: 16px;
}


/*------------- Gallery Section ---------- */

ul#gallery {
	width: auto;
	margin: 25px 0;
	padding: 0;
}

ul#gallery li {
	margin: 8px;
	width: 75px;
	height: 75px;
	display: block;
	float: left;
	border: 3px solid #f3d39f;
}

ul#gallery a {
	width: 75px;
	height: 75px;
	display: block;
}



/*------------- Footer Section ---------- */

div.footer_shading {
	height:					38px;
	width:					1200px;
	background:				url(../../images/interface/footer_shading.png) top center no-repeat;
	margin: 				0 auto;
	display:				block;
}

#footer-wrapper {
	height:					auto;
	width:					100%;
	background:				url(../../images/interface/footer_trans_bg.png) repeat;
	margin:					0 auto;
	margin-top: 			60px;
	padding: 				12px 0;
	color:					#444;
	clear:					both;
}

#footer {
	height:					50px;
	width:					1000px;
	background:				none;
	margin:         		0px auto;
	padding:        		0px;
	position:       		relative;
	z-index:				20;
	line-height:			20px;
}

#copyright {
	width:					500px;
	float:					left;
}

#webdesign {
	width:					500px;
	float:					left;
	text-align:				right;
}

#copyright a, #webdesign a {
	color:					#FFF;
	font-size:        		10px;
	text-decoration:		none;
}

.footer_btns a{ color: #888; }

#footer_cta a {
	font-size: 12px;
	font-weight: bold;
	color: #fbde05;
}
#footer_cta a:hover {
	color: #fff;
}

/*-------------- Form Section -------- */

.textfield{
	background: #e8d3a8;
	color: #000;
	border: 1px solid #5a0c02;
	width: 300px;
	height: 20px;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	padding: 4px;
	font-size: 14px;
	margin-top: 4px;
}


.textarea {
	background: #e8d3a8;
	color: #000;
	border: 1px solid #5a0c02;
	width: 300px;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	padding: 4px;
	font-size: 14px;
	margin-top: 4px;
}

#reserve { width: 195px; }

span.confirm_btns_default {   }
span.confirm_btns_bookings {  float: right; margin-right: -10px; }

.select {
	background: #e8d3a8;
	color: #000;
	border: 1px solid #5a0c02;
	width: 100px;
	height: 30px;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	padding: 4px 12px;
	margin-top: 6px;
}



span.info {
	font-size: 10px;
	color: #666;
	display: block;
}

.button {
	width: auto;
	font-size: 12px;
	background: #e8d3a8;
	color: #000;
	border: 1px solid #5a0c02;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	font-weight: bold;
	padding: 5px 12px 5px 12px;
	cursor: pointer;
	letter-spacing: 1px;
}

.button:hover {
	background: #fff;
	color: #000;
	border: 1px solid #5a0c02;
	-moz-box-shadow: 0 0 3px #FF0000;
	-webkit-box-shadow: 0 0 3px #FF0000;
}

.over {
	background: #fff;
	color: #000;
	border: 1px solid #5a0c02;
	-moz-box-shadow: 0 0 3px #FF0000;
	-webkit-box-shadow: 0 0 3px #FF0000;
}

form p {
	color: #e8d3a8;
	font-weight: bold;
	position: relative;
}

form#default {
	width:310px;
	margin-bottom:	50px;
}


div.map_address {
	position: absolute;
	right: -25px;
	top: 110px;
	text-align: right;
	font-size: 11px;
}

div.map_address img {
	border: 3px solid #f3d39f;
	margin-bottom: 5px;
}


/*------------- Hacks/Fixes ------------- */

/* Firefox Float Fix                     */

.clearfix:after {
	height:					0;
	visibility: 			hidden;
	display: 				block;
	clear: 					both;
	content: 				".";
	line-height: 			0;
}

.clearfix {
	display: 				block;
}

html[xmlns] .clearfix {
	display:				block;
}

* html .clearfix {
	height: 				1%;
}

div.clear { clear: both; }

/*------------- Form Security ------------- */

.fsec { display: none; }

/*------------- Misc. ------------- */

.align_center {
	text-align: center;
}

.float_left {
	float: left;
	border: 3px solid #f3d39f;
	margin: 8px;
}

.float_right {
	float: right;
	border: 3px solid #f3d39f;
	margin: 8px;
}
.couple {
	position: absolute;
	right: -206px;
	top: 76px;
	z-index: 2000;
}