
@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@300;700&display=swap');


@font-face {
    font-family: 'icon';

    src: url('icons/icon.ttf?neosmh') format('truetype'),
         url('icons/icon.woff?neosmh') format('woff'),
         url('icons/icon.svg?neosmh#icon') format('svg');

    font-weight: normal;
    font-style: normal;
    font-display: block;
}

@keyframes blink {
      0% { opacity: 0 }
     50% { opacity: 1 }
    100% { opacity: 0 }
}

* {
    border: 0;
    margin: 0;
    padding: 0;

    resize: none;
    outline: none;

    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;

    background: transparent;
}

html,
body {
    color: #ffffff;

    display: flex;
    align-items: center;
    justify-content: center;

    font-size: 10px;
    font-weight: 400;
    line-height: 10px;
    font-family: 'Open Sans';

    min-width: 100%;
    min-height: 100vh;

    background: #202f3b;
}

.icon {
    font-family: 'icon' !important;
    speak: never;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
}

.icon-youtube:before { content: "\e901"; }
.icon-whatsapp:before { content: "\e902"; }
.icon-instagram:before { content: "\e900"; }

.error,
.success {
    color: white;

    font-size: 1.4rem;
    font-weight: 700;
    line-height: 1.8rem;

    margin-right: 1rem;
}

.error {
    color: #f44336;
}

.validation {
    color: #ffffff;

    font-size: 1.4rem;
    font-style: normal;
    font-weight: 700;
    line-height: 1.8rem;
    letter-spacing: 0.01em;

    right: 1rem;
    bottom: calc(100% + 0.8rem);
    padding: 0.7rem 1.2rem;
    max-width: 100%;

    background: #990000;
    box-shadow: 0rem 0.2rem 0.4rem rgba(0,0,0,0.05);

    position: absolute;
}

.validation:after {
    right: 0;
    bottom: -1rem;

    content: '';
    display: block;
    position: absolute;

    border: 1rem solid transparent;
    border-right-color: #990000
}

.background {
    z-index: 1;

    top: 0;
    left: 0;
    right: 0;
    bottom: 0;

    overflow: hidden;
    position: fixed;
}

.background .inner {
    opacity: 0;

    width: 100%;
    height: 100%;

    background: url(images/bg.jpg);
    background-size: cover;
    background-position: center right;

    transform: scale(1.05);
    transform-origin: center bottom;
}

.container {
    z-index: 2;

    width: 100%;
    margin: auto;
    position: relative;

    display: flex;
    align-items: center;
    justify-content: flex-end;

    max-width: 1430px;
}

.container .box {
    width: 100%;
    margin: 4rem 0;
    max-width: 52rem;
}

.container .box h1 {
    overflow: hidden;

    width: 0rem;
    height: 0rem;

    text-indent: -5000rem;
}

.container .box h2 {
    width: 100%;
    color: #ffffff;

    font-size: 6.0rem;
    font-weight: 300;
    line-height: 7.0rem;

    text-transform: lowercase;
}

.container .box h2 span {
    speak: none;
    display: block;
    position: relative;
}

.container .box h2 > span:last-child {
    height: 0rem;

    speak: normal;
    overflow: hidden;

    text-indent: -5000rem;
}

.container .box h2 span.writing:after {
    top: -0.2rem;

    content: '|';
    display: inline;
    position: relative;

    animation: blink 0.8s linear infinite;
}

.container .box h2 span:nth-child(2):before {
    z-index: 1;

    top: 0;
    left: -1rem;
    width: 0rem;
    bottom: -1rem;

    content: '';
    display: block;
    position: absolute;

    background: #3eaf90;
}

.container .box h2 span.strike:nth-child(2) span {
    z-index: 2;
    position: relative;
}

.container .box h2 span.strike:nth-child(2):before {
    width: 37rem;
    transition: 0.3s ease-out;
}

.container .box p {
    color: #ffffff;

    font-size: 1.8rem;
    font-weight: 300;
    line-height: 2.6rem;

    height: 0rem;
    overflow: hidden;
}

.container .box p a,
.container .box p strong {
    position: relative;

    font-weight: 700;
    letter-spacing: 0.01em;

    text-decoration: none;
}

.container .box p a {
    color: #ffffff;
}

.container .box p a i {
    speak: none;
    color: #ffffff;

    font-size: 1.6rem;
    font-style: normal;
    font-weight: 700;
    line-height: 3.2rem;
    letter-spacing: 0.01em;

    right: 20%;
    bottom: calc(100% + 0.8rem);
    padding: 0 1.2rem;

    opacity: 0;
    position: absolute;
    transform: rotate(-5deg) translateY(1rem);
    transform-origin: right bottom;

    background: #3eaf90;
    transition: 0.2s ease;
    box-shadow: 0rem 0.2rem 0.4rem rgba(0,0,0,0.05);

    white-space: nowrap;
}

.container .box p a i:after {
    right: 0;
    bottom: -1rem;

    content: '';
    display: block;
    position: absolute;

    border: 1rem solid transparent;
    border-right-color: #3eaf90
}

.container .box p span {
    opacity: 0;
    display: inline-block;
    transform: rotate(8deg) translate3d(4px,12px,0);
}

.container .box form {
    height: 0;
    padding: 0;

    overflow: hidden;
    position: relative;

    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.container .box form.overflow {
    overflow: visible;
}

.container .box form:after {
    left: 0;
    right: 0;
    bottom: 9.2rem;
    opacity: 0;

    width: 100%;
    height: 0.5rem;

    background: url(images/line.png);
    background-size: auto 100%;
    background-repeat: repeat;

    content: '';
    display: block;
    position: absolute;
}

.container .box form .input,
.container .box form .button {
    width: 100%;
    margin: 0 0 1.8rem;
    opacity: 0;
    position: relative;
}

.container .box form .input.col-40 {
    width: calc(40% - 0.6rem);
}

.container .box form .input.col-60 {
    width: calc(60% - 0.6rem);
}

.container .box form .button {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.container .box form .input input,
.container .box form .input textarea,
.container .box form .button button {
    color: #ffffff;

    width: 100%;
    padding: 1.0rem;

    font-size: 1.6rem;
    font-weight: 300;
    line-height: 2.0rem;
    font-family: 'Open Sans';

    appearance: none;
    box-sizing: border-box;

    border: 2px solid #3eaf90;
}

.container .box form .input textarea {
    height: 12rem;
}

.container .box form .input input::placeholder,
.container .box form .input textarea::placeholder {
    color: #ffffff;
}

.container .box form .button button {
    line-height: 4.2rem;

    width: auto;
    margin: 0 0 0 auto;
    border: 0rem;
    padding: 0 3rem 0 4rem;

    background: #3eaf90;
    background-image: url(images/pattern.png);
    background-repeat: repeat-y;
    background-position: left;
}

.container .box form .logos {
    display: flex;

    width: 100%;
    height: 12rem;

    align-items: flex-end;
}

.container .box form .logos .inner {
    display: flex;

    width: 100%;
    flex-grow: 0;
    flex-shrink: 0;

    align-items: center;
    justify-content: space-between;
}

.container .box form .logos .inner img {
    opacity: 0;
    width: auto;
    height: 5.4rem;
}

.container .box form .logos .inner .social {
    display: flex;

    margin-left: auto;
    padding-top: 1rem;

    align-items: center;
}

.container .box form .logos .inner .social a {
    color: #ffffff;
    display: inline-block;

    width: 3rem;
    height: 2.4rem;
    margin: 0 0 0 0.6rem;
    opacity: 0;

    font-size: 1.8rem;
    line-height: 2.4rem;

    text-align: center;
    text-decoration: none;
}

.container .box form .logos .inner .social a.icon-youtube {
    font-size: 2.2rem;
    margin-right: 0.2rem;
}




.content .background .inner {
    opacity: 1;
    transform: scale(1.00);
    transition: 4.0s ease;
    transition-delay: 0.2s;
}

.content .container .box h2 {
    margin: 0 0 2.4rem;
    transition: 0.4s ease-out;
    transition-delay: 0.4s;
}

.content .container .box p {
    height: 12.8rem;
    transition: 0.4s ease-out;
    transition-delay: 0.6s;
}

.content .container .box p span.show {
    opacity: 1;
    transition: 0.2s ease-out;
    transform: rotate(0deg) translate3d(0px,0px,0);
}

.content .container .box form {
    height: 45rem;
    transition: 0.6s linear;
    transition-delay: 0.6s;
}

.content .container .box form:after,
.content .container .box form .input,
.content .container .box form .button,
.content .container .box form .logos .inner img,
.content .container .box form .logos .inner .social a {
    opacity: 1;
    transition: 0.4s ease-out;
}

.content .container .box form .input:nth-child(1) { transition-delay: 1.0s }
.content .container .box form .input:nth-child(2) { transition-delay: 1.2s }
.content .container .box form .input:nth-child(3) { transition-delay: 1.4s }
.content .container .box form .input:nth-child(4) { transition-delay: 1.6s }
.content .container .box form .button:nth-child(5) { transition-delay: 1.8s }

.content .container .box form:after { transition-delay: 2.0s }
.content .container .box form .logos .inner img { transition-delay: 2.2s }
.content .container .box form .logos .inner .social a { transition-delay: 2.2s }




@media (min-width: 992px) {

    .container .box p a:hover i {
        opacity: 1;
        transform: rotate(0deg) translateY(0rem);
    }

    .container .box form .button button,
    .container .box form .logos .inner .social a {
        cursor: pointer;
        transition: 0.2s ease;
    }

    .container .box form .button button:hover {
        padding: 0 3.5rem 0 4.5rem;
    }

    .container .box form .logos .inner .social a:hover {
        transform: scale(1.1);
    }

}


@media (max-width: 1540px) {

    .container {
        max-width: 1170px;
    }

}

@media (max-width: 1240px) {

    html,
    body {
        font-size: 9px;
        line-height: 9px;
    }

    .container {
        margin: 0 20px;
    }

}

@media (max-width: 992px) {

    .container {
        justify-content: center;
    }

}

@media (max-width: 487px) {

    .container .box p br {
        display: none;
    }

    .container .box p strong {
        display: block;
    }


}

@media (max-width: 360px) {

    html,
    body {
        font-size: 8px;
        line-height: 8px;
    }

}
