@import url("https://pro.fontawesome.com/releases/v5.15.4/css/all.css");

/* ### BACKGROUND/LAYOUT ### */
a{ text-decoration: none; }
.bg_header{ background: linear-gradient(90deg, #FDDC01 0%, #fde557 100%, rgba(255, 255, 255, 0.25) 100%); }

/* Padronização das imagens de imóveis */
.single-imovel .position-relative {
    height: 220px;
    overflow: hidden;
}
.single-imovel .position-relative img.img-fluid {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.estrutura{ width: 100%; float: left; }
body{
    font-family: "Roboto", sans-serif;
    font-weight: 300;
    font-style: normal;
}
.img-fluid.img100{
    width: 100% !important;
}
strong{
    font-family: "Roboto", sans-serif;
    font-weight: 700;
    font-style: normal;
}
.bg_mercado_imobiliario{
    background: #fddf1f url("../images/bg-mercado.png") no-repeat bottom;
    background-size: cover;
}

.bg_socios{
    position: relative;
    background: #000 url("../images/bg-time.png") no-repeat right top;
    background-size: cover;
}
.bg_socios:before{
    content: "";
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    opacity: 0.8;
    background: url("../images/bg-socios.jpg") no-repeat top right;
    background-size: cover;
    z-index: 1;
}
.bg_socios .container{
    position: relative;
    z-index: 2;
}
.socios_linha{
    background: #FDDC01;
    height: 100px;
    width: 2px;
}
.bg_time{
    background: #020202;
}

.links_rodape a{
    width: 100%;
    float: left;
}
.links_rodape a:hover{ color: #FDDC01 !important; }
.btn_rodape_whatsapp{
    background-color: #10B628;
    color: #fff;
    border: none;
    margin-right: 30px;
    padding: 10px 8px 10px 20px;
    -webkit-border-radius: 31px; -moz-border-radius: 31px; border-radius: 31px;
}
.btn_rodape_whatsapp span {
    border-left: 1px solid #fff;
    margin-left: 7px;
    padding-left: 10px;
}
.borda_rodape{
    border-bottom: 6px solid #FDDC01;
}

.caption{
    position: absolute;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#000000+0,000000+100&0.2+0,0.45+50,0.7+90 */
    background: linear-gradient(to bottom,  rgba(0,0,0,0.2) 0%,rgba(0,0,0,0.45) 50%,rgba(0,0,0,0.7) 90%,rgba(0,0,0,0.7) 100%);
}

/*.btn_saiba_mais_destaque{ right: -20px; }*/
/* ### FIM BACKGROUND/LAYOUT ### */

/* ### MENU ### */
.site-header {
    position: relative;
    background: linear-gradient(135deg, #FDDC01 0%, #fde557 55%, rgba(255, 255, 255, 0.92) 100%);
    border-bottom: 1px solid rgba(10, 18, 26, 0.08);
    box-shadow: 0 12px 30px rgba(10, 18, 26, 0.08);
    z-index: 1000;
}

.site-header::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -26px;
    height: 26px;
    background: linear-gradient(180deg, rgba(253, 220, 1, 0.5) 0%, rgba(253, 220, 1, 0) 100%);
    pointer-events: none;
}

.site-nav {
    padding: 1.25rem 0;
}

.site-nav .navbar-brand {
    padding: 0;
    margin-right: 1.5rem;
}

.site-nav__menu {
    flex-direction: column;
    align-items: stretch;
}

.site-nav .navbar-nav {
    gap: 0.5rem;
}

/* Resetar estilos do Bootstrap no menu */
.navbar-nav .nav-link {
    color: #2D5294 !important;
    background: transparent !important;
    border-radius: 8px !important;
    margin: 0 0.25rem !important;
    padding: 0.75rem 1rem !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    position: relative !important;
}

.navbar-nav .nav-link:hover,
.navbar-nav .nav-link:focus {
    color: #ffffff !important;
    background: linear-gradient(135deg, #2D5294 0%, #3a5f9d 100%) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 25px rgba(45, 82, 148, 0.3) !important;
}

.navbar-nav .nav-link.active {
    color: #ffffff !important;
    background: linear-gradient(135deg, #2D5294 0%, #3a5f9d 100%) !important;
    box-shadow: 0 4px 15px rgba(45, 82, 148, 0.2) !important;
}

.navbar-nav .nav-link.active::after {
    content: '' !important;
    position: absolute !important;
    bottom: -4px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: 40px !important;
    height: 3px !important;
    background: #FDDD04 !important;
    border-radius: 2px !important;
    animation: slideInUp 0.4s ease-out !important;
}

@keyframes slideInUp {
    from {
        opacity: 0;
        transform: translateX(-50%) translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateX(-50%) translateY(0);
    }
}

.site-header__actions {
    width: 100%;
}

.site-header__cta {
    font-size: 0.75rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.site-header__social-link {
    width: 36px;
    height: 36px;
    border-radius: 999px;
    border: 1px solid rgba(10, 18, 26, 0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #0A121A;
    transition: all 0.3s ease;
    background: rgba(255, 255, 255, 0.55);
}

.site-header__social-link:hover,
.site-header__social-link:focus {
    color: #FDDC01;
    border-color: #0A121A;
    background: #0A121A;
}

.site-nav .navbar-toggler {
    border: none;
    padding: 0.35rem 0.5rem;
    margin-left: 0.75rem;
}

.site-nav .navbar-toggler:focus {
    box-shadow: none;
}

.site-nav .navbar-toggler-icon,
.site-nav .navbar-toggler-icon::before,
.site-nav .navbar-toggler-icon::after {
    display: block;
    width: 28px;
    height: 3px;
    border-radius: 999px;
    background-color: #0A121A;
    transition: all 0.3s ease;
    content: "";
}

.site-nav .navbar-toggler-icon {
    position: relative;
}

.site-nav .navbar-toggler-icon::before,
.site-nav .navbar-toggler-icon::after {
    position: absolute;
    left: 0;
}

.site-nav .navbar-toggler-icon::before {
    top: -8px;
}

.site-nav .navbar-toggler-icon::after {
    bottom: -8px;
}

.site-nav .navbar-toggler:not(.collapsed) .navbar-toggler-icon {
    background-color: transparent;
}

.site-nav .navbar-toggler:not(.collapsed) .navbar-toggler-icon::before {
    transform: rotate(45deg);
    top: 0;
}

.site-nav .navbar-toggler:not(.collapsed) .navbar-toggler-icon::after {
    transform: rotate(-45deg);
    bottom: 0;
}

@media (min-width: 992px) {
    .site-nav__menu {
        flex-direction: row;
        align-items: center;
    }

    .site-nav .navbar-nav {
        margin-left: auto;
        margin-right: auto;
    }

    .site-nav .nav-link::after {
        content: "";
        position: absolute;
        left: 1rem;
        right: 1rem;
        bottom: 0.4rem;
        height: 3px;
        border-radius: 999px;
        background: transparent;
        transition: background 0.3s ease;
    }

    .site-nav .nav-link:hover::after,
    .site-nav .nav-link:focus::after,
    .site-nav .nav-link.active::after {
        background: #0A121A;
    }

    .site-header__actions {
        width: auto;
    }
}

@media (max-width: 991px) {
    .site-nav {
        padding: 1rem 0;
    }

    .site-nav .navbar-collapse {
        position: fixed;
        inset: 0;
        padding: 5rem 1.5rem 2rem;
        background: linear-gradient(145deg, #FDDC01 0%, rgba(255, 255, 255, 0.96) 100%);
        overflow-y: auto;
    }

    .site-nav__menu {
        background: rgba(255, 255, 255, 0.92);
        border-radius: 18px;
        padding: 1.5rem;
        box-shadow: 0 18px 45px rgba(10, 18, 26, 0.1);
    }

    .site-nav .navbar-nav {
        padding: 0;
    }

    .site-nav .nav-link {
        font-size: 1rem;
        border-bottom: 1px solid rgba(10, 18, 26, 0.08);
        margin: 0;
        border-radius: 0;
        padding: 1rem 1.5rem;
    }

    .site-nav .nav-link:last-child {
        border-bottom: none;
    }

    .site-nav .nav-link:hover,
    .site-nav .nav-link:focus {
        background: rgba(45, 82, 148, 0.1);
        color: #2D5294;
        transform: none;
        box-shadow: none;
        padding-left: 2rem;
    }

    .site-nav .nav-link.active {
        background: rgba(45, 82, 148, 0.15);
        color: #2D5294;
        box-shadow: none;
        border-left: 4px solid #2D5294;
    }

    .site-nav .nav-link.active::after {
        display: none;
    }

    .site-header__actions {
        margin-top: 2rem;
        align-items: stretch !important;
    }

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

    .site-header__social {
        justify-content: center;
    }
}
/* ### FIM MENU ### */

/* ### PAGINACAO ### */
.page-link{
    color: #687983;

}
.page-link:hover{
    color: #FDDC01;
    background-color: #fff;
    border-color: #FDDC01;
}
.active>.page-link{
    color: #fff;
    background-color: #FDDC01;
    border-color: #FDDC01;
}
/* ### FIM PAGINACAO ### */

/* ### SLIDES ### */
.slider_parceiros_css,
.slider_parceiros_css .item{
    max-height: 300px;
    overflow: hidden;
}
.slider_parceiros_css .item{
    display: flex;
    position: relative;
}
.slider_parceiros_css .item a{
    display: flex;
    align-items: center;
    border: 3px solid #fff;
    width: 100%;
    height: 170px;
    text-align: center;
}
.slider_parceiros_css .item a:hover{ border-color: #FDDC01; }

.slider_parceiros_css .tns-nav,
.slider_jarvis_praia_css .tns-nav,
.slider_lancamentos_css .tns-nav,
.slider_super_destaque_css .tns-nav{
    text-align: center;
    margin-top: 20px;
}
.slider_parceiros_css .tns-nav button,
.slider_jarvis_praia_css .tns-nav button,
.slider_lancamentos_css .tns-nav button,
.slider_super_destaque_css .tns-nav button{
    width: 16px; height: 16px;
    background-color: #687983;
    border: none;
    margin: 10px 4px;
    -webkit-border-radius: 10px; -moz-border-radius: 10px; border-radius: 10px;

    -webkit-transition: all 400ms;
    -moz-transition: all 400ms;
    -ms-transition: all 400ms;
    -o-transition: all 400ms;
    transition: all 400ms;
}
.slider_parceiros_css .tns-nav button:hover,
.slider_jarvis_praia_css .tns-nav button:hover,
.slider_lancamentos_css .tns-nav button:hover,
.slider_super_destaque_css .tns-nav button:hover{
    width: 18px;
    height: 18px;
}
.slider_parceiros_css .tns-nav button.tns-nav-active,
.slider_jarvis_praia_css .tns-nav button.tns-nav-active,
.slider_lancamentos_css .tns-nav button.tns-nav-active,
.slider_super_destaque_css .tns-nav button.tns-nav-active{
    width: 20px;
    height: 20px;
    background-color: #FDDC01 !important;
}

.slider_time_css .item a{
    background: #FDDC01;
    width: 100%;
}
.slider_time_css .item img{ 
    width: auto;
    min-width: 100%;
    height: 230px;
    object-fit: cover;
    border-top-left-radius: 8px;
    border-top-right-radius: 8px;
}
.slider_time_css .item hr{
    border-width: 1px;
    border-color: #FDDC01;
    opacity: 1;
}
.slider_time_css .tns-controls button,
.slider_prontos_morar_css .tns-controls button{
    background: none;
    border: none;
    opacity: 0.5;
}
.slider_time_css .tns-controls button:hover,
.slider_prontos_morar_css .tns-controls button:hover{ opacity: 1; }
.slider_time_css .tns-controls i{ color: #ffffff; }
.slider_time_css .tns-controls button[disabled],
.slider_prontos_morar_css .tns-controls button[disabled]{ opacity: 0.1 }
.slider_time_css .tns-controls button[data-controls="prev"],
.slider_prontos_morar_css .tns-controls button[data-controls="prev"]{
    float: left;
    margin: 170px 0 0 -22px;
}
.slider_time_css .tns-controls button[data-controls="next"],
.slider_prontos_morar_css .tns-controls button[data-controls="next"]{
    float: right;
    margin: 170px -22px 0 0;
}

.slider_prontos_morar_css .tns-controls i.fa-circle{ color: #FDDC01; }
.slider_prontos_morar_css .tns-controls i.fa-inverse{ color: #0A121A; }

.slider_prontos_morar_css h1{
    min-height: 96px;
    max-height: 96px;
}
/* ### FIM SLIDES ### */

/* ### HERO ### */
.hero-impact {
    position: relative;
    padding: 1rem 0 7rem;
    color: #0A121A;
    overflow: hidden;
}

.hero-impact__bg {
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, #FDDC01 0%, #fde557 100%, rgba(255, 255, 255, 0.25) 100%);
    z-index: 0;
}

@keyframes float {
    0%, 100% { transform: translateY(0) rotate(35deg); }
    50% { transform: translateY(-20px) rotate(35deg); }
}

@keyframes pulse {
    0%, 100% { transform: scale(1); opacity: 0.8; }
    50% { transform: scale(1.05); opacity: 0.6; }
}

@keyframes slideInLeft {
    from { opacity: 0; transform: translateX(-50px); }
    to { opacity: 1; transform: translateX(0); }
}

@keyframes slideInRight {
    from { opacity: 0; transform: translateX(50px); }
    to { opacity: 1; transform: translateX(0); }
}

@keyframes bounce {
    0%, 20%, 50%, 80%, 100% { transform: translateY(0); }
    40% { transform: translateY(-10px); }
    60% { transform: translateY(-5px); }
}

@keyframes fadeInDown {
    from {
        opacity: 0;
        transform: translateY(-30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeInRight {
    from {
        opacity: 0;
        transform: translateX(30px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes float {
    0%, 100% {
        transform: translate(0, 0) rotate(0deg);
    }
    33% {
        transform: translate(30px, -30px) rotate(1deg);
    }
    66% {
        transform: translate(-20px, 20px) rotate(-1deg);
    }
}

.hero-impact .container {
    position: relative;
    z-index: 1;
}

.hero-impact__eyebrow {
    font-size: 0.75rem;
    letter-spacing: 0.3em;
    display: inline-block;
    padding: 0.5rem 1.25rem;
    border-radius: 999px;
    background: rgba(10, 18, 26, 0.08);
    backdrop-filter: blur(5px);
    animation: fadeInDown 0.8s ease-out;
}

.hero-impact__title {
    font-size: clamp(1.25rem, 3vw, 2.25rem);
    line-height: 1.1;
    margin-top: 1.5rem;
    position: relative;
    animation: fadeInUp 0.8s ease-out 0.2s both;
}

.hero-impact__title::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -0.5rem;
    width: 80px;
    height: 4px;
    background: #0A121A;
    border-radius: 2px;
}

.hero-impact__copy {
    font-size: 1.1rem;
    margin-top: 2rem;
    animation: fadeInUp 0.8s ease-out 0.4s both;
}

.hero-impact__actions {
    margin-top: 2.5rem;
    animation: fadeInUp 0.8s ease-out 0.6s both;
}

.hero-impact__media {
    background: #fff;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 25px 50px -12px rgba(10, 18, 26, 0.15);
    transform: perspective(1000px) rotateY(-5deg);
    transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    animation: fadeInRight 0.8s ease-out 0.4s both;
}

.hero-impact__media:hover {
    transform: perspective(1000px) rotateY(0deg) translateY(-10px) scale(1.02);
    box-shadow: 0 30px 60px -15px rgba(10, 18, 26, 0.25);
}

.hero-impact__media img {
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.hero-impact__media:hover img {
    transform: scale(1.05);
}

@keyframes fadeInDown {
    from {
        opacity: 0;
        transform: translateY(-20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeInRight {
    from {
        opacity: 0;
        transform: translateX(20px) perspective(1000px) rotateY(-5deg);
    }
    to {
        opacity: 1;
        transform: translateX(0) perspective(1000px) rotateY(-5deg);
    }
}

@media (max-width: 991px) {
    .hero-impact {
        padding: 4rem 0 5rem;
    }

    .hero-impact__eyebrow {
        font-size: 0.7rem;
    }

    .hero-impact__media {
        transform: none;
        margin-top: 2rem;
    }

    .hero-impact__media:hover {
        transform: translateY(-10px) scale(1.02);
    }
}

.hero-search {
    margin-top: -3rem;
    margin-bottom: 3rem;
    z-index: 2;
}

.hero-search__box {
    background: #ffffff;
    border-radius: 18px;
    box-shadow: 0 18px 45px rgba(10, 18, 26, 0.08);
    padding: 2.5rem;
    position: relative;
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.8);
}

.hero-search__box::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, #FDDC01 0%, #fde557 100%);
    border-radius: 18px 18px 0 0;
}

.hero-search__box label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #687983;
    font-weight: 500;
    transition: color 0.2s;
}

.hero-search__box .form-control:focus + label,
.hero-search__box .form-select:focus + label {
    color: #FDDC01;
}

.hero-search__box .form-control,
.hero-search__box .form-select {
    padding: 0.875rem 1rem;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    font-size: 0.875rem;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    background: rgba(255, 255, 255, 0.9);
}

.hero-search__box .form-control:focus,
.hero-search__box .form-select:focus {
    outline: none;
    border-color: #FDDC01;
    box-shadow: 0 0 0 3px rgba(253, 220, 1, 0.2);
    transform: translateY(-2px);
}

.hero-search__box .form-select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%230A121A' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    padding-right: 2.5rem;
    cursor: pointer;
}

.hero-search__box .btn {
    background: #2d5294;
    color: white;
    border: none;
    padding: 0.875rem 2rem;
    border-radius: 10px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
}

.hero-search__box .btn::before {
    content: "";
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transition: left 0.5s;
}

.hero-search__box .btn:hover::before {
    left: 100%;
}

.hero-search__box .btn:hover {
    background: #FDDD04;
    transform: translateY(-2px);
    box-shadow: 0 10px 20px -5px rgba(10, 18, 26, 0.3);
}

@media (max-width: 991px) {
    .hero-search {
        margin-top: -2rem;
    }

    .hero-search__box {
        padding: 1.25rem;
    }
}

@media (max-width: 575px) {
    .hero-search {
        margin-top: 0;
    }
    
    .hero-impact {
        padding: 2.5rem 0;
    }
    
    .hero-impact__title {
        font-size: 1.75rem;
    }
    
    .hero-impact__copy {
        font-size: 0.95rem;
    }
    
    .hero-impact__eyebrow {
        font-size: 0.75rem;
    }
    
    .hero-impact__actions {
        flex-direction: column;
        align-items: stretch;
    }
    
    .hero-impact__actions .btn {
        width: 100%;
        justify-content: center;
    }
    
    .hero-search__box {
        padding: 1rem;
    }
    
    .hero-search__box .form-control,
    .hero-search__box .form-select {
        padding: 0.75rem 0.875rem;
        font-size: 0.8rem;
    }
    
    .hero-search__box .btn {
        padding: 0.75rem 1.5rem;
        font-size: 0.875rem;
    }
}

.hero-search__box.rounded-bottom-0 {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

.hero-search__box--more {
    margin-top: 0;
    border-radius: 0 0 18px 18px;
    box-shadow: none;
    border-top: 1px solid rgba(10, 18, 26, 0.08);
    padding: 1.25rem 1.75rem 1.75rem;
}

.hero-search__box--more select,
.hero-search__box--more input {
    font-size: 0.9rem;
}
/* ### FIM HERO ### */

/* ### UTILITY ### */
.logo-brand {
    display: inline-block;
    background-color: #FDDC01;
    border-radius: 4px;
    padding: 6px;
}

/* ### BUTTONS ### */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.875rem 2rem;
    font-weight: 500;
    text-decoration: none;
    border-radius: 10px;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    overflow: hidden;
    font-size: 0.95rem;
    cursor: pointer;
    border: none;
}

.btn::before {
    content: "";
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transition: left 0.5s;
}

.btn:hover::before {
    left: 100%;
}

.btn-primary {
    background: #0A121A;
    color: white;
    box-shadow: 0 4px 14px 0 rgba(10, 18, 26, 0.2);
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
    background: #1a2b3a;
    transform: translateY(-3px);
    box-shadow: 0 10px 20px -5px rgba(10, 18, 26, 0.3);
}

.btn-secondary {
    background: transparent;
    color: #0A121A;
    border: 2px solid #0A121A;
}

.btn-secondary:hover,
.btn-secondary:focus,
.btn-secondary:active {
    background: #0A121A;
    color: white;
    transform: translateY(-3px);
    box-shadow: 0 10px 20px -5px rgba(10, 18, 26, 0.2);
}

.btn-accent {
    background: #FDDC01;
    color: #0A121A;
    box-shadow: 0 4px 14px 0 rgba(253, 220, 1, 0.3);
}

.btn-accent:hover,
.btn-accent:focus,
.btn-accent:active {
    background: #fde557;
    transform: translateY(-3px);
    box-shadow: 0 10px 20px -5px rgba(253, 220, 1, 0.4);
}

.btn-outline-dark {
    color: #0A121A;
    border-color: #0A121A;
    background-color: transparent;
}

.btn-outline-dark:hover,
.btn-outline-dark:focus,
.btn-outline-dark:active {
    color: #0A121A;
    border-color: #0A121A;
    background-color: rgba(10, 18, 26, 0.08);
}

.semOverflow{overflow: hidden;}

.btn{cursor: pointer;}

.aSemUnderline a, .aSemUnderline a:hover{text-decoration: none;}

hr{clear:both;border-bottom:0;border-top:1px dotted #ccc;border-right:0;border-left:0;margin:30px 0;min-height: 0px;height:1px;}
hr.alt1{border-style: solid;}
hr.alt2{border-style: dashed;}

.animacao1{transition: all 0.5s ease;}
.animacao2{
    -webkit-transition: all 400ms;
    -moz-transition: all 400ms;
    -ms-transition: all 400ms;
    -o-transition: all 400ms;
    transition: all 400ms;
}
.animacao2:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.1);
}

.letter-spacing-03 { letter-spacing: 0.3em; }

.line-height-30{ line-height: 30px; }
.line-height-36{ line-height: 36px; }
.line-height-40{ line-height: 40px; }
/* ### FIM UTILITY ### */

/* ### CORES ### */
.bg_laranja{ background-color: #FDDC01; }
.bg_black_light90{ background-color: #222931; }
.bg_black_light{ background-color: #2d5295; }
.bg_cinza{ background-color: #E0E9EE; }
.bg_cinza2{ background-color: #E2ECEC; }
.bg_amarelo{ background-color: #FDDC01; }

.laranja, .laranja a{ color: #FDDC01; } .laranja a:hover{ color: #FDDC01; }
.cinza, .cinza a{ color: #687983; } .cinza a:hover{ color: #687983; }
.amarelo, .amarelo a{ color: #FDDC01; } .amarelo a:hover{ color: #FDDC01; }

/* Estilos para ícones de redes sociais com contraste melhorado */
.social-icon-dark { color: #2D5294; }
.social-icon-dark .fa-stack-2x { color: #2D5294; }
.social-icon-dark .fa-stack-1x { color: #FFFFFF; }
.social-icon-dark:hover .fa-stack-1x {
    color: #2D5294;
    transition: color 0.3s ease;
}
.social-icon-dark:hover .fa-stack-2x {
    color: #FFFFFF;
    transition: color 0.3s ease;
}
/* ### FIM CORES ### */

/* ### FONTES ### */
.font-helvetica{ font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; }
.roboto-light {
    font-family: "Roboto", sans-serif;
    font-weight: 300;
    font-style: normal;
}
.roboto-regular {
    font-family: "Roboto", sans-serif;
    font-weight: 400;
    font-style: normal;
}
.roboto-bold {
    font-family: "Roboto", sans-serif;
    font-weight: 700;
    font-style: normal;
}

.font-11{ font-size: 11px !important; } .font-12{ font-size: 12px !important; } .font-13{ font-size: 13px !important; }
.font-14{ font-size: 14px !important; } .font-16{ font-size: 16px !important; }
.font-18{ font-size: 18px !important; } .font-20{ font-size: 20px !important; }
.font-22{ font-size: 22px !important; } .font-24{ font-size: 24px !important; }
.font-26{ font-size: 26px !important; } .font-28{ font-size: 28px !important; }
.font-30{ font-size: 30px !important; } .font-32{ font-size: 32px !important; }
.font-34{ font-size: 34px !important; } .font-36{ font-size: 36px !important; }
/* ### FIM FONTES ### */

/* ### FOOTER ### */
.site-footer {
    width: 100%;
    background-color: #e0e9ef;
    border-bottom: 6px solid #FDDC01;
    padding: 3rem 0 1.5rem;
    position: relative;
}

.site-footer__top {
    margin-bottom: 3rem;
    padding-bottom: 2rem;
    border-bottom: 2px solid rgba(45, 82, 148, 0.1);
}

.site-footer__logo {
    display: inline-block;
    transition: transform 0.3s ease;
}

.site-footer__logo:hover {
    transform: translateY(-3px);
}

.site-footer__logo img {
    max-width: 160px;
    height: auto;
}

.site-footer__logo .logo-brand {
    background-color: transparent;
    padding: 0;
}

.site-footer__main {
    margin-bottom: 2rem;
}

.site-footer__nav-column {
    margin-bottom: 2rem;
}

.site-footer__nav-title {
    color: #2D5294;
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 1.25rem;
    font-weight: 700;
}

.site-footer__nav {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.site-footer__nav-link {
    color: #4A5F70;
    font-size: 0.9375rem;
    line-height: 1.8;
    text-decoration: none;
    transition: all 0.3s ease;
    display: block;
    width: fit-content;
}

.site-footer__nav-link:hover {
    color: #2D5294;
    transform: translateX(8px);
    padding-left: 4px;
}

.site-footer__nav-link:focus {
    outline: 2px solid #2D5294;
    outline-offset: 2px;
    color: #2D5294;
}

.site-footer__contact .site-footer__nav-link i {
    color: #2D5294;
    width: 18px;
    transition: transform 0.3s ease;
}

.site-footer__contact .site-footer__nav-link:hover i {
    transform: scale(1.2);
}

.site-footer__social-wrapper {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

.site-footer__cta-whatsapp {
    background: linear-gradient(135deg, #10B628 0%, #0d9921 100%);
    color: #fff;
    border: none;
    padding: 0.75rem 1.25rem;
    border-radius: 999px;
    font-size: 1rem;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    align-items: center;
    box-shadow: 0 4px 14px 0 rgba(16, 182, 40, 0.3);
}

.site-footer__cta-whatsapp:hover {
    background: linear-gradient(135deg, #0d9921 0%, #0a7a19 100%);
    transform: translateY(-3px);
    box-shadow: 0 8px 20px rgba(16, 182, 40, 0.4);
    color: #fff;
}

.site-footer__cta-whatsapp span {
    border-left: 1px solid rgba(255, 255, 255, 0.5);
    margin-left: 0.75rem;
    padding-left: 0.75rem;
}

.site-footer__social {
    display: flex;
    gap: 0.5rem;
    justify-content: flex-end;
}

.site-footer__social-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    text-decoration: none;
}

.site-footer__social-link:focus {
    outline: 2px solid #2D5294;
    outline-offset: 4px;
}

.site-footer__social-link .fa-stack-2x {
    color: #2D5294;
    transition: all 0.3s ease;
}

.site-footer__social-link .fa-stack-1x {
    color: #FFFFFF;
    transition: all 0.3s ease;
}

.site-footer__social-link:hover .fa-stack-2x {
    color: #FDDC01;
    transform: scale(1.1);
}

.site-footer__social-link:hover .fa-stack-1x {
    color: #2D5294;
}

.site-footer__bottom {
    padding-top: 1.5rem;
    border-top: 1px solid rgba(104, 121, 131, 0.2);
}

.site-footer__credit {
    display: inline-block;
    opacity: 0.7;
    transition: opacity 0.3s ease;
}

.site-footer__credit:hover {
    opacity: 1;
}

.site-footer__credit img {
    max-height: 35px;
}

/* Responsive Footer */
@media (max-width: 767px) {
    .site-footer {
        padding: 2rem 0 1rem;
    }

    .site-footer__top {
        text-align: center;
        margin-bottom: 2rem;
    }

    .site-footer__logo img {
        max-width: 140px;
    }

    .site-footer__social-wrapper {
        align-items: center;
    }

    .site-footer__social {
        justify-content: center;
    }

    .site-footer__cta-whatsapp {
        margin-bottom: 1rem;
    }

    .site-footer__nav-column {
        text-align: left;
        padding-left: 1rem;
    }

    .site-footer__nav-title {
        font-size: 0.9375rem;
    }

    .site-footer__nav-link:hover {
        transform: none;
    }

    .site-footer__bottom {
        text-align: center !important;
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .site-footer__logo img {
        max-width: 150px;
    }

    .site-footer__social-wrapper {
        align-items: flex-start;
    }

    .site-footer__social {
        justify-content: flex-start;
    }

    .site-footer__nav-column {
        margin-bottom: 2rem;
    }
}
/* ### FIM FOOTER ### */

@media (max-width: 575px){ /* Extra small */
    .line-height-40{ line-height: 30px; }
    .slider_time_css .tns-controls button[data-controls="prev"],
    .slider_prontos_morar_css .tns-controls button[data-controls="prev"]{
        margin-left: -30px;
    }
    .slider_time_css .tns-controls button[data-controls="next"],
    .slider_prontos_morar_css .tns-controls button[data-controls="next"]{
        margin-right: -30px;
    }
    .bg_socios{ padding-top: 210px; }
    .slider_jarvis_praia_css img.img-fluid{ width: 100%; }
}
@media (min-width: 576px) and (max-width: 767px){ /* Small */
    .bg_socios{ padding-top: 240px; }
}
@media (max-width: 767px){/* Extra small + Small */
    .bg_socios:before{ background-size: 210%; }
    .socios_linha{ background: none; }
    .btn_rodape_whatsapp{ margin-right: 0; }
}
@media (min-width: 768px) and (max-width: 991px){ /* Medium */
    .bg_socios{ padding-top: 280px; }
    .bg_socios:before{ background-size: 200%; }
    .socios_linha{ background: none; }
    .btn_rodape_whatsapp{ margin-right: 0; }
}
@media (min-width: 992px) and (max-width: 1199px){ /* Large */
    .bg_socios:before{ background-size: 130%; }
}
@media (min-width: 1200px) and (max-width: 1399px){ /* X-Large */
    
}
@media (min-width: 1400px){ /* XX-Large */
    /*.slider_time_css .item a{ height: 360px; }*/
}
