* {
    margin: 0;
    padding: 0;
    box-sizing: border-box
}

html {
    scroll-behavior: smooth
}

body {
    font-family: "Work Sans", sans-serif;
    background: #fff
}

body h1,
body h2,
body h3,
body h4,
body h5,
body h6,
body p {
    margin-bottom: 0
}

.btn-default,
button {
    transition: .3s all
}

.btn-default:hover,
button:hover {
    transform: scale(1.02)
}

#hero {
    padding-top: 74px;
    position: relative
}

#hero .arrow {
    position: absolute;
    bottom: -25px;
    left: 50%;
    transform: translateX(-50%)
}

#hero .container {
    display: flex;
    flex-direction: column;
    align-items: center
}

#hero .container .title {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-bottom: 61px
}

#hero .container .title .logo img {
    width: 224px
}

#hero .container .title .avatar {
    margin-top: 49px;
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 9px 24px;
    border-radius: 44px;
    background: #e0f7f4
}

#hero .container .title .avatar p {
    color: #00c3a5;
    font-size: .75rem;
    line-height: 1;
    font-weight: 500;
    line-height: normal;
    text-transform: uppercase
}

#hero .container .title .titulo {
    margin-top: 29px;
    display: flex;
    flex-direction: column;
    align-items: center
}

#hero .container .title .titulo h2 {
    color: #00c3a5;
    text-align: center;
    font-size: 2.84rem;
    font-style: normal;
    font-weight: 500;
    line-height: 101.564%;
    width: 70%
}

#hero .container .title .titulo .verified {
    display: flex;
    align-items: center;
    gap: 12px;
    border-radius: 37.888px;
    background: #e0f7f4;
    padding: 6px 24px 8px 24px;
    margin-top: 8px
}

#hero .container .title .titulo .verified h2 {
    width: 100%;
    line-height: 20px
}

#hero .content {
    background: #e0f7f4;
    padding-top: 22px;
    padding-bottom: 46px
}

#hero .content .container {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: 38px
}

#hero .content .container #formulario {
    background: #00c3a5;
    padding-top: 54px;
    padding-bottom: 70px;
    padding-left: 78px;
    padding-right: 57px;
    position: absolute;
    z-index: 999;
    right: 0;
    border-radius: 16px 0px 0px 16px;
    max-width: 42%
}

#hero .content .container #formulario.floating {
    position: fixed;
    top: 50%;
    transform: translateY(-50%)
}

#hero .content .container #formulario.bottom-fixed {
    position: fixed;
    top: auto;
    top: 50%;
    transform: translateY(-50%)
}

#hero .content .container #formulario .overlay {
    position: absolute;
    top: 0;
    right: 0
}

#hero .content .container #formulario .step-1,
#hero .content .container #formulario .step-2 {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 7px
}

#hero .content .container #formulario .step-1 .group-inputs,
#hero .content .container #formulario .step-2 .group-inputs {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 10px;
    width: 100%
}

#hero .content .container #formulario .step-1 .group-inputs .one,
#hero .content .container #formulario .step-2 .group-inputs .one {
    flex: 1 1 calc(30% - 10px)
}

#hero .content .container #formulario .step-1 .group-inputs .two,
#hero .content .container #formulario .step-2 .group-inputs .two {
    flex: 1 1 calc(60% - 10px)
}

#hero .content .container #formulario .step-1 .group-inputs input,
#hero .content .container #formulario .step-2 .group-inputs input {
    flex: 1 1 calc(50% - 10px)
}

#hero .content .container #formulario .container {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 30px;
    position: relative;
    z-index: 1
}

#hero .content .container #formulario .container h2 {
    color: #fff;
    font-size: 2.25rem;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    text-align: center
}

#hero .content .container #formulario .container form {
    display: flex;
    flex-direction: column;
    max-width: 88%;
    width: 100%;
    gap: 5px;
    position: relative;
    z-index: 1
}

#hero .content .container #formulario .container form .group-input {
    display: flex;
    gap: 11px;
    width: 100%
}

#hero .content .container #formulario .container form .group-input select {
    flex: 1 1 calc(30% - 11px)
}

#hero .content .container #formulario .container form .group-input input {
    flex: 1 1 calc(70% - 11px)
}

#hero .content .container #formulario .container form input::-webkit-outer-spin-button,
#hero .content .container #formulario .container form input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0
}

#hero .content .container #formulario .container form input[type=number] {
    -moz-appearance: textfield
}

#hero .content .container #formulario .container form input,
#hero .content .container #formulario .container form select {
    border-radius: 34.062px;
    border: .852px solid #fff;
    background: rgba(0, 94, 81, .37);
    height: 45.429px;
    color: #fff;
    font-size: .85rem;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    padding: 0 20px;
    width: 100%
}

#hero .content .container #formulario .container form input:focus-visible,
#hero .content .container #formulario .container form select:focus-visible {
    outline: none
}

#hero .content .container #formulario .container form input::-moz-placeholder,
#hero .content .container #formulario .container form select::-moz-placeholder {
    color: #fff;
    font-size: .85rem;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    text-transform: uppercase
}

#hero .content .container #formulario .container form input::placeholder,
#hero .content .container #formulario .container form select::placeholder {
    color: #fff;
    font-size: .85rem;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    text-transform: uppercase
}

#hero .content .container #formulario .container form button {
    display: flex;
    width: 136.247px;
    height: 41.725px;
    padding: 9.367px 20.437px 8.515px 20.437px;
    justify-content: center;
    align-items: center;
    gap: 8.515px;
    flex-shrink: 0;
    border-radius: 34.062px;
    background: #1b2734;
    border: 0px;
    display: flex;
    align-self: flex-end;
    margin-top: 13px;
    transition: .3s all
}

#hero .content .container #formulario .container form button:hover {
    background: #2a3e53
}

#hero .content .container #formulario .container form button p {
    color: #fff;
    text-align: center;
    font-size: 13.625px;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    text-transform: uppercase
}

#hero .content .container .conteudo {
    max-width: 60%;
    padding-top: 72px
}

#hero .content .container .conteudo .info {
    margin-bottom: 81px;
    max-width: 80%
}

#hero .content .container .conteudo .info p {
    color: #1b2734;
    font-size: 20px;
    font-style: normal;
    font-weight: 300;
    line-height: normal;
    max-width: 78%
}

#hero .content .container .conteudo .info p b {
    font-weight: 500
}

#hero .content .container .conteudo .info .btn-default {
    display: flex;
    padding: 16px 24px;
    justify-content: center;
    align-items: center;
    gap: 10px;
    border-radius: 40px;
    background: #00c3a5;
    text-decoration: none;
    margin-top: 27px;
    width: -moz-fit-content;
    width: fit-content;
    gap: 10px;
    transition: .3s all
}

#hero .content .container .conteudo .info .btn-default:hover {
    background: #01a088
}

#hero .content .container .conteudo .info .btn-default p {
    color: #fff;
    font-size: .95rem;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    text-transform: uppercase;
    width: 100%;
    max-width: 100%
}

#sobre {
    padding: 58px 0 94px 0
}

#sobre .container {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: 37px
}

#sobre .container .info h4 {
    color: #00c3a5;
    font-size: 1.5rem;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    margin-bottom: 16px
}

#sobre .container .info p {
    color: #1b2734;
    font-size: 1rem;
    font-weight: 300;
    line-height: normal
}

#sobre .container .info p b {
    font-weight: 500
}

#sobre .container .statics {
    display: flex;
    flex-direction: column;
    gap: 14px
}

#sobre .container .statics .item {
    display: flex;
    align-items: center;
    display: inline-flex;
    padding: 9px 24px;
    align-items: center;
    gap: 16px;
    border-radius: 44px;
    background: #00c3a5;
    width: -moz-fit-content;
    width: fit-content
}

#sobre .container .statics .item h5 {
    color: #fff;
    font-size: 1.25rem;
    font-style: normal;
    font-weight: 500;
    line-height: normal
}

#sobre .container .statics .item p {
    color: #fff;
    font-size: .75rem;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    text-transform: uppercase
}

#sobre .container .statics .two {
    background: #e0f7f4
}

#sobre .container .statics .two h5 {
    color: #00c3a5
}

#sobre .container .statics .two p {
    color: #1b2734
}

#informacoes {
    padding: 56px 0 0 0;
    background: #e0f7f4;
    position: relative
}

#informacoes .container {
    display: flex;
    flex-direction: column;
    align-items: flex-start
}

#informacoes .container .content {
    max-width: 50%;
    display: flex;
    flex-direction: column;
    align-items: center
}

#informacoes .container .content .img_informacoes {
    width: 100%
}

#informacoes .container .content h2 {
    text-align: center;
    color: #00c3a5;
    text-align: center;
    font-size: 2.25rem;
    font-style: normal;
    font-weight: 500;
    line-height: normal
}

#informacoes .container .content .list-items {
    padding-top: 46px;
    padding-bottom: 39px;
    display: flex;
    flex-wrap: wrap;
    gap: 15px
}

#informacoes .container .content .list-items .item {
    display: flex;
    padding: 20.507px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 5.981px;
    border-radius: 13.672px;
    background: #fff;
    flex: 1 1 calc(50% - 15px);
    transition: .3s all
}

#informacoes .container .content .list-items .item:hover {
    transform: translateY(-5px)
}

#informacoes .container .content .list-items .item img {
    width: 43px
}

#informacoes .container .content .list-items .item h5 {
    color: #00c3a5;
    text-align: center;
    font-size: .96rem;
    font-style: normal;
    font-weight: 500;
    line-height: normal
}

#informacoes .container .content .list-items .item p {
    color: #1b2734;
    text-align: center;
    font-size: .74rem;
    font-style: normal;
    font-weight: 300;
    line-height: normal
}

#informacoes .container .content .list-items .item p b {
    font-weight: 500
}

#informacoes .container .content .btn-default {
    display: inline-flex;
    padding: 16px 24px;
    justify-content: center;
    align-items: center;
    gap: 10px;
    border-radius: 40px;
    background: #1b2734;
    text-decoration: none;
    margin-bottom: 45px;
    transition: .3s all
}

#informacoes .container .content .btn-default:hover {
    background: #2a3e53
}

#informacoes .container .content .btn-default p {
    color: #fff;
    text-align: center;
    font-size: 1rem;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    text-transform: uppercase
}

footer {
    display: flex;
    justify-content: center;
    padding: 39px 0
}

.loading-wrapper {
    margin-top: 5px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.spinner {
    width: 24px;
    height: 24px;
    border: 3px solid rgba(0, 0, 0, 0.1);
    border-top: 3px solid #007bff;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

.autocomplete-list {
  display: none;
  position: absolute;
  top: 100%; 
  left: 0;
  right: 0;
  background: #fff;
  border: 1px solid #ccc;
  border-top: none;
  max-height: 200px;
  overflow-y: auto;
  z-index: 1000;
  list-style: none;
  margin: 0;
  padding: 0;
}

.autocomplete-list li {
  padding: 8px 12px;
  cursor: pointer;
}

.autocomplete-list li:hover {
  background: #f0f0f0;
}


@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}


@media(max-width: 1400px) {
    #hero .content .container #formulario {
        padding-left: 58px;
        padding-right: 35px
    }

    #hero .content .container #formulario .container h2 {
        font-size: 2rem
    }
}

@media(max-width: 1200px) {
    #hero .container #formulario {
        padding-left: 35px !important;
        padding-right: 35px !important
    }

    #hero .container #formulario .container h2 {
        font-size: 1.8rem
    }

    #hero .container #formulario .container h2 br {
        display: none
    }

    #hero .container .title .titulo h2 {
        width: 97%
    }

    #hero .content .container .conteudo {
        max-width: 100%
    }

    #hero .content .container .image {
        flex: 1 1 calc(60% - 38px)
    }

    #hero .content .container .image img {
        width: 100%
    }

    #hero .content .container .info {
        flex: 1 1 calc(40% - 38px)
    }

    #hero .content .container .info p {
        max-width: 100%
    }

    #hero .content .container .info p br {
        display: none
    }

    #sobre .container {
        gap: 65px
    }

    #informacoes .container .list-items {
        flex-wrap: wrap;
        justify-content: center
    }

    #informacoes .container .list-items .item {
        flex: 1 1 calc(50% - 15px);
        max-width: calc(50% - 15px)
    }
}

@media(max-width: 990px) {
    #hero {
        padding-top: 595px
    }

    #hero .container .conteudo .info {
        max-width: 100% !important
    }

    #hero .container #formulario {
        top: 0 !important;
        max-width: 100%;
        padding-left: 20px;
        padding-right: 20px;
        border-radius: 0px 0px 16px 16px;
        transform: none !important;
        padding-top: 40px;
        padding-bottom: 40px;
        position: absolute !important;
        max-width: 100% !important;
        width: 100%
    }

    #hero .container #formulario form .form-buttons {
        align-self: center
    }

    #hero .container #formulario .container h2 {
        font-size: 1.7rem
    }

    #hero .container .title .titulo h2 {
        width: 100%;
        font-size: 2.1rem
    }

    #hero .container .title .titulo .verified img {
        width: 35px
    }

    #hero .content .container {
        flex-direction: column;
        gap: 65px
    }

    #hero .content .container .image {
        order: 2;
        flex: 1 1 calc(100% - 38px)
    }

    #hero .content .container .image img {
        width: 100%
    }

    #hero .content .container .info {
        flex: 1 1 calc(40% - 38px);
        display: flex;
        flex-direction: column;
        align-items: center;
        order: 1
    }

    #hero .content .container .info .btn-default {
        margin-top: 40px
    }

    #hero .content .container .info p {
        max-width: 100%;
        text-align: center
    }

    #hero .content .container .info p br {
        display: none
    }

    #sobre .container {
        gap: 65px;
        flex-direction: column
    }

    #sobre .container .info {
        display: flex;
        flex-direction: column;
        align-items: center
    }

    #sobre .container .info p {
        text-align: center
    }

    #sobre .container .info p br {
        display: none
    }

    #sobre .container .statics {
        flex-direction: row
    }

    #informacoes .container .content {
        max-width: 100%
    }

    #informacoes .container .list-items {
        flex-wrap: wrap;
        justify-content: center
    }

    #informacoes .container .list-items .item {
        flex: 1 1 calc(50% - 15px);
        max-width: calc(50% - 15px)
    }

    #formulario .container {
        flex-direction: column
    }

    #formulario .container h2 {
        position: relative;
        z-index: 1;
        text-align: center;
        margin-bottom: 0px
    }

    #formulario .container h2 br {
        display: none
    }

    #formulario .container form {
        max-width: 70%
    }
}

@media(max-width: 768px) {
    #hero {
        padding-top: 575px
    }

    #hero .content .container .conteudo {
        padding-top: 39px
    }

    #hero .content .container .conteudo .info {
        max-width: 100%
    }

    #hero .content .container .conteudo .info p {
        max-width: 100%
    }

    #hero .content .container #formulario {
        top: 0 !important;
        max-width: 100%;
        padding-left: 20px;
        padding-right: 20px;
        border-radius: 0px 0px 16px 16px;
        transform: none !important;
        padding-top: 40px;
        padding-bottom: 40px;
        position: absolute !important
    }

    #hero .content .container #formulario form .form-buttons {
        align-self: center
    }

    #hero .content .container #formulario .container h2 {
        font-size: 1.7rem
    }

    #sobre {
        padding: 58px 0 65px 0
    }

    #sobre .container {
        gap: 51px;
        align-items: center
    }

    #sobre .container .statics {
        flex-direction: column;
        align-items: center
    }

    #informacoes .container .content {
        max-width: 100%
    }

    #informacoes .container .content .list-items .item {
        flex: 1 1 100%
    }

    #informacoes .container .img_informacoes {
        width: 100%
    }

    #formulario .container form {
        max-width: 87%
    }
}

@media(max-width: 576px) {
    #hero .container .title .titulo h2 {
        font-size: 1.8rem
    }

    #informacoes .container .list-items .item {
        flex: 1 1 calc(100% - 15px);
        max-width: calc(100% - 15px)
    }

    #formulario .container {
        gap: 43px
    }

    #formulario .container h2 {
        font-size: 1.6rem
    }

    #formulario .container form {
        max-width: 90%
    }

    #hero .content .container #formulario .container form .group-input select {
        flex: 1 1 calc(40% - 11px)
    }
}

@media(max-width: 400px) {
    #sobre .container .statics .two p br {
        display: none
    }

    #sobre .container .statics .two h5 {
        white-space: nowrap
    }

    #hero .content .container #formulario .container form .group-input select {
        flex: 1 1 calc(40% - 11px)
    }

    #hero .container #formulario {
        padding-left: 15px !important;
        padding-right: 15px !important
    }
}

#formulario form .step-1,
#formulario form .step-2 {
    position: absolute;
    width: 100%;
    visibility: hidden;
    opacity: 0;
    transform: translateX(20px);
    transition: opacity .2s ease, transform .2s ease, visibility .4s
}

#formulario form .active {
    position: relative;
    visibility: visible;
    opacity: 1;
    transform: translateX(0);
    display: flex;
    flex-direction: column;
    gap: 5px
}

#formulario form .form-buttons {
    display: flex;
    justify-content: flex-end;
    align-self: flex-end;
    margin-top: 13px;
    gap: 15px
}

#formulario form .prev-step {
    display: flex;
    width: 136.247px;
    height: 41.725px;
    padding: 9.367px 20.437px 8.515px 20.437px;
    justify-content: center;
    align-items: center;
    gap: 8.515px;
    flex-shrink: 0;
    border-radius: 34.062px;
    background: #1b2734;
    border: 0px;
    transition: .3s all;
    align-self: flex-start
}

#formulario form .prev-step:hover {
    background: #2a3e53
}

#formulario form .prev-step p {
    color: #fff;
    text-align: center;
    font-size: 13.625px;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    text-transform: uppercase
}

#formulario form .submit-form {
    display: flex;
    width: 136.247px;
    height: 41.725px;
    padding: 9.367px 20.437px 8.515px 20.437px;
    justify-content: center;
    align-items: center;
    gap: 8.515px;
    flex-shrink: 0;
    border-radius: 34.062px;
    background: #00c3a5;
    border: 0px;
    transition: .3s all;
    align-self: flex-end
}

#formulario form .submit-form:hover {
    background: #00a58c
}

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


#hero .content .container #formulario .container form select {
    text-transform: uppercase;
    appearance: none;
    /* -webkit-appearance: none; */
    -moz-appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='18' height='19' viewBox='0 0 18 19' fill='none'><path d='M8.10101 12.8491L2.76765 6.75283C2.13823 6.03556 2.64977 4.90906 3.60502 4.90906H14.2718C14.4855 4.90887 14.6948 4.97032 14.8746 5.08603C15.0544 5.20174 15.197 5.36682 15.2853 5.56149C15.3737 5.75616 15.4041 5.97217 15.3728 6.18366C15.3416 6.39515 15.25 6.59314 15.1091 6.75394L9.77575 12.8479C9.67138 12.9674 9.54265 13.0631 9.39822 13.1287C9.2538 13.1943 9.09701 13.2282 8.93838 13.2282C8.77976 13.2282 8.62297 13.1943 8.47854 13.1287C8.33412 13.0631 8.20539 12.9674 8.10101 12.8479V12.8491Z' fill='white'/></svg>");
    background-repeat: no-repeat;
    background-position: right 14px center;
    background-size: 18px 19px;
}

.group-checkbox {
    margin-top: 13px;
    display: flex;
    flex-direction: column;
    gap: 7px;
    margin-left: 10px;
}

.group-checkbox label {
    display: flex;
    align-items: center;
    gap: 10px;
}

.group-checkbox label input[type="checkbox"] {
    width: 16px !important;
    height: 16px !important;
    accent-color: rgba(0, 94, 81, .37);
}

.group-checkbox label p {
    font-size: .85rem;
    color: #fff;
}

#informacoes .container .content .list-items .item p {
    font-size: 1rem;
}

#informacoes .container .content .list-items .item h5 {
    font-size: 1.1rem;
}

@media (max-width: 768px) {
    #informacoes .container .content .list-items .item h5 br {
        display: none;
    }

    #hero .content .container .conteudo {
        order: 2;
    }

    #hero .content .container #formulario {
        position: relative !important;
        order: 1;
    }

    #hero {
        padding-top: 75px;
    }

    #hero .content .container {
        padding: 0px;
    }

    #hero .content {
        padding-top: 0px;
    }

    #hero .content .container .conteudo {
        padding-top: 10px;
    }

    #hero .container #formulario {
        padding-left: 20px !important;
        padding-right: 20px !important;
    }
}

@media (max-width: 576px) {
    #hero .container .title .titulo h2 {
        font-size: 1.7rem;
    }
}