/*--------------------------- CSS Reset -------------------------------*/
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,p,blockquote,th,td,html,label,table,tr,td {margin:0;padding:0;}
table{border-collapse:collapse;border-spacing:0;}
fieldset,img,a img,:link img,:visited img {border:0;}
address,caption,cite,code,dfn,th,var {font-style:normal;font-weight:normal;}
ol,ul {list-style:none;}
caption,th {text-align:left;}
h1,h2,h3,h4,h5,h6 {font-size:100%;}
q:before,q:after {content:'';}

/* global elements
 * ------------------------------------------------------------------------- */
@font-face {
    font-family: 'BrockScriptRegular';
    src: url('../fonts/BrockScript-webfont.eot');
    src: url('../fonts/BrockScript-webfont.eot?#iefix') format('embedded-opentype'),
         url('../fonts/BrockScript-webfont.woff') format('woff'),
         url('../fonts/BrockScript-webfont.ttf') format('truetype'),
         url('../fonts/BrockScript-webfont.svg#BrockScriptRegular') format('svg');
    font-weight: normal;
    font-style: normal;
}

/* ----- type selectors ----- */ 
body { 
	background:#ccc url("../images/bg-body.jpg");
	text-align:center; 
	font:12px/16px Arial, Helvetica, sans-serif; 
	color:#4E6300;
	}

blockquote { 
	margin-left:10px; 
	margin-right:10px; 
	}

h1	{ font-size:1.2em; color:#4E6300; }
h2	{ font-size:1.1em; color:#4E6300; }
body#gallery h2	{ font-size:1.1em; color:#4E6300; border-bottom:1px solid #F4DDE0; }
h3	{ font-size: 1.65em; color: #818643; font-family: 'BrockScriptRegular'; font-weight: bold; line-height:2em; }

h1 span,h2 span,h3 span	{ display:none; }

a:link,a:visited	{ color:#4E6300; text-decoration:underline; outline:none; }
a:hover,a:active	{ color:#4E6300; text-decoration:underline; outline:none; }

/* ----- classes ----- */

.clear {
	clear:both;
	}

div.clear	{ 
	clear:both;
	height:.01em; 
	overflow:hidden; 
	}

div.mini-col {
	width:185px;
	float:left;
	}
	
p.back-to-top {
	text-align:right;
	display:block;
	}

p.learn-more {
	text-align:right;
	display:block;
	text-transform:uppercase;
	font-size:10px;
	}
	
	p.learn-more a:link, p.learn-more a:visited, p.learn-more a:hover, p.learn-more a:active { text-decoration:none; color:#837F3A; }
	
p.footnote {
	font-size:10px;
	}
	
img.img-left { 
	float:left; 
	margin:0; 
	}
	
img.img-right { 
	float:right; 
	margin:0; 
	}
	
div.bnas img {
	margin-left:150px;
	}

div.center-align {
	text-align:center;
	margin:0 auto;
	width:515px;
	margin-left:25px;
	}
	
	#column-right div.center-align p, #column-right div.center-align h3 {
		margin:0 0 20px 0;
		}

a.button{
	background:url("../images/button.jpg") no-repeat;
	color:#4e6300;
	display:block;
	font-weight:bold;
	height:38px;
	line-height:38px;
	padding:0 0 0 20px;
	text-decoration:none;
	width:142px;
	}

/* ----- global form elements ----- */ 

form {
	width:151px;
	margin:0 0 15px 0;
	}

form label	{ font-size:.95em; }

form br { line-height:0; height:0; } /* defaults vertical spacing between fields */

input, textarea, select { 
	background-color:#FFF !important; /* to prevent highlighting by Google Toolbar */
	border:1px solid #CAB58E;
	color:#4E6300;
	width:146px; /* 5 pixles smaller than form width !important */
	height:18px;
	line-height:18px;
	vertical-align: middle;
	margin-bottom:4px; /* sets vertical spacing between fields */
	padding-top:1px; /* vertically position text in input/textarea field */
	padding-left:4px; /* horizontally position text in input/textarea field */
	font-family:Arial, Helvetica, sans-serif; 
	font-size:11px;
	}
	
select { width:150px; padding:0; } /* same width as form - !important */

textarea { height:90px; overflow:auto; }

#contact-business { display: none; } /* do not remove */ 


/* ----- main contact form ----- */ 
 
#contact-main { margin:20px 0 10px 0; }

#contact-main label { 
	width:220px; 
	position:relative; 
	display:block; 
	text-align:right; 
	margin-bottom:10px;
	font-size:1.0em;
	}
	
#contact-main label input, #contact-main label textarea, #contact-main label select { 
	width:170px;
	position:absolute; 
	left:110%; 
	top:-2px;
	}
	
#contact-main label select { width:177px; }
	
#contact-main label textarea { height:100px; overflow:auto; }

#contact-business-main { display: none; } /* do not remove */ 


/* ----- submit button form elements ----- */ 

input.submit-contact-main { margin:85px 0 5px 243px; }

body#index input.submit, input.submit-contact-main { 
	background:url("../images/btn-submit.jpg");
	width:55px;
	height:20px;
	border:none;
	cursor:pointer;
	}

input.submit { 
	background:url("../images/btn-submit-sub.jpg");
	width:55px;
	height:20px;
	border:none;
	cursor:pointer;
	}


/* framework
 * ------------------------------------------------------------------------- */
#bg-gradient {
	background:url("../images/bg-gradient.jpg") repeat-x;
	width:100%;
	margin:0;
	}

#bg-flora {
	background:url("../images/bg-flora.jpg") top center no-repeat;
	width:100%;
	margin:0;
	}
	
body#index #bg-wrap-bottom {
	background:url("../images/bg-wrap-bottom.jpg") bottom no-repeat;
	width:834px;
	}

#bg-wrap-bottom {
	background:url("../images/bg-wrap-bottom-sub.jpg") bottom no-repeat;
	padding-bottom: 50px;
	width:834px;
	}

body#index #wrap {
	background:url("../images/bg-wrap.jpg") repeat-y;
	width:834px;
	margin:0 auto;
	text-align:left;
	}

#wrap {
	background:url("../images/bg-wrap-sub.jpg") repeat-y;
	width:834px;
	margin:0 auto;
	text-align:left;
	}
	
#masthead {
	position:relative;
	background:url("../images/masthead.jpg");
	height:75px;
	}
	/* index page link within #masthead */		
	#masthead a {	
		position:absolute;
		left:43px;
		width:260px;
		top:15px;
		height:55px; 
		}
	#masthead a span {
		display:none;
		}

/* ----- column-left ----- */

#column-left {
	width:232px;
	float:left;
	}

body#thankyou #column-left {
	width:232px;
	height:680px;
	float:left;
	}
	
	#column-left p, #column-left h1, #column-left h2, #column-left ul, #column-left dl, #patientform, a.blog {
		margin:0 10px 20px 57px;
		}
	#column-left h3 {
		margin:0 0 20px 50px;
		}
		#column-left #patientform h3{
			margin:0;
			}
		#column-left h3.blog{
			margin-bottom:0;
			}
		#column-left form { margin-left:60px; }
		
	/* single column list */
	#column-left ul { padding-left:10px; }
		#column-left ul li { 
			background:transparent url("../images/bullet.gif") 0px 6px no-repeat;
			padding-left:10px; /* pushes text to the right to display bg img */
			}
			
	#column-left ul li ul { margin:0 0 0 5px; }
	
	#img-location {
		background:url("../images/img-location.jpg") no-repeat 0 25px;
		height:205px;
		position:relative;
		}
		
		#img-location a {
			position:absolute;
			width:135px;
			height:80px;
			left:67px;
			top:125px;
			}
			
			#img-location span { display:none; }
	#last-button { margin-bottom:30px;}
/* ----- column-middle ----- */

#column-middle {
	width:370px;
	float:left;
	}
	
	#column-middle p, #column-middle h1, #column-middle h2, #column-middle h3, #column-middle ul, #column-middle dl {
		margin:0 15px 20px 15px;
		}
	#column-middle form { margin-left:0px; }
	
	/* single column list */
	#column-middle ul { padding-left:5px; }
		#column-middle ul li { 
			background:transparent url("../images/bullet.gif") 0px 6px no-repeat;
			padding-left:10px; /* pushes text to the right to display bg img */
			}
			
	#column-middle ul li ul { margin:0 0 0 5px; }
	
	#img-bna {
		background:url("../images/img-bna.jpg");
		height:141px;
		position:relative;
		margin-top:-15px;
		}
		
		#img-bna .bna-caption {
			position:absolute;
			left:215px;
			top:0px;
			width:155px;
			}

			
/* ----- column-right ----- */

body#index #column-right {
	width:232px;
	float:left;
	}

	body#index #column-right p, body#index #column-right h1, body#index #column-right h2, body#index #column-right h3, body#index #column-right ul, body#index #column-right dl {
		margin:0 47px 20px 10px;
		position:relative;
		z-index:99;
		}

	#column-right p, #column-right h1, #column-right h2, #column-right h3, #column-right ul, #column-right dl {
		margin:0 57px 20px 20px;
		}
	
#column-right {
	width:602px;
	float:left;
	}
	
	#column-right form { margin-left:0px; }
	
	 
	/* single column list */
	#column-right ul { padding-left:5px; }
		#column-right ul li { 
			background:transparent url("../images/bullet.gif") 0px 6px no-repeat;
			padding-left:10px;  /* pushes text to the right to display bg img */
			}

	#column-right ul li ul { margin:0 0 0 5px; }
	
	div.hrule { 
		background:url("../images/hrule.jpg") no-repeat;
		height:90px;
		margin-top:-55px;
		}

	
/* ----- bottom-wrap ----- */
 
body#index #bottom-wrap {
	background:url("../images/bottom-wrap.jpg") center no-repeat;
	height:79px;
	clear:both;
	width:980px; 
	margin:0 auto;
	}

#bottom-wrap {
	background:url("../images/bottom-wrap-sub.jpg") center no-repeat;
	height:79px;
	clear:both;
	width:980px; 
	margin:0 auto;
	}
	
/* header framework
 * ------------------------------------------------------------------------- */

#header-graphic { height:326px; background: url("../images/header-graphic.jpg");} /* sets height for all non-flash headers */

/* subhead framework
 * ------------------------------------------------------------------------- */

#subhead { height:120px; margin-bottom:-43px; } /* sets height for all non-flash subheads */

	body#index #subhead { background:url("../images/subhead-index.jpg"); }
	body#about #subhead { background:url("../images/subhead-about.jpg"); }
	body#general #subhead { background:url("../images/subhead-general.jpg"); }
	body#cosmetic #subhead { background:url("../images/subhead-cosmetic.jpg"); }
	body#gallery #subhead { background:url("../images/subhead-gallery.jpg"); }
	body#contact #subhead { background:url("../images/subhead-contact.jpg"); }
	body#thankyou #subhead { background:url("../images/subhead-thankyou.jpg"); }
	body#sitemap #subhead { background:url("../images/subhead-sitemap.jpg"); }

h2#invisalign {
	background:url("../images/logo-invisalign.gif");
	width:100px;
	height:26px;
	}
	
/* ------------------------ title framework with varying heights ------------------------- */
body#index #title-qcontact {
	height:104px;
	background:url("../images/title-qcontact.jpg") ;
	}

#title-qcontact {
	height:93px;
	background:url("../images/title-qcontact-sub.jpg") ;
	}

body#contact #title-qcontact, body#thankyou #title-qcontact {
	height:93px;
	background:url("../images/title-office.jpg") ;
	}

#title-procedures {
	height:93px;
	background:url("../images/title-procedures.jpg") ;
	}

#title-ftrd-procedure {
	height:135px;
	background:url("../images/title-ftrd-procedure.jpg") 0 -15px;
	margin-top: 40px;
	}

#title-about {
	height:77px;
	background:url("../images/title-about.jpg") ;
	}

#title-news {
	height:99px;
	background:url("../images/title-news.jpg") ;
	}

#title-events {
	height:55px;
	background:url("../images/title-events.gif") ;
	}
	
#title-children {
	height:39px;
	background:url("../images/title-children.jpg") ;
	}


/* footer
 * ------------------------------------------------------------------------- */
 
#footer {
	width:834px;
	margin:0 auto;
	text-align:center;
	color:#828741;
	}

#footer a:link, #footer a:visited	{ color:#828741; text-decoration:underline; outline:none; }
#footer a:hover, #footer a:active	{ color:#828741; text-decoration:underline; outline:none; }

#footer p {
	margin:0 20px 10px 20px;
	}

#footer ul {margin-bottom:10px;}

#footer li { /* if your li's float, you can adjust border height w/ line-height */
	padding:0 5px 0 7px;
	display: inline;
	border-left: 1px solid #828741;
	}

	#footer li.first { border: none; }

/* Horizontal Sprite Nav
 * ------------------------------------------------------------------------- */

#nav { 
	background:url("../images/nav.jpg") no-repeat; 
	width:834px; 
	height:46px; 
	margin:0;
	padding:0; 
	}

#nav span { display: none; }

#nav li, #nav a { height:46px; display:block; } /* change height here also */

#nav li { float:left; list-style:none; _display:inline; position:relative; }

#nav-01 { width: 44px; margin-left: 50px;}
#nav-02 { width: 113px; margin-left: 17px;}
#nav-03 { width: 118px; margin-left: 17px;}
#nav-04 { width: 122px; margin-left: 17px;}
#nav-05 { width: 80px; margin-left: 17px;}
#nav-06 { width: 73px; margin-left: 17px;}


/*-------------- (-79px) X position of button / (-46px) height of image from above ------------- */
#nav-01 a:hover { background:url("../images/nav.jpg")  -50px -46px no-repeat; }
#nav-02 a:hover { background:url("../images/nav.jpg") -111px -46px no-repeat; }
#nav-03 a:hover { background:url("../images/nav.jpg") -241px -46px no-repeat; }
#nav-04 a:hover { background:url("../images/nav.jpg") -376px -46px no-repeat; }
#nav-05 a:hover { background:url("../images/nav.jpg") -515px -46px no-repeat; }
#nav-06 a:hover { background:url("../images/nav.jpg") -612px -46px no-repeat; }


/*-------------- OPTIONAL - Keeps the hover state on each page based on body #id ------------- */
body#index #nav-01 { background:url("../images/nav.jpg")  -50px -46px no-repeat; }
body#about #nav-02 { background:url("../images/nav.jpg") -111px -46px no-repeat; }
body#general #nav-03 { background:url("../images/nav.jpg") -241px -46px no-repeat; }
body#cosmetic #nav-04 { background:url("../images/nav.jpg") -376px -46px no-repeat; }
body#gallery #nav-05 { background:url("../images/nav.jpg") -515px -46px no-repeat; }
body#contact #nav-06 { background:url("../images/nav.jpg") -612px -46px no-repeat; }

/* Son of Suckerfish: Horizontal Sprite Nav
 * ------------------------------------------------------------------------- */

#nav li ul {
	position:absolute;
	left:-9999px;
	padding-right:1px;			/* Fixes one px spacing for border-right in FF */
	background-color:#F0F1E5;	/* Background color of drop down nav - add more styles (i.e. background image) if you want */
	}

#nav li ul li { 
	height:20px; 				/* Height of each drop down nav item */
	border:1px solid #D9D8BA;
	border-top:none;
	}	

#nav li ul li a {
	width:100%;
	height:20px;				/* Height of each drop down nav item, should match above */
	line-height:20px;			/* Height of each drop down nav item again, should match above */
	}

#nav li ul li a span {
	display:block;
	padding-left:5px;
	}

/* Drop down link styles */
#nav a:link, #nav a:visited, #nav a:hover, #nav a:active {
	font-size:1.0em;
	color:#4E6300;
	text-decoration:none;
	}

#nav li:hover ul, #nav li.sfHover ul	{ left: auto; }

/* Hover styles for drop down items */
#nav-02 ul a:hover, #nav-03 ul a:hover, #nav-04 ul a:hover { 
	background-image:none;
	background-color:#D9DAC5;
	color:#7A3230;
	text-decoration:none;
	}

/* width of drop down nav - choose width that allows items to display on one line */
#nav-02 ul, #nav-02 li { width:145px; }		
#nav-03 ul, #nav-03 li { width:150px; }		
#nav-04 ul, #nav-04 li { width:130px; }

/*-------------- Privacy Notice ------------- */

body#privacy-notice {
	background:none;
	}

body#privacy-notice #wrap {
	background-color:#fff;
	background-image:none;
	width:500px;
	}
	
	body#privacy-notice #wrap p {
		margin-bottom:20px;
		}
	

