* {
	margin: 0px;
	padding: 0px;
}

html {
	height:90%; 
	/* margin: 0px; */
}

body {
	font-family: Arial, Helvetica, sans-serif;
	/* background-image:url(/images/plain_aqua_lt.jpg); */
	color: #000000;
	background-repeat: repeat;
	/* background-color: #03a996; */
	background-color: #ffffff;
	height:100%;
}
.body{
	-webkit-user-select: none;  /* Chrome all / Safari all */
	-moz-user-select: none;     /* Firefox all */
	-ms-user-select: none;      /* IE 10+ */
	-o-user-select: none;
	user-select: none;
	}	

.serif {
	font-family: "Times New Roman", "Times", serif;
}

font.serif_14_normal_gray {
	font-size: 14pt; 
	font-style: normal; 
	font-family: 'Times New Roman', 'Times', 'serif';
	color: #707070;
	line-height: normal;
}

font.serif_14_bold_gray {
	font-size: 14pt; 
	font-style: normal; 
    font-weight: bolder;
	font-family: 'Times New Roman', 'Times', 'serif';
	color: #707070;
	line-height: normal;
}

font.serif_18_oblique_gray {
	font-size: 18pt; 
	font-style: oblique; 
	font-family: 'Times New Roman', 'Times', 'serif';
	color: #707070;
}

font.serif_18_gray_bold {
	font-size: 18pt; 
	font-weight: bold; 
	font-style: normal;
	font-family: 'Times New Roman', 'Times', 'serif';
	color: #707070;
	line-height: normal;
	font-stretch: extra-expanded;
}

font.serif_20_normal_gray {
	font-size: 20pt; 
	font-style: normal; 
	font-family: 'Times New Roman', 'Times', 'serif';
	color: #707070;
	line-height: normal;
}

font.serif_28_bold {
	font-size: 28pt; 
	font-weight: bold; 
	font-style: normal;
	font-family: 'Times New Roman', 'Times', 'serif';
	line-height: normal;
}

font.serif_28_gray_bold {
	font-size: 28pt; 
	font-weight: bold; 
	font-style: normal;
	font-family: 'Times New Roman', 'Times', 'serif';
	color: #707070;
	line-height: normal;
	font-stretch: extra-expanded;
}

font.serif_36_bold_oblique_gray {
	font-size: 36pt; 
	font-weight: bold; 
	font-style: oblique;
	font-family: 'Times New Roman', 'Times', 'serif';
	color: #707070;
}

font.cursive_gray {
	font-family:'Brush Script MT', 'Phyllis', 'Lucida Handwriting', cursive;
	color: #707070;
}
.sansserif {
  font-family: "Arial", "Helvetica", sans-serif;
}

.monospace {
  font-family: "Lucida Console", "Courier", monospace;
}

img {
	border: 0px;
	margin: 0px;
	padding: 0px;
	line-height: 0px;
	font-size: 0px;
}

a {
	text-decoration: underline;
	background-color: transparent;
	color: #0066CC;
	font-size: 14px;
}
a:visited {
	color: #6A7880;
}
a:hover {
	background-color: #EDF7FA;
	color: black;

}

a.logo_link, a.logo_link:visited, a.logo_link:hover,a.logo_link:active {
	text-decoration: none;
	background: transparent;
}

#contact_info_box a:hover {
	background-color: #03a996;
	color: white;
	text-decoration: underline;
}

#envelope {
	width: 90%;
	vertical-align: top;
	position: static;
/*	height: 100%; */
	border: thin groove #CCCCCC;
	margin-left: 5%;
	/* background-color: #81d4cb; */
	background-color: white;
	/*  background-image: url(/images/plain_red_lt.jpg); */
	min-height: 110%;
	display: flex;
    flex-direction: column;
}

#centered_box {
	width: 100%;
	position: static;
	top: 0px;
	left: 0px;
	_left: 5px;
}

#header_photo {
	z-index: 2;
	position: static;
/*	top: 95px;  
	top: 0px; */
	left: 0px;
	width: 100%;
	visibility: visible;
	right: 0px;
	bottom: 0px;
	border-bottom-width: thin;
	border-bottom-style: solid;
	border-bottom-color: #000f26;
	background-color:#000f26;
	
}

#black_box {
	z-index: 1;
	position: static;
	top: 0px;
	left: 605px;
	height: 135px;
	width: 148px;
	background: black;
	opacity: 0.66;
	-moz-opacity: 0.66;	
	filter: alpha(opacity=66);		
}

#logo {
	z-index: 2;
	position: static;
	top: 2px;
	left: 13px;
	height: 41px;
	width: 149px;
}

#title_box {
	z-index: 1;
	text-align: center;
	color: #000000;
	font-family:Arial, Helvetica, sans-serif;
	font-size:16px;
	font-weight: 900;
	position: static;
	top: 0px;
	width: 100%;
	background-color:#FFFFFF;
	border: thin groove #CCCCCC;
}

#contact_info_box {
	z-index: 2;
	text-align: right;
	color: white;
	font-family: Verdana, sans-serif;
	font-size: 12px;
	position: static;
	top: 9px;
	left: 82%;
	height: auto;
	width: 130px;
	background: black;
	opacity: 0.66;
	-moz-opacity: 0.66;	
	filter: alpha(opacity=66);
}

#content_envelope {
	z-index: 6;
	position:static;
	background-color: white; /* #81d4cb; */
	/*  background-image: url(/images/plain_red_lt.jpg); */
	background-repeat: repeat;
	height: 100%;
	padding-top: 5px;
	padding-bottom: 5px;
	flex:1
}

#main_content {
	background-color: white;
	width: 59%;
	/* margin-bottom: 10px; */
	font-family: Verdana, sans-serif;
	font-size: 12px;
	color: black;
	line-height: 22px;
	padding-left: 10px;
	padding-right: 10px;
	margin-left: 2%;
	margin-right: 2%;
	-moz-border-radius: 7px;
	float: left;
	margin-bottom: 20px;
	min-height: 100%;
}

#main_content_full {
	background-color: white;
	width: 95%;
	/* margin-bottom: 10px; */
	font-family: Verdana, sans-serif;
	font-size: 12px;
	color: black;
	line-height: 22px;
	padding-left: 10px;
	padding-right: 10px;
	margin-left: 2%;
	margin-right: 2%;
	-moz-border-radius: 7px;
	float: left;
	margin-bottom: 20px;	
	
	border-right-style: ridge;
	border-right-color: #E2E2E2;
	border-left-style: ridge;
	border-left-color: #E2E2E2;
	border-top-style: ridge;
	border-top-color: #E2E2E2;
	border-bottom-style: ridge;
	border-bottom-color: #E2E2E2;
	min-height: 90%;
	flex:1
}

#main_content_tri_left {
	background-color: white;
	float:left;
	align-content:center;
	width: 20%;
	margin-bottom: 10px;
	font-family: Verdana, sans-serif;
	font-size: 12px;
	color: black;
	line-height: 22px;
	padding-right: 10px;
	padding-left: 10px;
	margin-left: 15px;
	margin-top:10%;
	border-right-style: ridge;
	border-right-color: #E2E2E2;
	border-left-style: ridge;
	border-left-color: #E2E2E2;
	border-top-style: ridge;
	border-top-color: #E2E2E2;
	border-bottom-style: ridge;
	border-bottom-color: #E2E2E2;
}
#main_content_tri_center {
	position:static;
	/* left: 35%; */
	background-color: white;
	display:inline-block;
	width: 25%;
	margin-bottom: 10px;
	font-family: Verdana, sans-serif;
	font-size: 12px;
	color: black;
	line-height: 22px;
	padding-right: 10px;
	padding-left: 10px;
	margin-left: 16px;
	margin-right: 16px;
	border-right-style: ridge;
	border-right-color: #E2E2E2;
	border-left-style: ridge;
	border-left-color: #E2E2E2;
	border-top-style: ridge;
	border-top-color: #E2E2E2;
	border-bottom-style: ridge;
	border-bottom-color: #E2E2E2;
}
#main_content_tri_right {
	background-color: white;
	float: right;
	width: 38%;
	margin-bottom: 10px;
	font-family: Verdana, sans-serif;
	font-size: 12px;
	color: black;
    margin-top:10%;
	line-height: 22px;
	padding-right: 10px;
	padding-left: 10px;
	margin-right: 15px;
	border-right-style: ridge;
	border-right-color: #E2E2E2;
	border-left-style: ridge;
	border-left-color: #E2E2E2;
	border-top-style: ridge;
	border-top-color: #E2E2E2;
	border-bottom-style: ridge;
	border-bottom-color: #E2E2E2;
}
#main_content_duel_left {
	background-color: white;
	float: left;
	width: 47%;
	margin-bottom: 10px;
	font-family: Verdana, sans-serif;
	font-size: 12px;
	color: black;
	margin-top:10%;
	line-height: 22px;
	padding-right: 10px;
	padding-left: 10px;
	margin-left: 15px;
	border-right-style: ridge;
	border-right-color: #E2E2E2;
	border-left-style: ridge;
	border-left-color: #E2E2E2;
	border-top-style: ridge;
	border-top-color: #E2E2E2;
	border-bottom-style: ridge;
	border-bottom-color: #E2E2E2;

}	

#main_content_duel_right {
	background-color: white;
	float: right;
	width: 47%;
	margin-bottom: 10px;
	font-family: Verdana, sans-serif;
	font-size: 12px;
	color: black;
	line-height: 22px;
	padding-right: 10px;
	padding-left: 10px;
	margin-right: 15px;
	border-right-style: ridge;
	border-right-color: #E2E2E2;
	border-left-style: ridge;
	border-left-color: #E2E2E2;
	border-top-style: ridge;
	border-top-color: #E2E2E2;
	border-bottom-style: ridge;
	border-bottom-color: #E2E2E2;

}	

#sub_main_content {
	background-color: white;
	font-family: Verdana, sans-serif;
	font-size: 12px;
	color: black;
	line-height: 22px;
	padding-left: 10px;
	padding-right: 10px;
	margin-left: 2%;
	margin-right: 2%;
	margin-top: 10px;
	-moz-border-radius: 7px;
}

p.breadcrumb_trail {
	font-size: 12px;
	font-family: Tahoma, Verdana, sans-serif;
}	

h1 {
	font-weight: normal;
	font-size: 17px;
	font-family: 'Trebuchet MS', Verdana, sans-serif;	
	margin-top: 18px;
	margin-bottom: 24px; 
}
h1.subsequent {
	margin-top: 40px;
}

h2 {
	font-weight: bold; 
	font-size: 24px;
	font-family: 'Trebuchet MS', Verdana, sans-serif;
	/* font-family: 'Trebuchet MS', Verdana, sans-serif;	*/
	border-bottom: solid 1px #bbb;
	border-top: solid 1px #bbb;
	margin-top: 16px;
	margin-bottom: 16px; 
	margin-right:16px;
	margin-left:16px;
	padding-top: 10px;
	padding-bottom: 10px;
}

p {

	margin-bottom: 16px; 
	font-family: 'Trebuchet MS', Verdana, sans-serif;
	font-size: 14px;
}

p.contact_info {
	font-size: 18px;
	font-family: Verdana, sans-serif;
		margin-bottom: 3px;
}

p.title_info {
	font-family:'Brush Script MT', Phyllis, 'Lucida Handwriting', cursive;
	/* font-family:Arial, Helvetica, sans-serif; */
	font-size: 48px;
	font-weight: bolder;
	margin-bottom: 1px;
}
.photo_frame {
	background: #F8F8F4;
	border: solid 1px #ddd;
	padding: 10px;
	padding-top: 12px;
	padding-left: 12px;
	padding-bottom: 10px;
	margin-bottom: 16px; 		
	font-family: Verdana, sans-serif;
	font-size: 9px;
	-moz-border-radius: 8px;
	text-align: center;
}

div.photo_frame img {
	margin-bottom: 10px;
	margin-bottom: -3px;
}

.photo_caption {
	margin-top: 10px; 
	margin-bottom: 0px;
	font-family: Verdana, sans-serif;
	font-size: 12px;
	text-align:center;
}

p.data {
	font-family: Verdana, sans-serif;
	font-size: 12px;
}

ul, ol {
	font-size: 12px;
	padding: 10px;
	padding-right: 20px;	
	padding-left: 30px;
	padding-bottom: 5px;	
	margin: 0px;
	margin-bottom: 20px;
}

ul ul {
	padding: 0px;
	margin-bottom: 0px;	
	margin-left: 30px;	
}

ul ul ul {
	list-style-type: circle;	
}

li {
	margin-bottom: 5px;
	list-style-type: circle;
	font-size: 12px;
}

li.list_heading {
	margin-left: -15px;
	margin-bottom: 5px;
	list-style-type: none;
}

li.no_bullet {
	list-style-type: none;
	list-style-image: none;	
}

dl {
	font-family: Verdana, sans-serif;
	padding-left: 30px;
	margin-bottom: 20px;
}

dt {
	font-weight: bold;
	margin-bottom: 5px;	
}

dd {
	font-size: 12px;
	color: #666;
	margin-bottom: 15px;	
}

p.lead_text {
	font: 13px Tahoma, Arial, sans-serif;
	color: #099;
	letter-spacing: 1px;	
	clear: both;
}

.quote {
	background: #F8F8F4;
	font-family: Georgia, serif;
	border: solid 1px #ccc;
	font-size: 12px;
	padding: 20px;
	margin-bottom: 20px;
	line-height: 22px;
	-moz-border-radius: 8px;	
}

.quote_attribution {
	font-famiy: Verdana, sans-serif;
	font-size: 12px;
	margin-top: 20px;
	margin-bottom: 20px;
	line-height: 22px;
}

.callout {
	border: solid 1px #ddd;	
	background-color: #ffe;	
	padding: 20px;
	margin-bottom: 20px;
	padding-right: 20px;
}

.note {
	padding: 10px;
	color: #000;
	background-color: #ffe;
	line-height: 20px;
	font-size: 12px;
	border: dashed 1px #ccc;
	font-family: Verdana, sans-serif;	
	margin-right: 1px;
	margin-top: 30px;
	margin-bottom: 20px;
}	

div.note p {
	padding: 5px;
	font-size: 12px;
	font-family: Verdana, sans-serif;	
	margin-right: 10px;
	margin-bottom: 0px;
}


.info_box {
	border: solid 1px #ccc;
	padding: 10px;
	margin-bottom: 20px;	
}

table.border {
	border: solid 1px #ccc;
	\\ width: 100%;	
	border-spacing: 0px;
}

#table_no_border {
	border: none
}

table.noborder {
	border: none
}
#td_rt_brder_2col {
	border-right:groove;
	border-right-color: #ccc;
	width: 50%
}

td {
	padding: 5px;
	text-align: left;
	vertical-align: top;
	font-size: 12px;
}

div.sitemap_block {
	-moz-border-radius: 7px;
	background: #fafafa;
	border: solid 1px #ddd;
	padding: 10px;
	margin-bottom: 16px;
}

div.graphic_box {
	background: #EBF2EE;
	border: solid 1px #ccc;
	margin-bottom: 40px;
	padding: 20px;
}
div.graphic_box_image {
	float: left;
	width: 316px;	
	position: relative;
}
div.graphic_box_text {
	float: right;
	width: 316px;
	-moz-border-radius: 7px;
}
div.graphic_box p.graphic_title {
	font: bold 14px Tahoma, Arial, sans-serif;	
}

table.photo_grid {
	padding: 3px;
	border: solid 1px #ddd;
	width: 430px;
	background: #F8F8F4;	

	font-size: 12px;
	font-family: Tahoma, Verdana, sans-serif;
}

table.photo_grid tr, table.photo_grid td  {
	text-align: center;
	margin: 0px;
	padding: 0px;
}

table.photo_grid td  {
	width: 138px;
	padding-bottom: 20px;
}

div.float {
	float: left;
	margin-right: 10px;
	margin-bottom: 10px;	
	padding-bottom: 10px;
	text-align: center;
	background: #F8F8F4;
	border: solid 1px #ddd;
	font-size: 12px;
	width: 132px;
	height: 150px;
	line-height: 13px;
}

div.float img {
	margin-bottom: 10px;
}

#nav_box {
	z-index: 4;
	padding-top: 10px;
	text-align: center;
	width: 100%;
	background-color: white; /* #81d4cb; */
	overflow: auto;
	display:block;
	clear:both;
}

#nav_box ul {
	background: transparent; 
	padding: 10px;
	margin: 0px;
	font-family: Tahoma, Verdana, sans-serif;
}

#nav_box li {
	-moz-border-radius-topleft: 7px;
	-moz-border-radius-topright: 6px;
	display: inline;
	margin: 0px;
	padding: 0px;
	padding-top: 10px;
	font-weight:bold;
}

a.nav_tab_link,a.nav_tab_link:visited {
	border-left: solid 1px black;
	border-top: solid 1px #aaa;	
	border-bottom: solid 1px #aaa;
	-moz-border-radius-topleft: 6px;
	-moz-border-radius-topright: 6px;
	text-decoration: none;
	background: white; /* #E8E8DF; */
	color: #333;
	padding-top: 7px;
	padding-bottom: 7px;	
	padding-left: 7px;
	padding-right: 8px;

}
a.nav_tab_link:hover {
	background-color: #B2B2B2;
	color: black;
}

a.current_tab,a.current_tab:visited {
	border-bottom: solid 1px white;
	background-color: white;
	color: black;
}
a.current_tab:hover {
	border-bottom: solid 1px white;
	background-color: white;
}


#sidebar {
	margin-right: 15px;
	margin-top: 1px;
	display: inline;
	width: 30%;


	*margin-bottom: 40px;
	*table-layout: auto;
	clear: none;
	float: right;
}

div.sidebar_module {
	margin-bottom: 16px;
	border: 1px solid #BBBBBB;
	-moz-border-radius: 7px;
	border-radius: 7px;
	*position: relative; 
	background-color: #FFFFFF;
}

div.sidebar_divider {
	height: 10px;
	_margin-bottom: -15px;
	border-top: dashed 1px #ccc;
}

.sidebar_heading {
	padding-left: 15px;
	margin-bottom: 3px;
	color: black;
	font-family: Tahoma, Verdana, sans-serif;
	font-size: 12px;
	font-weight: bold;
	-moz-border-radius-topleft: 6px;	
	-moz-border-radius-topright: 6px;		
	border-bottom: solid 1px #ddd;
	background-color: #BBBBBB;
	padding-top: 7px;
	padding-right: 7px;
	padding-bottom: 7px;
}

.sidebar_text {
	padding: 10px;
	margin-bottom: 3px;
	font-size: 12px;
	font-family: Tahoma, sans-serif;
	line-height: 18px;
	color: #444;
}

.sidebar_image {
	margin: 9px;
	margin-bottom: 5px;
}

.sidebar_image_border {
	margin: 9px;
	margin-bottom: 5px;
	border: solid 1px #ccc;
}

#sidebar ul {
	margin-bottom: 0px;
}

#sidebar li {
	margin-bottom: 20px;
	font-family: Tahoma, Verdana, sans-serif;
	font-size: 12px;
	padding-bottom: 0px;
	color: #444;
	line-height: 8px;
}

.sidebar_footnote {
	font-size: 10px;
}

div.sidebar_module_with_no_title {
	padding-top: 0px;
	margin-bottom: 16px;
	border: solid 1px #BBBBBB;
	background: #F8F8F4;	
	-moz-border-radius: 7px;
	*position: relative; 
}

#footer {
	clear: both;
	/* width: 100%; */
	background-color: #F5F5F1;
	padding-bottom: 5px;	
	font: 10px Verdana, sans-serif;
	line-height: 15px;
	border-top: solid 1px #aaa;
	vertical-align: bottom;
}	

.footer_text_box_lt {
	float: left;
	margin-left: 2%;
}

.footer_text_box_rt {
	float:right;
	margin-right: 2%;
}

.footer_header_text {
	size: 18px;
	font-family:Arial, Helvetica, sans-serif; 
	font-weight: bold;
}


.footer_logo {
	float: right;
	padding: 0px;
}

#credits_spacer {
	background-color: #E8E8DF;
	height:100%;
}

#copyright_and_credits {
	clear: both;
	width: 100%;
	_width: 100%;
	background-color: #E8E8DF;

	font: 9px Tahoma, Verdana, sans-serif;
	color: #333;
	border-top: solid 1px #aaa;
	
	text-align:right
}	

.last_updated {
	font-size: 10px;
	font-family: Tahoma, Verdana, sans-serif;
	color: #999;
	float: right;
}
#main_content strong {
	font-size: 12px;
	font-family: Verdana, Tahoma, sans-serif;	
}

.fix {
	padding: 10px;
	color: red;
	background-color: #ffe;
	line-height: 20px;
	font-size: 12px;
	border: dashed 1px #ccc;
}	
.fuchia {
	color: #CC00CC;
	font-weight: bold;
}
.lightpurple {color: #CC33FF}
.Blue {
	color: #0000FF;
	font-weight: bold;
}

#map {
	height: 450px;
	width: 450px;
}
#td_rt_brder_3col {
	border-right:groove;
	border-right-color: #ccc;
	width: 33%
}
.td_valign_title {
	text-align: center;
	vertical-align: middle;
	font-size: 12px;
	font-weight: bold;
}
.td_right {
	padding: 5px;
	text-align: right;
	vertical-align: top;
	font-size: 12px;
}
.td_cntr_sm {
	text-align: center;
	vertical-align: top;
	font-size: 9px;
}
.td_cntr_normal {
	padding: 5px;
	text-align: center;
	vertical-align: middle;
	font-size: 12px;
}

#block_cent {
	position:absolute;
	top:30%;
	left:40%;
	margin-top:-60px; /* this is half the height of your div*/  
	margin-left:-80px; /*this is half of width of your div*/
}



/* ============================================================================================================================
== BUBBLE WITH AN ISOCELES TRIANGLE
** ============================================================================================================================ */

/* THE SPEECH BUBBLE
------------------------------------------------------------------------------------------------------------------------------- */

.triangle-isosceles {
  position:relative;
  padding:15px;
  margin:1em 0 3em;
  color:#000;
  background:#f3961c; /* default background for browsers without gradient support */
  /* css3 */
  background:-webkit-gradient(linear, 0 0, 0 100%, from(#f9d835), to(#f3961c));
  background:-moz-linear-gradient(#f9d835, #f3961c);
  background:-o-linear-gradient(#f9d835, #f3961c);
  background:linear-gradient(#f9d835, #f3961c);
  -webkit-border-radius:10px;
  -moz-border-radius:10px;
  border-radius:10px;
}

/* Variant : for top positioned triangle
------------------------------------------ */

.triangle-isosceles.top {
  background:-webkit-gradient(linear, 0 0, 0 100%, from(#f3961c), to(#f9d835));
  background:-moz-linear-gradient(#f3961c, #f9d835);
  background:-o-linear-gradient(#f3961c, #f9d835);
  background:linear-gradient(#f3961c, #f9d835);
}

/* Variant : for left/right positioned triangle
------------------------------------------ */

.triangle-isosceles.left {
  margin-left:50px;
  background:#f3961c;
}

/* Variant : for right positioned triangle
------------------------------------------ */

.triangle-isosceles.right {
  margin-right:50px;
  background:#f3961c;
}

/* THE TRIANGLE
------------------------------------------------------------------------------------------------------------------------------- */

/* creates triangle */
.triangle-isosceles:after {
  content:"";
  position:absolute;
  bottom:-15px; /* value = - border-top-width - border-bottom-width */
  left:50px; /* controls horizontal position */
  border-width:15px 15px 0; /* vary these values to change the angle of the vertex */
  border-style:solid;
  border-color:#f3961c transparent;
  /* reduce the damage in FF3.0 */
  display:block;
  width:0;
}

/* Variant : top
------------------------------------------ */

.triangle-isosceles.top:after {
  top:-15px; /* value = - border-top-width - border-bottom-width */
  right:50px; /* controls horizontal position */
  bottom:auto;
  left:auto;
  border-width:0 15px 15px; /* vary these values to change the angle of the vertex */
  border-color:#f3961c transparent;
}

/* Variant : left
------------------------------------------ */

.triangle-isosceles.left:after {
  top:16px; /* controls vertical position */
  left:-50px; /* value = - border-left-width - border-right-width */
  bottom:auto;
  border-width:10px 50px 10px 0;
  border-color:transparent #f3961c;
}

/* Variant : right
------------------------------------------ */

.triangle-isosceles.right:after {
  top:16px; /* controls vertical position */
  right:-50px; /* value = - border-left-width - border-right-width */
  bottom:auto;
  left:auto;
  border-width:10px 0 10px 50px;
  border-color:transparent #f3961c;
}


/* ============================================================================================================================
== BUBBLE WITH A RIGHT-ANGLED TRIANGLE
** ============================================================================================================================ */

/* THE SPEECH BUBBLE
------------------------------------------------------------------------------------------------------------------------------- */

.triangle-right {
  position:relative;
  padding:15px;
  margin:1em 0 3em;
  color:#fff;
  background:#075698; /* default background for browsers without gradient support */
  /* css3 */
  background:-webkit-gradient(linear, 0 0, 0 100%, from(#2e88c4), to(#075698));
  background:-moz-linear-gradient(#2e88c4, #075698);
  background:-o-linear-gradient(#2e88c4, #075698);
  background:linear-gradient(#2e88c4, #075698);
  -webkit-border-radius:10px;
  -moz-border-radius:10px;
  border-radius:10px;
}

/* Variant : for top positioned triangle
------------------------------------------ */

.triangle-right.top {
  background:-webkit-gradient(linear, 0 0, 0 100%, from(#075698), to(#2e88c4));
  background:-moz-linear-gradient(#075698, #2e88c4);
  background:-o-linear-gradient(#075698, #2e88c4);
  background:linear-gradient(#075698, #2e88c4);
}

/* Variant : for left positioned triangle
------------------------------------------ */

.triangle-right.left {
  margin-left:40px;
  background:#075698;
}

/* Variant : for right positioned triangle
------------------------------------------ */

.triangle-right.right {
  margin-right:40px;
  background:#075698;
}

/* THE TRIANGLE
------------------------------------------------------------------------------------------------------------------------------- */

.triangle-right:after {
  content:"";
  position:absolute;
  bottom:-20px; /* value = - border-top-width - border-bottom-width */
  left:50px; /* controls horizontal position */
  border-width:20px 0 0 20px; /* vary these values to change the angle of the vertex */
  border-style:solid;
  border-color:#075698 transparent;
  /* reduce the damage in FF3.0 */
  display:block;
  width:0;
}

/* Variant : top
------------------------------------------ */

.triangle-right.top:after {
  top:-20px; /* value = - border-top-width - border-bottom-width */
  right:50px; /* controls horizontal position */
  bottom:auto;
  left:auto;
  border-width:20px 20px 0 0; /* vary these values to change the angle of the vertex */
  border-color:transparent #075698;
}

/* Variant : left
------------------------------------------ */

.triangle-right.left:after {
  top:16px;
  left:-40px; /* value = - border-left-width - border-right-width */
  bottom:auto;
  border-width:15px 40px 0 0; /* vary these values to change the angle of the vertex */
  border-color:transparent #075698;
}

/* Variant : right
------------------------------------------ */

.triangle-right.right:after {
  top:16px;
  right:-40px; /* value = - border-left-width - border-right-width */
  bottom:auto;
  left:auto;
  border-width:15px 0 0 40px; /* vary these values to change the angle of the vertex */
  border-color:transparent #075698 ;
}


/* ============================================================================================================================
== BUBBLE WITH AN OBTUSE TRIANGLE
** ============================================================================================================================ */

/* THE SPEECH BUBBLE
------------------------------------------------------------------------------------------------------------------------------- */

.triangle-obtuse {
  position:relative;
  padding:15px;
  margin:1em 0 3em;
  color:#fff;
  background:#c81e2b;
  /* css3 */
  background:-webkit-gradient(linear, 0 0, 0 100%, from(#f04349), to(#c81e2b));
  background:-moz-linear-gradient(#f04349, #c81e2b);
  background:-o-linear-gradient(#f04349, #c81e2b);
  background:linear-gradient(#f04349, #c81e2b);
  -webkit-border-radius:10px;
  -moz-border-radius:10px;
  border-radius:10px;
}

/* Variant : for top positioned triangle
------------------------------------------ */

.triangle-obtuse.top {
  background:-webkit-gradient(linear, 0 0, 0 100%, from(#c81e2b), to(#f04349));
  background:-moz-linear-gradient(#c81e2b, #f04349);
  background:-o-linear-gradient(#c81e2b, #f04349);
  background:linear-gradient(#c81e2b, #f04349);
}

/* Variant : for left positioned triangle
------------------------------------------ */

.triangle-obtuse.left {
  margin-left:50px;
  background:#c81e2b;
}

/* Variant : for right positioned triangle
------------------------------------------ */

.triangle-obtuse.right {
  margin-right:50px;
  background:#c81e2b;
}

/* THE TRIANGLE
------------------------------------------------------------------------------------------------------------------------------- */

/* creates the wider right-angled triangle */
.triangle-obtuse:before {
  content:"";
  position:absolute;
  bottom:-20px; /* value = - border-top-width - border-bottom-width */
  left:60px; /* controls horizontal position */
  border:0;
  border-right-width:30px; /* vary this value to change the angle of the vertex */
  border-bottom-width:20px; /* vary this value to change the height of the triangle. must be equal to the corresponding value in :after */
  border-style:solid;
  border-color:transparent #c81e2b;
  /* reduce the damage in FF3.0 */
  display:block;
  width:0;
}

/* creates the narrower right-angled triangle */
.triangle-obtuse:after {
  content:"";
  position:absolute;
  bottom:-20px; /* value = - border-top-width - border-bottom-width */
  left:80px; /* value = (:before's left) + (:before's border-right/left-width)  - (:after's border-right/left-width) */
  border:0;
  border-right-width:10px; /* vary this value to change the angle of the vertex */
  border-bottom-width:20px; /* vary this value to change the height of the triangle. must be equal to the corresponding value in :before */
  border-style:solid;
  border-color:transparent #fff;
  /* reduce the damage in FF3.0 */
  display:block;
  width:0;
}

/* Variant : top
------------------------------------------ */

.triangle-obtuse.top:before {
  top:-20px; /* value = - border-top-width - border-bottom-width */
  bottom:auto;
  left:auto;
  right:60px; /* controls horizontal position */
  border:0;
  border-left-width:30px; /* vary this value to change the width of the triangle */
  border-top-width:20px; /* vary this value to change the height of the triangle. must be equal to the corresponding value in :after */
  border-color:transparent #c81e2b;
}

.triangle-obtuse.top:after {
  top:-20px; /* value = - border-top-width - border-bottom-width */
  bottom:auto;
  left:auto;
  right:80px; /* value = (:before's right) + (:before's border-right/left-width)  - (:after's border-right/left-width) */
  border-width:0;
  border-left-width:10px; /* vary this value to change the width of the triangle */
  border-top-width:20px; /* vary this value to change the height of the triangle. must be equal to the corresponding value in :before */
  border-color:transparent #fff;
}

/* Variant : left
------------------------------------------ */

.triangle-obtuse.left:before {
  top:15px; /* controls vertical position */
  bottom:auto;
  left:-50px; /* value = - border-left-width - border-right-width */
  border:0;
  border-bottom-width:30px; /* vary this value to change the height of the triangle */
  border-left-width:50px; /* vary this value to change the width of the triangle. must be equal to the corresponding value in :after */
  border-color:#c81e2b transparent;
}

.triangle-obtuse.left:after {
  top:35px; /* value = (:before's top) + (:before's border-top/bottom-width)  - (:after's border-top/bottom-width) */
  bottom:auto;
  left:-50px; /* value = - border-left-width - border-right-width */
  border:0;
  border-bottom-width:10px; /* vary this value to change the height of the triangle */
  border-left-width:50px; /* vary this value to change the width of the triangle. must be equal to the corresponding value in :before */
  border-color:#fff transparent;
}

/* Variant : right
------------------------------------------ */

.triangle-obtuse.right:before {
  top:15px; /* controls vertical position */
  bottom:auto;
  left:auto;
  right:-50px; /* value = - border-left-width - border-right-width */
  border:0;
  border-bottom-width:30px; /* vary this value to change the height of the triangle */
  border-right-width:50px; /* vary this value to change the width of the triangle. must be equal to the corresponding value in :after */
  border-color:#c81e2b transparent;
}

.triangle-obtuse.right:after {
  top:35px; /* value = (:before's top) + (:before's border-top/bottom-width)  - (:after's border-top/bottom-width) */
  bottom:auto;
  right:-50px; /* value = - border-left-width - border-right-width */
  left:auto;
  border:0;
  border-bottom-width:10px; /* vary this value to change the height of the triangle */
  border-right-width:50px; /* vary this value to change the width of the triangle. must be equal to the corresponding value in :before */
  border-color:#fff transparent;
}


/* ============================================================================================================================
== BUBBLE WITH A BORDER AND TRIANGLE
** ============================================================================================================================ */

/* THE SPEECH BUBBLE
------------------------------------------------------------------------------------------------------------------------------- */

.triangle-border {
  position:relative;
  padding:15px;
  margin:1em 0 3em;
  border:5px solid #5a8f00;
  color:#333;
  background:#fff;
  /* css3 */
  -webkit-border-radius:10px;
  -moz-border-radius:10px;
  border-radius:10px;
}

/* Variant : for left positioned triangle
------------------------------------------ */

.triangle-border.left {
  margin-left:30px;
}

/* Variant : for right positioned triangle
------------------------------------------ */

.triangle-border.right {
  margin-right:30px;
}

/* THE TRIANGLE
------------------------------------------------------------------------------------------------------------------------------- */

.triangle-border:before {
  content:"";
  position:absolute;
  bottom:-20px; /* value = - border-top-width - border-bottom-width */
  left:40px; /* controls horizontal position */
  border-width:20px 20px 0;
  border-style:solid;
  border-color:#5a8f00 transparent;
  /* reduce the damage in FF3.0 */
  display:block;
  width:0;
}

/* creates the smaller  triangle */
.triangle-border:after {
  content:"";
  position:absolute;
  bottom:-13px; /* value = - border-top-width - border-bottom-width */
  left:47px; /* value = (:before left) + (:before border-left) - (:after border-left) */
  border-width:13px 13px 0;
  border-style:solid;
  border-color:#fff transparent;
  /* reduce the damage in FF3.0 */
  display:block;
  width:0;
}

/* Variant : top
------------------------------------------ */

/* creates the larger triangle */
.triangle-border.top:before {
  top:-20px; /* value = - border-top-width - border-bottom-width */
  bottom:auto;
  left:auto;
  right:40px; /* controls horizontal position */
  border-width:0 20px 20px;
}

/* creates the smaller  triangle */
.triangle-border.top:after {
  top:-13px; /* value = - border-top-width - border-bottom-width */
  bottom:auto;
  left:auto;
  right:47px; /* value = (:before right) + (:before border-right) - (:after border-right) */
  border-width:0 13px 13px;
}

/* Variant : left
------------------------------------------ */

/* creates the larger triangle */
.triangle-border.left:before {
  top:10px; /* controls vertical position */
  bottom:auto;
  left:-30px; /* value = - border-left-width - border-right-width */
  border-width:15px 30px 15px 0;
  border-color:transparent #5a8f00;
}

/* creates the smaller  triangle */
.triangle-border.left:after {
  top:16px; /* value = (:before top) + (:before border-top) - (:after border-top) */
  bottom:auto;
  left:-21px; /* value = - border-left-width - border-right-width */
  border-width:9px 21px 9px 0;
  border-color:transparent #fff;
}

/* Variant : right
------------------------------------------ */

/* creates the larger triangle */
.triangle-border.right:before {
  top:10px; /* controls vertical position */
  bottom:auto;
  left:auto;
  right:-30px; /* value = - border-left-width - border-right-width */
  border-width:15px 0 15px 30px;
  border-color:transparent #5a8f00;
}

/* creates the smaller  triangle */
.triangle-border.right:after {
  top:16px; /* value = (:before top) + (:before border-top) - (:after border-top) */
  bottom:auto;
  left:auto;
  right:-21px; /* value = - border-left-width - border-right-width */
  border-width:9px 0 9px 21px;
  border-color:transparent #fff;
}


/* ============================================================================================================================
== SPEECH BUBBLE ICON
** ============================================================================================================================ */

.example-commentheading {
  position:relative;
  padding:0;
  color:#b513af;
}

/* creates the rectangle */
.example-commentheading:before {
  content:"";
  position:absolute;
  top:9px;
  left:-25px;
  width:15px;
  height:10px;
  background:#b513af;
  /* css3 */
  -webkit-border-radius:3px;
  -moz-border-radius:3px;
  border-radius:3px;
}

/* creates the triangle */
.example-commentheading:after {
  content:"";
  position:absolute;
  top:15px;
  left:-19px;
  border:4px solid transparent;
  border-left-color:#b513af;
  /* reduce the damage in FF3.0 */
  display:block;
  width:0;
}


/* ============================================================================================================================
== BLOCKQUOTE WITH RIGHT-ANGLED TRIANGLE
** ============================================================================================================================ */

.example-right {
  position:relative;
  padding:15px 30px;
  margin:0;
  color:#fff;
  background:#5a8f00; /* default background for browsers without gradient support */
  /* css3 */
  background:-webkit-gradient(linear, 0 0, 0 100%, from(#b8db29), to(#5a8f00));
  background:-moz-linear-gradient(#b8db29, #5a8f00);
  background:-o-linear-gradient(#b8db29, #5a8f00);
  background:linear-gradient(#b8db29, #5a8f00);
  -webkit-border-radius:10px;
  -moz-border-radius:10px;
  border-radius:10px;
}

/* display of quote author (alternatively use a class on the element following the blockquote) */
.example-right + p {margin:15px 0 2em 85px; font-style:italic;}

/* creates the triangle */
.example-right:after {
  content:"";
  position:absolute;
  bottom:-50px;
  left:50px;
  border-width:0 20px 50px 0px;
  border-style:solid;
  border-color:transparent #5a8f00;
  /* reduce the damage in FF3.0 */
  display:block;
  width:0;
}


/* ============================================================================================================================
== BLOCKQUOTE WITH OBTUSE TRIANGLE
** ============================================================================================================================ */

.example-obtuse {
  position:relative;
  padding:15px 30px;
  margin:0;
  color:#000;
  background:#f3961c; /* default background for browsers without gradient support */
  /* css3 */
  background:-webkit-gradient(linear, 0 0, 0 100%, from(#f9d835), to(#f3961c));
  background:-moz-linear-gradient(#f9d835, #f3961c);
  background:-o-linear-gradient(#f9d835, #f3961c);
  background:linear-gradient(#f9d835, #f3961c);
  /* Using longhand to avoid inconsistencies between Safari 4 and Chrome 4 */
  -webkit-border-top-left-radius:25px 50px;
  -webkit-border-top-right-radius:25px 50px;
  -webkit-border-bottom-right-radius:25px 50px;
  -webkit-border-bottom-left-radius:25px 50px;
  -moz-border-radius:25px / 50px;
  border-radius:25px / 50px;
}

/* display of quote author (alternatively use a class on the element following the blockquote) */
.example-obtuse + p {margin:10px 150px 2em 0; text-align:right; font-style:italic;}

/* creates the larger triangle */
.example-obtuse:before {
  content:"";
  position:absolute;
  bottom:-30px;
  right:80px;
  border-width:0 0 30px 50px;
  border-style:solid;
  border-color:transparent #f3961c;
  /* reduce the damage in FF3.0 */
  display:block;
  width:0;
}

/* creates the smaller triangle */
.example-obtuse:after {
  content:"";
  position:absolute;
  bottom:-30px;
  right:110px;
  border-width:0 0 30px 20px;
  border-style:solid;
  border-color:transparent #fff;
  /* reduce the damage in FF3.0 */
  display:block;
  width:0;
}


/* ============================================================================================================================
== TWITTER
** ============================================================================================================================ */

.example-twitter {
  position:relative;
  padding:15px;
  margin:100px 0 0.5em;
  color:#333;
  background:#eee;
  /* css3 */
  -webkit-border-radius:10px;
  -moz-border-radius:10px;
  border-radius:10px;
}

.example-twitter p {font-size:28px; line-height:1.25em;}

/* this isn't necessary, just saves me having to edit the HTML of the demo */
.example-twitter:before {
  content:url(twitter-logo.gif);
  position:absolute;
  top:-60px;
  left:0;
  width:155px;
  height:36px;
  /* reduce the damage in FF3.0 */
  display:block;
}

/* creates the triangle */
.example-twitter:after {
  content:"";
  position:absolute;
  top:-30px;
  left:50px;
  border:15px solid transparent;
  border-bottom-color:#eee;
  /* reduce the damage in FF3.0 */
  display:block;
  width:0;
}

/* display of quote author (alternatively use a class on the element following the blockquote) */
.example-twitter + p {padding-left:15px; font:14px Arial, sans-serif;}


/* ============================================================================================================================
== NUMBER
** ============================================================================================================================ */

.example-number {
  position:relative;
  width:200px;
  height:200px;
  margin:50px 0 200px;
  text-align:center;
  font:140px/200px Arial, sans-serif;
  color:#fff;
  background:#C91F2C;
}

/* creates the larger triangle */
.example-number:before {
  content:"";
  position:absolute;
  bottom:-140px;
  right:0;
  border-width:0 0 140px 140px;
  border-style:solid;
  border-color:transparent #C91F2C;
}

/* creates the larger triangle */
.example-number:after {
  content:"";
  position:absolute;
  bottom:-140px;
  right:85px;
  border-width:0 0 140px 55px;
  border-style:solid;
  border-color:transparent #fff;
}


/* ============================================================================================================================
== PINCHED SPEECH BUBBLE (more CSS3)
** ============================================================================================================================ */

.pinched {
  position:relative;
  padding:15px;
  margin:50px 0 3em;
  text-align:center;
  color:#fff;
  background:#333;
  /* css3 */
  -webkit-border-radius:10px;
  -moz-border-radius:10px;
  border-radius:10px;
}

/* creates a rectangle of the colour wanted for the pointy bit */
.pinched:before {
  content:"";
  position:absolute;
  top:-20px;
  left:50%;
  width:100px;
  height:20px;
  margin:0 0 0 -50px;
  background:#333;
}

/* creates a rounded rectangle to cover part of the rectangle generated above */
.pinched:after {
  content:"";
  position:absolute;
  top:-20px;
  left:0;
  width:50%;
  height:20px;
  background:#fff;
  /* css3 */
  -webkit-border-bottom-right-radius:15px;
  -moz-border-radius-bottomright:15px;
  border-bottom-right-radius:15px;
}

/* creates the other rounded rectangle */
.pinched > :first-child:before {
  content:"";
  position:absolute;
  top:-20px;
  right:0;
  width:50%;
  height:20px;
  background:#fff;
  /* css3 */
  -webkit-border-bottom-left-radius:15px;
  -moz-border-radius-bottomleft:15px;
  border-bottom-left-radius:15px;
}


/* ============================================================================================================================
== OVAL SPEECH BUBBLE (more CSS3)
** ============================================================================================================================ */

.oval-speech {
  position:relative;
  width:135px;
  padding:30px 20px;
  margin:1em auto 30px;
  text-align:center;
  color:#fff;
  background:#000000;
  /* css3 */
  background:-webkit-gradient(linear, 0 0, 0 100%, from(#5e4c29), to(#000000));
  background:-moz-linear-gradient(#5e4c29, #000000);
  background:-o-linear-gradient(#5e4c29, #000000);
  background:linear-gradient(#5e4c29, #000000);  /*
  NOTES:
  -webkit-border-radius:220px 120px; // produces oval in safari 4 and chrome 4
  -webkit-border-radius:220px / 120px; // produces oval in chrome 4 (again!) but not supported in safari 4
  Not correct application of the current spec, therefore, using longhand to avoid future problems with webkit corrects this
  */
  -webkit-border-top-left-radius:220px 120px;
  -webkit-border-top-right-radius:220px 120px;
  -webkit-border-bottom-right-radius:220px 120px;
  -webkit-border-bottom-left-radius:220px 120px;
  -moz-border-radius:220px / 120px;
  border-radius:220px / 120px;
}

.oval-speech p {font-size:3em;}

/* creates part of the curve */
.oval-speech:before {
  content:"";
  position:absolute;
  z-index:2;
  bottom:-30px;
  right:50%;
  height:30px;
  border-right:60px solid #000000;
  background:#000000; /* need this for webkit - bug in handling of border-radius */
  /* css3 */
  -webkit-border-bottom-right-radius:80px 50px;
  -moz-border-radius-bottomright:80px 50px;
  border-bottom-right-radius:80px 50px;
  /* using translate to avoid undesired appearance in CSS2.1-capabable but CSS3-incapable browsers */
  -webkit-transform:translate(0, -2px);
  -moz-transform:translate(0, -2px);
  -ms-transform:translate(0, -2px);
  -o-transform:translate(0, -2px);
  transform:translate(0, -2px);
}

/* creates part of the curved pointy bit */
.oval-speech:after {
  content:"";
  position:absolute;
  z-index:2;
  bottom:-30px;
  right:50%;
  width:60px;
  height:30px;
  background:#fff;
  /* css3 */
  -webkit-border-bottom-right-radius:40px 50px;
  -moz-border-radius-bottomright:40px 50px;
  border-bottom-right-radius:40px 50px;
  /* using translate to avoid undesired appearance in CSS2.1-capabable but CSS3-incapable browsers */
  -webkit-transform:translate(-30px, -2px);
  -moz-transform:translate(-30px, -2px);
  -ms-transform:translate(-30px, -2px);
  -o-transform:translate(-30px, -2px);
  transform:translate(-30px, -2px);
	display:block;
}

.oval-speech-right {
  position:relative;
  width:120px;
  padding:30px 20px;
  margin:1em auto 50px;
  text-align:center;
  color:#fff;
  background:#000000;
  /* css3 */
  background:-webkit-gradient(linear, 0 0, 0 100%, from(#5e4c29), to(#000000));
  background:-moz-linear-gradient(#5e4c29, #000000);
  background:-o-linear-gradient(#5e4c29, #000000);
  background:linear-gradient(#5e4c29, #000000);
  /*
  NOTES:
  -webkit-border-radius:220px 120px; // produces oval in safari 4 and chrome 4
  -webkit-border-radius:220px / 120px; // produces oval in chrome 4 (again!) but not supported in safari 4
  Not correct application of the current spec, therefore, using longhand to avoid future problems with webkit corrects this
  */
  -webkit-border-top-left-radius:220px 120px;
  -webkit-border-top-right-radius:220px 120px;
  -webkit-border-bottom-right-radius:220px 120px;
  -webkit-border-bottom-left-radius:220px 120px;
  -moz-border-radius:220px / 120px;
  border-radius:220px / 120px;
}

.oval-speech-right p {font-size:3em;}

/* creates part of the curve */
.oval-speech-right:before {
  content:"";
  position:absolute;
  z-index:2;
  bottom:-30px;
  right:30%;
  height:30px;
  border-right:60px solid #000000;
  background:#000000; /* need this for webkit - bug in handling of border-radius */
  /* css3 */
  -webkit-border-bottom-left-radius:80px 50px;
  -moz-border-radius-bottomleft:80px 50px;
  border-bottom-left-radius:80px 50px;
  /* using translate to avoid undesired appearance in CSS2.1-capabable but CSS3-incapable browsers */
  -webkit-transform:translate(0, -2px);
  -moz-transform:translate(0, -2px);
  -ms-transform:translate(0, -2px);
  -o-transform:translate(0, -2px);
  transform:translate(0, -2px);
}

/* creates part of the curved pointy bit */
.oval-speech-right:after {
  content:"";
  position:absolute;
  z-index:2;
  bottom:-30px;
  left:65%;
  width:60px;
  height:30px;
  background:#fff;
  /* css3 */
  -webkit-border-bottom-left-radius:40px 50px;
  -moz-border-radius-bottomleft:40px 50px;
  border-bottom-left-radius:40px 50px;
  /* using translate to avoid undesired appearance in CSS2.1-capabable but CSS3-incapable browsers */
  -webkit-transform:translate(-30px, -2px);
  -moz-transform:translate(-30px, -2px);
  -ms-transform:translate(-30px, -2px);
  -o-transform:translate(-30px, -2px);
  transform:translate(-30px, -2px);
	display:block;
}

/* ============================================================================================================================
== OVAL THOUGHT BUBBLE (more CSS3)
** ============================================================================================================================ */

.oval-thought {
  position:relative;
  width:270px;
  padding:50px 40px;
  margin:1em auto 80px;
  text-align:center;
  color:#fff;
  background:#075698;
  /* css3 */
  background:-webkit-gradient(linear, 0 0, 0 100%, from(#2e88c4), to(#075698));
  background:-moz-linear-gradient(#2e88c4, #075698);
  background:-o-linear-gradient(#2e88c4, #075698);
  background:linear-gradient(#2e88c4, #075698);
  /*
  NOTES:
  -webkit-border-radius:220px 120px; // produces oval in safari 4 and chrome 4
  -webkit-border-radius:220px / 120px; // produces oval in chrome 4 (again!) but not supported in safari 4
  Not correct application of the current spec, therefore, using longhand to avoid future problems with webkit corrects this
  */
  -webkit-border-top-left-radius:220px 120px;
  -webkit-border-top-right-radius:220px 120px;
  -webkit-border-bottom-right-radius:220px 120px;
  -webkit-border-bottom-left-radius:220px 120px;
  -moz-border-radius:220px / 120px;
  border-radius:220px / 120px;
}

.oval-thought p {font-size:1.25em;}

/* creates the larger circle */
.oval-thought:before {
  content:"";
  position:absolute;
  bottom:-20px;
  left:50px;
  width:30px;
  height:30px;
  background:#075698;
  /* css3 */
  -webkit-border-radius:30px;
  -moz-border-radius:30px;
  border-radius:30px;
}

/* creates the smaller circle */
.oval-thought:after {
  content:"";
  position:absolute;
  bottom:-30px;
  left:30px;
  width:15px;
  height:15px;
  background:#075698;
  /* css3 */
  -webkit-border-radius:15px;
  -moz-border-radius:15px;
  border-radius:15px;
}

/* ============================================================================================================================
== OVAL SPEECH BUBBLE WITH QUOTATION MARKS (more CSS3)
** ============================================================================================================================ */

.oval-quotes {
  position:relative;
  width:400px;
  height:350px;
  margin:2em auto 10px;
  color:#000;
  background:#ffed26;
  /* css3 */
  /*
  NOTES:
  -webkit-border-radius:Apx Bpx; // produces oval in safari 4 and chrome 4
  -webkit-border-radius:Apx / Bpx; // produces oval in chrome 4 (again!) but not supported in safari 4
  Not correct application of the current spec, therefore, using longhand to avoid future problems with webkit corrects this
  */
  -webkit-border-top-left-radius:400px 350px;
  -webkit-border-top-right-radius:400px 350px;
  -webkit-border-bottom-right-radius:400px 350px;
  -webkit-border-bottom-left-radius:400px 350px;
  -moz-border-radius:400px / 350px;
  border-radius:400px / 350px;
}

/* creates opening quotation mark */
.oval-quotes:before {
  content:"\201C";
  position:absolute;
  z-index:1;
  top:20px;
  left:20px;
  font:80px/1 Georgia, serif;
  color:#ffed26;
}

/* creates closing quotation mark */
.oval-quotes:after {
  content:"\201D";
  position:absolute;
  z-index:1;
  bottom:0;
  right:20px;
  font:80px/0.25 Georgia, serif;
  color:#ffed26;
}

.oval-quotes p {
  width:250px;
  height:250px;
  padding:50px 0 0;
  margin:0 auto;
  text-align:center;
  font-size:35px;
}

/* creates smaller curve */
.oval-quotes p:before {
  content:"";
  position:absolute;
  z-index:-1;
  bottom:-30px;
  right:55%;
  width:180px; /* wider than necessary to make it look a bit better in IE8 */
  height:60px;
  background:#fff; /* need this for webkit - bug in handling of border-radius */
  /* css3 */
  -webkit-border-bottom-right-radius:40px 50px;
  -moz-border-radius-bottomright:40px 50px;
  border-bottom-right-radius:40px 50px;
  /* using translate to avoid undesired appearance in CSS2.1-capabable but CSS3-incapable browsers */
  -webkit-transform:translate(-30px, -2px);
  -moz-transform:translate(-30px, -2px);
  -ms-transform:translate(-30px, -2px);
  -o-transform:translate(-30px, -2px);
  transform:translate(-30px, -2px);
}

/* creates larger curve */
.oval-quotes p:after {
  content:"";
  position:absolute;
  z-index:-2;
  bottom:-30px;
  right:25%;
  height:80px;
  border-right:200px solid #ffed26;
  background:#ffed26; /* need this for webkit - bug in handling of border-radius */
  /* css3 */
  -webkit-border-bottom-right-radius:200px 100px;
  -moz-border-radius-bottomright:200px 100px;
  border-bottom-right-radius:200px 100px;
  /* using translate to avoid undesired appearance in CSS2.1-capabable but CSS3-incapable browsers */
  -webkit-transform:translate(0, -2px);
  -moz-transform:translate(0, -2px);
  -ms-transform:translate(0, -2px);
  -o-transform:translate(0, -2px);
  transform:translate(0, -2px);
  /* reduce the damage in FF3.0 */
  display:block;
  width:0;
}

.oval-quotes + p {
  position:relative; /* part of the IE8 width compromise */
  width:150px;
  margin:0 0 2em;
  font-size:18px;
  font-weight:bold;
}


/* ============================================================================================================================
== RECTANGLE-BORDER STYLE WITH CURVE
** ============================================================================================================================ */

.rectangle-speech-border {
  position:relative;
  padding:50px 15px;
  margin:1em 0 3em;
  border:10px solid #5a8f00;
  text-align:center;
  color:#333;
  background:#fff;
  /* css3 */
  -webkit-border-radius:20px;
  -moz-border-radius:20px;
  border-radius:20px;
}

/* creates larger curve */
.rectangle-speech-border:before {
  content:"";
  position:absolute;
  z-index:10;
  bottom:-40px;
  left:50px;
  width:50px;
  height:30px;
  border-style:solid;
  border-width:0 10px 10px 0;
  border-color:#5a8f00;
  background:transparent;
  /* css3 */
  -webkit-border-bottom-right-radius:80px 50px;
  -moz-border-radius-bottomright:80px 50px;
  border-bottom-right-radius:80px 50px;
  /* reduce the damage in FF3.0 */
  display:block;
}

/* creates smaller curve */
.rectangle-speech-border:after {
  content:"";
  position:absolute;
  z-index:10;
  bottom:-40px;
  left:50px;
  width:20px;
  height:30px;
  border-style:solid;
  border-width:0 10px 10px 0;
  border-color:#5a8f00;
  background:transparent;
  /* css3 */
  -webkit-border-bottom-right-radius:40px 50px;
  -moz-border-radius-bottomright:40px 50px;
  border-bottom-right-radius:40px 50px;
  /* reduce the damage in FF3.0 */
  display:block;
}

/* creates a small circle to produce a rounded point where the two curves meet */
.rectangle-speech-border > :first-child:before {
  content:"";
  position:absolute;
  bottom:-40px;
  left:45px;
  width:10px;
  height:10px;
  background:#5a8f00;
  /* css3 */
  -webkit-border-radius:10px;
  -moz-border-radius:10px;
  border-radius:10px;
}

/* creates a white rectangle to cover part of the oval border*/
.rectangle-speech-border > :first-child:after {
  content:"";
  position:absolute;
  bottom:-10px;
  left:76px;
  width:24px;
  height:15px;
  background:#fff;
}

/* ============================================================================================================================
== OVER SPEECH BUBBLE, EMPTY, WITH BORDER (more CSS3)
** ============================================================================================================================ */

.oval-speech-border {
  position:relative;
  padding:70px 30px;
  margin:1em auto 60px;
  border:10px solid #f3961c;
  text-align:center;
  color:#333;
  background:#fff;
  /* css3 */
  /*
  NOTES:
  -webkit-border-radius:240px 140px; // produces oval in safari 4 and chrome 4
  -webkit-border-radius:240px / 140px; // produces oval in chrome 4 (again!) but not supported in safari 4
  Not correct application of the current spec, therefore, using longhand to avoid future problems with webkit corrects this
  */
  -webkit-border-top-left-radius:240px 140px;
  -webkit-border-top-right-radius:240px 140px;
  -webkit-border-bottom-right-radius:240px 140px;
  -webkit-border-bottom-left-radius:240px 140px;
  -moz-border-radius:240px / 140px;
  border-radius:240px / 140px;
}

/* creates larger curve */
.oval-speech-border:before {
  content:"";
  position:absolute;
  z-index:2;
  bottom:-40px;
  right:50%;
  width:50px;
  height:30px;
  border-style:solid;
  border-width:0 10px 10px 0;
  border-color:#f3961c;
  margin-right:-10px;
  background:transparent;
  /* css3 */
  -webkit-border-bottom-right-radius:80px 50px;
  -moz-border-radius-bottomright:80px 50px;
  border-bottom-right-radius:80px 50px;
  /* reduce the damage in FF3.0 */
  display:block;
}

/* creates smaller curve */
.oval-speech-border:after {
  content:"";
  position:absolute;
  z-index:2;
  bottom:-40px;
  right:50%;
  width:20px;
  height:31px;
  border-style:solid;
  border-width:0 10px 10px 0;
  border-color:#f3961c;
  margin-right:20px;
  background:transparent;
  /* css3 */
  -webkit-border-bottom-right-radius:40px 50px;
  -moz-border-radius-bottomright:40px 50px;
  border-bottom-right-radius:40px 50px;
  /* reduce the damage in FF3.0 */
  display:block;
}

/* creates a small circle to produce a rounded point where the two curves meet */
.oval-speech-border > :first-child:before {
  content:"";
  position:absolute;
  z-index:1;
  bottom:-40px;
  right:50%;
  width:10px;
  height:10px;
  margin-right:45px;
  background:#f3961c;
  /* css3 */
  -webkit-border-radius:10px;
  -moz-border-radius:10px;
  border-radius:10px;
}

/* creates a white rectangle to cover part of the oval border*/
.oval-speech-border > :first-child:after {
  content:"";
  position:absolute;
  z-index:1;
  bottom:-10px;
  right:50%;
  width:30px;
  height:15px;
  background:#fff;
}

/* ============================================================================================================================
== OVER THOUGHT BUBBLE, EMPTY, WITH BORDER (more CSS3)
** ============================================================================================================================ */

.oval-thought-border {
  position:relative;
  padding:70px 30px;
  margin:1em auto 80px;
  border:10px solid #c81e2b;
  text-align:center;
  color:#333;
  background:#fff;
  /* css3 */
  /*
  NOTES:
  -webkit-border-radius:240px 140px; // produces oval in safari 4 and chrome 4
  -webkit-border-radius:240px / 140px; // produces oval in chrome 4 (again!) but not supported in safari 4
  Not correct application of the current spec, therefore, using longhand to avoid future problems with webkit corrects this
  */
  -webkit-border-top-left-radius:240px 140px;
  -webkit-border-top-right-radius:240px 140px;
  -webkit-border-bottom-right-radius:240px 140px;
  -webkit-border-bottom-left-radius:240px 140px;
  -moz-border-radius:240px / 140px;
  border-radius:240px / 140px;
}

/* creates the larger circle */
.oval-thought-border:before {
  content:"";
  position:absolute;
  z-index:10;
  bottom:-40px;
  right:100px;
  width:50px;
  height:50px;
  border:10px solid #c81e2b;
  background:#fff;
  /* css3 */
  -webkit-border-radius:50px;
  -moz-border-radius:50px;
  border-radius:50px;
  /* reduce the damage in FF3.0 */
  display:block;
}

/* creates the smaller circle */
.oval-thought-border:after {
  content:"";
  position:absolute;
  z-index:10;
  bottom:-60px;
  right:50px;
  width:25px;
  height:25px;
  border:10px solid #c81e2b;
  background:#fff;
  /* css3 */
  -webkit-border-radius:25px;
  -moz-border-radius:25px;
  border-radius:25px;
  /* reduce the damage in FF3.0 */
  display:block;
}

/* ######################################################################### */

.clearfix:after {
display:block;
clear:both;
}
/*----- Menu Outline -----*/
.menu-wrap {
width:100%;
/* box-shadow:0px 1px 3px rgba(0,0,0,0.2); */
background: white; /* #81d4cb; */
}
.menu {
width: 1000px
margin:0px auto;
color: white; /* #81d4cb; */
}
.menu li {
margin:0px;
list-style:none;
font-family: Tahoma, Verdana, sans-serif;
/* font-family:'Ek Mukta'; */
}
.menu a {
transition:all linear 0.15s;
color:#919191;
}
.menu li:hover > a, .menu .current-item > a {
text-decoration:none;
color:#be5b70;
}
.menu .arrow {
font-size:11px;
line-height:0%;
}
/*----- Top Level -----*/
.menu > ul > li {
float:left;
display:inline-block;
position:relative;
font-size:19px;
}
.menu > ul > li > a {
padding:10px 40px;
display:inline-block;
text-shadow:0px 1px 0px rgba(0,0,0,0.4);
}
.menu > ul > li:hover > a, .menu > ul > .current-item > a {
background:#D7EAEE;
}
/*----- Bottom Level -----*/
.menu li:hover .sub-menu {
z-index:1;
opacity:1;
}
.sub-menu {
width:160%;
padding:5px 0px;
position:absolute;
top:100%;
left:0px;
z-index:-1;
opacity:0;
transition:opacity linear 0.15s;
box-shadow:0px 2px 3px rgba(0,0,0,0.2);
background:#919191;
}
.sub-menu li {
display:block;
font-size:16px;
}
.sub-menu li a {
padding:10px 30px;
display:block;
}
.sub-menu li a:hover, .sub-menu .current-item a {
background:#D7EAEE;
}
