@charset "utf-8";
/* Simple fluid media
   Note: Fluid media requires that you remove the media's height and width attributes from the HTML
   http://www.alistapart.com/articles/fluid-images/ 
*/
/*BODY AND MAIN STYLES */
/* Mobile Layout: 480px and below. All others inherit unless overridden */ 
body {
    font-family: 'Fira Sans', sans-serif;
	margin-top: 0;
    background-image: url(/images/small-bg.jpg);
	background-position:top center;
	background-repeat: no-repeat;
	background-attachment: fixed;
    background-size: 100%;
	background-color: #000;
    font-size: 0.875em;
    line-height: 1.4;
    color: #333;
}
@media only screen and (min-width: 481px) {
	body {
		background-image: url(/images/medium-bg.jpg);
		font-size: 0.875em;
		line-height: 1.4;
	}
}
@media only screen and (min-width: 767px) {
	body {
		background-image: url(/images/large-bg.jpg);
		font-size: 1em;
		line-height: 1.4;
	}
}
.topBar {
	display: none;
}
@media only screen and (min-width: 897px) {
	.topBar {
		display: block;
		background: #000;
		width: auto;
		top: 0;
		padding: 5px 10px;
		color: #fff;
		font-weight: 400;
	}
}
.joinBox {
	float: right;
	padding: 5px 0;
}
.joinBox input[type="text"] {
	float: left;
    width: 165px;
	margin: 5px;
	background-color: #FAFAFA;
    border: 1px solid #fff;
    color: #666666;
	padding: 7px;
	font-size: 14px;
}
.joinList input[type="text"] {
    background: #fff;
    margin: 0 0 10px 5px;
	border: 1px solid #ccc;
    color: #4C4C4C;
    padding: 5px 10px;
    font-size: 75%;
    text-transform: uppercase;
    -moz-border-radius: 3px;
    border-radius: 3px;
    max-width: 75%;
}
@media only screen and (min-width: 552px) {
	.joinBox input[type="text"] {
		width: 200px;
	}
}
@media only screen and (min-width: 897px) {
	.joinBox input[type="text"]  {
		width: 170px;
	}
	.joinList input[type="text"] {
		max-width: 75%;
		margin: 0 0 10px 5px;
	}
}
@media only screen and (min-width: 991px) {
	.joinBox input[type="text"] {
		width: 200px;
	}
}
.joinBox input[type="submit"], .joinList input[type="submit"], .joinBox button {
    float:right;
	background: #2a69e5;
    border: 1px solid #2a69e5;
    color: #FFF;
    font-weight: normal;
	padding: 8px 10px;;
	font-size: 16px;
}
.joinList input[type="submit"] {
	float: left;
}
.joinBox input[type="submit"]:hover, .joinList input[type="submit"]:hover, joinBox button:hover {
	background: #BF3C44;
}
.joinText {
	float: right;
	clear: both;
	font-size: 85%; 
	padding: 15px 0;
}
@media only screen and (min-width: 1378px) {
	.joinText {
		clear: none;
		padding: 15px;
	}
}
.socialIcons {
	float: left;
	padding: 8px;
}
.socialIcons a,.socialIcons a:visited {
	color: #2B5FCD;
}
.socialIcons a:hover {
	color: #fff;
}
.socialIcons:hover, .socialIcons:hover a {
	background:#2B5FCD;
	color: #fff;
}
.socialNavMobile {
	float: left;
	padding: 10px 0 0 0;
}
.socialNavMobile a, .socialNavMobile a:visited {
	padding: 0 10px;
	color: #fff;
}
.socialNavMobile a:hover {
	padding: 0 10px;
	color: #BF3C44;
}
.fa-2x {
    font-size: 1.75em;
}
/* Mobile Layout: 480px and below. All others inherit unless overridden */ 
.gridContainer {
	margin-left: auto;
	margin-right: auto;
	width: 98%;
	clear: none;
	float: none;
}
@media only screen and (min-width: 691px) {
	.gridContainer {
		width: 97%;
	}		
}
@media only screen and (min-width: 1232px) {
	.gridContainer {
		width: 88.5%;
		max-width: 1232px;
	}
}
/* Mobile Layout: 480px and below. All others inherit unless overridden */ 
.small-header {
    display: block;
}
.small-header p {
	margin: 0;
}
@media only screen and (min-width: 481px) {
	.small-header {
		display: none;
	}
}
.medium-header {
    display: none;
}
@media only screen and (min-width: 481px) {
	.medium-header {
		display: block;
	}
	.medium-header p {
		margin: 0;
	}
}
@media only screen and (min-width: 897px) {
	.medium-header {
		display: none;
	}
}
.large-header {
    display: none;
}
@media only screen and (min-width: 897px) {
	.large-header {
		display: block;
		margin-top: 25px;
		padding: 10px 0 15px 0;
	}
	.large-header p {
		margin: 0;
	}
}
@media only screen and (min-width: 1042px) {
	.large-header {

	}
}
@media only screen and (min-width: 1350px) {
	.large-header {

	}
}
@media only screen and (min-width: 1650px) {
	.large-header {

	}
}
.headerText {
	float: none;
	padding: 10px;
}
@media only screen and (min-width: 1040px) {	
	.headerText {
		float: left;
		padding: 5px 2% 10px 1%;
    	max-width: 62%;
	}		
}
@media only screen and (min-width: 1200px) {	
	.headerText {
    	max-width: 65%;
	}		
}
@media only screen and (min-width: 1324px) {	
	.headerText {
		padding: 5px 2% 10px 2%;
	}		
}
@media only screen and (min-width: 1404px) {	
	.headerText {
		padding: 10px 2% 10px 5%;
	}		
}
.headerHighlight {
	float:none;
	margin: 0 auto;
    width: auto;
    padding: 15px;
	font-size: 16px;
	color: #fff;
	background: rgba(0, 0, 0, 0.65);
	border-radius: 10px;
	-moz-border-radius: 10px;
	text-align: center;
}
@media only screen and (min-width: 1040px) {
	.headerHighlight {
		float: left;
		background: rgba(0, 0, 0, 0.35);
		text-align: left;
		width: 30%;
		padding: 15px;
		font-size: 16px;
		margin-left: 1.5%;
	}		
}
@media only screen and (min-width: 1404px) {
	.headerHighlight {
		padding: 25px;
		font-size: 18px;
		margin-left: 2.5%;
	}		
}
.headerHighlight .redBtn {
	float:none;
	margin: 0 auto;
}
@media only screen and (min-width: 1040px) {
	.headerHighlight .redBtn {
		float: right;
		margin: auto;
	}	
}
.logo, .tagline {
	font-family: 'Bellefair', serif;
	text-transform: uppercase;
	color: #fff;
	text-shadow: 3px 2px 5px #333;
	text-align: center;
	line-height: 1;
}
.tagline {
	line-height: 1.25;
}
@media only screen and (min-width: 1040px) {
	.tagline {
		line-height: 1;
	}
	.logo, .tagline {
		text-align: left;
	}
}
.small-header .logo {
	font-size: 56px;
}
.small-header .tagline {
	font-size: 14px;
}
.medium-header .logo {
	font-size: 72px;
}
.medium-header .tagline {
	font-size: 15px;
}
.large-header .logo {
	font-size: 85px;
}
@media only screen and (min-width: 1200px) {
	.large-header .logo {
		font-size: 96px;
	}	
}
.large-header .tagline {
	font-size: 18px;
}
@media only screen and (min-width: 1200px) {
	.large-header .tagline {
		font-size: 20px;
	}	
}
/*MOBILE MENU */
.js #menu, #menu { /*don't display the menu that builds the mobile menu ever */
		display:none;
	}
.slicknav_menu {
	display:none;
}
.slicknav_menu {
    font-size: 1em;
    background: #000;
    padding: 5px;
}
.slicknav_nav {
    clear: both;
	background: #2a69e5;
    color: #fff;
    margin: 0;
    font-size: 1em;
}
.slicknav_btn {
	background-color: #2a69e5;
}
.slicknav_nav a:hover {
	background: #BF3C44;
}
.slicknav_nav a:visited{
	color: #FFF;
}
.slicknav_nav .slicknav_item:hover {
	background: #BF3C44;
}
.slicknav_menu .slicknav_menutxt {
    text-shadow: none;
}
.slicknav_menu .slicknav_icon-bar {
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
    box-shadow: none;
}
@media screen and (max-width: 896px) { /*display the mobile menu now up to 897px */	
	.js .slicknav_menu {
		display:block;
	}
}
/*END OF MOBILE MENU */
/*START OF MAIN MENU */
@media only screen and (min-width: 897px) {
	.mainlinks {
		float: left;
		padding-top: 3px;
	}
}
.mainlink {
	padding: 10px 8px;
	font-size: 16px;
	color: #fff;
	float: left;
	font-weight: 500;
}
@media only screen and (min-width: 979px) {
	.mainlink {
		font-size: 18px;
	}
}
@media only screen and (min-width: 1100px) {
	.mainlink {
		padding: 10px 13px;
		font-size: 20px;
	}
}
.mainlink a {
	color: #fff;
	text-decoration: none;
}
.mainlink a:hover {
	color: #fff;
	background: #2a69e53;
}
.mainlink a:visited {
	color: #fff;
}
.mainlink:hover {
	color: #fff;
	background: #2a69e5;
}
.mainlink:hover a {
	color: #fff;
}
/*Drop Down Flex Menu*/
.flexdropdownmenu, .flexdropdownmenu ul { /*topmost and sub ULs, respectively*/
	margin: 10px 0 0 0;
	padding: 0;
	left: 0;
	top: 10;
	background: #BF3C44;
	border: 1px solid #fff;
	box-shadow: 3px 3px 3px #999; /*shadow for CSS3 capable browsers.*/
	-webkit-box-shadow: 3px 3px 3px #000;
	-moz-box-shadow: 3px 3px 3px #000;
}
.flexdropdownmenu li a {
	width: 225px; /*width of menu (not including side paddings)*/
	color: #fff;
	background: #BF3C44;
	border-bottom: 1px solid #fff;
	padding: 4px 5px;
}
* html .flexdropdownmenu li { /*IE6 CSS hack*/
	width: 210px; /*width of menu (include side paddings of LI A*/
}
.flexdropdownmenu li a:hover, .flexdropdownmenu li.selected>a{
	background: #FF504D;
}
/* Mobile Layout: 480px and below. All others inherit unless overridden */ 
.main-content, .bottom-content {
    padding: 2% 5%;
    background: rgba(196, 220, 249, 0.75);
    border-top: none;
	border-radius: 15px 15px 0 0;
	-moz-border-radius: 15px 15px 0 0;
}
.bottom-content {
	border-radius: 0;
	-moz-border-radius: 0;	
}
@media only screen and (min-width: 897px) {
	.main-content, .bottom-content {
		padding: 2.5% 5%;
	}
	.main-content {
		border-radius: 25px 25px 0 0;
		-moz-border-radius: 25px 25px 0 0;
	}
}
.highlight-content {
    padding: 1% 5%;
    background: rgba(196, 220, 249, 0.85);
}
@media only screen and (min-width: 481px) {
	.highlight-content {
		padding: 1% 5%;
	}
}
@media only screen and (min-width: 897px) {
	.highlight-content {
		padding: 3% 5%;
	}
}
.main-footer {
    padding: 1% 5%;
    background-color: #043595;
	font-size: 70%;
	color: #fff;
	line-height: 145%;
}

/*END OF MAIN LAYOUT AND GENERAL STYLES */
img, object, embed, video {
	max-width: 100%;
}

/* IE 6 does not support max-width so default to width 100% */
.ie6 img {
	width:100%;
}
.clearDiv {
	clear:both;
}
/*START OF CUSTOMIZATIONS */
/* Mobile Layout: 480px and below. All others inherit unless overridden */ 
h1, h2, h3, h4, h5, h6 {
    -webkit-margin-before: 0.67em;
    -webkit-margin-after: 0.5em;
    -webkit-margin-start: 0px;
    -webkit-margin-end: 0px;
    font-weight: bold;
}
h1 {
	font-size: 1.25em;
	color: #043595;
	text-align: center;
}
h2 {
	font-size: 1.25em;
	color: #BF3C44;
}
h3 {
     font-size: 1.2em;
     color: #000;
}
h4 {
	font-size: 1.2em;
	color: #043595;
}
h5 {
    font-size: 1.1em;
    color : #BF3C44;
}
h6 {
    font-size: 1.1em;
    color : #000;
}
@media only screen and (min-width: 897px) {
	h1 {
		font-size: 1.5em;
		text-align: left;
	}
	h2 {
		font-size: 1.4em;
	}
	h3 {
		 font-size: 1.3em;
	}
	h4 {
		font-size: 1.2em;
	}
}
a  
{
  color : #2A4C95;
}

a:visited
{
  color : #415a91;
}

a:hover  
{
  color : #BF3C44;
}
a.copyright {
	color: #fff;
	text-decoration: none;
}
a.copyright:visited {
	color: #fff;
}
a.copyright:hover {
	color: #96c5f9;
}
.largecolor1 {
	color: #96c5f9;
	font-size: 24px;
}
.largecolor2 {
	color: #fff;
	font-size: 20px;
}
.xlargecolor1 {
	font-size: 2em;
	color: #000;
}
.smallcolor1 {
	font : .95em "Calibri", sans-serif;
	color: #000;
}
@media only screen and (min-width: 897px) {
	.smallcolor1 {
		font : 1.125em "Calibri", sans-serif;
	}
}
.color1 {
	color: #000;
}
.centerText {
	text-align: center;
}
.col2thirdleft {
	float: none;
	width: 98%;
	padding: 0 1%;
	margin: auto;
}
@media only screen and (min-width: 897px) {
	.col2thirdleft {
		float: left;
		width: 65%;	
	}
}
.col1thirdright {
	float: none;
	width: 98%;
	padding: 0 1%;
	margin: auto;
}
@media only screen and (min-width: 897px) {
	.col1thirdright {
		float: right;
		width: 30%;	
	}
}
.col2thirdright {
	float: none;
	width: 98%;
	padding: 0 1%;
	margin: auto;
}
@media only screen and (min-width: 897px) {
	.col2thirdright {
		float: right;
		width: 65%;	
	}
}
.col1thirdleft {
	float: none;
	width: 98%;
	padding: 0 1%;
	margin: auto;
}
@media only screen and (min-width: 897px) {
	.col1thirdleft {
		float: left;
		width: 30%;	
	}
}
.col1third {
	float: none;
	width: 98%;
	padding: 0 1%;
	margin: 10px auto 30px auto;
}
@media only screen and (min-width: 897px) {
	.col1third {
		float: left;
		width: 31%;
		padding: 0 1.1666666666666667%;
	}	
}
.col1half {
	float: none;
	width: 98%;
	padding: 0 1%;
	margin: auto;
}
@media only screen and (min-width: 655px) {
	.col1half {
		float: left;
		width: 45%;
		padding: 0 2.5%;
	}
}
.col1halfright {
	float: none;
	width: 98%;
	padding: 0 1%;
	margin: auto;
}
@media only screen and (min-width: 655px) {
	.col1halfright {
		float: right;
		width: 45%;
		padding: 0 2.5% 0 0;
	}
}
.col1halfleft {
	float: none;
	width: 98%;
	padding: 0 1%;
	margin: auto;
}
@media only screen and (min-width: 655px) {
	.col1halfleft {
		float: left;
		width: 45%;
		padding: 0 2.5% 0 0;
	}
}
.col1fourth {
	float: none;
	width: 98%;
	padding: 0 1%;
	margin: 10px auto 30px auto;
}
@media only screen and (min-width: 941px) {
	.col1fourth {
		float: left;
		width: 22%;
		padding: 0 1.5%;
	}	
}
/*Contact Form */
.emailFormError {
	margin:0px; 
	color:#FF0000
}
.inputButton {}
.inputText {
	width:95%; 
}
.inputValue {
	width:95%;
}
@media only screen and (min-width: 625px) {
	.inputText {
		width:85%; 
	}
	.inputValue {
		width:85%;
	}
}
/*EXTRAS */
/*a colored box without rounded corners */
.colorBox {
	background: rgba(196, 220, 249, 0.80);
	padding: 10px;
	margin: 25px auto;
}
/*Highlight Box with rounded corners centered */
.colorBoxRound {
    width: auto;
	padding: 15px;
    background: rgba(196, 220, 249, 0.80);
	margin: 25px auto;
	border-radius: 10px;
	-moz-border-radius: 10px;
}
@media only screen and (min-width: 625px) {
	.colorBoxRound{
	    padding: 15px 35px;
		margin: 40px auto;
	}
	.colorBox {
	margin: 25px auto;
	}	
}
ol {
	margin-left: 0;
}
ol li {
	margin-bottom: 15px;
}
/*padding on images - sub for hspace, vspace or both */
.imgHPad {
	border: none;
	padding: 0 10px;
}
.imgVPad {
	border: none;
	padding: 10px 0;
}
.imgBPad {
	border: none;
	padding: 10px;
}
.imgHMPad {
	border: none;
	margin: 0 10px;
}
.imgVMPad {
	border: none;
	margin: 10px 0;
}
.imgBMPad {
	border: none;
	margin: 10px;
}
.imgShadow {
    background: #fff;
    padding: 10px;
    -moz-box-shadow: 0 0 15px #ccc;
    -webkit-box-shadow: 0 0 15px #ccc;
    box-shadow: 0 0 15px #ccc;
}
.imgRight {
	float: none;
	margin: 15px auto;
}
@media only screen and (min-width: 625px) {
	.imgRight {
		float: right;
		margin: 5px 0 25px 25px;
	}	
}
.imgLeft {
	float: none;
	margin: 15px auto;
}
@media only screen and (min-width: 625px) {
	.imgLeft  {
		float: right;
		margin: 5px 25px 25px  0;
	}	
}
/* BUTTONS */
.redBtn, .blueBtn {
    padding: 5px 15px;
    border: none;
     -moz-border-radius: 8px;
    border-radius: 8px;
	font-size: 1em;
    text-transform: uppercase;
	text-align: center;
	font-weight: 400;
	margin: 10px 5px 10px 0;
	color: #fff;
}
.redBtn {
    background:#BF3C44;
}
.blueBtn {
    background:#043595;
}
.redBtn:hover, .blueBtn:hover {
	background:#FF504D;
}
.small {
	font-size: .75em;
}
.smallSlider {
	font-size: .75em;
	text-align: center;
	color: #0d46b4;
	font-weight: bold;
}
/*Home Page */
.signature {
	font-family: 'Bellefair', serif;
	font-size: 1.65em;
	color: #BF3C44;
	font-style: italic;
}
.quote {
	font-family: 'Bellefair', serif;
	text-align: center;
	font-size: 1.25em;
	margin-bottom: 15px;
}
@media only screen and (min-width: 897px) {
	.quote {
		font-size: 1.65em;
		margin-bottom: 0px;
	}
}
.reviewer {
	font-family: 'Fira Sans', sans-serif;
	color: #1F427D;
	font-size: .75em;
	font-weight: 500;
}
.award {
	font-family: 'Fira Sans', sans-serif;
	color: #1F427D;
	font-size: 1em;
	font-weight: 500;
}
span.reviewer::before {
    content: "-- ";
}
/*Book Pages*/
.bookCover {
    float: none;
    background: #fff;
    padding: 5px;
    -webkit-box-shadow: 1px 1px 3px 1px #b5b4b4;
    -moz-box-shadow: 1px 1px 3px 1px #b5b4b4;
	box-shadow: 1px 1px 3px 1px #b5b4b4;
}
.booksPage {
	margin: 0 auto;
	width: 90%;
	max-width: 250px;
}
.seriesPage {
	margin: 15px auto;
	width: 200px;
}
@media only screen and (min-width: 897px) {
	.seriesPage {
		margin: 0px 15px 20px 15px;
		width: 140px;
	}	
}
@media only screen and (min-width: 941px) {
	.booksPage {
		margin: 0;
	}	
}
@media only screen and (min-width: 1200px) {
	.booksPage {
	}	
}
@media only screen and (min-width: 1350px) {
	.booksPage {
	}	
}
.buyBox {
	margin: 35px 0 20px 0;
	background: #EBDECD;
	padding: 10px;
}
.buyBox img {
	padding: 5px 10px;
}
.seriesTitle {
	border-radius: 10%;
}
/*Accordion Tabs*/
.r-tabs {
	position: relative;
	margin: 15px 0 0 0;
    padding: 10px;
	background: rgba(196, 220, 249, 0.85);
	border-radius: 20px;
	-moz-border-radius: 20px;
}
.r-tabs .r-tabs-nav {
    padding: 5px 10px 0;
}
/* Tab element */
.r-tabs .r-tabs-nav .r-tabs-tab {
	position: relative;
}
/* Tab anchor */
.r-tabs .r-tabs-nav .r-tabs-anchor {
	display: inline-block;
	text-decoration: none;
    padding: 5px 10px;
	font-size: 1em;
    background: none;
    margin: 0 5px;
    border-radius: 5px;
}
/* Disabled tab */
.r-tabs .r-tabs-nav .r-tabs-state-disabled {
	opacity: 0.5;
}
/* Active state tab anchor */
.r-tabs .r-tabs-nav .r-tabs-state-active .r-tabs-anchor {
	color: #BF3C44;
	text-shadow: none;
	background: none;
	font-weight: bold;
}
/* Tab panel */
.r-tabs .r-tabs-panel {
	background: none;
}
.r-tabs .r-tabs-panel.r-tabs-state-active {
    padding: 5px 25px;
}
/* Accordion anchor */
.r-tabs .r-tabs-accordion-title .r-tabs-anchor {
	display: block;
	padding: 10px;
    background: rgba(196, 220, 249, 0.85);
	font-weight: bold;
	text-decoration: none;
	text-align: center;
}
@media only screen and (min-width: 769px) {
	.r-tabs .r-tabs-accordion-title .r-tabs-anchor {
		text-align: left;
	}		
}
/* Active accordion anchor */
.r-tabs .r-tabs-accordion-title.r-tabs-state-active .r-tabs-anchor {
    background: rgba(196, 220, 249, 0.85);
	color: #BF3C44;
	text-shadow: none;
}
/* Disabled accordion button */
.r-tabs .r-tabs-accordion-title.r-tabs-state-disabled {
	opacity: 0.5;
}
h1.summary {
	margin: 0;
}
#reviews {
	font-style: italic;
}
.reviewcredit {
	font-family: 'Fira Sans', sans-serif;
	font-style: normal;
	color: #1F427D;
	font-weight: 500;
}
.reviewcredit::before {
    content: "-- ";
}
/*Bio Styles */
.bioPic {
    max-width: 200px;
    float: none;
    background: #fff;
    padding: 10px;
    -moz-box-shadow: 0 0 15px #ccc;
    -webkit-box-shadow: 0 0 15px #ccc;
    box-shadow: 0 0 15px #ccc;
    margin: 10px auto 20px auto;
}
@media only screen and (min-width: 342px) {
	.bioPic {	
		max-width: 250px;
	}
}
@media only screen and (min-width: 897px) {
	.bioPic {	
		max-width: 190px;
	}
}
@media only screen and (min-width: 1042px) {
	.bioPic {	
		max-width: 225px;
	}
}
@media only screen and (min-width: 1200px) {
	.bioPic {	
		max-width: 250px;
	}
}
@media only screen and (min-width: 897px) {
	.bioCol {
		width: 60%;	
	}
}
ol.facts {
    margin-left: -25px;
}
/* Videos */
.video-container {
	position:relative;
	padding-bottom:56.25%;
	padding-top:30px;
	height:0;
	overflow:hidden;
	margin-bottom: 25px;
}
@media only screen and (min-width: 1024px) {
	.video-container {
		margin: 50px 0;
	}	
}
.video-container iframe, .video-container object, .video-container embed {
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
}
.iframe-container {
	position:relative;
	padding-bottom:200%;
	padding-top:30px;
	height:0;
	overflow:hidden;
}
.iframe-container iframe, .iframe-container object, .iframe-container embed {
	position:absolute;
	top:0;
	left:0;
	width:105%;
}
/*Flora Contact Form */
/* @form label + field :: field class is useful for validation 
---------------------------------------------------------------------- */
.floraforms .field-icon i { 
	color:#FF2826; 
}
.floraforms .field-label em{ 
	color:#FF2826;
}
/* @form element :hover state 
-------------------------------------------- */
.floraforms .flo-input:hover,
.floraforms .flo-textarea:hover,
.floraforms .flo-select > select:hover,
.floraforms .flo-selectmulti select:hover, 
.floraforms .flo-input:hover ~ .flo-hint,
.floraforms .flo-file .file-input:hover + .flo-input,
.floraforms .flo-textarea:hover ~ .flo-hint{
	border-color: #BF3C44;
}
/* @control border-size :: color etc for these elements 
----------------------------------------------------------- */
.floraforms .flo-input,
.floraforms .flo-select,
.floraforms .flo-textarea,
.floraforms .flo-select > select,
.floraforms .flo-selectmulti select{
	border: 2px solid #274D96;
}
/* @primary button theme
-------------------------------------------- */
.floraforms .btn-themed {  background-color: #BF3C44;  }
.floraforms .btn-themed:hover,
.floraforms .btn-themed:focus { background-color: #FF504D; }
.floraforms .btn-themed:active{ background-color: #FF504D; }


.floraforms .alert-info { color:#FF504D; background-color: #fff; }
.floraforms .alert-success { color:#fff; background-color: ##274D96; }
.floraforms .alert-warning { color: #fff; background-color: #FF504D; }
.floraforms .alert-error { color:#FF504D; background-color: #fff; }

/* @form element :focus state 
-------------------------------------------------------- */
.floraforms .flo-input:focus,
.floraforms .flo-textarea:focus,
.floraforms .flo-select > select:focus,
.floraforms .flo-selectmulti select:focus{ border-color: #BF3C44; color: #000; }
.floraforms .flo-selectmulti select:focus, 
.floraforms .flo-input:focus ~ .flo-hint,
.floraforms .flo-textarea:focus ~ .flo-hint, 
.floraforms .flo-file .file-input:focus + .flo-input{ border-color: #BF3C44; }
.floraforms .flo-select > select:focus + .arrow{ color:#C34247; }

/* @validation - error state
------------------------------------- */
.floraforms .state-error .flo-input,
.floraforms .state-error .flo-textarea,
.floraforms .state-error.flo-select > select,
.floraforms .state-error.flo-selectmulti > select,
.floraforms .state-error input:hover + .flo-checkbox, 
.floraforms .state-error input:hover + .flo-radio,
.floraforms .state-error input:focus + .flo-checkbox, 
.floraforms .state-error input:focus + .flo-radio,
.floraforms .state-error .flo-checkbox, 
.floraforms .state-error .flo-radio{
	background: rgba(255, 231, 192, 0.35);
	border-color:#BF3C44;
}
/* @captcha + reload button
-------------------------------------------------- */
.floraforms .captcode{
	background: #fff;
    border-color: #274D96;
}
.floraforms .refresh-captcha i{ 
	color: #BF3C44; 
}
.floraforms .state-success .flo-input, .floraforms .state-success .flo-textarea, .floraforms .state-success.flo-select > select, .floraforms .state-success.flo-selectmulti > select {
    background: #bed5ff;
    border-color: #5f8ddd;
}
.floraforms .alert-success {
    color: #fff;
    background-color: #5f8ddd;
}
/*end of floraforms*/