/* @group General Rules */

/* -- undo browser HTML defaults (see: http://tantek.com/log/2004/09.html#d06t2354) -- */

:link,:visited {
	text-decoration: none;
}

ul,ol {
	list-style: none;
}

h1,h2,h3,h4,h5,h6,pre,code,p {
	font-size: 1em;
}

ul,ol,dl,li,dt,dd,h1,h2,h3,h4,h5,h6,pre,form,body,html,p,blockquote,fieldset,input {
	margin: 0;
	padding: 0;
}

a img,:link img,:visited img {
	border: none;
}

address {
	font-style: normal;
}

span.hide {
	display: none;
}

em.warn {
	font-style: normal;
	color: #f00;
}

a {
	color: #43130f;
	text-decoration: underline;
}

a:hover {
	color: #43130f;
	text-decoration: underline;
}

strong {
	font-weight: bold;
}

em {
	font-style: italic;
}

ul, ol {
	list-style: none;
}

br.clear {
	clear: both;
}

html {
	display: block;
	font: 12px/150% Palatino, Georgia, "Times New Roman", Times, serif;
	background-image: url(../images/bg.jpg);
	height: 100%;
}

body {
	display: block;
	position: relative;
	color: #43130f;
	text-align: center;
}

/* @end */


#contain {
	display: inline;
	float: right;
	margin-right: 90px;
	position: relative;
	width: 900px;
	height: 100%;
	text-align: center;
	background: url(../images/bg-trans.png) repeat-y left top;
	z-index: 100;
}

#content {
	display: block;
	width: 860px;
	margin: 0 auto;
	height: 100%;
	z-index: 9999;
	background-image: url(../images/int-bg.jpg);
}

div#edge-left {
	display: block;
	position: absolute;
	width: 2px;
	height: 100%;
	top: 0;
	left: 20px;
	background: url(../images/edging.gif) repeat-y;
	z-index: 9999;
}

div#edge-right {
	display: block;
	position: absolute;
	width: 2px;
	height: 100%;
	top: 0;
	left: 879px;
	background: url(../images/edging.gif) repeat-y;
	z-index: 9999;
}

#branding-nav {
	display: block;
	position: relative;
	width: 860px;
}

body.index #branding-nav {
	display: block;
	position: relative;
	height: 474px;
}

body.index #branding-nav h1 a {
	display: block;
	position: relative;
	width: 860px;
	height: 374px;
	background: url(../images/the-west2.jpg) no-repeat left top;
}


body.interior #branding-nav h1 a {
	display: block;
	position: relative;
	width: 860px;
	height: 240px;
	background: url(../images/headers/int-top.jpg) no-repeat left top;
}

body.interior #branding-nav h2 {
	display: block;
	position: relative;
	width: 860px;
	height: 369px;
}



body.interior #branding-nav h3 a {
	display: block;
	position: absolute;
	left: 20px;
	top: 143px;
	width: 196px;
	height: 83px;
	z-index: 9999;
	background: url(../images/interior-logo-trans.png) no-repeat left top;
}

body.interior #branding-nav h2.our-vision {
	background: url(../images/headers/our-vision.jpg) no-repeat left top;
}

body.interior #branding-nav h2.the-working-ranch {
	background: url(../images/headers/working-ranch.jpg) no-repeat left top;
}

body.interior #branding-nav h2.the-teton-valley {
	background: url(../images/headers/teton-valley.jpg) no-repeat left top;
}

body.interior #branding-nav h2.the-opportunity {
	background: url(../images/headers/the-opportunity.jpg) no-repeat left top;
}

body.interior #branding-nav h2.contact {
	background: url(../images/headers/contact.jpg) no-repeat left top;
}

#content-main {
	display: inline;
	float: left;
	width: 540px;
	overflow: hidden;
	z-index: 9999;
	/*min-height: 300px;*/
	margin-bottom: 27px;
}

#content-main-intro {
	display: inline;
	float: left;
	/*width: 540px;
	overflow: hidden;*/
	z-index: 9999;
	margin-bottom: 30px;
}

#content-main img.main {
	display: block;
	position: relative;
	margin: 10px 0 15px 18px;
	padding: 3px;
	border: 1px solid #6e2300;
}

#maps-container {
	margin-left: -40px;
	border: 0px solid #ff3300;
	width: 280px;
}

.map {
	display: inline;
	float: left;
	padding: 0 0 20px 40px;
	/*margin: 0 0 0 40px;*/
	width: 100px;
}

.map a {
	text-decoration: none;
}

.map a:hover {
	color: #990000;
}

#ccrblog {
	display: block;
	width: 93px;
	height: 30px;
	padding: 0px;
	border: 0px solid #300;
	line-height: 33px;
	text-transform: uppercase;
	margin-top: 20px;
}

#ccrblog a {
	display: block;
	margin: 0;
	width: 93px;
	height: 30px;
	text-decoration: none;
	background: url(../images/blog-btn-bkgd.jpg) no-repeat left top;
	font-weight: bold;
	font-size: 11px;
	letter-spacing: 0px;
	text-align: center;
}

#ccrblog a:hover {
	color: #fff;
	background: url(../images/blog-btn-bkgd.jpg) no-repeat left -30px;
}


body.index #content-main {
	min-height: 230px;
}

#content-main h3 {
	display: block;
	position: relative;
	width: 540px;
	height: 115px;
	margin-top: 10px;
}

#content-main-intro h4 {
	display: block;
	position: relative;
	/*height: 25px;*/
	font-size: 24px;
	text-transform: uppercase;
	color: #663300;
	border-bottom: 1px solid #d7b957;
	margin: 33px 33px 10px 33px;
	text-align: left;
	text-indent: 0px;
	letter-spacing: 2px;
	font-weight: normal;
	padding-bottom: 20px;
	
}

body.index #content-main h3 {
	margin-top: 0;
}

#content-main p {
	display: block;
	position: relative;
	margin: 0px 0px 20px 33px;
	text-align: left;
}

#content-main p.center {
	text-align: center;
}

body.index #content-main p {
	display: block;
	position: relative;
	margin: 0px 0px 10px 33px;
	text-align: left;
	font-size: 12px;
	line-height: 21px;
}

body.index #content-main p.intro {
	display: block;
	position: relative;
	margin: 0px 0px 20px 33px;
	color: #921300;
	text-align: left;
	line-height: 33px;
	font-size: 27px;
	font-weight: bormal;
	font-style: italic;
	padding-bottom: 10px;
	/*border-bottom: 1px solid #d7b957;*/
}

#content-main-intro p.intro {
	display: block;
	position: relative;
	margin: 0px 33px 0px 33px;
	color: #921300;
	text-align: left;
	line-height: 32px;
	font-size: 19px;
	font-weight: bormal;
	font-style: italic;
	padding-bottom: 10px;
	border-bottom: 1px solid #d7b957;
	width: 795px;
}

#content-main-intro p.intro em {
	display: inline;
	font-size: 14px;
	font-weight: bold;
	text-transform: normal;
	font-style: italic;
	color: #963;
	letter-spacing: 1px;
	font-weight: normal;
}


#content-main p.intro {
	display: block;
	position: relative;
	margin: 20px 0px 20px 33px;
	color: #921300;
	text-align: left;
	line-height: 27px;
	font-size: 19px;
	font-weight: normal;
	font-style: italic;
}

#content-main p.form-response {
	display: block;
	position: relative;
	margin: 0 0px 20px 33px;
	color: #921300;
	text-align: center;
	line-height: 27px;
	font-size: 16px;
	font-weight: bold;
	font-style: normal;
}

#content-main h4 {
	text-align: left;
	font-size: 14px;
	margin: 20px 0 10px 33px;
}

#content-main img.eof {
	display: inline;
	margin-left: 5px;
}

#content-main span.hr {
	display: block;
	position: relative;
	width: 520px;
	height: 10px;
	margin-left: 20px;
	border: none;
	border: 0;
	background: url(../images/hr.gif) no-repeat left top;
}

#content-main ul {
	display: inline;
	float: left;
	position: relative;
	width: 240px;
	margin: 20px 0 30px 33px;
}

#content-main li {
	display: block;
	position: relative;
	text-align: left;
	padding-left: 23px;
	margin-bottom: 4px;
	line-height: 14px;
	background: url(../images/li-star.gif) no-repeat left center;
}

#content-main blockquote {
	display: inline;
	position: relative;
	float: right;
	text-align: left;
	font-size: 13px;
	line-height: 20px;
	font-weight: bold;
	font-style: italic;
	width: 240px;
	color: #714c27;
	margin: 20px 0 10px 0;
	padding: 10px 5px 0 5px;
	background: url(../images/bq-bg-top-trans.png) no-repeat left top;
}

#content-main blockquote cite {
	display: block;
	position: absolute;
	top: 100%;
	left: 0;
	width: 240px;
	height: 7px;
	background: url(../images/bq-bg-bottom-trans.png) no-repeat left top;
}

#content-sub {
	display: inline;
	float: right;
	width: 300px;
	/*border: 1px solid #000000;*/
}

#content-sub span.hr {
	display: block;
	position: relative;
	width: 268px;
	height: 8px;
	margin: 10px 0;
	border: none;
	border: 0;
	border-bottom: 1px solid #d7b957;
	/*background: url(../images/content-sub-hr.jpg) no-repeat left top;*/
}

#content-sub img.refine {
	display: block;
	position: relative;
	margin: 0 0 20px 0;
}

#content-sub img.train {
	margin: -20px 0 20px 0;
}

#content-sub img.buffalo {
	margin: 0 0 20px 0;
}

#content-sub img.horse {
	margin: -20px 0 20px 0;
}

body.index #content-sub img.refine {
	margin: 23px auto;
}


#content-sub dl, #content-sub ul {
	display: block;
	position: relative;
	text-align: left;
}

#content-sub dl {
	margin-bottom: 27px;
}

#content-sub dt, #content-sub li {
	display: block;
}

#content-sub dt a, #content-sub li a {
	display: block;
	position: relative;
	font-size: 13px;
	/*width: 270px;*/
	height: 20px;
	line-height: 12px;
	/*padding-left: 34px;*/
	padding-left: 0px;
	font-weight: bold;
	margin-right: 21px;
	/*background-image: url(../images/pointing-hand.gif);*/
	
}

#content-sub li a {
	/*height: 25px;*/
	width: 250px;
	font-weight: normal;
	font-size: 12px;
	padding-left: 15px;
	line-height: 23px;
	margin-bottom: 12px;
	border-bottom: 1px solid #d7b957;
	text-transform: uppercase;
	font-size: 10px;
	color: #000000;
	background: url(../images/li-star.gif) no-repeat left center;
}

#content-sub dt a:hover {	
	text-decoration: none;
	/*background-image: url(../images/pointing-hand-o.gif);*/
	color: #990000;
}

#content-sub li a:hover {	
	text-decoration: none;
	/*background-image: url(../images/wheel-o.gif);*/
	color: #990000;
}

#content-sub dd {
	display: block;
	position: relative;
	width: 242px;
	/*padding-left: 34px;*/
	padding-left: 0px;
	margin-right: 21px;
	margin-bottom: 15px;
	margin-top: 3px;
}

#content-sub h5 {
	display: block;
	position: relative;
	margin: 20px 30px 0 0;
}

#content-sub h3 {
	display: block;
	font-size: 14px;
	color:#930;
	position: relative;
	margin: 0 ;
	text-align: left;
}

#content-sub p {
	text-align: left;
}

/* @group Nav Main */

ul#nav-main {
	display: block;
	position: relative;
	width: 860px;
	height: 57px;
}

ul#nav-main li {
	display: inline;
	float: left;
}

ul#nav-main li a {
	display: inline;
	height: 57px;
	float: left;
	background: url(../images/nav.jpg) no-repeat left top;
}

ul#nav-main li#nav-our-vision a {
	width: 154px;
	background-position: left top;
}

ul#nav-main li#nav-our-vision a:hover {
	width: 154px;
	background-position: left -57px;
}

ul#nav-main li#nav-the-working-ranch a {
	width: 193px;
	background-position: -154px top;
}

ul#nav-main li#nav-the-working-ranch a:hover {
	background-position: -154px -57px;
}

ul#nav-main li#nav-teton-valley a {
	width: 184px;
	background-position: -347px top;
}

ul#nav-main li#nav-teton-valley a:hover {
	width: 184px;
	background-position: -347px -57px;
}

ul#nav-main li#nav-opportunity a {
	width: 176px;
	background-position: -531px top;
}

ul#nav-main li#nav-opportunity a:hover {
	width: 176px;
	background-position: -531px -57px;
}

ul#nav-main li#nav-contact a {
	width: 153px;
	background-position: -707px top;
}

ul#nav-main li#nav-contact a:hover {
	width: 153px;
	background-position: -707px -57px;
}

ul#nav-main li a span {
	display: none;
}

/* @end */

#content-footer {
	display: block;
	position: absolute;
	width: 860px;
	left: 20px;
	top: 100%;
	height: 182px;
	margin-top: -367px;
	z-index: 0;	
	/*background: transparent url(../images/teton-cowboy.jpg) no-repeat left top;*/
}

body.index #content-footer {
	height: 13px;
	margin-top: -198px;
	background: transparent url(../images/fringe-bottom.jpg) no-repeat left top;
}

#footer {
	display: block;
	position: relative;
	clear: both;
	width: 860px;
	height: 185px;
	color: #968247;
	background: transparent url(../images/footer-bg.jpg) no-repeat left bottom;
}

#footer h4 {
	display: block;
	position: relative;
	width: 860px;
	height: 65px;
	background: url(../images/this-is-the-american-cowboy.jpg) no-repeat left top;
}

#footer p {
	display: block;
	position: absolute;
	left: 25px;
	top: 90px;
}

#footer ul {
	display: block;
	position: absolute;
	top: 110px;
	left: 20px;
}

#footer li {
	display: inline;
	float: left;
}

#footer li a {
	text-decoration: underline;
	color: #968247;
	margin-left: 5px;
	padding-right: 5px;
	border-right: 1px solid #997231;
}

#footer li a:hover {
	text-decoration: none;
}

#footer dl.vcard {
	display: inline;
	float: right;
	margin: 15px 21px 0 40px;
	width: 120px;
	text-align: left;
}

#footer dl.vcard dt {
	display: block;
	position: relative;
	width: 110px;
	height: 30px;
	margin-bottom: 5px;
}

#footer dl.vcard dt strong {
	display: none;
}

#footer dl.vcard.sir dt {
	background: url(../images/sothebys.gif) no-repeat left top;
}

#footer dl.vcard.ccr dt {
	background: url(../images/ccr-logo.gif) no-repeat left top;
}

h3#stamp {
	display: block;
	position: absolute;
	width: 373px;
	height: 217px;
	left: 0;
	top: 244px;
	background: url(../images/inspired-stamp.jpg) no-repeat left top;
	z-index: 1;
}

/* contact Form styles */

#form-container {
	display: block;
	border: 0px solid #000;
	margin: 0 0 0 33px;
	z-index: 800;
}

form#contact {
	width: 420px;
	text-align: left;
	color:#151515;
	margin: 10px 0 10px 57px;
}

fieldset {
	margin: 0;
	border: 0;
	padding: 0;
}

legend {
	display: none;
}

form#contact h2 {
	clear: both;
	padding: 5px 0px 10px 0px;
	font-size: 14px;
	margin: 0;
	color: #c1582b;
}

form#contact label {
	display: block;
	width: 310px;
	font-size: 12px;
	line-height: 14px;
	padding: 0px 0px 12px 0px;
}

form#contact input {
	display: block;
	margin-top: 3px;
	border: 1px solid #999;
}

form#contact select {
	float: left;
	display: block;
}

form#contact label.field-first,
form#contact label.field-address,
form#contact label.field-city,
form#contact label.field-email {
	clear: left;
}


form#contact label.field-first,
form#contact label.field-last,
form#contact label.field-city,
form#contact label.field-email,
form#contact label.field-phone {
	float: left;
	margin: 0px 20px 0px 0px;
	width: 180px;
}


form#contact label.field-first input,
form#contact label.field-last input,
form#contact label.field-email input,
form#contact label.field-city input,
form#contact label.field-phone input {
	float: left;
	width: 180px;
	padding: 3px;
}

form#contact p.captcha {
	margin-left: 150px;
	width: 230px;
	line-height: 13px;
	margin-top: 20px;
	height: 25px;
}

form#contact input.captcha {
	float: left;
	width: 230px;
	padding: 3px;
	margin: 0;
}

form#contact span.small {
	font-size: 10px;
}

form#contact img.captcha {
	float: left;
	margin: 0 15px 0 0;
}

form#contact label.field-state {
	float: left;
	margin-right: 20px;
	width: 80px;
}

form#contact label.field-state select {
	width: 80px;
	float: left;
	margin-top: 3px;
}

form#contact label.field-zip {
	float: left;
	width: 80px;
}

form#contact label.field-zip input {
	float: left;
	width: 80px;
	padding: 3px;
}

form#contact label.field-address {
	float: left;
	width: 380px;
	margin: 0px 0px 0px 0px;
}

form#contact label.field-address input {
	float: left;
	width: 380px;
	padding: 3px;
}


form#contact input.submit {
	display: block;
	width: 55px;
	height: 25px;
	border: 1px solid #666;
	color: #fff;
	cursor: pointer;
	font-weight: bold;
	background: #333;
	margin-bottom: 160px;
}

form#contact input.submit:hover {
	border: 1px solid #666;
	color: #fdfee7;	
	background: #c1582b;
}

textarea {
	display: block;
}



form#contact textarea {
	margin-top: 3px;
	width: 380px;
	padding: 3px;
	border: 1px solid #999;
}

hr.home {
	border: none;
	display: block;
	clear: left;
	height: 0px;
	border-bottom: 1px solid #d7b957;
	background-color: #d7b957;
	width: 235px;
}