html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline; }

a {
  text-decoration: none; }
  a:active, a:hover {
    outline: 0; }

ul, li {
  list-style-type: none;
  margin: 0;
  padding: 0; }

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal; }

html {
  -webkit-box-sizing: border-box;
          box-sizing: border-box; }

*, *:before, *:after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box; }

:focus {
  outline: 0; }

img, audio, video {
  max-width: 100%;
  height: auto; }

audio, canvas, iframe, video, img, svg {
  vertical-align: middle; }

iframe {
  border: 0; }

textarea {
  resize: none;
  /*remove the resize handle on the bottom right*/
  overflow: auto;
  vertical-align: top;
  box-shadow: none;
  -webkit-box-shadow: none;
  -moz-box-shadow: none; }

input, textarea, select, button {
  outline: none;
  border: none;
  font-size: 100%;
  margin: 0; }

button, input {
  line-height: normal; }

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

td, th {
  padding: 0;
  text-align: left; }

*, *:before, *:after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box; }

h1, h2, h3, h4, h5, h6 {
  margin: 0; }

a {
  text-decoration: none; }

ul, li {
  margin: 0;
  padding: 0;
  list-style-type: none; }

.icon {
  display: inline-block;
  width: 1em;
  height: 1em;
  fill: currentColor; }

.header {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  z-index: 101;
  padding-top: 2em;
  display: none; }
  @media (min-width: 48em) {
    .header {
      display: block; } }
  .header--wrapper {
    padding: 0 1em;
    margin: 0 auto;
    width: 100%; }
    @media (min-width: 48em) {
      .header--wrapper {
        width: 700px; } }
    @media (min-width: 62em) {
      .header--wrapper {
        width: 920px; } }
    @media (min-width: 75em) {
      .header--wrapper {
        width: 1160px; } }
    @media (min-width: 87.5em) {
      .header--wrapper {
        width: 135em; } }
  .header--content {
    width: 80em;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between; }
  .header__logo img {
    width: 30em; }
  .header__line {
    width: 10em;
    height: 1px;
    background: #dedbd6; }
  .header__button {
    cursor: pointer;
    font-size: 1.8em;
    padding: 1em 2em;
    border-radius: 10em;
    color: #816700;
    border: 1px solid #816700;
    background: transparent; }
    .header__button:hover {
      color: #fff;
      background: #816700; }

.page__first {
  position: relative;
  padding-top: 37.5em;
  background: url("../img/first-bg.png") no-repeat right bottom;
  background-size: cover; }
  @media (min-width: 48em) {
    .page__first {
      height: 100vh;
      min-height: 60em;
      padding-top: 10em;
      background: url("../img/first-bg.png") no-repeat center bottom;
      background-size: cover; } }
  .page__first:after {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 95%;
    height: 100%;
    background: url("../img/first-girl.png") no-repeat right top;
    background-size: contain; }
    @media (min-width: 48em) {
      .page__first:after {
        width: 55%; } }
    @media (min-width: 62em) {
      .page__first:after {
        width: 65%;
        -webkit-transform: translateX(20%);
            -ms-transform: translateX(20%);
                transform: translateX(20%); } }
    @media (min-width: 75em) {
      .page__first:after {
        width: 55%;
        -webkit-transform: translateX(0%);
            -ms-transform: translateX(0%);
                transform: translateX(0%); } }
  .page__first-wrapper {
    padding: 0 1em;
    margin: 0 auto;
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    position: relative;
    z-index: 100; }
    @media (min-width: 48em) {
      .page__first-wrapper {
        width: 700px; } }
    @media (min-width: 62em) {
      .page__first-wrapper {
        width: 920px; } }
    @media (min-width: 75em) {
      .page__first-wrapper {
        width: 1160px; } }
    @media (min-width: 87.5em) {
      .page__first-wrapper {
        width: 135em; } }
  .page__first-title {
    color: #0f0f0f;
    line-height: 100%;
    font-size: 3em;
    font-weight: 600;
    font-style: italic; }
    @media (min-width: 48em) {
      .page__first-title {
        font-size: 5.5em; } }
  .page__first-desc {
    margin-top: 2em; }
    @media (min-width: 48em) {
      .page__first-desc {
        margin-top: 4em; } }
    .page__first-desc p {
      font-size: 1.7em;
      color: #0f0f0f;
      font-weight: 300;
      font-family: 'Roboto', sans-serif; }
      @media (min-width: 48em) {
        .page__first-desc p {
          font-size: 2.4em; } }
    .page__first-desc span {
      display: block;
      font-weight: 600;
      font-family: 'Roboto', sans-serif;
      font-size: 2.1em;
      position: relative;
      padding-left: 2em;
      margin-top: .5em; }
      @media (min-width: 48em) {
        .page__first-desc span {
          font-size: 3em; } }
      .page__first-desc span:after {
        content: '';
        position: absolute;
        width: 1.5em;
        left: 0;
        top: 0;
        bottom: 0;
        margin: auto;
        height: 1px;
        background: #0f0f0f; }

.page__title {
  width: 100%;
  font-size: 4em;
  font-weight: 600;
  font-style: italic;
  line-height: 100%; }
  @media (min-width: 48em) {
    .page__title {
      font-size: 6em; } }
  .page__title span {
    color: #816700; }
  @media (min-width: 48em) {
    .page__title br {
      display: none; } }
  @media (min-width: 75em) {
    .page__title br {
      display: block; } }

.page__desc {
  margin-top: 3em; }
  @media (min-width: 48em) {
    .page__desc {
      margin-top: 6em; } }
  .page__desc p {
    color: #0f0f0f;
    font-size: 1.7em;
    line-height: 1.45em;
    font-weight: 300;
    font-family: 'Roboto', sans-serif;
    margin-bottom: 1em; }
    @media (min-width: 48em) {
      .page__desc p {
        font-size: 2.1em; } }
    @media (min-width: 62em) {
      .page__desc p {
        font-size: 2.3em; } }
    .page__desc p:last-child {
      margin-bottom: 0; }
    .page__desc p.bold {
      font-weight: 700; }

.page--wrapper {
  padding: 0 1em;
  margin: 0 auto;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between; }
  @media (min-width: 48em) {
    .page--wrapper {
      width: 700px; } }
  @media (min-width: 62em) {
    .page--wrapper {
      width: 920px; } }
  @media (min-width: 75em) {
    .page--wrapper {
      width: 1160px; } }
  @media (min-width: 87.5em) {
    .page--wrapper {
      width: 135em; } }

.form {
  width: 100%;
  padding: 1.5em;
  margin-top: 6em;
  background: #fff;
  border-radius: 15px;
  -webkit-box-shadow: 0px 25px 58px 0px rgba(0, 0, 0, 0.07);
          box-shadow: 0px 25px 58px 0px rgba(0, 0, 0, 0.07); }
  @media (min-width: 48em) {
    .form {
      width: 50em; } }
  .form-wrapper {
    padding: 2em 2em;
    border-radius: 15px;
    border: 1px solid #e6e1cc; }
    @media (min-width: 48em) {
      .form-wrapper {
        padding: 2em 5em; } }
  .form-title {
    color: #816700;
    font-family: 'Roboto', sans-serif;
    font-weight: 600;
    text-align: center;
    font-size: 1.8em;
    margin-bottom: 1.5em; }
    @media (min-width: 48em) {
      .form-title {
        font-size: 2.4em; } }
  .form-group {
    margin-bottom: 1em; }
    .form-group:last-child {
      margin-bottom: 0; }
    .form-group input {
      display: block;
      width: 100%;
      height: 3.5em;
      border: 1px solid #b7b7b7;
      border-radius: 5px;
      font-size: 1.6em;
      padding-left: 1em;
      font-weight: 600;
      font-family: 'Roboto', sans-serif; }
      .form-group input::-webkit-input-placeholder {
        font-size: 1em;
        font-weight: 300; }
      .form-group input::-moz-placeholder {
        font-size: 1em;
        font-weight: 300; }
      .form-group input:-ms-input-placeholder {
        font-size: 1em;
        font-weight: 300; }
      .form-group input::-ms-input-placeholder {
        font-size: 1em;
        font-weight: 300; }
      .form-group input::placeholder {
        font-size: 1em;
        font-weight: 300; }
    .form-group button {
      cursor: pointer;
      width: 80%;
      display: block;
      margin: 0 auto;
      margin-top: 2em;
      color: #fff;
      font-size: 1.7em;
      height: 3em;
      font-family: 'Roboto', sans-serif;
      font-weight: 300;
      border-radius: 10em;
      background-color: #b56a4c;
      -webkit-box-shadow: 0px 6px 7.12px 0.88px rgba(83, 66, 0, 0.25);
              box-shadow: 0px 6px 7.12px 0.88px rgba(83, 66, 0, 0.25); }
      @media (min-width: 48em) {
        .form-group button {
          font-size: 2em;
          height: 3em; } }

.button {
  cursor: pointer;
  display: block;
  margin-top: 1.5em;
  color: #fff;
  font-size: 1.7em;
  padding: 0 3em;
  height: 3em;
  font-family: 'Roboto', sans-serif;
  font-weight: 300;
  border-radius: 10em; }
  @media (min-width: 48em) {
    .button {
      font-size: 2em;
      margin-top: 2em; } }
  .button-orange {
    background-color: #b56a4c;
    -webkit-box-shadow: 0px 6px 7.12px 0.88px rgba(83, 66, 0, 0.25);
            box-shadow: 0px 6px 7.12px 0.88px rgba(83, 66, 0, 0.25); }
.whatsapp {
  position: fixed;
  right: 3rem;
  bottom: 2rem;
  z-index: 1000000; }
  .whatsapp-icon {
    position: relative;
    z-index: 100; }
    @media (min-width: 48em) {
        .whatsapp-icon:hover + .whatsapp-text {
      opacity: 1;
      -webkit-transition: all 0.4s ease-in-out;
      transition: all 0.4s ease-in-out; }
    }
    
    .whatsapp-icon a {
      display: block; }
    .whatsapp-icon img {
      width: 6rem; }
  .whatsapp-text {
    opacity: 0;
    -webkit-transition: all 0.4s ease-in-out;
    transition: all 0.4s ease-in-out;
    position: absolute;
    right: -1.5rem;
    top: 0;
    bottom: 0;
    margin: auto;
    width: 11rem;
    height: 3rem;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
            font-family: 'Arial', sans-serif;
    font-size: 1.3rem;
    -webkit-transform: translateX(100%);
        -ms-transform: translateX(100%);
            transform: translateX(100%);
    background: #64b161;
    color: #fff;
    -webkit-border-radius: .5rem;
            border-radius: .5rem; }
    .whatsapp-text:before {
      content: '';
      position: absolute;
      left: -1.5rem;
      top: .75rem;
      border: 8px solid transparent;
      border-right: 8px solid #64b161; }

.cssload-loader {
  width: 10rem;
  height: 10rem;
  -webkit-border-radius: 50%;
          border-radius: 50%;
  margin: 3em;
  display: inline-block;
  position: absolute;
  background: #64b161;
  top: 50%;
  left: 50%;
  margin-left: -5rem;
  margin-top: -5rem;
  z-index: 99; }

.cssload-loader,
.cssload-loader:before,
.cssload-loader:after {
  animation: 1.5s infinite ease-in-out;
  -o-animation: 1.5s infinite ease-in-out;
  -ms-animation: 1.5s infinite ease-in-out;
  -webkit-animation: 1.5s infinite ease-in-out;
  -moz-animation: 1.5s infinite ease-in-out; }

.cssload-loader:before,
.cssload-loader:after {
  width: 100%;
  height: 100%;
  -webkit-border-radius: 50%;
          border-radius: 50%;
  position: absolute;
  top: 0;
  left: 0; }

.cssload-loader {
  animation-name: cssload-loader;
  -o-animation-name: cssload-loader;
  -ms-animation-name: cssload-loader;
  -webkit-animation-name: cssload-loader;
  -moz-animation-name: cssload-loader; }

@keyframes cssload-loader {
  from {
    -webkit-transform: scale(0);
            transform: scale(0);
    opacity: 1; }
  to {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 0; } }

@-webkit-keyframes cssload-loader {
  from {
    -webkit-transform: scale(0);
    opacity: 1; }
  to {
    -webkit-transform: scale(1);
    opacity: 0; } }

/***** Loading animation */