﻿html {
	/*height: 100%;
  min-height: 100%;*/
}

body {
	width: 100%;
	/*min-height: 100%;*/
	background-color: #fff;
	text-align: center;
}

.m-image-preloader {
  width: 0px;
  height: 0px;
  display: inline;
  background-image: url("../images/splash-logo-hover.png"), url("../images/logo-hover.png");
  background-position:-1000px -1000px;
}


/* ==========================================================================
   Section blocks
   ========================================================================== */

.m-container {
	clear: both;
	position: relative;
}

.container_hidden {
	overflow: hidden;
}

.container_white {
	background-color: #fff;
}

.container_light {
	background-color: #f2f2f2;
}

.b-block {
	width: 90%;
	min-width: 320px;
	max-width: 1340px;
	overflow: hidden;
	margin: 0 auto;
	padding: 90px 0;
	padding-top: 9vh;
	padding-bottom: 9vh;
}

@media only all and (max-width: 620px) {
	.b-block  {
		padding: 50px 0;
		padding-top: 9vh;
		padding-bottom: 9vh;
  }
}

.b-block h2 {
	color: #333;
	font-weight: 400;
	padding: 0 0 30px 0;
}

.b-imagebg {
	width: 90%;
	min-width: 320px;
	max-width: 1340px;
	margin: 0 auto;
	padding: 8em 0 6.4em 0;
	padding-top: 12vh;
	padding-bottom: 10vh;
}

@media only all and (max-width: 620px) {
	.b-imagebg  {
		padding: 5em 0 4em 0;
		padding-top: 12vh;
		padding-bottom: 10vh;
  }
}

.m-backstretch {
	position: absolute;
	z-index: -999998;
  top: 0; 
  left: -50%; 
  width: 200%; 
  height: 100%;
	overflow: hidden;
}

.backstretch__bg {
	position: absolute;
	z-index: -999999;
  top: 0; 
  left: 0; 
  right: 0; 
  bottom: 0; 
  margin: auto; 
  min-width: 50%;
  min-height: 100%;
	border: none;
}


/*.m-splash {
	width: 100%;
	min-height: 100%;
	margin: 0;
	padding: 0;
	position: absolute;
	z-index: -1;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;

	background: #646652 url("../images/bg-splash.jpg") 50% top no-repeat;
}

@media only all and (min-width: 1920px), screen and (min-device-width : 768px) and (max-device-width : 1024px) {
  .m-splash {
    -webkit-background-size: cover;
  	 	 -moz-background-size: cover;
  		   -o-background-size: cover;
  				  background-size: cover;
  }
}

.b-block {
	width: 90%;
	min-width: 520px;
	max-width: 1340px;
	margin: 0 auto;
	padding: 0 10px;
}

.block_bg h1,
.block_bg h2,
.block_bg h3,
.block_bg h4,
.block_bg p {
	color: #fff;
}

.block_full {
	height: 100%;
	height: 100vh;
}
*/

/* ==========================================================================
   Header
   ========================================================================== */

.b-header {
	position: relative;
	z-index: 100;
	width: 100%;
	height: 64px;
	padding: 15px 0;
	margin: 0 0 -94px 0;
}

.header_nav {
	width: 90%;
	min-width: 220px;
	max-width: 1340px;
	margin: 0 auto;
	overflow: hidden;
}

.header__stamp {
	float: left;
	display: block;
	width: 64px;
	height: 64px;
	margin: -2px 0 0 0;

	background: transparent url("../images/splash-stamp.png") 50% top no-repeat;

  -khtml-opacity: 0.4;
    -moz-opacity: 0.4;
         opacity: 0.4;

	-webkit-transition: all 1s ease;
					transition: all 1s ease;
}

.header__stamp:focus {
	border-bottom: none;
  -khtml-opacity: 0.75;
    -moz-opacity: 0.75;
         opacity: 0.75;
}

.header__stamp:hover {
  -khtml-opacity: 0.9;
    -moz-opacity: 0.9;
         opacity: 0.9;
}

@media only all and (max-width: 570px) {
	.header__connect {
		display: none;
	}
}

.b-nav {
	float: right;
	padding-top: 10px;
	list-style-type: none;
}

.b-nav li {
	float: left;
	padding: 0 0 0 20px;
}

.b-nav .nav__plain {
	padding-left: 20px;
	padding-right: 10px;
	font-size: 1.1em;
	line-height: 43px;
}

.b-nav .nav__plain:first-child {
	padding-left: 0;
}

@media only all and (max-width: 790px) {
	.nav__plain  {
    display: none;
  }
}

.nav__plain a,
.nav__plain a:visited {
	color: #fff;

	-webkit-transition: color 0.5s ease;
					transition: color 0.5s ease;
}

.nav__plain a:hover {
	color: #42c4ff;
	text-decoration: none;
}


/* ==========================================================================
   Splash
   ========================================================================== */

.b-splash {
	height: 100%;
	height: 76vh;
	min-height: 540px;
	padding-top: 180px;
	padding-top: 24vh;
}

@media only all and (max-height: 840px) {
  .b-splash { height: 80vh; padding-top: 80px; padding-top: 18vh; }
}

@media only screen and (min-device-width : 768px) and (max-device-width : 1024px) {
  .b-splash {
  	padding-top: 180px;
  	padding-top: 28vh;
    min-height: 582px;
  }
}

/*@media only all and (max-height: 615px) {
	.b-splash {
    padding-bottom: 40px;
  }
}*/

	.m-splash_wabout { height: 80vh; padding-top: 120px; padding-top: 20vh; }
@media only all and (max-height: 800px) {
  .m-splash_wabout { height: 86vh; padding-top: 60px; padding-top: 14vh; }
}
@media only all and (max-height: 700px) {
  .m-splash_wabout { height: 90vh; padding-top: 30px; padding-top: 10vh; }
}
@media only all and (max-height: 620px) {
  .m-splash_wabout { height: 92vh; padding-top: 10px; padding-top: 8vh; }
}

	.m-splash_one { height: 73vh; padding-top: 260px; padding-top: 27vh; }
@media only all and (max-height: 800px) {
  .m-splash_one { height: 78vh; padding-top: 150px; padding-top: 22vh; }
}
@media only all and (max-height: 570px) {
  .m-splash_one { height: 84vh; padding-top: 80px; padding-top: 16vh; }
}

	.m-splash_two { height: 78vh; padding-top: 140px; padding-top: 22vh; min-height: 600px; }
@media only all and (max-height: 800px) {
  .m-splash_two { height: 84vh; padding-top: 80px; padding-top: 16vh; min-height: 600px; }
}
@media only all and (max-height: 700px) {
  .m-splash_two { height: 88vh; padding-top: 50px; padding-top: 12vh; min-height: 600px; }
}
@media only all and (max-height: 620px) {
  .m-splash_two { height: 90vh; padding-top: 30px; padding-top: 10vh; min-height: 600px; }
}

.b-splash h1,
.b-splash h2,
.b-splash h3,
.b-splash h4,
.b-splash p {
	color: #fff;
}

/*@media only screen and (min-device-width : 768px) and (max-device-width : 1024px) and (orientation: landscape) {
  .b-splash { margin-top: 60px; }
}

@media only screen and (min-device-width : 768px) and (max-device-width : 1024px) and (orientation: portrait) {
  .b-splash { margin-top: 120px; }
}*/

.splash__logo {
	display: block;
	width: 357px;
	height: 125px;
	margin: 0 auto;

	background: transparent url("../images/splash-logo.png") 50% top no-repeat;

	-webkit-transition: background-image 0.5s ease;
					transition: background-image 0.5s ease;

	-webkit-backface-visibility: hidden;
					backface-visibility: hidden;

  -webkit-transform: translateZ(0);
     -moz-transform: translateZ(0);
       -o-transform: translateZ(0);
          transform: translateZ(0);
}

.splash__logo:hover,
.splash__logo:focus {
	border-bottom: none;
	background-image: url("../images/splash-logo-hover.png");
}

.splash__stamp {
	display: block;
	width: 72px;
	height: 72px;
	margin: 0 auto 50px auto;

	background: transparent url("../images/splash-stamp-big.png") 50% top no-repeat;

  -khtml-opacity: 0.6;
    -moz-opacity: 0.6;
         opacity: 0.6;

	-webkit-transition: opacity 0.5s ease;
					transition: opacity 0.5s ease;

	-webkit-backface-visibility: hidden;
					backface-visibility: hidden;

  -webkit-transform: translateZ(0);
     -moz-transform: translateZ(0);
       -o-transform: translateZ(0);
          transform: translateZ(0);
}

.splash__stamp:hover,
.splash__stamp:focus {
	border-bottom: none;

  -khtml-opacity: 1;
    -moz-opacity: 1;
         opacity: 1;
}

.splash__circles {
	width: 43px;
	height: 30px;
	margin: 0 auto 20px auto;
	background: transparent url("../images/splash-circles.png") 50% top no-repeat;

  -khtml-opacity: 0.6;
    -moz-opacity: 0.6;
         opacity: 0.6;

	-webkit-transition: all 1s ease;
					transition: all 1s ease;
}

.splash__circles:hover {
  -khtml-opacity: 1;
    -moz-opacity: 1;
         opacity: 1;
}

.b-splash h1 {
	padding-bottom: 0.4em;
	font-weight: 400;
}

.splash__about {
	color: #e7e7e7;
	font-size: 1.5em;
	line-height: 1.2em;
	font-weight: 200;
	padding: 20px 0 10px 0;
	margin: 0 auto;
	max-width: 840px;
}

.splash__button {
	margin: 25px 0 20px 0 !important;
}

.splash__next,
.splash__next:visited {
	position: absolute;
	right: 0;
	bottom: 40px;
	left: 0;
	display: block;
	min-width: 220px;
	color: #fff;
	font-size: 1.1em;
	font-weight: 200;
	text-decoration: none;

  -khtml-opacity: 0.6;
    -moz-opacity: 0.6;
         opacity: 0.6;

	-webkit-transition: all 0.5s ease;
					transition: all 0.5s ease;
}

.splash__next:hover,
.splash__next:focus {
	color: #fff;
	border-bottom: none;
	text-decoration: none;

  -khtml-opacity: 1;
    -moz-opacity: 1;
         opacity: 1;
}

.splash__next:focus {
	text-decoration: underline;
}

@media only all and (min-width: 941px) {
	@media only all and (max-height: 790px) {
		.splash__next,
		.splash__next:visited {
	    bottom: 15px;
	  }
	}
	@media only all and (max-height: 720px) {
		.splash__next,
		.splash__next:visited {
	    bottom: 5px;
	  }
	}
	@media only all and (max-height: 660px) {
		.splash__next,
		.splash__next:visited {
	    display: none;
	  }
	}
}

@media only all and (max-width: 940px) {
	.splash__next,
	.splash__next:visited {
    bottom: 15px;
  }
	@media only all and (max-height: 700px) {
		.splash__next,
		.splash__next:visited {
	    display: none;
	  }
	}
}

@media only all and (max-width: 720px) {
	.splash__next,
	.splash__next:visited {
    bottom: 5px;
  }
	@media only all and (max-height: 740px) {
		.splash__next,
		.splash__next:visited {
	    display: none;
	  }
	}
}

/*@media only all and (max-height: 770px) {
	.splash__next,
	.splash__next:visited {
    bottom: 10px;
  }
}

@media only all and (max-height: 720px) {
	.splash__next,
	.splash__next:visited {
    bottom: 15px;
  }
}
*/
@media only all and (max-height: 615px), all and (max-width: 535px) {
	.splash__next,
	.splash__next:visited {
    display: none;
  }
}

/*@media only all and (max-height: 615px), all and (max-width: 535px) {
	.splash__next,
	.splash__next:visited {
    display: none;
  }
}*/

.splash__arrow {
	display: block;
	width: 43px;
	height: 30px;
	margin: 2px auto 0 auto;
	text-decoration: none;

	background: transparent url("../images/splash-arrow-down.png") 50% top no-repeat;
}

.a-blinker {
  -webkit-animation-name: blinker;
  	 -moz-animation-name: blinker;
  				animation-name: blinker;

  -webkit-animation-duration: 2s;
  -webkit-animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: infinite;

  -moz-animation-duration: 2s;
  -moz-animation-timing-function: ease-in-out;
  -moz-animation-iteration-count: infinite;

  animation-duration: 2s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
}

@-moz-keyframes blinker {  
  0% { opacity: 1.0; }
  50% { opacity: 0.6; }
  100% { opacity: 1.0; }
}

@-webkit-keyframes blinker {  
  0% { opacity: 1.0; }
  50% { opacity: 0.6; }
  100% { opacity: 1.0; }
}

@keyframes blinker {  
  0% { opacity: 1.0; }
  50% { opacity: 0.6; }
  100% { opacity: 1.0; }
}

.a-blinker:hover {
  -webkit-animation: none;
  	 -moz-animation: none;
  				animation: none;
}

.a-shaker {
	position: relative;
	top: 0px;

  -webkit-animation-name: shaker;
  	 -moz-animation-name: shaker;
  				animation-name: shaker;

  -webkit-animation-duration: 2s;
  -webkit-animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: infinite;

  -moz-animation-duration: 2s;
  -moz-animation-timing-function: ease-in-out;
  -moz-animation-iteration-count: infinite;

  animation-duration: 2s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
}

@-moz-keyframes shaker {
  0% { top: 7px; }
  50% { top: 0px; }
  100% { top: 7px; }
}

@-webkit-keyframes shaker {  
  0% { top: 7px; }
  50% { top: 0px; }
  100% { top: 7px; }
}

@keyframes shaker {  
  0% { top: 7px; }
  50% { top: 0px; }
  100% { top: 7px; }
}


/* ==========================================================================
   Features & Content
   ========================================================================== */

.b-title {
	color: #fff;
	font-weight: 300;
	padding-bottom: 0.7em;
}

.b-title b {
	font-weight: 400;
}

.b-uptext {
	padding: 15px 0 1em 0;
}

.uptext_white {
	color: #fff;
}

.b-subtext {
	display: block;
	color: #777;
	font-size: 1.15em;
	line-height: 1.1em;
	padding: 0 0 0.5em 0;
}

.subtext_wbg {
	color: rgba(255,255,255,0.5);
}

.splash_subtext {
	max-width: 520px;
	margin: 0 auto;
	line-height: 1.2em;
}

.b-text-block {
	max-width: 820px;
	margin: 0 auto;
	padding: 0 0 2px 0;
	font-size: 1.6em;
	line-height: 1.4em;
	font-weight: 600;
	color: #444;
}

.b-text-block:nth-child(n) {
	padding-bottom: 25px;
}

.b-text-block:last-child {
	padding-bottom: 2px;
}


.b-features {
	list-style-type: none;
	overflow: hidden;
	font-size: 1.15em;
	line-height: 1.2em;
	margin: 0 auto;
}

.features__item {
	display: block;
	display: inline-block;
	width: 25%;
	padding: 30px 0 20px 0;
	vertical-align: top;
	text-align: center;
}

@media only all and (min-width: 720px) {
	.features__item { width: 33%; }
}

@media only all and (min-width: 940px) {
	.features__item { width: 25%; }
}

@media only all and (min-width: 1270px) {
	.features__item { width: 20%; }
}

@media only all and (max-width: 719px) {
	.features__item { width: 50%; }
}

.features_big {
	font-size: 1.5em;
}

.features_big .features__item {
	width: 33%;
}

@media only all and (min-width: 520px) {
	.features_big .features__item { width: 50%; }
}

@media only all and (min-width: 900px) {
	.features_big .features__item { width: 33%; }
}

/*@media only all and (min-width: 1180px) {
	.features_big .features__item { width: 25%; }
}

@media only all and (min-width: 1460px) {
	.features_big .features__item { width: 20%; }
}*/

@media only all and (max-width: 519px) {
	.features_big .features__item { width: 100%; }
}

.features__item img {
	display: block;
	margin: 0 auto 20px auto;
	vertical-align: top;
	border: none;
}

.features__item span {
	display: block;
	display: inline-block;
	padding: 0 10px;
}

@media only all and (min-width: 1200px) {
	.features__item span { padding: 0 15px; }
}

.features_big .features__item span {
	font-weight: 400;
}

.features_big .features__item .features__small {
	display: block;
	font-size: 0.75em;
	font-weight: 300;
}

.features_padafter {
	padding-bottom: 40px;
}

.b-keys {
	padding: 40px 0 30px 0;
	list-style-type: none;
}

.keys__item {
	overflow: hidden;
	padding: 0 0 70px 0;
}

.keys__item:last-child {
	padding-bottom: 0;
}

.keys__about {
	float: left;
	width: 40%;
	padding: 45px 0 0 0;
	text-align: left;
}

.keys__about h3 {
	font-weight: 600;
	margin: 0 40px 0 0;
}

.keys__brief {
	padding: 10px 40px 0 0;
	font-size: 1.5em;
	line-height: 1.4em;
	font-weight: 300;
}

.keys__image {
	float: right;
	width: 60%;
}

.keys__image img {
	width: 100%;
	max-width: 700px;
	vertical-align: top;
	border: none;
}

.keys__item_reverse .keys__about {
	float: right;
	text-align: left;
}

.keys__item_reverse .keys__about h3 {
	margin: 0 0 0 40px;
}
.keys__item_reverse .keys__brief {
	padding: 10px 0 0 40px;
}
.keys__image {
	float: left;
}

@media only all and (max-width: 1400px) {
	.keys__about { padding-top: 30px; width: 45%; }
	.keys__image { width: 55%; }
}

@media only all and (max-width: 1300px) {
	.keys__about { padding-top: 20px; width: 50%; }
	.keys__image { width: 50%; }
}

@media only all and (max-width: 1200px) {
	.keys__about { padding-top: 0; }
}

@media only all and (max-width: 1100px) {
	.b-keys { padding-top: 25px; }
	.keys__brief { padding-top: 5px; }
	.keys__about { padding-top: 0px; width: 100%; }
	.keys__image { padding-top: 25px; width: 100%; text-align: left; }
}


.b-reviews {

}

.reviews__box {
	display: block;
	list-style-type: none;
	margin: 0 6%;
	vertical-align: top;
}

.reviews__arrow {
	display: block;
	float: left;
	position: absolute;
	z-index: 100;
	top: 0;
	bottom: 0;
	left: 5%;
	width: 5%;
	min-height: 45px;
	vertical-align: middle;
	background-color: #f2f2f2;
}

.reviews__arrow_right {
	float: right;
	left: auto;
	right: 5%;
}

@media only all and (max-width: 700px) {
	.reviews__arrow { left: 3%; }
	.reviews__arrow_right { left: auto; right: 3%; }
}

@media only all and (min-width: 1650px) {
	.reviews__arrow { left: 9%; }
	.reviews__arrow_right { left: auto; right: 9%; }
}

@media only all and (min-width: 1900px) {
	.reviews__arrow { left: 14%; }
	.reviews__arrow_right { left: auto; right: 14%; }
}

.reviews__arrow i {
	display: block;
	display: inline-block;
	width: 21px;
	height: 45px;
	position: absolute;
	top: 45%;
	left: 25%;
	vertical-align: middle;
	background: #ccc url("../images/review-arrow-left.png") left 50% no-repeat;
}

.reviews__arrow:focus i {
	background-color: #999;
}

.reviews__arrow:hover i {
	background-color: #30b7f4;
}

.reviews__arrow_right i {
	left: auto;
	right: 25%;
	background: #ccc url("../images/review-arrow-right.png") right 50% no-repeat;
}

.b-review {
	position: relative;
	overflow: hidden;
	text-align: center;
}

.review__image {
	height: 144px;
}

.review__mask {
	position: absolute;
	z-index: 100;
	left: 0;
	right: 0;
	width: 144px;
	height: 144px;
	margin: 0 auto;
	background: transparent url("../images/review-photomask.png") 50% 50% no-repeat;
}

.review__photo {
	display: block;
	position: absolute;
	z-index: 99;
	left: 0;
	right: 0;
	width: 144px;
	height: 144px;
	margin: 0 auto;
	border: none;
	vertical-align: top;
}

.review__full {
	position: relative;
	z-index: 101;
	display: none;
	float: left;
	padding: 30px;
	margin: 0 auto;
	line-height: 1.2em;
	background-color: #fff;
}

.review__quote {
	display: inline-block;
	margin: 15px 0 0 0;
}

.review__quote h3,
.review__quote:visited h3 {
	color: #0e96db;
	padding-bottom: 0.4em;
}

.review__quote:focus h3 {
	text-decoration: underline;
}

.review__quote:hover h3 {
	color: #669b11;
}

.review__sign {
	font-weight: 300;
	margin: 0;
	padding: 0;
}

.review__sign span {
	color: #777;
}

.b-prices {
	list-style-type: none;
}

.prices__item {
	display: block;
	display: inline-block;
	width: 25%;
	padding: 40px 0 20px 0;
	vertical-align: bottom;
}

@media only all and (max-width: 1290px) {
	.prices__item { width: 33%; }
}

@media only all and (max-width: 970px) {
	.prices__item { width: 50%; }
}

@media only all and (max-width: 660px) {
	.prices__item { width: 100%; }
}

.prices__item h3 {
	padding: 1em 0 0 0;
}

.prices__cost {
	font-size: 3em;
	font-weight: 300;
	color: #777;
}

.prices__cost a:visited {
	color: #0e96db;
}

.prices__cost a:hover {
	color: #669b11;
}

.prices__nocost {
	color: #777;
}

.prices__cost span {
	font-size: 0.5em;
	font-weight: 300;
}

.prices__note {
	display: block;
	color: #0e96db;
	padding: 1em 0 0 0;
}

.prices__button {
	padding: 2.4em 0 1em 0;
}

.b-footer {

}

.b-footer h3 {
	padding: 0 0 1em 0;
}

.footer__delim {
	margin: 0 1em;
	color: #999;
}

@media only all and (max-width: 570px) {
	.footer__delim { display: block; }
}

.footer__delim_sep {
	margin: 0 5px 0 0;
}

.footer__delim_line {
	display: block;
	padding: 0;
	margin: 0;
	height: 7px;
	line-height: 7px;
	visibility: hidden;
}

.footer__logo {
	display: block;
	width: 220px;
	height: 94px;
	margin: -25px auto 1em auto;

	background: transparent url("../images/logo.png") 50% top no-repeat;

	-webkit-transition: background-image 0.5s ease;
					transition: background-image 0.5s ease;

	-webkit-backface-visibility: hidden;
					backface-visibility: hidden;

  -webkit-transform: translateZ(0);
     -moz-transform: translateZ(0);
       -o-transform: translateZ(0);
          transform: translateZ(0);
}

.footer__logo:hover,
.footer__logo:focus {
	border-bottom: none;
	background-image: url("../images/logo-hover.png");
}

/* ==========================================================================
   Form Elements
   ========================================================================== */

.b-form {
	
}

.js-offer-accept {
  display: block;
  width: 16px;
  height: 16px;
  margin: 0 0 -16px 0;
  position: relative;
  left: -200px;
}

.form-item_rightpad {
	margin-right: 15px !important;
}

@media only all and (max-width: 650px) {
	.form-item_rightpad { margin-right: 0 !important; }
}

.b-form .b-button,
.b-form .b-text {
	margin-bottom: 0.7em;
}

.b-button,
.b-button:visited,
.b-text {
	display: block;
	display: inline-block;
	border: none;
	height: 31px;
	margin: 0;
	padding: 19px 30px 0 30px;
	color: #fff;
	font-size: 1.5em;
	font-weight: 300;
	text-decoration: none !important;
	vertical-align: top;

	background-color: #30b7f4;

	text-shadow: 0 1px 1px rgba(0,0,0, 0.2);

  -webkit-border-radius: 25px;
     -moz-border-radius: 25px;
          border-radius: 25px;

  -webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, 0.2);
     -moz-box-shadow: 0 1px 1px rgba(0, 0, 0, 0.2);
          box-shadow: 0 1px 1px rgba(0, 0, 0, 0.2);

  background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, rgba(0,0,0,0)), color-stop(100%, rgba(0,0,0,0.2))); /* Chrome,Safari4+ */
  background-image: -webkit-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0.2) 100%); /* Chrome10+,Safari5.1+ */
  background-image:    -moz-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0.2) 100%); /* FF3.6+ */
  background-image:     -ms-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0.2) 100%); /* IE10+ */
  background-image:      -o-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0.2) 100%); /* Opera 11.10+ */
  background-image:         linear-gradient(to bottom, rgba(0,0,0,0) 0%, rgba(0,0,0,0.2) 100%); /* W3C */

	-webkit-transition: background 0.5s ease, color 0.5s ease, border-color 0.5s ease;
					transition: background 0.5s ease, color 0.5s ease, border-color 0.5s ease;
}

button.b-button {
	height: 50px;
	padding-top: 0px;
	line-height: 52px;
}

.b-button:focus {
	outline: none;
	border-bottom: none;
	background-color: #42c4ff;
}

.b-button:hover {
	background-color: #76b414;
}

.b-button:active {
	background-color: #1497d2;
}

.button_flat,
.button_flat:visited,
.button_ghost,
.button_ghost:visited {
	height: 28px;
	padding-top: 14px;
	color: #42c4ff;
	font-size: 1.1em;
	background: none;

	border: 1px solid #30b7f4;

	/*text-shadow: 0 1px 1px rgba(0,0,0, 0.2);*/

  -webkit-border-radius: 22px;
     -moz-border-radius: 22px;
          border-radius: 22px;

  -webkit-box-shadow: none;
     -moz-box-shadow: none;
          box-shadow: none;
}

.button_ghost.button_dark,
.button_ghost.button_dark:visited {
	color: #30b7f4;
}

.button_flat {
	color: #fff;
	background-color: #30b7f4;
}

.button_ghost:focus,
.button_ghost:hover {
	color: #fff;
	background: none;
	background-color: #30b7f4;
	border-color: #30b7f4;
}

.button_flat:focus,
.button_flat:hover {
	color: #fff;
	border-color: #76b414;
	background-color: #76b414;
}

.button_ghost:active {
  -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,0.24);
     -moz-box-shadow: inset 0 1px 1px rgba(0,0,0,0.24);
          box-shadow: inset 0 1px 1px rgba(0,0,0,0.24);
}

.button_ghost.button_invert,
.button_ghost.button_invert:visited {
	color: #8dd718;
	border: 1px solid #76b414;
}

.button_flat.button_invert,
.button_flat.button_invert:visited {
	color: #fff;
	border-color: #76b414;
	background-color: #76b414;
}

.button_ghost.button_invert:focus,
.button_ghost.button_invert:hover {
	color: #fff;
	background-color: #76b414;
	border-color: #76b414;
	text-shadow: 0 1px 1px rgba(0,0,0,0.4);
}

.button_flat.button_invert:focus,
.button_flat.button_invert:hover {
	color: #fff;
	background-color: #30b7f4;
	border-color: #30b7f4;
}

.button_ghost.button_white,
.button_ghost.button_white:visited {
	color: #fff;
	border: 1px solid rgba(255,255,255,0.8);
}

.button_ghost.button_white:focus {
	color: #fff;
	border: 1px solid #fff;
	background-color: rgba(255,255,255,0.14);
}

.button_ghost.button_white:hover {
	color: #333;
	background-color: rgba(255,255,255,0.9);
	border-color: rgba(255,255,255,0.9);
}

.button_ghost.button_red,
.button_ghost.button_red:visited {
	color: rgba(255,85,62,1);
	border: 1px solid rgba(255,85,62,0.8);
}

.button_ghost.button_red:focus {
	color: rgba(255,85,62,1);
	border: 1px solid rgba(255,85,62,1);
	background-color: rgba(255,255,255,0.14);
}

.button_ghost.button_red:hover {
	color: #fff;
	background-color: rgba(255, 85, 62, 0.75);
	border-color: rgba(255, 85, 62, 0.75);
}

.button_flat.button_red,
.button_flat.button_red:visited {
	color: #fff;
	border: 1px solid rgba(255, 85, 62, 0.75);
	background-color: rgba(255, 85, 62, 0.75);
}

.button_flat.button_red:focus {
	border: 1px solid rgba(255,85,62, 0.95);
	background-color: rgba(255, 85, 62, 0.95)
}

.button_flat.button_red:hover {
	color: #fff;
	border: 1px solid rgba(255,85,62, 1);
	background-color: rgba(255, 85, 62, 1)
}

.button_circle {
	width: 44px;
	padding-left: 0;
	padding-right: 0;
	text-align: center;
}

button.button_ghost,
button.button_ghost:visited {
	height: 44px;
	padding-top: 0;
	line-height: 44px;
	text-shadow: none;
}


.button_disabled,
.button_disabled:visited,
.button_disabled:hover,
.button_disabled:focus,
.button_disabled:active {
	background: #eee !important;
	color: #999 !important;
	border-color: #ccc !important;
	cursor: default !important;

	text-shadow: none !important;

  -webkit-box-shadow: none !important;
     -moz-box-shadow: none !important;
          box-shadow: none !important;

  -webkit-animation-name: none;
  	 -moz-animation-name: none;
  				animation-name: none;
}

.b-text {
	border: 1px solid #ccc;
	height: 48px;
	padding-top: 0;
	color: #333;
	line-height: 52px;
	background-color: #fff;

	text-shadow: none;

  -webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.09);
     -moz-box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.09);
          box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.09);

  background-image: none;

	-webkit-transition: border-color 0.5s ease, box-shadow 0.5s ease;
					transition: border-color 0.5s ease, box-shadow 0.5s ease;
}

.b-text:focus,
.b-text:active {
	outline: none;
	border-color: #aaa;
	
  -webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.14);
     -moz-box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.14);
          box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.14);
}

.b-select {
	display: block;
	display: inline-block;
	border: 1px solid rgba(0,0,0,0.4);
	height: 36px;
	line-height: 40px !important;
	min-width: 100px;
	padding: 2px 7px 0 7px;
	color: #333;
	font-size: 1.15em;
	font-weight: 300;
	vertical-align: middle;
	position: relative;
	top: 4px;
	background-color: rgba(255,255,255,0);
}

.b-text-ghost {
	display: block;
	display: inline-block;
	border: none;
	border-radius: 0;
	border-bottom: 1px solid rgba(255,255,255,0.4);
	height: 43px;
	line-height: 44px;
	min-width: 100px;
	padding: 0 10px;
	color: #fff;
	font-size: 1.15em;
	font-weight: 300;
	vertical-align: middle;
	background-color: rgba(255,255,255,0);

  -webkit-appearance: none;

	-webkit-transition: border-color 0.5s ease;
					transition: border-color 0.5s ease;
}

textarea.b-text-ghost {
	line-height: 1.2em;
	resize: vertical !important;
}

.b-text-ghost::-webkit-input-placeholder { color: #aaa; }
.b-text-ghost:-moz-placeholder { color: #aaa; }
.b-text-ghost::-moz-placeholder { color: #aaa; }
.b-text-ghost:-ms-input-placeholder { color: #aaa; }

.b-text-ghost:hover {
	border-bottom-color: rgba(255,255,255,1);
}

.b-text-ghost:focus,
.b-text-ghost:active {
	color: #fff;
	outline: none;
	border-color: rgba(255,255,255,1);
}

.b-text-ghost:focus:valid {
	border-color: #76b414 !important;
}

.text-ghost_dark {
	border-bottom: 1px solid rgba(0,0,0,0.4);
	color: #333;
}

.text-ghost_dark:hover {
	border-bottom-color: rgba(0,0,0,0.7);
}

.text-ghost_dark:focus,
.text-ghost_dark:active {
	color: #333;
	outline: none;
	border-color: rgba(0,0,0,0.7);
}

.textarea_full {
	width: 90%;
}

.form__column {
	width: 340px;
	width: 25vw;
	text-align: center;
	margin: 0 auto;
}

@media only all and (max-width: 1200px) {
	.form__column  { width: 30vw; }
}
@media only all and (max-width: 940px) {
	.form__column  { width: 35vw; }
}
@media only all and (max-width: 780px) {
	.form__column  { width: 45vw; }
}
@media only all and (max-width: 600px) {
	.form__column  { width: 60%; }
}
@media only all and (max-width: 300px) {
	.form__column  { width: 80%; }
}

.form__column .b-text-ghost {
	width: 90%;
	margin: 0 0 30px 0;
}

.form__column .b-button {
	min-width: 70%;
	margin: 0 0 40px 0;
	position: relative;
	top: 20px;
}

.b-sublinks {
	display: block;
	overflow: hidden;
}

.b-message {
	padding: 15px;
	text-align: center;
	background-color: rgba(255,255,255,0.2);
	margin: 0 0 20px 0;
	color: #fff;
	line-height: 120%;

  -webkit-border-radius: 5px;
     -moz-border-radius: 5px;
          border-radius: 5px;
}

.message_success {
	color: #669b11;
}

.message_error {
	color: #b10000;
}

/* ==========================================================================
   Global Modifiers
   ========================================================================== */

a.m-splash,
a.m-splash:visited {
	color: #fff;
}

a.m-splash:hover {
	color: #42c4ff;
}

a.m-splash_invert:hover {
	color: #8dd718;
}

.m-size__wide {
	width: 300px;
}
