/* =================================================================== */
/*
/*  CMM v1.0 Stylesheet
/*  2016-12-06
/*
/* =================================================================== */
/* =================================================================== */
/*
/*  KREO v1.0 Base Stylesheet
/*  url: styleshout.com
/*  10-12-2015
/*
/* =================================================================== */
/* 
/* Reset - normalize.css v3.0.1 | MIT License | git.io/normalize 
/* =================================================================== */
@import url("./fonts.css");
@import url("./font-awesome/css/font-awesome.min.css");
html {
  font-family: sans-serif;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%; }

body {
  margin: 0; }

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
summary {
  display: block; }

audio,
canvas,
progress,
video {
  display: inline-block;
  vertical-align: baseline; }

audio:not([controls]) {
  display: none;
  height: 0; }

[hidden],
template {
  display: none; }

a {
  background: transparent; }

a:active,
a:hover {
  outline: 0; }

abbr[title] {
  border-bottom: 1px dotted; }

b,
strong {
  font-weight: bold; }

dfn {
  font-style: italic; }

h1 {
  font-size: 2em;
  margin: 0.67em 0; }

mark {
  background: #ff0;
  color: #000; }

small {
  font-size: 80%; }

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sup {
  top: -0.5em; }

sub {
  bottom: -0.25em; }

img {
  border: 0; }

svg:not(:root) {
  overflow: hidden; }

figure {
  margin: 1em 40px; }

hr {
  -moz-box-sizing: content-box;
  box-sizing: content-box;
  height: 0; }

pre {
  overflow: auto; }

code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em; }

button,
input,
optgroup,
select,
textarea {
  color: inherit;
  font: inherit;
  margin: 0; }

button {
  overflow: visible; }

button,
select {
  text-transform: none; }

button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  cursor: pointer; }

button[disabled],
html input[disabled] {
  cursor: default; }

button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0; }

input {
  line-height: normal; }

input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  padding: 0; }

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto; }

input[type="search"] {
  -webkit-appearance: textfield;
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  box-sizing: content-box; }

input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em; }

legend {
  border: 0;
  padding: 0; }

textarea {
  overflow: auto; }

optgroup {
  font-weight: bold; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

td,
th {
  padding: 0; }

/*
/* Basic Setup Styles - Top Elements 
/* =================================================================== */
/* NOTE
html is set to 62.5% so that if you use REMS, all the measurements 
are based on 10px sizing. So basically 1.5rem = 15px  */
html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: 62.5%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box; }

html,
body {
  height: 100%; }

*,
*:before,
*:after {
  box-sizing: inherit; }

body {
  font-weight: normal;
  line-height: 1;
  text-rendering: optimizeLegibility; }

/*
/* Typography 
====================================================================== */
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
form,
p,
blockquote,
th,
td {
  margin: 0;
  padding: 0; }

h1,
h2,
h3,
h4,
h5,
h6 {
  text-rendering: optimizeLegibility;
  line-height: 1.2; }

hr {
  border: solid #ddd;
  border-width: 1px 0 0;
  clear: both;
  margin: 11px 0 24px;
  height: 0; }

em,
i {
  font-style: italic;
  line-height: inherit; }

strong,
b {
  font-weight: bold;
  line-height: inherit; }

small {
  font-size: 60%;
  line-height: inherit; }

ul {
  list-style: none; }

ol {
  list-style: decimal; }

ol,
ul.square,
ul.circle,
ul.disc {
  margin-left: 17px; }

ul.square {
  list-style: square; }

ul.circle {
  list-style: circle; }

ul.disc {
  list-style: disc; }

ul li {
  padding-left: 4px; }

ul ul,
ul ol,
ol ol,
ol ul {
  margin: 3px 0 3px 17px; }

/* links
---------------------------------------------------------------------- */
a {
  text-decoration: none;
  line-height: inherit; }

a img {
  border: none; }

a:focus {
  outline: none; }

p a,
p a:visited {
  line-height: inherit; }

/* 
/* Media 
/* =================================================================== */
img,
video,
embed,
object {
  max-width: 100%;
  height: auto; }

object,
embed {
  height: 100%; }

img {
  -ms-interpolation-mode: bicubic; }

/* 
/* Grid
===================================================================== */
.row {
  width: 90%;
  max-width: 1140px;
  margin: 0 auto; }

.row .row {
  width: auto;
  max-width: none;
  margin-left: -20px;
  margin-right: -20px; }

.row:before,
.row:after {
  content: "";
  display: table; }

.row:after {
  clear: both; }

.column,
.columns,
.bgrid {
  position: relative;
  min-height: 1px;
  float: left; }

.column,
.columns {
  padding: 0 20px; }

.column.centered,
.columns.centered {
  float: none;
  margin: 0 auto; }

.row.collapsed > .column,
.row.collapsed > .columns,
.column.collapsed,
.columns.collapsed {
  padding: 0; }

[class*="column"] + [class*="column"]:last-child {
  float: right; }

[class*="column"] + [class*="column"].end {
  float: right; }

.one,
.row .one {
  width: 8.33333%; }

.two,
.row .two {
  width: 16.66667%; }

.three,
.row .three {
  width: 25%; }

.four,
.row .four {
  width: 33.33333%; }

.five,
.row .five {
  width: 41.66667%; }

.six,
.row .six {
  width: 50%; }

.seven,
.row .seven {
  width: 58.33333%; }

.eight,
.row .eight {
  width: 66.66667%; }

.nine,
.row .nine {
  width: 75%; }

.ten .row .ten {
  width: 83.33333%; }

.eleven,
.row .eleven {
  width: 91.66667%; }

.twelve,
.row .twelve {
  width: 100%; }

/* small screens
--------------------------------------------------------------- */
@media screen and (max-width: 1024px) {
  .row .row {
    margin-left: -18px;
    margin-right: -18px; }

  .column,
  .columns {
    padding: 0 18px; } }
/* tablets
--------------------------------------------------------------- */
@media screen and (max-width: 768px) {
  .row {
    width: auto;
    padding-left: 30px;
    padding-right: 30px; }

  .row .row {
    padding-left: 0;
    padding-right: 0;
    margin-left: -15px;
    margin-right: -15px; }

  .column,
  .columns {
    padding: 0 15px; }

  .tab-fourth,
  .row .tab-fourth {
    width: 25%; }

  .tab-third,
  .row .tab-third {
    width: 33.33333%; }

  .tab-half,
  .row .tab-half {
    width: 50%; }

  .tab-2thirds,
  .row .tab-2thirds {
    width: 66.66667%; }

  .tab-3fourths,
  .row .tab-3fourths {
    width: 75%; }

  .tab-whole,
  .row .tab-whole {
    width: 100%; } }
/* large mobile devices
--------------------------------------------------------------- */
@media screen and (max-width: 600px) {
  .row {
    padding-left: 25px;
    padding-right: 25px; }

  .row .row {
    margin-left: -10px;
    margin-right: -10px; }

  .column,
  .columns {
    padding: 0 10px; }

  .mob-fourth,
  .row .mob-fourth {
    width: 25%; }

  .mob-half,
  .row .mob-half {
    width: 50%; }

  .mob-3fourths,
  .row .mob-3fourths {
    width: 75%; }

  .mob-whole,
  .row .mob-whole {
    width: 100%; } }
/* small mobile devices
--------------------------------------------------------------- */
@media screen and (max-width: 400px) {
  .row {
    padding-left: 30px;
    padding-right: 30px; }

  .row .row {
    padding-left: 0;
    padding-right: 0;
    margin-left: 0;
    margin-right: 0; }

  .column,
  .columns {
    width: auto !important;
    float: none !important;
    margin-left: 0;
    margin-right: 0;
    clear: both;
    padding: 0; }

  [class*="column"] + [class*="column"]:last-child {
    float: none; } }
/* 
/* block grids
===================================================================== */
.bgrid-sixth .bgrid {
  width: 16.66667%; }

.bgrid-fourth .bgrid {
  width: 25%; }

.bgrid-third .bgrid {
  width: 33.33333%; }

.bgrid-half .bgrid {
  width: 50%; }

.bgrid {
  padding: 0; }

/* Clearing for block grid columns. Allows columns with 
different heights to align properly.
--------------------------------------------------------------------- */
.bgrid-sixth .bgrid:nth-child(6n+1),
.bgrid-fourth .bgrid:nth-child(4n+1),
.bgrid-third .bgrid:nth-child(3n+1),
.bgrid-half .bgrid:nth-child(2n+1) {
  clear: both; }

/* small screens
--------------------------------------------------------------- */
@media screen and (max-width: 1024px) {
  /* block grids for small screens */
  .s-bgrid-sixth .bgrid {
    width: 16.66667%; }

  .s-bgrid-fourth .bgrid {
    width: 25%; }

  .s-bgrid-third .bgrid {
    width: 33.33333%; }

  .s-bgrid-half .bgrid {
    width: 50%; }

  .s-bgrid-whole .bgrid {
    width: 100%;
    clear: both; }

  [class*="bgrid-"] .bgrid:nth-child(n) {
    clear: none; }

  .s-bgrid-sixth .bgrid:nth-child(6n+1),
  .s-bgrid-fourth .bgrid:nth-child(4n+1),
  .s-bgrid-third .bgrid:nth-child(3n+1),
  .s-bgrid-half .bgrid:nth-child(2n+1) {
    clear: both; } }
/* tablets
--------------------------------------------------------------- */
@media screen and (max-width: 768px) {
  .tab-bgrid-sixth .bgrid {
    width: 16.66667%; }

  .tab-bgrid-fourth .bgrid {
    width: 25%; }

  .tab-bgrid-third .bgrid {
    width: 33.33333%; }

  .tab-bgrid-half .bgrid {
    width: 50%; }

  .tab-bgrid-whole .bgrid {
    width: 100%;
    clear: both; }

  [class*="tab-bgrid-"] .bgrid:nth-child(n) {
    clear: none; }

  .tab-bgrid-sixth .bgrid:nth-child(6n+1),
  .tab-bgrid-fourth .bgrid:nth-child(4n+1),
  .tab-bgrid-third .bgrid:nth-child(3n+1),
  .tab-bgrid-half .bgrid:nth-child(2n+1) {
    clear: both; } }
/* mobile devices
--------------------------------------------------------------- */
@media screen and (max-width: 600px) {
  .mob-bgrid-sixth .bgrid {
    width: 16.66667%; }

  .mob-bgrid-fourth .bgrid {
    width: 25%; }

  .mob-bgrid-third .bgrid {
    width: 33.33333%; }

  .mob-bgrid-half .bgrid {
    width: 50%; }

  .mob-bgrid-whole .bgrid {
    width: 100%;
    clear: both; }

  [class*="mob-bgrid-"] .bgrid:nth-child(n) {
    clear: none; }

  .mob-bgrid-sixth .bgrid:nth-child(6n+1),
  .mob-bgrid-fourth .bgrid:nth-child(4n+1),
  .mob-bgrid-third .bgrid:nth-child(3n+1),
  .mob-bgrid-half .bgrid:nth-child(2n+1) {
    clear: both; } }
/* stack on small mobile devices
--------------------------------------------------------------- */
@media screen and (max-width: 400px) {
  .stack .bgrid {
    width: auto !important;
    float: none !important;
    margin-left: 0;
    margin-right: 0;
    clear: both; } }
/* 
/* MISC
===================================================================== */
/* Clearing - (http://nicolasgallagher.com/micro-clearfix-hack/
--------------------------------------------------------------------- */
.group:before,
.group:after {
  content: "";
  display: table; }

.group:after {
  clear: both; }

/* Misc Helper Styles 
--------------------------------------------------------------------- */
.hide {
  display: none; }

.invisible {
  visibility: hidden; }

.antialiased {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale; }

.remove-bottom {
  margin-bottom: 0; }

.half-bottom {
  margin-bottom: 15px !important; }

.add-bottom {
  margin-bottom: 30px !important; }

.no-border {
  border: none; }

.text-center {
  text-align: center; }

.text-left {
  text-align: left; }

.text-right {
  text-align: right; }

.pull-left {
  float: left; }

.pull-right {
  float: right; }

.align-center {
  margin-left: auto;
  margin-right: auto;
  text-align: center; }

/* =================================================================== */
/*
/*  KREO 1.0 | Vendor/Third Party CSS 
/*  url: styleshout.com
/*  10-12-2015
/*
/* =================================================================== */
/**
 * jQuery FlexSlider v2.5.0
 * http://www.woothemes.com/flexslider/
 *
 * Copyright 2012 WooThemes
 * Free to use under the GPLv2 and later license.
 * http://www.gnu.org/licenses/gpl-2.0.html
 *
 * Contributing author: Tyler Smith (@mbmufffin)
 * 
 */
.flex-container a:hover, .flex-slider a:hover, .flex-container a:focus, .flex-slider a:focus {
  outline: none; }

.slides, .slides > li, .flex-control-nav, .flex-direction-nav {
  margin: 0;
  padding: 0;
  list-style: none; }

.flex-pauseplay span {
  text-transform: capitalize; }

.flexslider {
  margin: 0;
  padding: 0; }

.flexslider .slides > li {
  display: none;
  -webkit-backface-visibility: hidden; }

.flexslider .slides img {
  width: 100%;
  display: block; }

.flexslider .slides:after {
  content: "\0020";
  display: block;
  clear: both;
  visibility: hidden;
  line-height: 0;
  height: 0; }

html[xmlns] .flexslider .slides {
  display: block; }

* html .flexslider .slides {
  height: 1%; }

.no-js .flexslider .slides > li:first-child {
  display: block; }

/**
 *
 * Magnific Popup - v1.0.0 - 2015-09-17
 * http://dimsemenov.com/plugins/magnific-popup/
 * Copyright (c) 2015 Dmitry Semenov;
 * 
 */
.mfp-bg {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1042;
  overflow: hidden;
  position: fixed;
  background: #0b0b0b;
  opacity: 0.8;
  filter: alpha(opacity=80); }

.mfp-wrap {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1043;
  position: fixed;
  outline: none !important;
  -webkit-backface-visibility: hidden; }

.mfp-container {
  text-align: center;
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  padding: 0 8px;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box; }

.mfp-container:before {
  content: '';
  display: inline-block;
  height: 100%;
  vertical-align: middle; }

.mfp-align-top .mfp-container:before {
  display: none; }

.mfp-content {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  margin: 0 auto;
  text-align: left;
  z-index: 1045; }

.mfp-inline-holder .mfp-content, .mfp-ajax-holder .mfp-content {
  width: 100%;
  cursor: auto; }

.mfp-ajax-cur {
  cursor: progress; }

.mfp-zoom-out-cur, .mfp-zoom-out-cur .mfp-image-holder .mfp-close {
  cursor: -moz-zoom-out;
  cursor: -webkit-zoom-out;
  cursor: zoom-out; }

.mfp-zoom {
  cursor: pointer;
  cursor: -webkit-zoom-in;
  cursor: -moz-zoom-in;
  cursor: zoom-in; }

.mfp-auto-cursor .mfp-content {
  cursor: auto; }

.mfp-close, .mfp-arrow, .mfp-preloader, .mfp-counter {
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none; }

.mfp-loading.mfp-figure {
  display: none; }

.mfp-hide {
  display: none !important; }

.mfp-preloader {
  color: #CCC;
  position: absolute;
  top: 50%;
  width: auto;
  text-align: center;
  margin-top: -0.8em;
  left: 8px;
  right: 8px;
  z-index: 1044; }

.mfp-preloader a {
  color: #CCC; }

.mfp-preloader a:hover {
  color: #FFF; }

.mfp-s-ready .mfp-preloader {
  display: none; }

.mfp-s-error .mfp-content {
  display: none; }

button.mfp-close, button.mfp-arrow {
  overflow: visible;
  cursor: pointer;
  background: transparent;
  border: 0;
  -webkit-appearance: none;
  display: block;
  outline: none;
  padding: 0;
  z-index: 1046;
  -webkit-box-shadow: none;
  box-shadow: none; }

button::-moz-focus-inner {
  padding: 0;
  border: 0; }

.mfp-close {
  width: 44px;
  height: 44px;
  line-height: 44px;
  position: absolute;
  right: 0;
  top: 0;
  text-decoration: none;
  text-align: center;
  opacity: 0.65;
  filter: alpha(opacity=65);
  padding: 0 0 18px 10px;
  color: #FFF;
  font-style: normal;
  font-size: 28px;
  font-family: Arial,Baskerville,monospace; }

.mfp-close:hover, .mfp-close:focus {
  opacity: 1;
  filter: alpha(opacity=100); }

.mfp-close:active {
  top: 1px; }

.mfp-close-btn-in .mfp-close {
  color: #333; }

.mfp-image-holder .mfp-close, .mfp-iframe-holder .mfp-close {
  color: #FFF;
  right: -6px;
  text-align: right;
  padding-right: 6px;
  width: 100%; }

.mfp-counter {
  position: absolute;
  top: 0;
  right: 0;
  color: #CCC;
  font-size: 12px;
  line-height: 18px;
  white-space: nowrap; }

.mfp-arrow {
  position: absolute;
  opacity: 0.65;
  filter: alpha(opacity=65);
  margin: 0;
  top: 50%;
  margin-top: -55px;
  padding: 0;
  width: 90px;
  height: 110px;
  -webkit-tap-highlight-color: transparent; }

.mfp-arrow:active {
  margin-top: -54px; }

.mfp-arrow:hover, .mfp-arrow:focus {
  opacity: 1;
  filter: alpha(opacity=100); }

.mfp-arrow:before, .mfp-arrow:after, .mfp-arrow .mfp-b, .mfp-arrow .mfp-a {
  content: '';
  display: block;
  width: 0;
  height: 0;
  position: absolute;
  left: 0;
  top: 0;
  margin-top: 35px;
  margin-left: 35px;
  border: medium inset transparent; }

.mfp-arrow:after, .mfp-arrow .mfp-a {
  border-top-width: 13px;
  border-bottom-width: 13px;
  top: 8px; }

.mfp-arrow:before, .mfp-arrow .mfp-b {
  border-top-width: 21px;
  border-bottom-width: 21px;
  opacity: 0.7; }

.mfp-arrow-left {
  left: 0; }

.mfp-arrow-left:after, .mfp-arrow-left .mfp-a {
  border-right: 17px solid #FFF;
  margin-left: 31px; }

.mfp-arrow-left:before, .mfp-arrow-left .mfp-b {
  margin-left: 25px;
  border-right: 27px solid #3F3F3F; }

.mfp-arrow-right {
  right: 0; }

.mfp-arrow-right:after, .mfp-arrow-right .mfp-a {
  border-left: 17px solid #FFF;
  margin-left: 39px; }

.mfp-arrow-right:before, .mfp-arrow-right .mfp-b {
  border-left: 27px solid #3F3F3F; }

.mfp-iframe-holder {
  padding-top: 40px;
  padding-bottom: 40px; }

.mfp-iframe-holder .mfp-content {
  line-height: 0;
  width: 100%;
  max-width: 900px; }

.mfp-iframe-holder .mfp-close {
  top: -40px; }

.mfp-iframe-scaler {
  width: 100%;
  height: 0;
  overflow: hidden;
  padding-top: 56.25%; }

.mfp-iframe-scaler iframe {
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
  background: #000; }

img.mfp-img {
  width: auto;
  max-width: 100%;
  height: auto;
  display: block;
  line-height: 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  padding: 40px 0 40px;
  margin: 0 auto; }

.mfp-figure {
  line-height: 0; }

.mfp-figure:after {
  content: '';
  position: absolute;
  left: 0;
  top: 40px;
  bottom: 40px;
  display: block;
  right: 0;
  width: auto;
  height: auto;
  z-index: -1;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
  background: #444; }

.mfp-figure small {
  color: #BDBDBD;
  display: block;
  font-size: 12px;
  line-height: 14px; }

.mfp-figure figure {
  margin: 0; }

.mfp-bottom-bar {
  margin-top: -36px;
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  cursor: auto; }

.mfp-title {
  text-align: left;
  line-height: 18px;
  color: #F3F3F3;
  word-wrap: break-word;
  padding-right: 36px; }

.mfp-image-holder .mfp-content {
  max-width: 100%; }

.mfp-gallery .mfp-image-holder .mfp-figure {
  cursor: pointer; }

@media screen and (max-width: 800px) and (orientation: landscape), screen and (max-height: 300px) {
  .mfp-img-mobile .mfp-image-holder {
    padding-left: 0;
    padding-right: 0; }

  .mfp-img-mobile img.mfp-img {
    padding: 0; }

  .mfp-img-mobile .mfp-figure:after {
    top: 0;
    bottom: 0; }

  .mfp-img-mobile .mfp-figure small {
    display: inline;
    margin-left: 5px; }

  .mfp-img-mobile .mfp-bottom-bar {
    background: rgba(0, 0, 0, 0.6);
    bottom: 0;
    margin: 0;
    top: auto;
    padding: 3px 5px;
    position: fixed;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box; }

  .mfp-img-mobile .mfp-bottom-bar:empty {
    padding: 0; }

  .mfp-img-mobile .mfp-counter {
    right: 5px;
    top: 3px; }

  .mfp-img-mobile .mfp-close {
    top: 0;
    right: 0;
    width: 35px;
    height: 35px;
    line-height: 35px;
    background: rgba(0, 0, 0, 0.6);
    position: fixed;
    text-align: center;
    padding: 0; } }
@media all and (max-width: 900px) {
  .mfp-arrow {
    -webkit-transform: scale(0.75);
    transform: scale(0.75); }

  .mfp-arrow-left {
    -webkit-transform-origin: 0;
    transform-origin: 0; }

  .mfp-arrow-right {
    -webkit-transform-origin: 100%;
    transform-origin: 100%; }

  .mfp-container {
    padding-left: 6px;
    padding-right: 6px; } }
.mfp-ie7 .mfp-img {
  padding: 0; }

.mfp-ie7 .mfp-bottom-bar {
  width: 600px;
  left: 50%;
  margin-left: -300px;
  margin-top: 5px;
  padding-bottom: 5px; }

.mfp-ie7 .mfp-container {
  padding: 0; }

.mfp-ie7 .mfp-content {
  padding-top: 44px; }

.mfp-ie7 .mfp-close {
  top: 0;
  right: 0;
  padding-top: 0; }

/**
 *
 * Animate.css - http://daneden.me/animate
 * Licensed under the MIT license - http://opensource.org/licenses/MIT
 *
 * Copyright (c) 2015 Daniel Eden
 *
 */
.animated {
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both; }

.animated.infinite {
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite; }

.animated.hinge {
  -webkit-animation-duration: 2s;
  animation-duration: 2s; }

.animated.bounceIn, .animated.bounceOut, .animated.flipOutX, .animated.flipOutY {
  -webkit-animation-duration: .75s;
  animation-duration: .75s; }

@-webkit-keyframes bounce {
  20%,53%,80%,from,to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }
  40%,43% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    -webkit-transform: translate3d(0, -30px, 0);
    transform: translate3d(0, -30px, 0); }
  70% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    -webkit-transform: translate3d(0, -15px, 0);
    transform: translate3d(0, -15px, 0); }
  90% {
    -webkit-transform: translate3d(0, -4px, 0);
    transform: translate3d(0, -4px, 0); } }
@keyframes bounce {
  20%,53%,80%,from,to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }
  40%,43% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    -webkit-transform: translate3d(0, -30px, 0);
    transform: translate3d(0, -30px, 0); }
  70% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    -webkit-transform: translate3d(0, -15px, 0);
    transform: translate3d(0, -15px, 0); }
  90% {
    -webkit-transform: translate3d(0, -4px, 0);
    transform: translate3d(0, -4px, 0); } }
.bounce {
  -webkit-animation-name: bounce;
  animation-name: bounce;
  -webkit-transform-origin: center bottom;
  transform-origin: center bottom; }

@-webkit-keyframes flash {
  50%,from,to {
    opacity: 1; }
  25%,75% {
    opacity: 0; } }
@keyframes flash {
  50%,from,to {
    opacity: 1; }
  25%,75% {
    opacity: 0; } }
.flash {
  -webkit-animation-name: flash;
  animation-name: flash; }

@-webkit-keyframes pulse {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); }
  50% {
    -webkit-transform: scale3d(1.05, 1.05, 1.05);
    transform: scale3d(1.05, 1.05, 1.05); }
  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); } }
@keyframes pulse {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); }
  50% {
    -webkit-transform: scale3d(1.05, 1.05, 1.05);
    transform: scale3d(1.05, 1.05, 1.05); }
  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); } }
.pulse {
  -webkit-animation-name: pulse;
  animation-name: pulse; }

@-webkit-keyframes rubberBand {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); }
  30% {
    -webkit-transform: scale3d(1.25, 0.75, 1);
    transform: scale3d(1.25, 0.75, 1); }
  40% {
    -webkit-transform: scale3d(0.75, 1.25, 1);
    transform: scale3d(0.75, 1.25, 1); }
  50% {
    -webkit-transform: scale3d(1.15, 0.85, 1);
    transform: scale3d(1.15, 0.85, 1); }
  65% {
    -webkit-transform: scale3d(0.95, 1.05, 1);
    transform: scale3d(0.95, 1.05, 1); }
  75% {
    -webkit-transform: scale3d(1.05, 0.95, 1);
    transform: scale3d(1.05, 0.95, 1); }
  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); } }
@keyframes rubberBand {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); }
  30% {
    -webkit-transform: scale3d(1.25, 0.75, 1);
    transform: scale3d(1.25, 0.75, 1); }
  40% {
    -webkit-transform: scale3d(0.75, 1.25, 1);
    transform: scale3d(0.75, 1.25, 1); }
  50% {
    -webkit-transform: scale3d(1.15, 0.85, 1);
    transform: scale3d(1.15, 0.85, 1); }
  65% {
    -webkit-transform: scale3d(0.95, 1.05, 1);
    transform: scale3d(0.95, 1.05, 1); }
  75% {
    -webkit-transform: scale3d(1.05, 0.95, 1);
    transform: scale3d(1.05, 0.95, 1); }
  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); } }
.rubberBand {
  -webkit-animation-name: rubberBand;
  animation-name: rubberBand; }

@-webkit-keyframes shake {
  from,to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }
  10%,30%,50%,70%,90% {
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0); }
  20%,40%,60%,80% {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0); } }
@keyframes shake {
  from,to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }
  10%,30%,50%,70%,90% {
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0); }
  20%,40%,60%,80% {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0); } }
.shake {
  -webkit-animation-name: shake;
  animation-name: shake; }

@-webkit-keyframes swing {
  20% {
    -webkit-transform: rotate3d(0, 0, 1, 15deg);
    transform: rotate3d(0, 0, 1, 15deg); }
  40% {
    -webkit-transform: rotate3d(0, 0, 1, -10deg);
    transform: rotate3d(0, 0, 1, -10deg); }
  60% {
    -webkit-transform: rotate3d(0, 0, 1, 5deg);
    transform: rotate3d(0, 0, 1, 5deg); }
  80% {
    -webkit-transform: rotate3d(0, 0, 1, -5deg);
    transform: rotate3d(0, 0, 1, -5deg); }
  to {
    -webkit-transform: rotate3d(0, 0, 1, 0deg);
    transform: rotate3d(0, 0, 1, 0deg); } }
@keyframes swing {
  20% {
    -webkit-transform: rotate3d(0, 0, 1, 15deg);
    transform: rotate3d(0, 0, 1, 15deg); }
  40% {
    -webkit-transform: rotate3d(0, 0, 1, -10deg);
    transform: rotate3d(0, 0, 1, -10deg); }
  60% {
    -webkit-transform: rotate3d(0, 0, 1, 5deg);
    transform: rotate3d(0, 0, 1, 5deg); }
  80% {
    -webkit-transform: rotate3d(0, 0, 1, -5deg);
    transform: rotate3d(0, 0, 1, -5deg); }
  to {
    -webkit-transform: rotate3d(0, 0, 1, 0deg);
    transform: rotate3d(0, 0, 1, 0deg); } }
.swing {
  -webkit-transform-origin: top center;
  transform-origin: top center;
  -webkit-animation-name: swing;
  animation-name: swing; }

@-webkit-keyframes tada {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); }
  10%,20% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg); }
  30%,50%,70%,90% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg); }
  40%,60%,80% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg); }
  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); } }
@keyframes tada {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); }
  10%,20% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg); }
  30%,50%,70%,90% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg); }
  40%,60%,80% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg); }
  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); } }
.tada {
  -webkit-animation-name: tada;
  animation-name: tada; }

@-webkit-keyframes wobble {
  from {
    -webkit-transform: none;
    transform: none; }
  15% {
    -webkit-transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg);
    transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg); }
  30% {
    -webkit-transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg);
    transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg); }
  45% {
    -webkit-transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg);
    transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg); }
  60% {
    -webkit-transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg);
    transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg); }
  75% {
    -webkit-transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg);
    transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg); }
  to {
    -webkit-transform: none;
    transform: none; } }
@keyframes wobble {
  from {
    -webkit-transform: none;
    transform: none; }
  15% {
    -webkit-transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg);
    transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg); }
  30% {
    -webkit-transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg);
    transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg); }
  45% {
    -webkit-transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg);
    transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg); }
  60% {
    -webkit-transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg);
    transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg); }
  75% {
    -webkit-transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg);
    transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg); }
  to {
    -webkit-transform: none;
    transform: none; } }
.wobble {
  -webkit-animation-name: wobble;
  animation-name: wobble; }

@-webkit-keyframes jello {
  11.1%,from,to {
    -webkit-transform: none;
    transform: none; }
  22.2% {
    -webkit-transform: skewX(-12.5deg) skewY(-12.5deg);
    transform: skewX(-12.5deg) skewY(-12.5deg); }
  33.3% {
    -webkit-transform: skewX(6.25deg) skewY(6.25deg);
    transform: skewX(6.25deg) skewY(6.25deg); }
  44.4% {
    -webkit-transform: skewX(-3.125deg) skewY(-3.125deg);
    transform: skewX(-3.125deg) skewY(-3.125deg); }
  55.5% {
    -webkit-transform: skewX(1.5625deg) skewY(1.5625deg);
    transform: skewX(1.5625deg) skewY(1.5625deg); }
  66.6% {
    -webkit-transform: skewX(-0.78125deg) skewY(-0.78125deg);
    transform: skewX(-0.78125deg) skewY(-0.78125deg); }
  77.7% {
    -webkit-transform: skewX(0.39063deg) skewY(0.39063deg);
    transform: skewX(0.39063deg) skewY(0.39063deg); }
  88.8% {
    -webkit-transform: skewX(-0.19531deg) skewY(-0.19531deg);
    transform: skewX(-0.19531deg) skewY(-0.19531deg); } }
@keyframes jello {
  11.1%,from,to {
    -webkit-transform: none;
    transform: none; }
  22.2% {
    -webkit-transform: skewX(-12.5deg) skewY(-12.5deg);
    transform: skewX(-12.5deg) skewY(-12.5deg); }
  33.3% {
    -webkit-transform: skewX(6.25deg) skewY(6.25deg);
    transform: skewX(6.25deg) skewY(6.25deg); }
  44.4% {
    -webkit-transform: skewX(-3.125deg) skewY(-3.125deg);
    transform: skewX(-3.125deg) skewY(-3.125deg); }
  55.5% {
    -webkit-transform: skewX(1.5625deg) skewY(1.5625deg);
    transform: skewX(1.5625deg) skewY(1.5625deg); }
  66.6% {
    -webkit-transform: skewX(-0.78125deg) skewY(-0.78125deg);
    transform: skewX(-0.78125deg) skewY(-0.78125deg); }
  77.7% {
    -webkit-transform: skewX(0.39063deg) skewY(0.39063deg);
    transform: skewX(0.39063deg) skewY(0.39063deg); }
  88.8% {
    -webkit-transform: skewX(-0.19531deg) skewY(-0.19531deg);
    transform: skewX(-0.19531deg) skewY(-0.19531deg); } }
.jello {
  -webkit-animation-name: jello;
  animation-name: jello;
  -webkit-transform-origin: center;
  transform-origin: center; }

@-webkit-keyframes bounceIn {
  20%,40%,60%,80%,from,to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }
  0% {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3); }
  20% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1);
    transform: scale3d(1.1, 1.1, 1.1); }
  40% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9);
    transform: scale3d(0.9, 0.9, 0.9); }
  60% {
    opacity: 1;
    -webkit-transform: scale3d(1.03, 1.03, 1.03);
    transform: scale3d(1.03, 1.03, 1.03); }
  80% {
    -webkit-transform: scale3d(0.97, 0.97, 0.97);
    transform: scale3d(0.97, 0.97, 0.97); }
  to {
    opacity: 1;
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); } }
@keyframes bounceIn {
  20%,40%,60%,80%,from,to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }
  0% {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3); }
  20% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1);
    transform: scale3d(1.1, 1.1, 1.1); }
  40% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9);
    transform: scale3d(0.9, 0.9, 0.9); }
  60% {
    opacity: 1;
    -webkit-transform: scale3d(1.03, 1.03, 1.03);
    transform: scale3d(1.03, 1.03, 1.03); }
  80% {
    -webkit-transform: scale3d(0.97, 0.97, 0.97);
    transform: scale3d(0.97, 0.97, 0.97); }
  to {
    opacity: 1;
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1); } }
.bounceIn {
  -webkit-animation-name: bounceIn;
  animation-name: bounceIn; }

@-webkit-keyframes bounceInDown {
  60%,75%,90%,from,to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, -3000px, 0);
    transform: translate3d(0, -3000px, 0); }
  60% {
    opacity: 1;
    -webkit-transform: translate3d(0, 25px, 0);
    transform: translate3d(0, 25px, 0); }
  75% {
    -webkit-transform: translate3d(0, -10px, 0);
    transform: translate3d(0, -10px, 0); }
  90% {
    -webkit-transform: translate3d(0, 5px, 0);
    transform: translate3d(0, 5px, 0); }
  to {
    -webkit-transform: none;
    transform: none; } }
@keyframes bounceInDown {
  60%,75%,90%,from,to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, -3000px, 0);
    transform: translate3d(0, -3000px, 0); }
  60% {
    opacity: 1;
    -webkit-transform: translate3d(0, 25px, 0);
    transform: translate3d(0, 25px, 0); }
  75% {
    -webkit-transform: translate3d(0, -10px, 0);
    transform: translate3d(0, -10px, 0); }
  90% {
    -webkit-transform: translate3d(0, 5px, 0);
    transform: translate3d(0, 5px, 0); }
  to {
    -webkit-transform: none;
    transform: none; } }
.bounceInDown {
  -webkit-animation-name: bounceInDown;
  animation-name: bounceInDown; }

@-webkit-keyframes bounceInLeft {
  60%,75%,90%,from,to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }
  0% {
    opacity: 0;
    -webkit-transform: translate3d(-3000px, 0, 0);
    transform: translate3d(-3000px, 0, 0); }
  60% {
    opacity: 1;
    -webkit-transform: translate3d(25px, 0, 0);
    transform: translate3d(25px, 0, 0); }
  75% {
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0); }
  90% {
    -webkit-transform: translate3d(5px, 0, 0);
    transform: translate3d(5px, 0, 0); }
  to {
    -webkit-transform: none;
    transform: none; } }
@keyframes bounceInLeft {
  60%,75%,90%,from,to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }
  0% {
    opacity: 0;
    -webkit-transform: translate3d(-3000px, 0, 0);
    transform: translate3d(-3000px, 0, 0); }
  60% {
    opacity: 1;
    -webkit-transform: translate3d(25px, 0, 0);
    transform: translate3d(25px, 0, 0); }
  75% {
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0); }
  90% {
    -webkit-transform: translate3d(5px, 0, 0);
    transform: translate3d(5px, 0, 0); }
  to {
    -webkit-transform: none;
    transform: none; } }
.bounceInLeft {
  -webkit-animation-name: bounceInLeft;
  animation-name: bounceInLeft; }

@-webkit-keyframes bounceInRight {
  60%,75%,90%,from,to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }
  from {
    opacity: 0;
    -webkit-transform: translate3d(3000px, 0, 0);
    transform: translate3d(3000px, 0, 0); }
  60% {
    opacity: 1;
    -webkit-transform: translate3d(-25px, 0, 0);
    transform: translate3d(-25px, 0, 0); }
  75% {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0); }
  90% {
    -webkit-transform: translate3d(-5px, 0, 0);
    transform: translate3d(-5px, 0, 0); }
  to {
    -webkit-transform: none;
    transform: none; } }
@keyframes bounceInRight {
  60%,75%,90%,from,to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }
  from {
    opacity: 0;
    -webkit-transform: translate3d(3000px, 0, 0);
    transform: translate3d(3000px, 0, 0); }
  60% {
    opacity: 1;
    -webkit-transform: translate3d(-25px, 0, 0);
    transform: translate3d(-25px, 0, 0); }
  75% {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0); }
  90% {
    -webkit-transform: translate3d(-5px, 0, 0);
    transform: translate3d(-5px, 0, 0); }
  to {
    -webkit-transform: none;
    transform: none; } }
.bounceInRight {
  -webkit-animation-name: bounceInRight;
  animation-name: bounceInRight; }

@-webkit-keyframes bounceInUp {
  60%,75%,90%,from,to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 3000px, 0);
    transform: translate3d(0, 3000px, 0); }
  60% {
    opacity: 1;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0); }
  75% {
    -webkit-transform: translate3d(0, 10px, 0);
    transform: translate3d(0, 10px, 0); }
  90% {
    -webkit-transform: translate3d(0, -5px, 0);
    transform: translate3d(0, -5px, 0); }
  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }
@keyframes bounceInUp {
  60%,75%,90%,from,to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); }
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 3000px, 0);
    transform: translate3d(0, 3000px, 0); }
  60% {
    opacity: 1;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0); }
  75% {
    -webkit-transform: translate3d(0, 10px, 0);
    transform: translate3d(0, 10px, 0); }
  90% {
    -webkit-transform: translate3d(0, -5px, 0);
    transform: translate3d(0, -5px, 0); }
  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }
.bounceInUp {
  -webkit-animation-name: bounceInUp;
  animation-name: bounceInUp; }

@-webkit-keyframes bounceOut {
  20% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9);
    transform: scale3d(0.9, 0.9, 0.9); }
  50%,55% {
    opacity: 1;
    -webkit-transform: scale3d(1.1, 1.1, 1.1);
    transform: scale3d(1.1, 1.1, 1.1); }
  to {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3); } }
@keyframes bounceOut {
  20% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9);
    transform: scale3d(0.9, 0.9, 0.9); }
  50%,55% {
    opacity: 1;
    -webkit-transform: scale3d(1.1, 1.1, 1.1);
    transform: scale3d(1.1, 1.1, 1.1); }
  to {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3); } }
.bounceOut {
  -webkit-animation-name: bounceOut;
  animation-name: bounceOut; }

@-webkit-keyframes bounceOutDown {
  20% {
    -webkit-transform: translate3d(0, 10px, 0);
    transform: translate3d(0, 10px, 0); }
  40%,45% {
    opacity: 1;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0); }
  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0); } }
@keyframes bounceOutDown {
  20% {
    -webkit-transform: translate3d(0, 10px, 0);
    transform: translate3d(0, 10px, 0); }
  40%,45% {
    opacity: 1;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0); }
  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0); } }
.bounceOutDown {
  -webkit-animation-name: bounceOutDown;
  animation-name: bounceOutDown; }

@-webkit-keyframes bounceOutLeft {
  20% {
    opacity: 1;
    -webkit-transform: translate3d(20px, 0, 0);
    transform: translate3d(20px, 0, 0); }
  to {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0); } }
@keyframes bounceOutLeft {
  20% {
    opacity: 1;
    -webkit-transform: translate3d(20px, 0, 0);
    transform: translate3d(20px, 0, 0); }
  to {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0); } }
.bounceOutLeft {
  -webkit-animation-name: bounceOutLeft;
  animation-name: bounceOutLeft; }

@-webkit-keyframes bounceOutRight {
  20% {
    opacity: 1;
    -webkit-transform: translate3d(-20px, 0, 0);
    transform: translate3d(-20px, 0, 0); }
  to {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0); } }
@keyframes bounceOutRight {
  20% {
    opacity: 1;
    -webkit-transform: translate3d(-20px, 0, 0);
    transform: translate3d(-20px, 0, 0); }
  to {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0); } }
.bounceOutRight {
  -webkit-animation-name: bounceOutRight;
  animation-name: bounceOutRight; }

@-webkit-keyframes bounceOutUp {
  20% {
    -webkit-transform: translate3d(0, -10px, 0);
    transform: translate3d(0, -10px, 0); }
  40%,45% {
    opacity: 1;
    -webkit-transform: translate3d(0, 20px, 0);
    transform: translate3d(0, 20px, 0); }
  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0); } }
@keyframes bounceOutUp {
  20% {
    -webkit-transform: translate3d(0, -10px, 0);
    transform: translate3d(0, -10px, 0); }
  40%,45% {
    opacity: 1;
    -webkit-transform: translate3d(0, 20px, 0);
    transform: translate3d(0, 20px, 0); }
  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0); } }
.bounceOutUp {
  -webkit-animation-name: bounceOutUp;
  animation-name: bounceOutUp; }

@-webkit-keyframes fadeIn {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }
@keyframes fadeIn {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }
.fadeIn {
  -webkit-animation-name: fadeIn;
  animation-name: fadeIn; }

@-webkit-keyframes fadeInDown {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0); }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none; } }
@keyframes fadeInDown {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0); }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none; } }
.fadeInDown {
  -webkit-animation-name: fadeInDown;
  animation-name: fadeInDown; }

@-webkit-keyframes fadeInDownBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0); }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none; } }
@keyframes fadeInDownBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0); }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none; } }
.fadeInDownBig {
  -webkit-animation-name: fadeInDownBig;
  animation-name: fadeInDownBig; }

@-webkit-keyframes fadeInLeft {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0); }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none; } }
@keyframes fadeInLeft {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0); }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none; } }
.fadeInLeft {
  -webkit-animation-name: fadeInLeft;
  animation-name: fadeInLeft; }

@-webkit-keyframes fadeInLeftBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0); }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none; } }
@keyframes fadeInLeftBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0); }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none; } }
.fadeInLeftBig {
  -webkit-animation-name: fadeInLeftBig;
  animation-name: fadeInLeftBig; }

@-webkit-keyframes fadeInRight {
  from {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0); }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none; } }
@keyframes fadeInRight {
  from {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0); }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none; } }
.fadeInRight {
  -webkit-animation-name: fadeInRight;
  animation-name: fadeInRight; }

@-webkit-keyframes fadeInRightBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0); }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none; } }
@keyframes fadeInRightBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0); }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none; } }
.fadeInRightBig {
  -webkit-animation-name: fadeInRightBig;
  animation-name: fadeInRightBig; }

@-webkit-keyframes fadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0); }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none; } }
@keyframes fadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0); }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none; } }
.fadeInUp {
  -webkit-animation-name: fadeInUp;
  animation-name: fadeInUp; }

@-webkit-keyframes fadeInUpBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0); }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none; } }
@keyframes fadeInUpBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0); }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none; } }
.fadeInUpBig {
  -webkit-animation-name: fadeInUpBig;
  animation-name: fadeInUpBig; }

@-webkit-keyframes fadeOut {
  from {
    opacity: 1; }
  to {
    opacity: 0; } }
@keyframes fadeOut {
  from {
    opacity: 1; }
  to {
    opacity: 0; } }
.fadeOut {
  -webkit-animation-name: fadeOut;
  animation-name: fadeOut; }

@-webkit-keyframes fadeOutDown {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0); } }
@keyframes fadeOutDown {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0); } }
.fadeOutDown {
  -webkit-animation-name: fadeOutDown;
  animation-name: fadeOutDown; }

@-webkit-keyframes fadeOutDownBig {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0); } }
@keyframes fadeOutDownBig {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0); } }
.fadeOutDownBig {
  -webkit-animation-name: fadeOutDownBig;
  animation-name: fadeOutDownBig; }

@-webkit-keyframes fadeOutLeft {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0); } }
@keyframes fadeOutLeft {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0); } }
.fadeOutLeft {
  -webkit-animation-name: fadeOutLeft;
  animation-name: fadeOutLeft; }

@-webkit-keyframes fadeOutLeftBig {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0); } }
@keyframes fadeOutLeftBig {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0); } }
.fadeOutLeftBig {
  -webkit-animation-name: fadeOutLeftBig;
  animation-name: fadeOutLeftBig; }

@-webkit-keyframes fadeOutRight {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0); } }
@keyframes fadeOutRight {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0); } }
.fadeOutRight {
  -webkit-animation-name: fadeOutRight;
  animation-name: fadeOutRight; }

@-webkit-keyframes fadeOutRightBig {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0); } }
@keyframes fadeOutRightBig {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0); } }
.fadeOutRightBig {
  -webkit-animation-name: fadeOutRightBig;
  animation-name: fadeOutRightBig; }

@-webkit-keyframes fadeOutUp {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0); } }
@keyframes fadeOutUp {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0); } }
.fadeOutUp {
  -webkit-animation-name: fadeOutUp;
  animation-name: fadeOutUp; }

@-webkit-keyframes fadeOutUpBig {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0); } }
@keyframes fadeOutUpBig {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0); } }
.fadeOutUpBig {
  -webkit-animation-name: fadeOutUpBig;
  animation-name: fadeOutUpBig; }

@-webkit-keyframes flip {
  from {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -360deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -360deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; }
  40% {
    -webkit-transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; }
  50% {
    -webkit-transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }
  80% {
    -webkit-transform: perspective(400px) scale3d(0.95, 0.95, 0.95);
    transform: perspective(400px) scale3d(0.95, 0.95, 0.95);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }
  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; } }
@keyframes flip {
  from {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -360deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -360deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; }
  40% {
    -webkit-transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; }
  50% {
    -webkit-transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }
  80% {
    -webkit-transform: perspective(400px) scale3d(0.95, 0.95, 0.95);
    transform: perspective(400px) scale3d(0.95, 0.95, 0.95);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }
  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; } }
.animated.flip {
  -webkit-backface-visibility: visible;
  backface-visibility: visible;
  -webkit-animation-name: flip;
  animation-name: flip; }

@-webkit-keyframes flipInX {
  from {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0; }
  40% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }
  60% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    opacity: 1; }
  80% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -5deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -5deg); }
  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px); } }
@keyframes flipInX {
  from {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0; }
  40% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }
  60% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    opacity: 1; }
  80% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -5deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -5deg); }
  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px); } }
.flipInX {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  -webkit-animation-name: flipInX;
  animation-name: flipInX; }

@-webkit-keyframes flipInY {
  from {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0; }
  40% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }
  60% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    opacity: 1; }
  80% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -5deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -5deg); }
  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px); } }
@keyframes flipInY {
  from {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0; }
  40% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }
  60% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    opacity: 1; }
  80% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -5deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -5deg); }
  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px); } }
.flipInY {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  -webkit-animation-name: flipInY;
  animation-name: flipInY; }

@-webkit-keyframes flipOutX {
  from {
    -webkit-transform: perspective(400px);
    transform: perspective(400px); }
  30% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    opacity: 1; }
  to {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    opacity: 0; } }
@keyframes flipOutX {
  from {
    -webkit-transform: perspective(400px);
    transform: perspective(400px); }
  30% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    opacity: 1; }
  to {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    opacity: 0; } }
.flipOutX {
  -webkit-animation-name: flipOutX;
  animation-name: flipOutX;
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important; }

@-webkit-keyframes flipOutY {
  from {
    -webkit-transform: perspective(400px);
    transform: perspective(400px); }
  30% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    opacity: 1; }
  to {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    opacity: 0; } }
@keyframes flipOutY {
  from {
    -webkit-transform: perspective(400px);
    transform: perspective(400px); }
  30% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    opacity: 1; }
  to {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    opacity: 0; } }
.flipOutY {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  -webkit-animation-name: flipOutY;
  animation-name: flipOutY; }

@-webkit-keyframes lightSpeedIn {
  from {
    -webkit-transform: translate3d(100%, 0, 0) skewX(-30deg);
    transform: translate3d(100%, 0, 0) skewX(-30deg);
    opacity: 0; }
  60% {
    -webkit-transform: skewX(20deg);
    transform: skewX(20deg);
    opacity: 1; }
  80% {
    -webkit-transform: skewX(-5deg);
    transform: skewX(-5deg);
    opacity: 1; }
  to {
    -webkit-transform: none;
    transform: none;
    opacity: 1; } }
@keyframes lightSpeedIn {
  from {
    -webkit-transform: translate3d(100%, 0, 0) skewX(-30deg);
    transform: translate3d(100%, 0, 0) skewX(-30deg);
    opacity: 0; }
  60% {
    -webkit-transform: skewX(20deg);
    transform: skewX(20deg);
    opacity: 1; }
  80% {
    -webkit-transform: skewX(-5deg);
    transform: skewX(-5deg);
    opacity: 1; }
  to {
    -webkit-transform: none;
    transform: none;
    opacity: 1; } }
.lightSpeedIn {
  -webkit-animation-name: lightSpeedIn;
  animation-name: lightSpeedIn;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out; }

@-webkit-keyframes lightSpeedOut {
  from {
    opacity: 1; }
  to {
    -webkit-transform: translate3d(100%, 0, 0) skewX(30deg);
    transform: translate3d(100%, 0, 0) skewX(30deg);
    opacity: 0; } }
@keyframes lightSpeedOut {
  from {
    opacity: 1; }
  to {
    -webkit-transform: translate3d(100%, 0, 0) skewX(30deg);
    transform: translate3d(100%, 0, 0) skewX(30deg);
    opacity: 0; } }
.lightSpeedOut {
  -webkit-animation-name: lightSpeedOut;
  animation-name: lightSpeedOut;
  -webkit-animation-timing-function: ease-in;
  animation-timing-function: ease-in; }

@-webkit-keyframes rotateIn {
  from {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate3d(0, 0, 1, -200deg);
    transform: rotate3d(0, 0, 1, -200deg);
    opacity: 0; }
  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: none;
    transform: none;
    opacity: 1; } }
@keyframes rotateIn {
  from {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate3d(0, 0, 1, -200deg);
    transform: rotate3d(0, 0, 1, -200deg);
    opacity: 0; }
  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: none;
    transform: none;
    opacity: 1; } }
.rotateIn {
  -webkit-animation-name: rotateIn;
  animation-name: rotateIn; }

@-webkit-keyframes rotateInDownLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0; }
  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: none;
    transform: none;
    opacity: 1; } }
@keyframes rotateInDownLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0; }
  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: none;
    transform: none;
    opacity: 1; } }
.rotateInDownLeft {
  -webkit-animation-name: rotateInDownLeft;
  animation-name: rotateInDownLeft; }

@-webkit-keyframes rotateInDownRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0; }
  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: none;
    transform: none;
    opacity: 1; } }
@keyframes rotateInDownRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0; }
  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: none;
    transform: none;
    opacity: 1; } }
.rotateInDownRight {
  -webkit-animation-name: rotateInDownRight;
  animation-name: rotateInDownRight; }

@-webkit-keyframes rotateInUpLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0; }
  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: none;
    transform: none;
    opacity: 1; } }
@keyframes rotateInUpLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0; }
  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: none;
    transform: none;
    opacity: 1; } }
.rotateInUpLeft {
  -webkit-animation-name: rotateInUpLeft;
  animation-name: rotateInUpLeft; }

@-webkit-keyframes rotateInUpRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, -90deg);
    transform: rotate3d(0, 0, 1, -90deg);
    opacity: 0; }
  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: none;
    transform: none;
    opacity: 1; } }
@keyframes rotateInUpRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, -90deg);
    transform: rotate3d(0, 0, 1, -90deg);
    opacity: 0; }
  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: none;
    transform: none;
    opacity: 1; } }
.rotateInUpRight {
  -webkit-animation-name: rotateInUpRight;
  animation-name: rotateInUpRight; }

@-webkit-keyframes rotateOut {
  from {
    -webkit-transform-origin: center;
    transform-origin: center;
    opacity: 1; }
  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate3d(0, 0, 1, 200deg);
    transform: rotate3d(0, 0, 1, 200deg);
    opacity: 0; } }
@keyframes rotateOut {
  from {
    -webkit-transform-origin: center;
    transform-origin: center;
    opacity: 1; }
  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate3d(0, 0, 1, 200deg);
    transform: rotate3d(0, 0, 1, 200deg);
    opacity: 0; } }
.rotateOut {
  -webkit-animation-name: rotateOut;
  animation-name: rotateOut; }

@-webkit-keyframes rotateOutDownLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1; }
  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0; } }
@keyframes rotateOutDownLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1; }
  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0; } }
.rotateOutDownLeft {
  -webkit-animation-name: rotateOutDownLeft;
  animation-name: rotateOutDownLeft; }

@-webkit-keyframes rotateOutDownRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1; }
  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0; } }
@keyframes rotateOutDownRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1; }
  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0; } }
.rotateOutDownRight {
  -webkit-animation-name: rotateOutDownRight;
  animation-name: rotateOutDownRight; }

@-webkit-keyframes rotateOutUpLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1; }
  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0; } }
@keyframes rotateOutUpLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1; }
  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0; } }
.rotateOutUpLeft {
  -webkit-animation-name: rotateOutUpLeft;
  animation-name: rotateOutUpLeft; }

@-webkit-keyframes rotateOutUpRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1; }
  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, 90deg);
    transform: rotate3d(0, 0, 1, 90deg);
    opacity: 0; } }
@keyframes rotateOutUpRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1; }
  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, 90deg);
    transform: rotate3d(0, 0, 1, 90deg);
    opacity: 0; } }
.rotateOutUpRight {
  -webkit-animation-name: rotateOutUpRight;
  animation-name: rotateOutUpRight; }

@-webkit-keyframes hinge {
  0% {
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out; }
  20%,60% {
    -webkit-transform: rotate3d(0, 0, 1, 80deg);
    transform: rotate3d(0, 0, 1, 80deg);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out; }
  40%,80% {
    -webkit-transform: rotate3d(0, 0, 1, 60deg);
    transform: rotate3d(0, 0, 1, 60deg);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
    opacity: 1; }
  to {
    -webkit-transform: translate3d(0, 700px, 0);
    transform: translate3d(0, 700px, 0);
    opacity: 0; } }
@keyframes hinge {
  0% {
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out; }
  20%,60% {
    -webkit-transform: rotate3d(0, 0, 1, 80deg);
    transform: rotate3d(0, 0, 1, 80deg);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out; }
  40%,80% {
    -webkit-transform: rotate3d(0, 0, 1, 60deg);
    transform: rotate3d(0, 0, 1, 60deg);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
    opacity: 1; }
  to {
    -webkit-transform: translate3d(0, 700px, 0);
    transform: translate3d(0, 700px, 0);
    opacity: 0; } }
.hinge {
  -webkit-animation-name: hinge;
  animation-name: hinge; }

@-webkit-keyframes rollIn {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg);
    transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg); }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none; } }
@keyframes rollIn {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg);
    transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg); }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none; } }
.rollIn {
  -webkit-animation-name: rollIn;
  animation-name: rollIn; }

@-webkit-keyframes rollOut {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg);
    transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg); } }
@keyframes rollOut {
  from {
    opacity: 1; }
  to {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg);
    transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg); } }
.rollOut {
  -webkit-animation-name: rollOut;
  animation-name: rollOut; }

@-webkit-keyframes zoomIn {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3); }
  50% {
    opacity: 1; } }
@keyframes zoomIn {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3); }
  50% {
    opacity: 1; } }
.zoomIn {
  -webkit-animation-name: zoomIn;
  animation-name: zoomIn; }

@-webkit-keyframes zoomInDown {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }
  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }
@keyframes zoomInDown {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }
  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }
.zoomInDown {
  -webkit-animation-name: zoomInDown;
  animation-name: zoomInDown; }

@-webkit-keyframes zoomInLeft {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }
  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(10px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }
@keyframes zoomInLeft {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }
  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(10px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }
.zoomInLeft {
  -webkit-animation-name: zoomInLeft;
  animation-name: zoomInLeft; }

@-webkit-keyframes zoomInRight {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }
  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(-10px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }
@keyframes zoomInRight {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }
  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(-10px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }
.zoomInRight {
  -webkit-animation-name: zoomInRight;
  animation-name: zoomInRight; }

@-webkit-keyframes zoomInUp {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }
  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }
@keyframes zoomInUp {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }
  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }
.zoomInUp {
  -webkit-animation-name: zoomInUp;
  animation-name: zoomInUp; }

@-webkit-keyframes zoomOut {
  from {
    opacity: 1; }
  50% {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3); }
  to {
    opacity: 0; } }
@keyframes zoomOut {
  from {
    opacity: 1; }
  50% {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3); }
  to {
    opacity: 0; } }
.zoomOut {
  -webkit-animation-name: zoomOut;
  animation-name: zoomOut; }

@-webkit-keyframes zoomOutDown {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }
  to {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 2000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 2000px, 0);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }
@keyframes zoomOutDown {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }
  to {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 2000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 2000px, 0);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }
.zoomOutDown {
  -webkit-animation-name: zoomOutDown;
  animation-name: zoomOutDown; }

@-webkit-keyframes zoomOutLeft {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(42px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(42px, 0, 0); }
  to {
    opacity: 0;
    -webkit-transform: scale(0.1) translate3d(-2000px, 0, 0);
    transform: scale(0.1) translate3d(-2000px, 0, 0);
    -webkit-transform-origin: left center;
    transform-origin: left center; } }
@keyframes zoomOutLeft {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(42px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(42px, 0, 0); }
  to {
    opacity: 0;
    -webkit-transform: scale(0.1) translate3d(-2000px, 0, 0);
    transform: scale(0.1) translate3d(-2000px, 0, 0);
    -webkit-transform-origin: left center;
    transform-origin: left center; } }
.zoomOutLeft {
  -webkit-animation-name: zoomOutLeft;
  animation-name: zoomOutLeft; }

@-webkit-keyframes zoomOutRight {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(-42px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-42px, 0, 0); }
  to {
    opacity: 0;
    -webkit-transform: scale(0.1) translate3d(2000px, 0, 0);
    transform: scale(0.1) translate3d(2000px, 0, 0);
    -webkit-transform-origin: right center;
    transform-origin: right center; } }
@keyframes zoomOutRight {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(-42px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-42px, 0, 0); }
  to {
    opacity: 0;
    -webkit-transform: scale(0.1) translate3d(2000px, 0, 0);
    transform: scale(0.1) translate3d(2000px, 0, 0);
    -webkit-transform-origin: right center;
    transform-origin: right center; } }
.zoomOutRight {
  -webkit-animation-name: zoomOutRight;
  animation-name: zoomOutRight; }

@-webkit-keyframes zoomOutUp {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }
  to {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }
@keyframes zoomOutUp {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); }
  to {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1); } }
.zoomOutUp {
  -webkit-animation-name: zoomOutUp;
  animation-name: zoomOutUp; }

@-webkit-keyframes slideInDown {
  from {
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
    visibility: visible; }
  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }
@keyframes slideInDown {
  from {
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
    visibility: visible; }
  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }
.slideInDown {
  -webkit-animation-name: slideInDown;
  animation-name: slideInDown; }

@-webkit-keyframes slideInLeft {
  from {
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
    visibility: visible; }
  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }
@keyframes slideInLeft {
  from {
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
    visibility: visible; }
  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }
.slideInLeft {
  -webkit-animation-name: slideInLeft;
  animation-name: slideInLeft; }

@-webkit-keyframes slideInRight {
  from {
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
    visibility: visible; }
  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }
@keyframes slideInRight {
  from {
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
    visibility: visible; }
  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }
.slideInRight {
  -webkit-animation-name: slideInRight;
  animation-name: slideInRight; }

@-webkit-keyframes slideInUp {
  from {
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
    visibility: visible; }
  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }
@keyframes slideInUp {
  from {
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
    visibility: visible; }
  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }
.slideInUp {
  -webkit-animation-name: slideInUp;
  animation-name: slideInUp; }

@-webkit-keyframes slideOutDown {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }
  to {
    visibility: hidden;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0); } }
@keyframes slideOutDown {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }
  to {
    visibility: hidden;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0); } }
.slideOutDown {
  -webkit-animation-name: slideOutDown;
  animation-name: slideOutDown; }

@-webkit-keyframes slideOutLeft {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }
  to {
    visibility: hidden;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0); } }
@keyframes slideOutLeft {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }
  to {
    visibility: hidden;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0); } }
.slideOutLeft {
  -webkit-animation-name: slideOutLeft;
  animation-name: slideOutLeft; }

@-webkit-keyframes slideOutRight {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }
  to {
    visibility: hidden;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0); } }
@keyframes slideOutRight {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }
  to {
    visibility: hidden;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0); } }
.slideOutRight {
  -webkit-animation-name: slideOutRight;
  animation-name: slideOutRight; }

@-webkit-keyframes slideOutUp {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }
  to {
    visibility: hidden;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0); } }
@keyframes slideOutUp {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }
  to {
    visibility: hidden;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0); } }
.slideOutUp {
  -webkit-animation-name: slideOutUp;
  animation-name: slideOutUp; }

/* =================================================================== */
/*
/*
/*	 TOC:
/*  00. =variables
/*  01. =webfonts and iconfonts
/*  02. =document setup
/*  03. =preloader
/*  04. =forms
/*  05. =theme common styles
/*  06. =header styles
/*  07. =hero section
/*  08. =portfolio styles
/*  09. =about
/*  12. =contact
/*  13. =footer
/*
/* =================================================================== */
/** 
/* 00. =variables
/* =================================================================== */
/* COLOURS */
/* HERO VARIABLES */
/** 
/* INCLUDES
/* =================================================================== */
#portfolio, #portfolioa2, #about {
  padding-top: 100px; }

#portfolio .item-wrap:first-child .overlay, #about .item-wrap:first-child .overlay {
  background: rgba(255, 255, 255, 0.8);
  background-color: #646464;
  opacity: 0.1; }
#portfolio .portfolio-item-meta h5, #about .portfolio-item-meta h5 {
  color: black; }
#portfolio .link-icon, #about .link-icon {
  color: black; }

.folio-item:hover .item-wrap img {
  -moz-transform: scale(1.06);
  -o-transform: scale(1.06);
  -webkit-transform: scale(1.06);
  -ms-transform: scale(1.06);
  transform: scale(1.06); }

.mfp-img:hover {
  cursor: url("../img/plus.ico") 12 12, auto; }

.mfp-zoom-out-cur,
.mfp-zoom-out-cur .mfp-image-holder .mfp-close {
  cursor: default; }

#portfolio-wrapper .item-wrap {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0; }

#portfolio-wrapper .folio-item {
  height: 0; }

#portfolio-wrapper .folio-item img {
  max-height: 100%;
  max-width: 100%;
  margin: auto;
  display: block; }

.portfolio-wrapper.bgrid-fourth .folio-item {
  padding-top: 25%; }

.portfolio-wrapper .item-wrap {
  padding: 15px; }

@media screen and (max-width: 1024px) {
  .portfolio-wrapper.s-bgrid-third .folio-item {
    padding-top: 33.33333%; }

  .portfolio-wrapper .item-wrap {
    padding: 15px; } }
@media screen and (max-width: 768px) {
  .portfolio-wrapper.tab-bgrid-half .folio-item {
    padding-top: 50%; }

  .portfolio-wrapper .item-wrap {
    padding: 10px; } }
#contact {
  padding-bottom: 60px; }

@media only screen and (max-width: 768px) {
  #contact {
    padding-bottom: 50px; } }
@media only screen and (max-width: 600px) {
  #contact {
    padding-bottom: 40px; } }
@media only screen and (max-width: 480px) {
  #contact {
    padding-bottom: 30px; } }
#impressum {
  padding-top: 10px;
  padding-bottom: 60px;
  color: #9c9d9f; }

.cat-3 {
  /* ---- grid ---- */
  /* clear fix */
  /* ---- .grid-item ---- */ }
  .cat-3 .grid:after {
    content: '';
    display: block;
    clear: both;
    margin-top: 30px; }
  .cat-3 .grid-item {
    width: 220px;
    border: 1px gainsboro solid;
    margin-bottom: 20px;
    float: left; }
  .cat-3 .grid-item:hover {
    transform: scale(1.05); }
  .cat-3 .grid {
    width: 100%; }
  .cat-3 .grid:after {
    content: '';
    display: block;
    clear: both; }
  .cat-3 .grid-sizer,
  .cat-3 .grid-item {
    width: 220px;
    width: 278px; }
  .cat-3 .grid-item {
    float: left;
    position: relative; }
  .cat-3 .grid-item:hover {
    cursor: pointer; }
  .cat-3 .grid-item {
    -moz-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    -webkit-transition: all 0.3s ease-in-out;
    -ms-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out; }
  .cat-3 .grid-item .overlay {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    z-index: 1;
    background: #646464;
    opacity: 0.1;
    -moz-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    -webkit-transition: all 0.3s ease-in-out;
    -ms-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out; }
  .cat-3 .grid-item img {
    display: block;
    width: 220px;
    position: relative; }
  .cat-3 .grid {
    margin: 0 auto; }
  .cat-3 .garment-name {
    position: absolute;
    z-index: 2;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }
  .cat-3 .garment-name h3 {
    position: absolute;
    top: 50%;
    text-align: center;
    margin-top: -15px;
    color: black; }
  .cat-3 .active .overlay, .cat-3 .active h2 {
    opacity: 0; }
  .cat-3 .spacer-top {
    width: 100%;
    height: 120px; }

.cat-1 .overlay, .cat-2 .overlay {
  transform: scale(1.06); }

.ref-B-3 .section-head p {
  font: 20px/40px "merriweather-light" serif; }
.ref-B-3 .justify p {
  text-align: justify; }
.ref-B-3 #nav-wrap {
  font-family: "Helvetica", sans-serif;
  font-weight: 600;
  letter-spacing: 1.7; }
.ref-B-3 body {
  font: 16px/30px "merriweather-regular", serif; }
.ref-B-3 #hero-slider .slides .flex-caption h3 {
  font: 18px/1.9 "merriweather-light", sans-serif;
  text-shadow: none;
  margin-top: 24px;
  text-align: left;
  letter-spacing: 0;
  text-transform: none; }
.ref-B-3 hr, .ref-B-3 section {
  position: relative;
  z-index: 1; }
.ref-B-3 hr {
  margin: 11px 0 35px; }
.ref-B-3 .flex-canvas {
  background-attachment: fixed; }
@media only screen and (max-width: 1024px) {
  .ref-B-3 .section-head h1 {
    font-size: 35px; }
  .ref-B-3 .section-head p {
    font: 19px/37px "merriweather-light" serif; } }
@media only screen and (max-width: 768px) {
  .ref-B-3 .section-head h1 {
    font-size: 32px; }
  .ref-B-3 .section-head p {
    font: 18px/36px "merriweather-light" serif; } }
@media only screen and (max-width: 600px) {
  .ref-B-3 body {
    font: 15px/29px "merriweather-regular", serif; }
  .ref-B-3 .section-head h1 {
    font-size: 30px; }
  .ref-B-3 .section-head p {
    font: 17px/34px "merriweather-light" serif; }
  .ref-B-3 .flex-canvas {
    background-attachment: scroll; } }
@media only screen and (max-width: 480px) {
  .ref-B-3 .section-head h1 {
    font-size: 28px; }
  .ref-B-3 .section-head p {
    font: 16px/32px "merriweather-light" serif; }
  .ref-B-3 hr {
    margin: 9px 0 25px; }
  .ref-B-3 .justify p {
    text-align: left; } }
.ref-B-3 #hero-slider .frame.left,
.ref-B-3 #hero-slider .frame.right,
.ref-B-3 #hero-slider .frame.bottom {
  display: none; }
.ref-B-3 #contact .lead {
  margin-bottom: 20px; }
.ref-B-3 #about {
  padding-top: 0;
  padding-bottom: 0;
  background: white; }
.ref-B-3 #about .row:first-child {
  padding-top: 90px; }
.ref-B-3 #about .row:last-child {
  padding-bottom: 90px; }
.ref-B-3 #about .row {
  background-color: white; }
.ref-B-3 .ueber-meine-person {
  padding-bottom: 100px; }
.ref-B-3 .row.paralax {
  height: 420px;
  position: relative;
  z-index: 0;
  width: 100%;
  max-width: none;
  background-attachment: fixed;
  background-position: center center;
  background-repeat: no-repeat; }
  .ref-B-3 .row.paralax .screen {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: gainsboro;
    opacity: 0.1;
    z-index: 1; }
.ref-B-3 #about .row.paralax-1 {
  background-image: url(../img/referenzen/18.jpg); }
.ref-B-3 #about .row.paralax-3 {
  background-image: url(../img/referenzen/2.jpg); }
.ref-B-3 #contact .row.paralax-2 {
  background-image: url(../img/referenzen/15.jpg); }
.ref-B-3 .ueber-meine-person p > img {
  float: left;
  width: 280px;
  margin: 5px 35px 35px 0; }

.is-mobile.ref-B-3 .row.paralax {
  background-attachment: scroll; }

@media only screen and (max-width: 400px) {
  .row.paralax {
    display: none; }

  .paralax ~ .fake-section-start {
    padding-top: 0; }

  .ueber-meine-person .portrait-outer {
    padding-left: 20px; } }
@media only screen and (max-width: 480px) {
  #contact {
    padding-top: 60px; }

  #about,
  .ref-B-3 .ueber-meine-person {
    padding-bottom: 60px; }

  .ueber-meine-person p > img {
    float: left;
    width: 100%;
    margin: 25px 0; } }
@media only screen and (max-width: 600px) {
  .tab-bgrid-half .two-third.bgrid {
    width: 50%; } }
@media only screen and (max-width: 768px) {
  .tab-bgrid-whole .bgrid,
  .tab-bgrid-whole .two.bgrid {
    width: 100%; }

  .ref-B-3 .ueber-meine-person .portrait-outer {
    padding-left: 0; } }
@media only screen and (min-width: 768px) {
  .bgrid-third .two-third.bgrid {
    width: 66%; } }
@media only screen and (min-width: 1024px) {
  .ref-B-4 #contact p.lead,
  .ref-B-4 #about .section-head p,
  .ref-B-4 .ueber-meine-person p {
    width: 80%; } }

body.ref-B-4 {
  font: 15px/28px "merriweather-regular", serif; }

.legal {
  padding-top: 220px; }

@media only screen and (max-width: 480px) {
  .legal {
    padding-top: 100px; } }
@media only screen and (max-width: 600px) {
  .legal {
    padding-top: 140px; } }
@media only screen and (max-width: 768px) {
  .legal {
    padding-top: 160px; } }
/** 
/* CUSTOM
/* =================================================================== */
address {
  font-style: normal; }

section {
  padding-top: 100px;
  padding-bottom: 100px; }

#home {
  padding-bottom: 0; }

#contact textarea, #contact input {
  border: 3px rgba(0, 0, 0, 0.1) solid;
  border-radius: 0; }
#contact textarea:focus, #contact input:focus {
  border: 3px black solid; }

@font-face {
  font-family: cmm;
  src: url(../fonts/FelixTi.ttf); }
@font-face {
  font-family: bauplanung;
  src: url(../fonts/dokchamp.ttf); }
h3 {
  color: #004225;
  font-size: 15px;
  font-family: "Helvetica", sans-serif;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  padding: 0;
  text-align: left;
  margin-bottom: 6px; }

.section-info {
  padding-top: 90px;
  padding-bottom: 90px; }

.section-info h3 {
  padding: 0;
  margin-bottom: 6px; }

header {
  background-color: white; }

hr.half-rule {
  margin: auto;
  width: 100%;
  border-width: 1px 0 0; }

#nav-wrap {
  position: relative;
  z-index: 500; }

.masthead {
  position: relative;
  height: 45px;
  margin-top: 30px;
  border-bottom: 1px #5a5a5a solid;
  z-index: 1;
  color: #5a5a5a; }

.logo-cmm {
  position: absolute;
  left: 0;
  bottom: -1px;
  font-family: 'cmm';
  font-size: 54px;
  line-height: 37px;
  z-index: 2;
  background-color: white; }

.logo-bauplanung, .logo-bauplanung > .wrapper {
  width: 350px; }

.logo-bauplanung {
  margin: 0 auto;
  font-family: 'bauplanung';
  font-size: 22px;
  text-transform: uppercase;
  z-index: 2;
  height: 100%;
  position: relative; }
  .logo-bauplanung .wrapper {
    position: absolute;
    bottom: -1px;
    left: 0;
    background-color: white; }
  .logo-bauplanung span {
    line-height: 20px;
    display: block; }
  .logo-bauplanung span:first-child {
    padding: 0 3px;
    border-bottom: 1px #5a5a5a solid;
    letter-spacing: 21.33333px; }
  .logo-bauplanung span:last-child {
    padding: 0 2px;
    border-color: #5a5a5a;
    border-width: 0 1px;
    border-style: solid;
    letter-spacing: 18.3px; }

.logo-house {
  position: absolute;
  right: 0;
  bottom: 0;
  height: 75px;
  width: 100px;
  z-index: 0; }
  .logo-house img {
    position: absolute;
    bottom: -7px;
    right: -6px;
    z-index: 0; }

.nav-fixed .masthead {
  display: none; }
.nav-fixed .logo-house {
  display: none; }
.nav-fixed .logo-bauplanung {
  display: none; }

@media only screen and (max-width: 768px) {
  .masthead {
    display: none; }

  .logo-house {
    display: none; }

  .logo-bauplanung {
    display: none; }

  header {
    background: white;
    -webkit-box-shadow: 0 0 4px rgba(0, 0, 0, 0.2);
    box-shadow: 0 0 4px rgba(0, 0, 0, 0.2);
    padding-bottom: 0;
    position: fixed;
    left: 0;
    top: 0;
    height: 66px;
    border-bottom: 1px rgba(0, 0, 0, 0.05) solid; }
    header .logo {
      display: block; }
    header #nav-wrap {
      margin-left: 0; }
    header #nav-wrap ul {
      margin-left: 0; }

  .spacer-heading {
    display: none; } }
.fake-section-start {
  padding-top: 100px; }

.fake-section-end {
  padding-bottom: 100px; }

@media only screen and (max-width: 480px) {
  .row {
    padding-left: 20px;
    padding-right: 20px; }

  .fake-section-start {
    padding-top: 60px; }

  .fake-section-end {
    padding-bottom: 60px; } }
@media only screen and (max-width: 400px) {
  .row {
    padding-left: 15px;
    padding-right: 15px; } }
footer {
  background: rgba(0, 0, 0, 0.03);
  color: #9c9d9f;
  padding-bottom: 24px;
  position: relative; }

footer .content {
  margin-bottom: 12px;
  padding-top: 45px; }

footer a,
footer a:visited {
  color: #a3a4a6; }

footer a:hover,
footer a:focus {
  color: #004225; }

footer .info {
  width: 90%;
  max-width: 600px;
  margin: 42px auto 36px;
  text-align: center;
  clear: both; }

footer .legales {
  float: left; }

/* copyright */
footer .copyright {
  clear: both;
  margin: 0;
  padding: 24px 18px 6px 18px;
  font: 14px/24px "Helvetica", sans-serif;
  letter-spacing: .5px;
  text-align: center; }

footer .copyright li {
  display: inline-block;
  padding: 0 5px; }

footer hr {
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 30px;
  margin-top: 30px;
  max-width: 400px;
  width: 80%;
  border-top: 1px solid rgba(150, 150, 150, 0.4); }

footer ul.footer-links {
  float: left;
  font-family: "Helvetica", sans-serif;
  font-weight: 400;
  font-size: 13px;
  line-height: 22px;
  letter-spacing: 1.5px;
  list-style: none;
  margin: 0; }

footer .footer-links li {
  margin: 0;
  padding: 0; }

footer .footer-links li:first-child {
  margin-left: 0; }

footer .impressum {
  float: right; }

footer h4 {
  margin: 0; }

footer .impressum p {
  font-family: "Helvetica", sans-serif;
  font-size: 14px;
  line-height: 22px;
  margin-top: 0; }

footer .impressum h4,
footer .impressum p {
  text-align: right; }

/* media queries - .social-links */
@media only screen and (max-width: 600px) {
  footer .content {
    padding-top: 20px; }

  footer .footer-links {
    font-size: 12px; }

  footer ul.footer-links {
    float: none;
    text-align: center; }

  footer .impressum {
    margin-top: 35px;
    float: none; }

  footer h4,
  footer .impressum p {
    text-align: center; }

  footer .legales {
    float: none; }

  footer .impressum h4,
  footer .impressum p {
    text-align: center; } }
@media only screen and (max-width: 480px) {
  footer .content {
    padding-top: 20px; }

  footer .footer-links {
    font-size: 11px; } }
@media only screen and (max-width: 400px) {
  footer .footer-links {
    font-size: 10px; } }
@media only screen and (max-width: 350px) {
  footer .footer-links {
    font-size: 10px; } }
#home {
  padding-top: 130px; }

@media only screen and (max-width: 768px) {
  #home {
    padding-top: 66px; } }
@media only screen and (max-width: 600px) {
  #home {
    padding-top: 80px;
    padding-bottom: 30px; } }
#home .hero-content {
  position: static;
  padding-top: 0 !important;
  height: 100% !important; }

#home .hero-container {
  position: relative;
  height: 100% !important; }

.hero-container {
  height: 100% !important; }

#hero-slider {
  overflow: visible !important;
  margin-top: 0 !important;
  height: 100% !important; }
  #hero-slider ul, #hero-slider li {
    height: 100%; }

#home .flex-caption, #home .flex-control-nav {
  padding-left: 0; }

#home .flex-caption {
  margin-top: 86px !important;
  z-index: 200;
  position: absolute;
  bottom: 70px; }

#home .screen {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: gainsboro;
  opacity: 0.15;
  z-index: 3; }

#home .slides li .screen {
  display: none; }

#hero-slider {
  margin-bottom: 0 !important; }

#home .flex-control-nav {
  position: relative;
  margin-top: -74px; }

#hero-slider a {
  color: #5a5a5a;
  border-bottom: 1px #5a5a5a solid !important; }
  #hero-slider a:hover {
    color: #004225; }

.flex-canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%; }

/** 
/* 01. =webfonts and iconfonts
/* =================================================================== */
/** 
/* 02. =document setup
/* =================================================================== */
/* Body 
---------------------------------------------------------------------- */
html,
body {
  height: 100%; }

body {
  background: white;
  font: 16px/30px "merriweather-regular", serif;
  font-weight: normal;
  color: #535455; }

@media only screen and (max-width: 600px) {
  body {
    font: 15px/25px "merriweather-regular", serif; } }
/* links 
---------------------------------------------------------------------- */
a,
a:visited {
  outline: none;
  -moz-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  -webkit-transition: all 0.3s ease-in-out;
  -ms-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out; }

a:hover,
a:focus {
  color: #004225; }

/* Typography
--------------------------------------------------------------------- */
h1 {
  font-family: "helvetica", sans-serif; }

h2,
h3,
h4,
h5,
h6 {
  font-family: "Helvetica", sans-serif;
  font-style: normal;
  text-rendering: optimizeLegibility;
  margin: 18px 0 15px; }

h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a {
  font-weight: inherit; }

h1 {
  font-size: 30px;
  line-height: 36px;
  margin-top: 0;
  letter-spacing: -1px; }

h2 {
  font-size: 24px;
  line-height: 30px; }

h3 {
  font-size: 15px;
  line-height: 30px;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.15em; }

h4 {
  font-size: 17px;
  line-height: 30px; }

h5 {
  font-size: 14px;
  line-height: 30px;
  margin-top: 15px;
  text-transform: uppercase;
  letter-spacing: 1px; }

h6 {
  font-size: 13px;
  line-height: 30px;
  margin-top: 15px;
  text-transform: uppercase;
  letter-spacing: 1px; }

p {
  margin: 15px 0 15px 0; }

p img {
  margin: 0; }

p.lead {
  font: 18px/35px "merriweather-light", serif;
  color: #707273;
  color: #535455; }

em {
  font: 16px/30px "merriweather-italic", serif;
  font-style: normal; }

strong,
b {
  font: 16px/30px "merriweather-bold", serif;
  font-weight: normal; }

small {
  font-size: 11px;
  line-height: inherit; }

blockquote {
  margin: 18px 0px;
  padding-left: 40px;
  position: relative; }

blockquote:before {
  content: "\201C";
  opacity: 0.45;
  font-size: 80px;
  line-height: 0px;
  margin: 0;
  font-family: arial, sans-serif;
  position: absolute;
  top: 30px;
  left: 0; }

blockquote p {
  font-family: georgia, serif;
  font-style: italic;
  padding: 0;
  font-size: 18px;
  line-height: 30px; }

blockquote cite {
  display: block;
  font-size: 12px;
  font-style: normal;
  line-height: 18px; }

blockquote cite:before {
  content: "\2014 \0020"; }

blockquote cite a,
blockquote cite a:visited {
  color: #707273;
  border: none; }

abbr {
  font-family: "merriweather-bold", serif;
  font-variant: small-caps;
  text-transform: lowercase;
  letter-spacing: .5px;
  color: #707273; }

pre,
code {
  font-family: Consolas, "Andale Mono", Courier, "Courier New", monospace; }

pre {
  white-space: pre;
  white-space: pre-wrap;
  word-wrap: break-word; }

code {
  padding: 3px;
  background: #ECF0F1;
  color: #707273;
  border-radius: 3px; }

del {
  text-decoration: line-through; }

abbr[title],
dfn[title] {
  border-bottom: 1px dotted;
  cursor: help; }

mark {
  background: #FFF49B;
  color: #000; }

hr {
  border: solid #707273;
  border-width: 1px 0 0;
  clear: both;
  margin: 23px 0 12px;
  height: 0; }

/* Lists  
--------------------------------------------------------------------- */
ul,
ol {
  margin-top: 15px;
  margin-bottom: 15px; }

ul {
  list-style: disc;
  margin-left: 17px; }

dl {
  margin: 0 0 15px 0; }

dt {
  margin: 0;
  color: #004225; }

dd {
  margin: 0 0 0 20px; }

/* Floated image  
--------------------------------------------------------------------- */
img.pull-right {
  margin: 12px 0px 0px 18px; }

img.pull-left {
  margin: 12px 18px 0px 0px; }

/* Style Placeholder Text  
--------------------------------------------------------------------- */
::-webkit-input-placeholder {
  color: #12151B; }

:-moz-placeholder {
  /* Firefox 18- */
  color: #12151B; }

::-moz-placeholder {
  /* Firefox 19+ */
  color: #12151B; }

:-ms-input-placeholder {
  color: #12151B; }

.placeholder {
  color: #12151B !important; }

/* block grids default paddings 
--------------------------------------------------------------------- */
.bgrid {
  padding: 0 20px; }

@media only screen and (max-width: 1024px) {
  .bgrid {
    padding: 0 18px; } }
@media only screen and (max-width: 768px) {
  .bgrid {
    padding: 0 15px; } }
@media only screen and (max-width: 600px) {
  .bgrid {
    padding: 0 10px; } }
@media only screen and (max-width: 400px) {
  .bgrid {
    padding: 0; } }
/* 
/* 03. =Preloader
/* =================================================================== */
#preloader {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #151515;
  background: white;
  z-index: 900;
  height: 100%;
  width: 100%; }

.no-js #preloader,
.oldie #preloader {
  display: none; }

#loader {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 60px;
  height: 60px;
  margin: -30px 0 0 -30px;
  padding: 0; }

#loader:before {
  content: "";
  display: block;
  height: 60px;
  width: 60px;
  -webkit-animation: rotate .9s infinite linear;
  animation: rotate .9s infinite linear;
  border: 10px solid #FFFFFF;
  border-right-color: transparent;
  border-radius: 50%; }

#loader:before {
  content: "";
  border-top: 8px solid rgba(0, 0, 0, 0.2);
  border-right: 8px solid rgba(0, 0, 0, 0.2);
  border-bottom: 8px solid rgba(0, 0, 0, 0.2);
  border-left: 8px solid #000000;
  -webkit-animation: load 1.1s infinite linear;
  animation: load 1.1s infinite linear;
  display: block;
  border-radius: 50%;
  width: 60px;
  height: 60px; }

@-webkit-keyframes load {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg); }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg); } }
@keyframes load {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg); }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg); } }
@-webkit-keyframes rotate {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg); }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg); } }
@keyframes rotate {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg); }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg); } }
/* 
/* 04. =forms
/* =================================================================== */
form {
  margin-bottom: 30px; }

fieldset {
  margin: 0 0 30px 0;
  padding: 0;
  border: none; }

input,
button {
  -webkit-font-smoothing: antialiased; }

input[type="text"],
input[type="password"],
input[type="email"],
textarea,
select {
  display: block;
  padding: 18px 20px;
  margin: 0 0 12px 0;
  border: 0;
  outline: none;
  vertical-align: middle;
  color: #a3a4a6;
  font-family: "raleway-bold", sans-serif;
  font-size: 15px;
  line-height: 24px;
  border-radius: 3px;
  max-width: 100%;
  background: rgba(255, 255, 255, 0.1);
  -moz-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  -webkit-transition: all 0.3s ease-in-out;
  -ms-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out; }

textarea {
  min-height: 252px; }

input[type="text"]:focus,
input[type="password"]:focus,
input[type="email"]:focus,
select:focus,
textarea:focus {
  color: #000000;
  background: #FFFFFF; }

.button,
.button:visited,
button,
input[type="submit"],
input[type="reset"],
input[type="button"] {
  display: inline-block;
  font: 16px/30px "raleway-heavy", sans-serif;
  padding: 9px 16px;
  margin: 0 3px 6px 0;
  background: #004225;
  color: #000000;
  border: 3px black solid;
  text-decoration: none;
  cursor: pointer;
  height: auto;
  text-align: center;
  border: none;
  -webkit-appearance: none;
  -webkit-font-smoothing: inherit;
  border-radius: 0;
  -moz-transition: all 0.1s ease-in-out;
  -o-transition: all 0.1s ease-in-out;
  -webkit-transition: all 0.1s ease-in-out;
  -ms-transition: all 0.1s ease-in-out;
  transition: all 0.1s ease-in-out; }

.button:hover,
button:hover,
input[type="submit"]:hover,
input[type="reset"]:hover,
input[type="button"]:hover {
  color: #FFFFFF; }

label,
legend {
  font: 15px/30px "raleway-bold", sans-serif;
  margin: 12px 0;
  color: #252525;
  display: block; }

label span,
legend span {
  color: #535455;
  font: 16px/30px "raleway-bold", sans-serif; }

input[type="checkbox"],
input[type="radio"] {
  font-size: 15px;
  color: #535455; }

input[type="checkbox"] {
  display: inline; }

/** 
/* 05. =theme common styles
/* =================================================================== */
/* hr */
hr {
  border: solid #004225;
  border-width: 3px 0 0;
  width: 120px;
  margin: 11px 0 30px;
  height: 0;
  clear: both;
  text-align: left;
  -moz-transition: all 0.5s ease-in-out;
  -o-transition: all 0.5s ease-in-out;
  -webkit-transition: all 0.5s ease-in-out;
  -ms-transition: all 0.5s ease-in-out;
  transition: all 0.5s ease-in-out; }

/* for css animations */
.show {
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  opacity: 1;
  zoom: 1; }

/* sections */
.section-head h1 {
  letter-spacing: 2.5px;
  color: black;
  font-size: 38px;
  font-family: "Helvetica", sans-serif;
  font-weight: 500;
  text-transform: none;
  margin-top: 18px;
  margin-bottom: 24px; }

.section-head h1 span {
  color: #004225;
  position: relative;
  left: 3px; }

.section-head p {
  font: 18px/35px "merriweather-light", serif;
  width: 95%; }

@media only screen and (max-width: 768px) {
  .section-head {
    text-align: center; }

  .section-head p {
    font: 18px/36px "merriweather-light", serif;
    width: auto; }

  .section-head h1 + hr {
    margin-left: auto;
    margin-right: auto; } }
@media only screen and (max-width: 600px) {
  .section-head p {
    font: 17px/33px "merriweather-light", serif;
    width: auto; } }
@media only screen and (max-width: 400px) {
  .section-head p {
    font: 16px/31px "merriweather-light", serif;
    width: auto; }

  .section-head [class*="column"] {
    padding: 0; } }
/** 
/* 06. =header styles
/* =================================================================== */
/* header logo */
/* media queries:  
/* header/header components */
/* primary navigation
--------------------------------------------------------------------- */
#nav-wrap,
#nav-wrap ul,
#nav-wrap li,
#nav-wrap a {
  margin: 0;
  padding: 0; }

/* nav-wrap */
#nav-wrap {
  font: 13px "raleway-heavy", sans-serif;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  float: left; }

/* hide toggle button */
#nav-wrap > a {
  display: none; }

ul#nav {
  min-height: 66px;
  display: inline-block;
  width: auto;
  /* left align the menu */
  text-align: left; }

ul#nav li {
  position: relative;
  list-style: none;
  display: inline-block;
  height: 66px; }

/* Links */
ul#nav li a {
  display: block;
  padding: 14px 26px;
  line-height: 38px;
  text-decoration: none;
  text-align: left;
  color: #5a5a5a;
  position: relative;
  -moz-transition: color 0.2s ease-in-out;
  -o-transition: color 0.2s ease-in-out;
  -webkit-transition: color 0.2s ease-in-out;
  -ms-transition: color 0.2s ease-in-out;
  transition: color 0.2s ease-in-out; }

ul#nav li a:hover {
  color: #004225; }

ul#nav li a:active {
  background-color: transparent !important; }

ul#nav li.current a {
  color: #004225; }

/* mobile navigation 
--------------------------------------------------------------------- */
@media only screen and (max-width: 768px) {
  #nav-wrap {
    z-index: 700;
    display: block;
    width: 100%;
    float: none;
    position: absolute;
    top: 0;
    right: 0; }

  /* mobile-btn and toggle-btn */
  #nav-wrap > a {
    border: none;
    color: #FFFFFF;
    height: 40px;
    min-width: 40px;
    font-size: 12px;
    text-align: left;
    float: right;
    display: block;
    padding: 0;
    position: relative;
    top: 13px;
    right: 20px; }

  #nav-wrap > a:hover .menu-icon {
    background: #FFFFFF;
    background: #004225; }

  #nav-wrap .menu-icon {
    display: inline-block;
    width: 24px;
    height: 3px;
    margin-top: -3px;
    position: absolute;
    right: 8px;
    top: 50%;
    bottom: auto;
    left: auto;
    background: #004225;
    background: #5a5a5a;
    -moz-transition: all 0.3s ease-in-out;
    -o-transition: all 0.3s ease-in-out;
    -webkit-transition: all 0.3s ease-in-out;
    -ms-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
    font: 0/0 a;
    text-shadow: none;
    color: transparent; }

  #nav-wrap .menu-icon:before,
  #nav-wrap .menu-icon:after {
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
    background-color: inherit;
    left: 0; }

  #nav-wrap .menu-icon:before {
    bottom: 8px; }

  #nav-wrap .menu-icon:after {
    top: 8px; }

  /* dropdown nav */
  #nav-wrap ul#nav {
    background: #fafafa;
    padding: 54px 45px 60px 45px;
    margin: 0;
    height: auto;
    display: none;
    clear: both;
    width: 100%;
    float: none;
    position: absolute;
    top: 66px;
    right: 0; }

  #nav-wrap ul#nav > li {
    display: block;
    float: none;
    height: auto;
    text-align: left;
    border-bottom: 1px dotted rgba(200, 200, 200, 0.6);
    padding: 6px 0; }

  #nav-wrap ul#nav > li:first-child {
    border-top: 1px dotted rgba(200, 200, 200, 0.1); }

  #nav-wrap ul#nav li a {
    display: block;
    width: auto;
    padding: 0;
    color: #cacbcb;
    padding: 12px 0;
    line-height: 16px;
    border: none; }

  #nav-wrap ul#nav li a:hover {
    color: #FFFFFF; }

  #nav-wrap ul#nav li.current > a {
    background: none;
    color: #004225; }

  #nav-wrap ul#nav li.current > a:after {
    display: none; }

  #nav-wrap a.mobile-btn {
    display: none; }

  .js #nav-wrap a#toggle-btn {
    display: block; }

  /* if js is disabled */
  .no-js #nav-wrap:not(:target) > a:first-of-type,
  .no-js #nav-wrap:target > a:last-of-type {
    display: block; }

  .no-js #nav-wrap:target ul#nav {
    display: block; } }
header {
  width: 100%;
  position: relative;
  left: 0;
  top: 0;
  -moz-transition: all 0.5s ease-in-out;
  -o-transition: all 0.5s ease-in-out;
  -webkit-transition: all 0.5s ease-in-out;
  -ms-transition: all 0.5s ease-in-out;
  transition: all 0.5s ease-in-out;
  background: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(80%, #ffffff), color-stop(100%, rgba(255, 255, 255, 0)));
  background: -moz-linear-gradient(top, #ffffff 80%, rgba(255, 255, 255, 0));
  background: -webkit-linear-gradient(top, #ffffff 80%, rgba(255, 255, 255, 0));
  background: linear-gradient(to bottom, #ffffff 80%, rgba(255, 255, 255, 0));
  z-index: none;
  padding-bottom: 10px;
  position: absolute;
  top: 0;
  left: 0; }

header .logo {
  float: left;
  width: auto;
  margin-left: 15px;
  margin-right: 30px;
  z-index: 600;
  /* add position relative since z-index only applies to  
  elements that have been given an explicit position */
  position: relative;
  display: none; }

header .logo a {
  display: block;
  margin: 0;
  padding: 0;
  border: none;
  font: 0/0 a;
  text-shadow: none;
  width: 114px;
  height: 66px;
  background-size: 61px 14px;
  background: transparent url("../img/haus2.svg") no-repeat center center; }

header.nav-fixed {
  background: white;
  -webkit-box-shadow: 0 0 4px rgba(0, 0, 0, 0.2);
  box-shadow: 0 0 4px rgba(0, 0, 0, 0.2);
  z-index: 1000;
  padding-bottom: 0;
  position: fixed;
  left: 0;
  top: -70px;
  display: none;
  border-bottom: 1px rgba(0, 0, 0, 0.05) solid; }

header.nav-fixed ul#nav li.current a:after {
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 40px;
  height: 2px;
  margin-left: -23px;
  background-color: #5a5a5a;
  content: '\0020';
  display: block;
  -moz-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  -webkit-transition: all 0.3s ease-in-out;
  -ms-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out; }

header.nav-fixed.active {
  top: 0;
  display: block; }

header.nav-fixed .logo {
  display: block; }

.nav-fixed + section {
  padding-top: 151px; }

#nav-wrap {
  margin-left: 50%; }

#nav-wrap ul {
  margin-left: -251px;
  margin-left: -185px; }

header.nav-fixed #nav-wrap,
header.nav-fixed #nav-wrap ul {
  margin-left: 0; }

@media only screen and (max-width: 400px) {
  header .logo {
    margin-left: -20px; } }
@media only screen and (max-width: 768px) {
  header {
    position: fixed;
    background: white;
    z-index: 600;
    top: 0;
    left: 0; }

  header .logo {
    display: block;
    margin-left: -30px; }

  header .row {
    width: 100%; }

  header {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1); } }
/* make sure the menu is visible on larger screens
--------------------------------------------------------------------- */
@media only screen and (min-width: 769px) {
  #nav-wrap ul#nav {
    display: block !important; } }
/* 
/* 07. =hero section
/* =================================================================== */
.about-wrapper {
  width: 100%;
  background: #f9f9f9;
  padding: 90px 60px; }

#home .frame {
  position: absolute;
  z-index: 10;
  display: none; }

@media only screen and (min-width: 1141px) {
  #home .frame {
    display: block; } }
@media screen and (max-width: 768px) {
  #home .row {
    padding: 0; } }
@media only screen and (max-width: 480px) {
  #home {
    border-bottom: 1px green solid; } }
#home .frame.right {
  right: 0;
  top: 0;
  height: 100%;
  width: 8px;
  background: -moz-linear-gradient(right, #ffffff 10%, rgba(255, 255, 255, 0));
  background: -webkit-linear-gradient(right, #ffffff 10%, rgba(255, 255, 255, 0));
  background: linear-gradient(to left, #ffffff 10%, rgba(255, 255, 255, 0)); }

#home .frame.left {
  left: 0;
  top: 0;
  height: 100%;
  width: 8px;
  background: -moz-linear-gradient(left, #ffffff 10%, rgba(255, 255, 255, 0));
  background: -webkit-linear-gradient(left, #ffffff 10%, rgba(255, 255, 255, 0));
  background: linear-gradient(to right, #ffffff 10%, rgba(255, 255, 255, 0)); }

#home .frame.bottom {
  left: 0;
  bottom: 0;
  height: 8px;
  width: 100%;
  background: -moz-linear-gradient(bottom, #ffffff 10%, rgba(255, 255, 255, 0));
  background: -webkit-linear-gradient(bottom, #ffffff 10%, rgba(255, 255, 255, 0));
  background: linear-gradient(to top, #ffffff 10%, rgba(255, 255, 255, 0)); }

#home .row.hero-content {
  width: 100%; }

#home .flex-canvas {
  background-size: contain; }

#home .flex-canvas.cover {
  background-size: cover; }

#home .flex-canvas.right {
  background-position-x: right; }

#home .flex-canvas.bottom {
  background-position-y: bottom; }

#home .flex-canvas.top {
  background-position-y: 130px; }

@media screen and (max-width: 480px) {
  #home .flex-canvas {
    background-position-y: top; } }
@media screen and (max-width: 768px) {
  #home .flex-canvas.mobile-top {
    background-position-y: top; } }
.flex-canvas-1 {
  background: transparent url(./../img/hero/portfolio-1/1-hero.jpg) no-repeat center; }

.flex-canvas-2 {
  background: transparent url(./../img/hero/portfolio-1/2-hero.jpg) no-repeat center; }

.flex-canvas-3 {
  background: transparent url(./../img/hero/portfolio-1/3-hero.jpg) no-repeat center; }

.flex-canvas-4 {
  background: transparent url(./../img/hero/portfolio-1/4-hero.jpg) no-repeat center; }

.flex-canvas-5 {
  background: transparent url(./../img/hero/portfolio-1/5-hero.jpg) no-repeat center; }

.flex-canvas-6 {
  background: transparent url(./../img/hero/portfolio-1/6-hero.jpg) no-repeat center; }

.flex-canvas-7 {
  background: transparent url(./../img/hero/portfolio-1/7-hero.jpg) no-repeat center; }

.flex-canvas-8 {
  background: transparent url(./../img/hero/portfolio-1/8-hero.jpg) no-repeat center; }

.flex-canvas-9 {
  background: transparent url(./../img/hero/portfolio-1/9-hero.jpg) no-repeat center; }

.flex-canvas-10 {
  background: transparent url(./../img/hero/portfolio-1/10-hero.jpg) no-repeat center; }

.flex-canvas-11 {
  background: transparent url(./../img/hero/portfolio-1/11-hero.jpg) no-repeat center; }

.flex-canvas-12 {
  background: transparent url(./../img/hero/portfolio-1/12-hero.jpg) no-repeat center; }

.flex-canvas-13 {
  background: transparent url(./../img/hero/portfolio-1/13-hero.jpg) no-repeat center; }

#home {
  -webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover;
  min-height: 630px;
  width: 100%;
  text-align: left;
  position: relative; }

.hero-content {
  position: relative;
  padding-top: 66px;
  z-index: 450; }

/* hero slider */
#hero-slider {
  margin: 120px 0 54px; }

#hero-slider .slides .flex-caption {
  margin: 0 35% 0 45px;
  background: rgba(255, 255, 255, 0.8);
  padding: 0 20px; }

@media only screen and (max-width: 480px) {
  #home .screen {
    background-color: rgba(255, 255, 255, 0.8); }

  #hero-slider .slides .flex-caption {
    background: transparent; } }
#hero-slider .slides .flex-caption h1 {
  font: 49px/1.1 "helvetica", sans-serif;
  letter-spacing: -1px;
  padding-bottom: 24px;
  color: #5a5a5a;
  text-shadow: none;
  position: relative;
  font-weight: 500;
  /* for css animations */ }
  #hero-slider .slides .flex-caption h1 .minor {
    font-weight: 200;
    font-size: 65%; }

#hero-slider .slides .flex-caption h1::after {
  display: block;
  background-color: #004225;
  width: 100px;
  height: 3px;
  content: '\0020';
  position: absolute;
  left: 0;
  bottom: 0; }

#hero-slider .slides .flex-caption h3 {
  font: 18px/1.9 "merriweather-light", sans-serif;
  color: #5a5a5a;
  text-shadow: none;
  margin-top: 24px;
  text-align: left;
  /* for css animations */ }

#hero-slider .slides .flex-caption h1 span,
#hero-slider .slides .flex-caption h1 a {
  display: inline-block; }

/* for oldIE - IE9 */
.oldie #hero-slider .slides .flex-caption h1 {
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  opacity: 1;
  zoom: 1; }

.oldie #hero-slider .slides .flex-caption h3 {
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  opacity: 1;
  zoom: 1; }

/* media queries:  
/* #home / .hero-contert / #hero-slider */
@media only screen and (max-width: 1200px) {
  #hero-slider .slides .flex-caption h1 {
    font: 45px/1.1 "helvetica", sans-serif;
    font-weight: 500; } }
@media only screen and (max-width: 1024px) {
  #hero-slider .slides .flex-caption h1 {
    font: 42px/1.3 86px, sans-serif; }

  #hero-slider .slides .flex-caption h3 {
    font: 16px/1.9 "merriweather-light", sans-serif; } }
@media only screen and (max-width: 768px) {
  #home {
    min-height: auto; }

  .hero-content {
    padding-bottom: 72px; }

  #hero-slider {
    margin: 84px 0 36px; }

  #hero-slider .slides .flex-caption {
    margin: 0 40px 0;
    width: auto; }

  #hero-slider .slides .flex-caption h1 {
    font: 41px/1.3 86px, sans-serif; }

  #hero-slider .slides .flex-caption h3 {
    font: 16px/1.9 "merriweather-light", sans-serif;
    width: 85%; } }
@media only screen and (max-width: 600px) {
  .hero-content {
    padding-bottom: 72px; }

  #hero-slider {
    margin: 84px 0 36px; }

  #hero-slider .slides .flex-caption {
    margin: 0 35px 0;
    width: auto; }

  #hero-slider .slides .flex-caption h1 {
    font: 39px/1.3 86px, sans-serif; }

  #hero-slider .slides .flex-caption h3 {
    font: 15px/1.9 "merriweather-light", sans-serif;
    width: 90%; } }
@media only screen and (max-width: 480px) {
  .hero-content {
    padding-bottom: 72px; }

  #hero-slider {
    margin: 78px 0 36px; }

  #hero-slider .slides .flex-caption {
    margin: 0 20px 0;
    width: auto; }

  #hero-slider .slides .flex-caption h1 {
    font: 36px/1.3 86px, sans-serif; }

  #hero-slider .slides .flex-caption h3 {
    width: auto; } }
@media only screen and (max-width: 400px) {
  .hero-content {
    padding-bottom: 54px; }

  #hero-slider {
    margin: 72px 0 24px; }

  #hero-slider .slides .flex-caption {
    margin: 0; }

  #hero-slider .slides .flex-caption h1 {
    font: 30px/1.3 86px, sans-serif; } }
/* control nav */
#home .flex-control-nav {
  text-align: left;
  display: none;
  display: block;
  position: relative;
  position: absolute;
  bottom: 30px;
  left: 45px;
  z-index: 20;
  padding-left: 20px; }

@media only screen and (max-width: 480px) {
  #home .flex-control-nav {
    display: none; } }
@media only screen and (max-width: 600px) {
  #home .flex-control-nav {
    left: 35px; } }
@media only screen and (max-width: 768px) {
  #home .flex-control-nav {
    padding-left: 0; } }
#home .flex-control-nav li {
  margin: 0 6px;
  display: inline-block;
  zoom: 1; }

#home .flex-control-paging li a {
  width: 12px;
  height: 12px;
  display: block;
  cursor: pointer;
  text-indent: -9999px;
  border-radius: 50%;
  background: white;
  border: 1px #5a5a5a solid; }

#home .flex-control-paging li a:hover {
  background: white;
  border: 1px rgba(0, 0, 0, 0.5) solid; }

#home .flex-control-paging li a.flex-active {
  background: #004225;
  border: 1px #004225 solid; }
  #home .flex-control-paging li a.flex-active:hover {
    border: 1px rgba(0, 0, 0, 0.5) solid; }

/** 
/* 08. =portfolio styles
/* =================================================================== */
#portfolio {
  background: #111417;
  padding-top: 90px;
  padding-bottom: 90px; }

#portfolio .row.items {
  max-width: 1140px; }

/* media queries - portfolio */
@media only screen and (max-width: 1300px) {
  #portfolio .row.items {
    width: 94%;
    padding: 0; }

  #portfolio .row.items .columns {
    padding: 0; } }
/* portfolio content */
#portfolio-wrapper:before,
#portfolio-wrapper:after {
  content: "";
  display: table; }

#portfolio-wrapper:after {
  clear: both; }

.folio-item .item-wrap {
  overflow: hidden;
  position: relative; }

.folio-item .item-wrap a {
  display: block;
  cursor: pointer;
  position: relative; }

/* overlay */
.folio-item .item-wrap .overlay {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.85);
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  opacity: 0;
  zoom: 1;
  -moz-transition: opacity 0.5s ease-in-out;
  -o-transition: opacity 0.5s ease-in-out;
  -webkit-transition: opacity 0.5s ease-in-out;
  -ms-transition: opacity 0.5s ease-in-out;
  transition: opacity 0.5s ease-in-out; }

.folio-item .item-wrap .link-icon {
  display: block;
  height: 30px;
  width: 30px;
  margin-left: -15px;
  margin-top: -15px;
  font-size: 14px;
  line-height: 30px;
  text-align: center;
  color: #FFFFFF;
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  opacity: 0;
  zoom: 1;
  -moz-transition: opacity 0.5s ease-in-out;
  -o-transition: opacity 0.5s ease-in-out;
  -webkit-transition: opacity 0.5s ease-in-out;
  -ms-transition: opacity 0.5s ease-in-out;
  transition: opacity 0.5s ease-in-out;
  position: absolute;
  top: 50%;
  left: 50%; }

.folio-item .item-wrap img {
  vertical-align: bottom;
  -moz-transition: all 0.5s ease-in-out;
  -o-transition: all 0.5s ease-in-out;
  -webkit-transition: all 0.5s ease-in-out;
  -ms-transition: all 0.5s ease-in-out;
  transition: all 0.5s ease-in-out; }

.folio-item .portfolio-item-meta {
  width: 100%;
  text-align: center;
  position: absolute;
  top: 20%;
  left: -100px;
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  opacity: 0;
  zoom: 1;
  -moz-transition: all 0.5s ease-in-out;
  -o-transition: all 0.5s ease-in-out;
  -webkit-transition: all 0.5s ease-in-out;
  -ms-transition: all 0.5s ease-in-out;
  transition: all 0.5s ease-in-out; }

.folio-item .portfolio-item-meta h5 {
  font: 14px/21px "raleway-bold", sans-serif;
  letter-spacing: 2px;
  color: white;
  margin: 0; }

.folio-item .portfolio-item-meta p {
  font: 14px/18px "raleway-semibold", sans-serif;
  color: #8A8A8A;
  margin: 0; }

/* on hover */
.folio-item:hover .overlay,
.folio-item:hover .link-icon,
.folio-item:hover .portfolio-item-meta {
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  opacity: 1;
  zoom: 1; }

.folio-item:hover .portfolio-item-meta {
  left: 0; }

/* media queries - .portfolio-item-meta */
@media only screen and (max-width: 500px) {
  .folio-item .portfolio-item-meta {
    top: 16%; }

  .folio-item .portfolio-item-meta h5 {
    font: 13px/21px "raleway-bold", sans-serif;
    letter-spacing: 1px; }

  .folio-item .portfolio-item-meta p {
    font: 13px/18px "raleway-semibold", sans-serif; } }
@media only screen and (max-width: 400px) {
  .folio-item .portfolio-item-meta {
    top: 12%; }

  .folio-item .portfolio-item-meta h5 {
    font: 11px/18px "raleway-bold", sans-serif;
    letter-spacing: 1px; }

  .folio-item .portfolio-item-meta p {
    font: 11px/16px "raleway-semibold", sans-serif; } }
/* Popup Modal 
/* ------------------------------------------------------------------ */
.popup-modal {
  max-width: 550px;
  background: #FFFFFF;
  position: relative;
  margin: 0 auto; }

.popup-modal .media {
  position: relative; }

.popup-modal img {
  vertical-align: bottom; }

/* description */
.popup-modal .description-box {
  padding: 6px 36px 30px; }

.popup-modal .description-box h4 {
  font: 15px/24px "raleway-heavy", sans-serif;
  color: #000000; }

.popup-modal .description-box p {
  font: 14px/24px "merriweather-regular", serif;
  color: #A1A1A1;
  margin-bottom: 12px; }

/* categories */
.popup-modal .categories {
  font: 11px/18px "raleway-heavy", sans-serif;
  text-transform: uppercase;
  letter-spacing: 1px;
  display: block;
  text-align: left;
  color: rgba(0, 0, 0, 0.5); }

/* media queries - popup-modal */
@media only screen and (max-width: 600px) {
  .popup-modal {
    width: auto;
    margin: 0 20px; } }
/* transition effect for modal popup
/* ------------------------------------------------------------------ */
/* overlay at start */
.mfp-fade.mfp-bg {
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  opacity: 0;
  zoom: 1;
  -moz-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  -webkit-transition: all 0.3s ease-in-out;
  -ms-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out; }

/* overlay animate in */
.mfp-fade.mfp-bg.mfp-ready {
  filter: alpha(opacity=80);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)";
  opacity: 0.8;
  zoom: 1; }

/* overlay animate out */
.mfp-fade.mfp-bg.mfp-removing {
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  opacity: 0;
  zoom: 1; }

/* content at start */
.mfp-fade.mfp-wrap .mfp-content {
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  opacity: 0;
  zoom: 1;
  -moz-transform: translateY(-100%);
  -o-transform: translateY(-100%);
  -webkit-transform: translateY(-100%);
  -ms-transform: translateY(-100%);
  transform: translateY(-100%);
  -moz-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  -webkit-transition: all 0.3s ease-in-out;
  -ms-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out; }

/* content animate in */
.mfp-fade.mfp-wrap.mfp-ready .mfp-content {
  filter: alpha(opacity=100);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  opacity: 1;
  zoom: 1;
  -moz-transform: translateY(0);
  -o-transform: translateY(0);
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0); }

/* content animate out */
.mfp-fade.mfp-wrap.mfp-removing .mfp-content {
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  opacity: 0;
  zoom: 1;
  -moz-transform: translateY(-100%);
  -o-transform: translateY(-100%);
  -webkit-transform: translateY(-100%);
  -ms-transform: translateY(-100%);
  transform: translateY(-100%); }

/** 
/* 09. =about
/* =================================================================== */
#about .portrait-wrapper {
  width: 280px;
  float: left;
  margin: 5px 30px 20px 0;
  font-size: 13px; }

@media screen and (max-width: 600px) {
  #about .portrait-wrapper {
    float: none;
    display: block; } }
@media screen and (max-width: 400px) {
  #about .portrait-wrapper {
    width: 100%;
    margin: 0 auto 20px auto;
    float: none;
    display: block; } }
/** 
/* 12. =contact
/* =================================================================== */
#contact .left {
  padding-right: 35px; }

#contact .right {
  padding-left: 35px;
  position: relative;
  top: -6px; }

/* media queries:  
/* #contact / .left .right */
@media only screen and (max-width: 1024px) {
  #contact .left {
    padding-right: 30px; }

  #contact .right {
    padding-left: 30px; } }
@media only screen and (max-width: 768px) {
  #contact .left,
  #contact .right {
    width: 100%;
    padding: 0 15px; }

  #contact .right p.lead {
    font: 18px/36px "merriweather-light", serif; } }
@media only screen and (max-width: 600px) {
  #contact .left,
  #contact .right {
    padding: 0 10px; }

  #contact .right p.lead {
    font: 17px/33px "merriweather-light", serif; } }
@media only screen and (max-width: 400px) {
  #contact .left,
  #contact .right {
    padding: 0; } }
/* contact form */
#contact form {
  margin-top: 12px;
  margin-bottom: 30px; }

#contact form div {
  position: relative; }

#contact form div:before,
#contact form div:after {
  content: "";
  display: table; }

#contact form div:after {
  clear: both; }

#contact form div label {
  font: 11px/24px "raleway-bold", sans-serif;
  position: absolute;
  bottom: 3px;
  right: 6px;
  border-radius: 3px;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 0 20px;
  color: #e64e04; }

input[type="text"],
input[type="password"],
input[type="email"],
#contact textarea,
#contact select {
  margin-bottom: 45px;
  width: 100%; }

#contact button.submitform {
  font: 15px/30px "raleway-heavy", sans-serif;
  text-transform: uppercase;
  letter-spacing: 2px;
  height: 60px;
  display: inline-block;
  width: 100%;
  background: transparent;
  border: 3px black solid;
  padding: 12px 30px; }
  #contact button.submitform:hover {
    background: black;
    color: white; }

#message-warning,
#message-success {
  display: none;
  background: rgba(0, 0, 0, 0.03);
  padding: 24px;
  margin-bottom: 36px;
  width: 100%; }

#message-warning {
  color: #e64e04; }

#message-success {
  color: #004225; }

#message-warning i,
#message-success i {
  margin-right: 10px; }

/* form loader */
#submit-loader {
  display: none;
  position: relative;
  left: 0;
  top: 18px;
  width: 100%;
  text-align: center; }

#submit-loader .text-loader {
  display: none;
  font: 14px/30px "raleway-heavy", sans-serif;
  color: #FFFFFF;
  letter-spacing: 3px;
  text-transform: uppercase; }

.oldie #submit-loader .s-loader {
  display: none; }

.oldie #submit-loader .text-loader {
  display: block; }

/* loader animation 
------------------------------------------- */
.s-loader {
  margin: 12px auto 30px;
  width: 70px;
  text-align: center;
  -moz-transform: translateX(2.5px);
  -o-transform: translateX(2.5px);
  -webkit-transform: translateX(2.5px);
  -ms-transform: translateX(2.5px);
  transform: translateX(2.5px); }

.s-loader > div {
  width: 12px;
  height: 12px;
  background-color: #FFFFFF;
  border-radius: 100%;
  display: inline-block;
  margin-right: 5px;
  -webkit-animation: sk-bouncedelay 1.4s infinite ease-in-out both;
  animation: sk-bouncedelay 1.4s infinite ease-in-out both; }

.s-loader .bounce1 {
  -webkit-animation-delay: -0.32s;
  animation-delay: -0.32s; }

.s-loader .bounce2 {
  -webkit-animation-delay: -0.16s;
  animation-delay: -0.16s; }

@-webkit-keyframes sk-bouncedelay {
  0%,
	80%,
	100% {
    -moz-transform: scale(0);
    -o-transform: scale(0);
    -webkit-transform: scale(0);
    -ms-transform: scale(0);
    transform: scale(0); }
  40% {
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1); } }
@keyframes sk-bouncedelay {
  0%,
	80%,
	100% {
    -moz-transform: scale(0);
    -o-transform: scale(0);
    -webkit-transform: scale(0);
    -ms-transform: scale(0);
    transform: scale(0); }
  40% {
    -moz-transform: scale(1);
    -o-transform: scale(1);
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1); } }

/*# sourceMappingURL=main.css.map */
