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

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

[hidden] {
    display: none
}

a {
    line-height: normal
}

body {
    line-height: 1
}

menu, ol, ul {
    list-style: none
}

blockquote, q {
    quotes: none
}

blockquote:after, blockquote:before, q:after, q:before {
    content: "";
    content: none
}

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

* {
    box-sizing: border-box
}

header {
    transition: all .3s ease-in-out;
    padding: 30px 0;
    position: fixed;
    width: 100%;
    top: 0;
    left: 0;
    z-index: 10 !important
}

.top .abs {
    padding-top: 100px;
}

header .btn-msd {
    font-size: 12px;
    color: #fff;
    font-family: roc-grotesk-wide, sans-serif;
    text-decoration: none
}

header .container {
    max-width: 1360px
}

header.act {
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1);
    padding: 12px 0;
    background-color: #466857b0 !important;
    backdrop-filter: blur(2px);
    border-bottom-left-radius: 30px;
    border-bottom-right-radius: 30px;
}

header .menuMobile {
    display: flex;
    align-items: center
}

.teaser header {
    background: #3d2416;
    background: linear-gradient(180deg, #3d2416, rgba(186, 158, 46, 0));
    height: 117px;
    z-index: 6
}

.teaser header.act {
    height: auto;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, .1);
    padding: 12px 0;
    background: rgba(131, 117, 94, .75) !important;
    backdrop-filter: blur(2px)
}

@media (max-width: 890px) {

    header:not(.act) .traducao {
        display: none !important;
    }
    .flex-images .translate {
        padding: 8px !important;
    }

    .video {
        height: auto !important;
        min-height: auto !important;
    }

    .video > div {
        padding: 0px !important;
    }

    .video iframe {
        position: relative !important;
        aspect-ratio: 16 / 9;
        height: auto !important;
    }

    .menu {
        backdrop-filter: blur(2px);
        position: fixed;
        top: 50px;
        right: -100vw;
        max-width: 100vw;
        display: block !important;
        height: 100vh;
        background-color: rgba(131, 117, 94, .65);
        width: 100%;
        transition: all .3s ease-in-out
    }

    .menu > .flex {
        padding: 60px;
        flex-direction: column
    }

    header .menu {
        top: 110px
    }

    header.act .menu {
        top: 50px
    }

    header {
        max-width: 100vw
    }

    header.act .menu.act, header .menu.act {
        right: 0
    }

    .menu a, .menu a.btn {
        font-size: 16px
    }
}

.top {
    color: #fff;
    position: relative
}

.top .background {
    max-height: 100vh;
    height: 100vh;
    object-position: bottom;
    min-height: 600px;
    object-fit: cover;
    width: 100%;
    display: block
}

.top .sticky {
    position: sticky;
    height: 35vh;
    top: 0
}

.top .abs, .top .sticky .background {
    position: absolute;
    top: 0;
    left: 0
}

.top .abs {
    width: 100%;
    height: 100vh
}

.top .content {
    position: relative;
    max-width: 807px;
    box-sizing: border-box;
    padding: 57px 60px
}

.top .content p {
    font-size: 20px
}

.top .content p, .top .content p span {
    color: #fff;
    font-family: roc-grotesk-wide, sans-serif
}

.top .content p span {
    display: block;
    margin-top: 26px;
    font-size: 12px
}

.top .content p strong {
    color: #fff;
    font-size: 20px;
    font-family: roc-grotesk-wide, sans-serif;
    font-weight: 600
}

.top .line-1 {
    position: absolute;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #bf3127
}

.top .line-1 .container {
    position: relative
}

.top .line-1 .line-internal {
    content: "";
    display: block;
    position: absolute;
    top: -3px;
    left: 0;
    height: 6px;
    width: 375px;
    background-color: #bf3127
}

.top .sd {
    padding-bottom: 60px
}

.top .form {
    z-index: 2;
    min-width: 376px;
    max-width: 376px;
    width: 100%;
    padding: 34px 43px;
    box-sizing: border-box;
    background-color: #f9f9f9;
    border-radius: 19px
}

.top h2 {
    letter-spacing: 1px;
    text-align: center;
    font-size: 15px;
    text-transform: uppercase;
    color: #83755e
}

.top h2, h1 strong {
    font-family: roc-grotesk-wide, sans-serif
}

h1 strong {
    font-weight: 600
}

.teaser .top .abs-back {
    position: absolute;
    bottom: 0;
    width: 100%;
    height: 299px;
    background-image: url(../images/background-top.png);
    display: flex
}

.teaser .top .abs-back h1 {
    margin-top: 64px;
    max-width: 330px;
    font-size: 24px;
    font-family: roc-grotesk-wide, sans-serif;
    line-height: 1.5;
    color: #83755e;
    text-transform: uppercase
}

.form-bottom {
    padding: 110px 0;
    position: relative;
    z-index: 2;
    background-color: #fff
}

.form-bottom .flex {
    gap: 24px;
    display: flex
}

.form-bottom h2 {
    width: 100%;
    color: #83755e;
    font-size: 20px;
    text-transform: uppercase;
    text-align: center;
    font-family: roc-grotesk-wide, sans-serif
}

.form-bottom h2:after {
    display: block;
    content: "";
    max-width: 76px;
    height: 1px;
    width: 100%;
    background-color: #83755e;
    margin: 34px auto 0
}

.form-bottom .form {
    max-width: 680px;
    margin: 75px auto 0
}

.form-bottom .form input[type=email], .form-bottom .form input[type=tel], .form-bottom .form input[type=text] {
    font-family: roc-grotesk-wide, sans-serif;
    font-size: 12px;
    padding-bottom: 16px;
    padding-top: 16px
}

.form-bottom .form .btn-primary {
    padding: 16px 32px
}

*, html {
    scroll-behavior: smooth
}

.mt-12 {
    margin-top: 12px
}

.mt-14 {
    margin-top: 14px
}

.mt-16 {
    margin-top: 16px
}

.mt-18 {
    margin-top: 18px
}

.mt-20 {
    margin-top: 20px
}

.mt-22 {
    margin-top: 22px
}

.mt-24 {
    margin-top: 24px
}

.mt-26 {
    margin-top: 26px
}

.mt-28 {
    margin-top: 28px
}

.mt-30 {
    margin-top: 30px
}

.mt-32 {
    margin-top: 32px
}

.mt-34 {
    margin-top: 34px
}

.mt-36 {
    margin-top: 36px
}

.mt-38 {
    margin-top: 38px
}

.mt-40 {
    margin-top: 40px
}

.mt-42 {
    margin-top: 42px
}

.mt-44 {
    margin-top: 44px
}

.mt-46 {
    margin-top: 46px
}

.mt-48 {
    margin-top: 48px
}

.mt-56 {
    margin-top: 56px
}

body, html {
    scroll-behavior: smooth
}

*, body {
    font-family: roc-grotesk, sans-serif;
    box-sizing: border-box
}

.flex-align-center {
    display: flex;
    align-items: center
}

.flex-between {
    width: 100%;
    display: flex;
    justify-content: space-between
}

.container {
    max-width: 1371px;
    margin: 0 auto;
    width: 100%
}

input[type=email], input[type=tel], input[type=text] {
    font-family: PP Mori, sans-serif !important;
    width: 100%;
    background-color: transparent;
    appearance: none;
    outline: none;
    border: none;
    border-bottom: 1px solid #83755e;
    height: 20px;
    font-size: 12px;
    color: #83755e;
    letter-spacing: 1px
}

input[type=email]::placeholder, input[type=tel]::placeholder, input[type=text]::placeholder {
    color: #9a8e87;
    font-family: PP Mori, sans-serif
}

input[type=checkbox] {
    appearance: none;
    width: 10px;
    height: 10px;
    border: 1px solid #9a8e87
}

.flex-center {
    display: flex;
    justify-content: center
}

.flex-align-end {
    align-items: flex-end
}

.neg {
    background-color: #fff;
    position: relative;
    z-index: 3
}

.teaser .neg {
    padding-bottom: 145px
}

.top {
    min-height: 100vh
}

.teaser .top .background {
    height: calc(100vh - 298px)
}

.sd .pause {
    position: absolute;
    bottom: 60px;
    left: 60px;
    cursor: pointer
}

.sd .pause svg {
    max-width: 32px;
    height: auto
}

.sd .pause g, .sd .pause path, .sd .pause svg {
    border-radius: 0 !important
}

.sd .pause path {
    fill: #fff
}

.mid {
    background-color: #fff;
    position: relative;
    z-index: 2;
    height: auto !important;
    min-height: auto !important
}

.mid .embreve {
    min-height: 467px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%
}

.mid .embreve .container {
    max-width: 740px !important
}

.mid .embreve h2 {
    width: 100%;
    color: #83755e;
    font-size: 32px;
    text-transform: uppercase;
    text-align: center;
    font-family: roc-grotesk-wide, sans-serif
}

.mid .embreve p, .mid .embreve p strong {
    font-family: roc-grotesk-wide, sans-serif;
    text-align: center;
    text-transform: uppercase;
    font-size: 20px;
    color: #83755e
}

.mid .embreve p strong {
    font-weight: 600
}

.teaser .mid .embreve {
    min-height: 285px
}

.btn-primary {
    appearance: none;
    border: none;
    outline: none;
    border-radius: 28px;
    background-color: #bf3127;
    color: #fff;
    padding: 16px 52px;
    font-size: 12px;
    text-decoration: none;
    font-family: Inter, sans-serif;
    font-weight: 600;
    transition: all .3s ease-in-out;
    cursor: pointer;
    display: inline-block
}

.btn-primary:hover {
    background-color: #79482c
}

.btn {
    transition: all .3s ease-in-out
}

.btn:hover {
    background-color: #79482c !important
}

form label span {
    display: contents !important
}

form a, form label, form label span {
    font-family: PP Mori, sans-serif;
    display: inline-block;
    font-size: 12px;
    letter-spacing: .6px;
    color: #3d2416;
    line-height: 16px
}

form a input[type=checkbox], form label input[type=checkbox], form label span input[type=checkbox] {
    position: relative;
    top: 4px;
    transition: all .3s ease-in-out
}

form a input[type=checkbox]:checked, form label input[type=checkbox]:checked, form label span input[type=checkbox]:checked {
    background-color: #83755e;
    border-color: #83755e
}

header {
    z-index: 4
}

@media (min-width: 890px) {
    .min-h {
        min-height: calc(100vh - 108px);
        display: flex;
        align-items: center
    }

    .min-h .hidden-content {
        position: relative
    }

    .min-h .hidden-content #family {
        position: relative;
        top: -9vw
    }
}

.hidden {
    aspect-ratio: 1371/4000
}

.hidden .sticky {
    position: sticky;
    top: 80px
}

.options {
    padding-bottom: 45px
}

.options .col:last-child, .options .col:last-child img {
    border-top-right-radius: 20px;
    border-bottom-right-radius: 20px
}

.options .col:first-child, .options .col:first-child img {
    border-top-left-radius: 20px;
    border-bottom-left-radius: 20px
}

.options .flex {
    display: flex;
    aspect-ratio: 1371/803
}

.options .flex .col {
    transition: all .3s ease-in-out;
    position: relative;
    flex: 1;
    overflow: hidden
}

.options .flex .col .abs {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    padding: 60px;
    background: transparent
}

.options .flex .col .abs .cont {
    position: relative;
    z-index: 1
}

.options .flex .col .abs:after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    transition: all 1s ease-in-out;
    width: 0;
    height: 100%;
    background: linear-gradient(90deg, rgba(0, 0, 0, .36), hsla(0, 0%, 100%, 0))
}

.options .flex .col .abs svg {
    margin-top: 161px
}

.options .flex .col .abs p {
    transition: all .3s ease-in-out;
    opacity: 0;
    margin-top: 50px;
    font-family: roc-grotesk-wide, sans-serif;
    font-weight: 400;
    font-size: 15px;
    color: #fff;
    max-width: 334px
}

.options .flex .col img {
    transition: all .3s ease-in-out;
    display: block
}

@media (min-width: 769px) {
    .options .flex .col:hover p {
        opacity: 1
    }

    .options .flex .col:hover .abs {
        border-top-left-radius: 20px;
        border-bottom-left-radius: 20px
    }

    .options .flex .col:hover .abs:after {
        width: 100%
    }
}

.options .flex .col img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: left
}

.options .flex .col:last-child {
    position: relative;
    z-index: 2
}

.options .flex .col:last-child img {
    object-fit: cover;
    object-position: right
}

.options .flex .col:last-child .abs {
    justify-content: flex-start;
    border-top-right-radius: 20px;
    border-bottom-right-radius: 20px;
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    transform: rotate(180deg)
}

.options .flex .col:last-child .abs .cont {
    transform: rotate(180deg)
}

.options .flex .col:last-child .abs:after {
    right: 0;
    float: right
}

.options .flex .col:last-child .cont {
    max-width: 300px
}

.flex {
    display: flex
}

.gap-27 {
    gap: 27px
}

.flex-end {
    display: flex;
    justify-content: flex-end
}

a.btn {
    padding: 9px 10px 7px;
    background-color: #bf3127;
    border-radius: 22px
}

.menu a, .menu a.btn, a.btn {
    font-family: roc-grotesk-wide, sans-serif;
    font-size: 12px;
    color: #fff;
    text-decoration: none
}

.menu a.btn {
    padding: 7px 10px;
    background-color: #bf3127;
    border-radius: 22px
}

footer {
    padding: 114px 0;
    background: url(../images/background.png);
    background-size: cover
}

footer .flex-between.bp {
    padding-bottom: 58px;
    border-bottom: 1px solid #fff
}

.form-bottom h2 {
    font-size: 32px;
    color:#4d4d4d !important;
    font-weight: bold;
}

footer a {
    font-size: 14px;
    display: block;
    text-decoration: none;
    color: #fff;
    font-family: PP Mori, sans-serif
}

.text-uppercase {
    text-transform: uppercase
}

.gap-24 {
    gap: 24px
}

.video {
    aspect-ratio: 1371/803;
    z-index: 4
}

.video .gu {
    width: 100%;
    height: 100%;
    overflow: hidden
}

.video iframe {
    width: calc(100% + 55px);
    height: 100%
}

.hidden-content {
    aspect-ratio: 1371/500;
    overflow: hidden;
    border-radius: 20px
}

.video {
    aspect-ratio: 1371/500;
    box-sizing: border-box
}

@media (min-width: 1400px) {
    footer .container, header .container {
        max-width: 100%;
        padding: 0 104px;
        margin: 0 auto
    }
}

@media (max-width: 1400px) {
    .container {
        max-width: 1263px !important;
        padding: 0 20px;
        margin: 0 auto
    }

    .neg > .container {
        max-width: 1100px !important;
        padding: 0
    }

    .video iframe {
        width: calc(100% + 50px)
    }

    .options .container {
        padding: 0
    }
}

.mobile {
    display: none !important
}

@media (max-width: 890px) {
    .mobile {
        display: flex !important
    }
}

.whatsapp {
    position: fixed;
    bottom: 15px;
    right: 15px;
    z-index: 9
}

.loading-box {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    background: rgba(33, 33, 33, .99);
    z-index: 999
}

.gooey {
    position: relative;
    width: 142px;
    height: 40px
}

.gooey .dot {
    position: absolute;
    width: 16px;
    height: 16px;
    top: 12px;
    left: 15px;
    background: #fff;
    border-radius: 50%;
    -webkit-animation: dot 1.5s infinite;
    animation: dot 1.5s infinite
}

.gooey .dot, .gooey .dots {
    -webkit-transform: translateX(0);
    transform: translateX(0)
}

.gooey .dots {
    margin-top: 12px;
    margin-left: 31px;
    -webkit-animation: dots 1.5s infinite;
    animation: dots 1.5s infinite
}

.gooey .dots span {
    display: block;
    float: left;
    width: 16px;
    height: 16px;
    margin-left: 16px;
    background: #fff;
    border-radius: 50%
}

@-webkit-keyframes dot {
    50% {
        -webkit-transform: translateX(96px);
        transform: translateX(96px)
    }
}

@keyframes dot {
    50% {
        -webkit-transform: translateX(96px);
        transform: translateX(96px)
    }
}

@-webkit-keyframes dots {
    50% {
        -webkit-transform: translateX(-31px);
        transform: translateX(-31px)
    }
}

@keyframes dots {
    50% {
        -webkit-transform: translateX(-31px);
        transform: translateX(-31px)
    }
}

@-webkit-keyframes move {
    0% {
        -webkit-transform: translateY(-15px);
        transform: translateY(-15px)
    }
    to {
        -webkit-transform: translateY(5px);
        transform: translateY(5px)
    }
}

@keyframes move {
    0% {
        -webkit-transform: translateY(-15px);
        transform: translateY(-15px)
    }
    to {
        -webkit-transform: translateY(5px);
        transform: translateY(5px)
    }
}

.col1, .col2 {
    transition: none !important
}

.col1 > *, .col2 > *, .sd#mbo {
    height: 100%
}

.sd#mbo {
    position: absolute;
    top: 0;
    width: 100%
}

.sd#mbo, .sd#mbo * {
    border-radius: 20px
}

#family {
    position: relative;
    z-index: 9 !important
}

.enable.col {
    border-radius: 20px
}

.logo, .logo img {
    display: block
}

.design {
    position: relative;
    z-index: 2;
    background-color: #fff;
    padding: 112px 0
}

.design .container {
    max-width: 1165px
}

.design h2 {
    font-size: 36px;
    line-height: 1.1;
    color: #83755e;
    text-transform: uppercase;
    max-width: 423px;
    font-family: roc-grotesk-wide, sans-serif
}

.design p, .design p strong {
    font-family: Inter, sans-serif;
    font-size: 16px;
    line-height: 24px;
    color: #83755e
}

.design p strong {
    font-weight: 600
}

.design p + p {
    margin-top: 16px
}

.design .flex {
    justify-content: space-between
}

.design .col {
    flex: 1
}

.design .col:last-child {
    max-width: 480px
}

.video-as {
    padding: 92px 0;
    background-color: #fff;
    position: relative;
    z-index: 2;
    height: 400vh;
    transition: background-color .3s ease-in-out
}

.video-as.act {
    background-color: #80715e;
    z-index: 9
}

.video-as .container {
    position: sticky;
    top: 0;
    max-width: 100%;
    min-height: 100vh;
    display: flex;
    align-items: center
}

.video-as #vimeo01, .video-as #vimeo02 {
    transform: scale(.8)
}

.video-as iframe {
    display: block;
    aspect-ratio: 1371/481;
    height: auto;
    width: 100%
}

.video-as .play {
    position: absolute;
    top: calc(50% - 38px);
    left: calc(50% - 38px)
}

.topo-maringa {
    position: relative;
    overflow: hidden
}

.topo-maringa .sad {
    position: absolute;
    top: 0;
    width: 100%;
    height: 100%
}

.topo-maringa .sad img {
    position: relative;
    z-index: 4
}

.topo-maringa .sd {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 4;
    height: 100%;
    background: rgba(0, 0, 0, .5)
}

.topo-maringa .relative {
    position: relative;
    z-index: 3
}

.topo-maringa .line-1 {
    top: 35vh;
    z-index: 4
}

.topo-maringa .line-1 span {
    position: relative;
    z-index: 9;
    top: -2px;
    left: 15%;
    height: 6px;
    background-color: #bf3127;
    width: 260px;
    display: block
}

.topo-maringa h1 {
    max-width: 441px;
    margin-bottom: 32px;
    font-style: normal;
    font-weight: 400;
    line-height: 46px;
    text-transform: uppercase
}

.topo-maringa h1, .topo-maringa h1 strong {
    color: #fff;
    font-family: roc-grotesk-wide, sans-serif;
    font-size: 32px
}

.topo-maringa h1 strong {
    font-weight: 600
}

.topo-maringa .container-fix {
    max-width: calc(100vw - 360px);
    margin: 0 auto;
    width: 100%
}

.topo-maringa img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    min-height: 100%;
    position: absolute;
    top: 0;
    left: 0
}

.topo-maringa .container {
    max-width: 1140px
}

.topo-maringa .relative-fix {
    position: relative;
    width: 100%
}

.topo-maringa .form .line-1 {
    z-index: 2;
    display: block;
    position: absolute;
    width: 100%;
    left: 0;
    height: 1px;
    bottom: 200px;
    background-color: #bf3127
}

.topo-maringa .form .line-1 span {
    top: -2px;
    height: 6px;
    position: relative;
    background-color: #bf3127;
    width: 260px;
    display: block
}

.topo-maringa .form .line-2 {
    left: 0;
    z-index: 2;
    position: absolute;
    display: block;
    width: 100%;
    bottom: 97px;
    height: 1px;
    background-color: #bf3127
}

.topo-maringa .form .line-2 span {
    top: -2px;
    height: 6px;
    position: relative;
    background-color: #bf3127;
    width: 260px;
    left: 30vw;
    display: block
}

.topo-maringa .form .relative {
    background: #fff;
    box-shadow: 0 11px 24.8px 0 rgba(0, 0, 0, .05);
    position: relative;
    z-index: 2;
    min-width: 376px;
    max-width: 376px;
    width: 100%;
    padding: 34px 43px;
    box-sizing: border-box;
    background-color: #f9f9f9;
    border-radius: 19px
}

.topo-maringa .form .relative h2 {
    font-family: roc-grotesk-wide, sans-serif;
    letter-spacing: 1px;
    text-align: center;
    font-size: 15px;
    text-transform: uppercase;
    color: #83755e
}

.topo-maringa .abs {
    padding: 180px 0;
    display: flex;
    align-items: center;
    width: 100%;
    min-height: 100vh;
    height: 100%
}

@media (max-width: 768px) {
    .topo-maringa .container-fix {
        max-width: calc(100% - 40px)
    }
}

.jardins .video-as iframe {
    aspect-ratio: 16/7
}

.jardins header.act .menu-teaser .traducao .btn-msd path {
    fill: white !important
}

.jardins header.act .menu-teaser .traducao .btn-msd, .jardins header.act .menu-teaser a:not(.btn) {
    color: white !important;
    font-weight: 700
}

.jardins .menu-teaser a {
    text-transform: uppercase;
    text-decoration: none;
    color: #fff;
    font-size: 12px
}

.jardins .logo {
    transition: all .3s ease-in-out
}

.jardins header:not(.act) .logo {
    opacity: 0
}

.jardins .btn {
    background-color: #647867;
    padding: 12px;
    border-radius: 8px
}

.jardins .localizacao-nova {
    overflow: hidden
}

.jardins .btn-primary {
    background-color: #466857;
    padding: 12px 24px;
    border-radius: 8px
}

.jardins * {
    font-family: "Mazzard H", sans-serif !important
}

.jardins .whatsapp {
    z-index: 101
}

.jardins .para-nos {
    padding: 137px 0
}

.jardins .para-nos, .jardins .video-as.act {
    background-color: #f3e7d7;
    position: relative
}

.jardins .video-as.act {
    z-index: 99
}

.jardins .para-nos .container {
    max-width: 1080px !important
}

.jardins .para-nos .flex {
    align-items: center;
    justify-content: space-between
}

.jardins .para-nos .flex .col:last-child {
    max-width: 360px
}

.jardins .para-nos .flex p {
    font-weight: 300;
    color: #524846;
    font-size: 24px;
    text-align: right
}

.jardins .para-nos .flex p + p {
    margin-top: 24px
}

.jardins .para-nos .flex h3 {
    text-align: right;
    margin-top: 60px;
    font-size: 28px;
    font-weight: 600;
    text-transform: uppercase;
    color: #80574a
}

.jardins .para-nos .flex span {
    display: block;
    text-align: right;
    color: #80574a;
    font-size: 16px;
    font-weight: 300
}

.jardins .text-center {
    width: 100% !important;
    max-width: 100% !important;
    font-weight: 300
}

.jardins .text-center, .jardins .text-center strong {
    text-align: center;
    color: #80574a !important;
    font-size: 32px
}

.jardins .text-center strong {
    font-weight: 600 !important;
    display: block
}

.jardins .mapaLocalizacao {
    padding: 110px 0;
    background-color: #f3e7d7
}

.jardins .mapaLocalizacao .flex {
    gap: 96px;
    align-items: center;
    justify-content: space-between
}

.jardins .mapaLocalizacao .flex h2 {
    font-size: 26px;
    text-transform: uppercase;
    font-weight: 300;
    color: #524846
}

.jardins .mapaLocalizacao .flex .col:first-child {
    flex: 3
}

.jardins .mapaLocalizacao .flex .col:first-child img {
    max-width: 100%;
    width: 100%;
    height: auto
}

.jardins .mapaLocalizacao .flex p {
    font-size: 26px;
    font-weight: 300;
    color: #524846
}

.jardins .mapaLocalizacao .flex .col:last-child {
    max-width: 390px;
    align-items: flex-start;
    flex: 2;
    flex-direction: column;
    display: flex;
    gap: 26px
}

.jardins .mapaLocalizacao .flex .col:last-child .flex-center {
    align-items: center;
    width: 100%
}

.jardins .mapaLocalizacao .flex .col:last-child .btn-primary {
    font-size: 24px;
    font-weight: 300;
    text-transform: uppercase
}

.jardins .logos {
    z-index: 3;
    width: 100%;
    overflow: hidden;
    white-space: nowrap;
    position: relative;
    display: inline-flex
}

.jardins .logos .logo_items {
    display: inline-flex;
    align-items: center;
    animation: slides 105s linear infinite
}

.jardins .logos .logo_items .item {
    min-width: 300px;
    object-fit: scale-down;
    font-size: 26px;
    text-transform: uppercase;
    color: #524846;
    text-align: center
}

.jardins .localizacao-nova {
    padding: 82px 0
}

.jardins .localizacao-nova .flex-video {
    margin-top: 82px;
    display: flex;
    align-items: center;
    gap: 84px;
    justify-content: space-between
}

.jardins .localizacao-nova .flex-video iframe {
    width: 100%;
    height: 100%;
    aspect-ratio: 16/9;
    background: #000
}

.jardins .localizacao-nova .flex-video .col {
    flex: 1
}

.jardins .localizacao-nova .flex-video .col:last-child {
    max-width: 459px
}

.jardins .localizacao-nova .flex-video .col:last-child h2 {
    font-size: 30px;
    font-weight: 600;
    color: #466857 !important;
}

.jardins .localizacao-nova .flex-video .col:last-child .context {
    margin-top: 60px
}

.jardins .localizacao-nova .flex-video .col:last-child p {
    color: #524846;
    font-size: 22px;
    font-weight: 300
}

.jardins .localizacao-nova .flex-video .col:last-child p + p {
    margin-top: 26px
}

.jardins .flex-mapa {
    margin-top: 60px;
    display: flex;
    gap: 32px;
    align-items: center;
    justify-content: space-between
}

.jardins .flex-mapa .grid-2-col {
    display: grid;
    grid-template-columns:repeat(2, 1fr);
    gap: 32px;
    margin-top: 32px
}

.jardins .flex-mapa .grid-2-col p {
    max-width: 190px
}

.jardins .flex-mapa .col {
    flex: 1
}

.jardins .flex-mapa .col p {
    color: #524846
}

.jardins .flex-mapa .col img {
    width: 100%;
    max-width: 100%;
    height: auto
}

.jardins .flex-mapa .col h2 {
    max-width: 460px;
    font-size: 26px;
    font-weight: 300;
    color: #524846;
    text-transform: uppercase
}

.jardins .flex-mapa .col h3 {
    font-size: 50px;
    color: #524846
}

.jardins .flex-mapa .col h3 span {
    color: #524846
}

.jardins .flex-mapa .col:first-child {
    max-width: 520px
}

.jardins .composicao {
    margin-top: 32px
}

.jardins .composicao h2 {
    margin-bottom: 14px
}

.jardins .flex-comp {
    margin-top: 12px;
    display: flex;
    gap: 16px;
    color: #80574a
}

.jardins .flex-comp span, .jardins .flex-comp a {
    color: #524846;
    text-decoration: none;
}

.jardins footer {
    background-color: #466857;
    background-image: none !important
}

.jardins .localizacao-nova, .jardins .mapaLocalizacao, .jardins .para-nos {
    max-width: 100vw !important;
    overflow: hidden
}

.float_modal {
    z-index: 1e+21
}

@keyframes slides {
    0% {
        transform: translateX(0)
    }
    to {
        transform: translateX(-100%)
    }
}

@media (max-width: 1420px) {
    .jardins .design, .jardins .localizacao-nova, .jardins .mapaLocalizacao, .jardins .para-nos {
        padding: 80px 0
    }

    .jardins .text-center, .jardins .text-center strong {
        font-size: 28px
    }

    .jardins .para-nos .flex p {
        font-size: 20px
    }

    .jardins .para-nos .flex h3 {
        font-size: 24px
    }

    .jardins .para-nos .flex span {
        font-size: 14px
    }

    .jardins .flex-mapa .col h2, .jardins .mapaLocalizacao .flex h2 {
        font-size: 24px
    }

    .jardins .mapaLocalizacao .flex .col:last-child .btn-primary, .jardins .mapaLocalizacao .flex p {
        font-size: 20px
    }

    .jardins .localizacao-nova .flex-video .col:last-child h2 {
        font-size: 26px
    }

    .jardins .localizacao-nova .flex-video .col:last-child p {
        font-size: 20px
    }
}

@media (max-width: 768px) {
    .top .form {
        max-width: 376px;
        min-width: auto;
        width: 100%
    }

    .top.mobile .sticky {
        top: 14vh
    }
}

.btn-white {
    color: #fff;
    text-decoration: none;
    text-align: center;
    font-family: Inter, sans-serif;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: normal
}

.float_modal {
    display: none;
    z-index: 111;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transition: none !important
}

.float_modal .background {
    background-color: rgba(0, 0, 0, .5);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.float_modal .float_modal_content {
    padding: 20px 40px;
    background-color: #fff;
    position: absolute;
    bottom: 0;
    right: 0;
    width: 390px;
    max-width: 100%;
    z-index: 2;
    box-sizing: border-box
}

.float_modal .close {
    position: absolute;
    top: 26px;
    right: 15px
}

.float_modal .close:after, .float_modal .close:before {
    content: "";
    width: 20px;
    height: 3px;
    background-color: #000;
    position: relative;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    display: block
}

.float_modal .form a {
    font-size: 14px
}

.float_modal .flex.justify-center {
    display: flex;
    justify-content: center
}

.float_modal .close:before {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    top: 2.5px
}

.float_modal .title {
    font-family: roc-grotesk-wide, sans-serif;
    color: #897773;
    display: block;
    font-size: 24px;
    text-align: center;
    text-transform: uppercase
}

.float_modal .field {
    display: block;
    border: 0;
    border-bottom: 1px solid #897773;
    width: 100%;
    margin: 20px 0;
    padding: 5px 0;
    outline: none
}

.float_modal label {
    display: block;
    font-size: 14px;
    margin: 20px 0
}

.float_modal .button {
    background-color: #897773;
    text-align: center;
    display: table;
    color: #fff;
    margin: 0 auto 10px
}

#ifrAddIntelligence {
    display: none !important
}

.design-italino {
    padding: 112px 0;
    background-color: #83755e;
    display: flex;
    align-items: center
}

.design-italino .col {
    max-width: 480px
}

.design-italino .align-center-sd {
    justify-content: space-between
}

.design-italino .container {
    position: relative;
    max-width: 1165px
}

.design-italino .container .play {
    position: absolute;
    top: calc(50% - 36px);
    left: calc(50% - 36px)
}

.design-italino #vimeo01 iframe {
    width: 100%;
    height: 100%;
    aspect-ratio: 16/9
}

.design-italino .align-center-sd {
    display: flex
}

.design-italino .align-center-sd .col {
    flex: 1
}

.design-italino .align-center-sd .col h2 {
    font-size: 36px;
    color: #fff;
    font-family: roc-grotesk-wide, sans-serif;
    max-width: 421px;
    line-height: 1.1
}

.design-italino .align-center-sd .col .context {
    display: flex;
    justify-content: flex-end
}

.design-italino .align-center-sd .col .context > div {
    position: relative;
    padding-top: 48px;
    max-width: 502px
}

.design-italino .align-center-sd .col .context > div:before {
    height: 1px;
    max-width: 260px;
    background-color: #fff;
    content: "";
    display: block;
    width: 100%;
    position: absolute;
    left: 0;
    top: 0
}

.design-italino .align-center-sd .col strong {
    font-weight: 500 !important
}

.design-italino .align-center-sd .col p, .design-italino .align-center-sd .col strong {
    font-size: 16px;
    color: #fff;
    font-family: Inter, sans-serif;
    line-height: 24px;
    font-weight: 200
}

.design-italino .align-center-sd .col p + p {
    margin-top: 16px
}

.diretores {
    min-height: 100vh;
    padding: 100px 0;
    display: flex;
    align-items: center
}

.diretores .container {
    max-width: 1165px
}

.diretores .container .row + .row {
    margin-top: 128px
}

.diretores .container .row {
    justify-content: space-between;
    display: flex;
    align-items: flex-end
}

.diretores .container .row.reverse {
    flex-direction: row-reverse
}

.diretores .container .row.reverse .col:first-child {
    max-width: 421px
}

.diretores .container .row .col {
    flex: 1
}

.diretores .container .row .col .context {
    max-width: 503px
}

.diretores .container .row .col .context p {
    font-family: roc-grotesk-wide, sans-serif;
    font-size: 20px;
    color: #83755e
}

.diretores .container .row .col .context .dir {
    margin-top: 23px;
    padding-top: 60px;
    max-width: 284px;
    border-top: 1px solid #83755e
}

.diretores .container .row .col .context .dir p {
    text-transform: uppercase
}

.diretores .container .row .col .context .dir span {
    color: #83755e;
    font-size: 12px;
    font-family: roc-grotesk-wide, sans-serif;
    text-transform: uppercase;
    display: block
}

.diretores .container .row .images-click > img:not(.act) {
    opacity: 0;
    position: absolute;
    top: 0;
    width: 100%;
    height: 100%;
    object-fit: cover
}

.diretores .container .row .images-click > img:not(.act).act {
    opacity: 1
}

.diretores .container .row .col:last-child {
    max-width: 465px
}

.diretores .container .row .col:last-child img {
    max-width: 465px;
    height: 544px;
    object-fit: cover;
    display: block
}

.projeto {
    background-color: #83755e;
    padding: 100px 0
}

.projeto .container {
    max-width: 1176px
}

.projeto h2 {
    font-weight: 500;
    text-align: center;
    font-size: 20px;
    font-family: roc-grotesk-wide, sans-serif;
    color: #fff;
    margin-bottom: 20px;
    text-transform: uppercase
}

.projeto .flex-center {
    margin-top: 96px
}

.projeto .explore {
    border-radius: 15px
}

.projeto .explore img {
    display: block;
    border-top-right-radius: 15px;
    border-top-left-radius: 15px
}

.projeto .explore .context {
    background-color: #fff;
    padding: 24px 44px;
    justify-content: space-between;
    display: flex;
    align-items: center;
    border-bottom-right-radius: 15px;
    border-bottom-left-radius: 15px
}

.projeto .explore .context a {
    text-decoration: none;
    display: flex;
    align-items: center;
    color: #bf3127;
    font-size: 16px;
    font-weight: 500;
    gap: 8px
}

.projeto .explore h3 {
    font-size: 14px;
    font-family: Inter, sans-serif;
    color: #83755e
}

.projeto .line {
    max-width: 76px;
    width: 100%;
    margin: 0 auto;
    height: 1px;
    background-color: #fff
}

.projeto p {
    text-align: center;
    font-size: 16px;
    color: #fff;
    text-transform: uppercase;
    font-family: roc-grotesk-wide, sans-serif;
    font-weight: 200;
    max-width: 817px;
    margin: 48px auto 68px
}

.image-total img {
    width: 100%;
    object-fit: cover;
    height: 100%;
    max-height: 100vh
}

.teaser .top .form {
    position: relative;
    z-index: 3
}

.traducao {
    position: relative
}

.traducao svg {
    transition: all .3s ease-in-out
}

.traducao .submenu {
    position: absolute;
    top: 0;
    left: 0;
    display: none
}

.traducao .submenu a {
    display: block;
    padding: 8px 0
}

.traducao:hover svg {
    transform: rotate(180deg)
}

.traducao:hover .submenu {
    top: 0;
    padding-top: 20px;
    display: block
}

.traducao a {
    display: flex;
    align-items: center;
    gap: 4px
}

header .submenu {
    top: 35px !important;
    padding: 0 8px 8px !important;
    background-color: rgba(148, 136, 116, .75);
    backdrop-filter: blur(2px)
}

header .submenu:before {
    top: -33px;
    left: 0;
    content: "";
    display: block;
    position: absolute;
    width: 100%;
    height: 35px
}

.line-1.line-2 {
    bottom: 110px;
    top: inherit
}

.line-1.line-2 .line-internal {
    right: 0;
    left: inherit
}

.video {
    position: relative
}

.unmuted {
    position: absolute;
    bottom: 60px;
    right: 60px;
    cursor: pointer
}

.unmuted svg {
    max-width: 32px;
    height: auto
}

.unmuted svg path {
    fill: #fff
}

.diretores, .top .abs {
    overflow-x: hidden
}

.top strong {
    font-size: 24px;
    font-family: roc-grotesk-wide, sans-serif;
    line-height: 1.5;
    color: #83755e;
    text-transform: uppercase;
    font-weight: 600
}

.teaser #video-mp4-muted {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.diretores .container .row .col:last-child, .top .form {
    position: relative
}

.top .form {
    top: 40px
}

.projeto .explore img {
    width: 100%;
    height: auto
}

.teaser .video-as #vimeo01 {
    transform: scale(.8)
}

.design-italino .align-center-sd .col h2 {
    text-transform: uppercase
}

.mobile, .video-mp4 {
    display: none
}

@media (max-width: 890px) {
    .teaser section .container {
        padding: 20px 40px !important
    }

    .teaser section .abs-back .container {
        padding: 20px 40px !important;
        max-height: 195px;
        display: flex;
        align-items: center;
        flex-direction: column;
        justify-content: center
    }

    .teaser section .abs-back .container h1 {
        margin-top: 0 !important
    }

    .teaser section {
        padding: 32px 0 !important
    }

    .teaser .top {
        padding-top: 0 !important
    }

    .teaser #familias {
        padding-left: 20px !important;
        padding-right: 20px !important
    }

    .teaser header.actMenu {
        background: rgba(131, 117, 94, .75) !important;
        backdrop-filter: blur(2px)
    }

    .teaser .top .background {
        height: calc(100vh - 300px)
    }

    #familias {
        padding-right: 20px;
        padding-left: 20px
    }

    .design-italino .align-center-sd {
        flex-direction: column !important;
        gap: 24px
    }

    .diretores .container .row .col:last-child {
        margin-top: 60px
    }

    .diretores .row {
        flex-direction: column-reverse !important;
        gap: 24px
    }

    .diretores .container .row + .row, .projeto .flex-center {
        margin-top: 32px !important
    }

    .diretores, .projeto {
        padding: 32px 0
    }

    .top .line-1 .line-internal {
        width: 260px;
        height: 4px;
        top: -2px
    }

    .image-total img {
        object-position: -40vw;
        aspect-ratio: 4/4
    }

    .options .flex #second svg {
        max-width: 230px;
        height: auto !important
    }

    .projeto .explore img {
        max-width: 100%;
        height: auto;
        aspect-ratio: 4/2;
        object-fit: cover;
        display: block
    }

    .diretores .container .row .col img {
        max-width: 100% !important;
        height: auto !important
    }

    .video-as #vimeo01 {
        transform: scale(1) !important
    }

    .video-mp4 {
        position: relative;
        z-index: 999999
    }

    .video-mp4 video {
        aspect-ratio: 16/9;
        object-fit: cover;
        max-width: 100%;
        display: block;
        height: auto
    }

    .video-mp4 video:fullscreen {
        object-fit: contain;
        position: relative;
        z-index: 9999999
    }

    .video-mp4 .play {
        position: absolute;
        top: calc(50% - 38px);
        left: calc(50% - 38px)
    }

    .video-mp4 {
        aspect-ratio: 16/9;
        object-fit: cover;
        display: block
    }

    .video-as {
        padding: 32px 0;
        display: none !important;
        height: auto
    }

    .video-as .container {
        min-height: auto
    }

    .design {
        padding: 32px 0
    }

    .design h2 br {
        display: none
    }

    .design h2 {
        font-size: 32px;
        margin-bottom: 32px
    }

    a[href="#design"] {
        display: none
    }

    .form-bottom {
        padding: 32px 0
    }

    .menu {
        display: none
    }

    .diretores .container .row .col .context .dir {
        padding-top: 32px
    }

    .design .flex {
        flex-direction: column
    }

    .options .col:first-child, .options .col:last-child {
        border-radius: 0 !important
    }

    .top .content p br, .top .form {
        display: none
    }

    .top .content p, .top .content p strong {
        font-size: 18px
    }

    .whatsapp {
        z-index: 999999999
    }

    .flex-center-mobile {
        justify-content: center;
        display: flex
    }

    .design .container, .form-bottom .container {
        padding: 20px 40px
    }

    #mid .flex-end {
        justify-content: center !important
    }

    .top .content {
        padding: 57px 39px
    }

    .options .flex {
        aspect-ratio: auto !important;
        flex-direction: column
    }

    .options .flex .col img {
        height: calc(100vh - 75px)
    }

    .options .flex .col .abs {
        align-items: flex-end !important
    }

    .options .flex .col:first-child img {
        object-position: -25vh 0
    }

    .diretores .container .row .col .context .dir p {
        font-weight: 600
    }

    .teaser #video-mp4-muted {
        display: none !important
    }

    .teaser .video-mp4, .teaser .video-mp4 video {
        aspect-ratio: 16/16
    }

    .options .flex .col:last-child img {
        object-position: -100vh 0
    }

    .teaser .video-mp4 video {
        width: 100%
    }

    .diretores .container .row.reverse {
        margin-top: 80px !important
    }

    .teaser section.image-total {
        padding-top: 0 !important
    }

    .options .flex .col .abs svg {
        margin-top: 0
    }

    .top .sd {
        padding-bottom: 0
    }

    .options .col:first-child, .options .col:last-child {
        flex: 1 !important
    }

    .options .col:first-child p, .options .col:last-child p {
        opacity: 1 !important
    }

    .options .col:first-child .abs, .options .col:last-child .abs {
        padding: 30px 30px 60px !important;
        background: linear-gradient(90deg, rgba(0, 0, 0, .36), hsla(0, 0%, 100%, 0)) !important
    }

    .col {
        transition: none !important
    }

    .neg {
        margin-top: 0 !important
    }

    .pin {
        overflow-x: hidden
    }

    .logo, .logo img {
        max-width: 100%;
        height: auto
    }

    .diretores .container .row .col img {
        aspect-ratio: 442/516;
        display: block
    }

    .form .mt-30.flex-end {
        justify-content: center
    }

    header > .container > .flex-between.flex-align-center {
        gap: 16px
    }

    .menu {
        z-index: 9999
    }

    .options {
        pointer-events: none !important
    }

    .options .flex .col:last-child .abs, .options .flex .col:last-child .abs .cont {
        transform: rotate(0)
    }

    .hidden {
        aspect-ratio: inherit;
        min-height: calc(300vh - 225px)
    }

    .neg > .container {
        padding: 0 10px !important
    }

    .options .col:last-child, .options .col:last-child img {
        border-radius: 0 !important
    }

    .video iframe {
        left: calc(-50% - 50vw);
        position: relative
    }

    #family {
        max-height: calc(100vh - 75px)
    }

    .options .container {
        padding: 0 !important
    }

    .hidden-content {
        aspect-ratio: inherit;
        height: calc(100vh - 75px)
    }

    .diretores .container .row .col:last-child {
        margin-top: 0
    }

    .menu a, .menu a.btn {
        font-size: 16px
    }

    .top.mobile .sticky {
        margin-top: 0px !important;
        height: auto !important;
    }

    .hidden .sticky {
        position: relative;
        top: 0;
        min-height: 300vh
    }

    .hidden .sticky > div {
        position: sticky;
        top: 63px
    }

    .sd#mbo {
        overflow: hidden
    }

    .unmuted {
        bottom: 30px;
        left: 30px;
        right: inherit;
        z-index: 9
    }

    .options .col1 {
        position: relative !important;
        z-index: 3 !important
    }

    .options .col2 {
        position: absolute !important;
        top: 0;
        left: 0;
        z-index: 1
    }

    .video {
        aspect-ratio: inherit;
        height: calc(100vh - 75px)
    }

    .diretores .container .row.reverse .col:first-child {
        max-width: 100%
    }

    .design-italino.video-sd {
        padding-top: 0;
        min-height: inherit;
        height: auto
    }

    .menuMobile {
        flex-direction: column;
        gap: 5px
    }

    .menuMobile > div {
        width: 30px;
        height: 3px;
        border-radius: 25px;
        background-color: #fff;
        display: block
    }

    .whatsapp {
        bottom: 21px
    }

    .whatsapp svg {
        max-width: 52px;
        height: auto
    }
}

@media (max-height: 672px) and (min-width: 890px) {
    header:not(.act) .btn, header:not(.act) .menu-teaser a {
        opacity: 0;
        pointer-events: none
    }

    header.act .btn {
        opacity: 1
    }
}

#section-mp4.act {
    display: block !important
}

@media (max-width: 768px) {
    .jardins .para-nos .flex {
        flex-direction: column
    }

    .jardins img {
        max-width: 100%;
        height: auto
    }

    .jardins .localizacao-nova .flex-video, .jardins .mapaLocalizacao .flex {
        flex-direction: column;
        gap: 16px
    }

    .jardins .flex-mapa .col:first-child, .jardins .mapaLocalizacao .flex .col:last-child, .jardins .para-nos .flex .col:last-child {
        max-width: 100%
    }

    .mapaLocalizacao, .para-nos {
        padding: 32px 0 !important
    }

    .jardins .localizacao-nova .flex-video .col {
        width: 100%
    }

    .flex-mapa, .localizacao-nova, .mapaLocalizacao, .para-nos {
        overflow: hidden;
        max-width: 100vw
    }

    .jardins .flex-mapa {
        flex-direction: column-reverse;
        gap: 32px
    }

    .jardins .localizacao-nova .flex-video .col:last-child h2 br {
        display: none
    }

    .jardins .mapaLocalizacao .flex .col:last-child {
        gap: 16px
    }

    iframe {
        display: block;
        width: 100%;
        height: 100%
    }

    .design h2 {
        margin-bottom: 0 !important
    }

    .jardins .logos .logo_items {
        min-width: fit-content;
        max-width: fit-content
    }

    .jardins {
        overflow-x: hidden;
        max-width: 100vw
    }

    .jardins .flex-mapa .grid-2-col {
        grid-template-columns:repeat(1, 1fr);
        gap: 16px
    }

    .jardins .flex-mapa .grid-2-col p {
        max-width: 100%
    }

    .jardins .menu-teaser .traducao a {
        display: block !important
    }

    .menu-teaser a:not(.btn) {
        display: none !important
    }
}

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