/* General Style */
@media (max-width: 768px) {
	.hide-on-mobile {
		display: none !important;
	}
}

@media (min-width: 769px) and (max-width: 1032px) {
	.hide-on-tablet {
		display: none !important;
	}
}

@media (min-width: 1033px) {
	.hide-on-desktop {
		display: none !important;
	}
}

/* ============== Mobile General Style ============== */

@media only screen and (max-width: 1026px){
h1{
    font-size: 40px!important;
}
h2{
    font-size: 30px!important;
}
h3{
    font-size: 24px!important;
}
h4{
    font-size: 20px!important;
}
h5{
    font-size: 18px!important;
}
h6, p{
    font-size: 16px!important;
}
}

/* ============== Header Style ============== */

/* Header Wrapper */

.header-wrapper{
position: absolute;
left: 0;
top: 0;
width: 100%;
z-index: 99;
background-color: transparent;
margin-top: 60px !important;
} 

.header-wrapper-sencodary{
position: absolute;
left: 0;
top: 0;
width: 100%;
z-index: 99;

}
.nav-primary--mobile{
min-height: 90px;
flex-direction: row;
}
.nav-primary--desktop{
display: none !important;
}
.cursor_new h2, .mouse_tag h2 { 
    display: none;
}
.cursor_new h2 + div, .mouse_tag h2 + div {
    margin-block-start: 0;
}
.menu_desk {
    left: 10px;
    top: 40%;
    position: fixed;
    display: flex;
    flex-direction: column;
    z-index: 999;
  }
  .vertical-text, .vertical-text > div {
    display: flex;
    flex-direction: column;
    gap: 15px;
    align-items: center;
    color: white;
  }
  .vertical-text a {
    writing-mode: vertical-rl;
    text-orientation: mixed;
    font-family: "Inter Tight", sans-serif;
    font-weight: normal;
    font-size: 18px;
  }
  .cursor_novo h2,
  .mouse_tag h2 {
    display: none;
  }
  .cursor_novo h2 + div,
  .mouse_tag h2 + div {
    margin-block-start: 0;
  }

/* Nav Desktop */ 
@media only screen and (max-width: 1032px){
    .menu_desk {
        display: none !important;
    }

/*Esconde Menu em telas menores */
.nav-primary--mobile{
display: flex !important;
}
.nav-primary--desktop{
display: none !important;
}

}

/* Nav Mobile */ 

@media only screen and (min-width: 1033px){

/*Esconde Menu em telas maiores */    
.nav-primary--mobile{
display: none !important;
}
.nav-primary--desktop{
display: flex !important;
}
    

}

/* ============== Footer Style ============== */

@media only screen and (max-width: 1026px){
    .footer-content{
    padding-top: 0px!important;

    a, p{
        font-size: 16px!important;

    }
    }
}


/* ============== Menu and Sub-Menu Style ============== */

/* Menu */
.wp-block-navigation-link a{
  }
  .wp-block-navigation-link a:hover,
  .wp-block-navigation-link a:focus {
   color: var(--wp--preset--color--custom-contrast)!important;
   transition: 1s ease;
  }


/* Menu Mobile */
@media only screen and (max-width: 1032px){
.nav-primary--mobile{
    margin-top: 0!important;
}

.general-header .eb-row-inner{
    display: flex!important;
    flex-direction: column!important;
    align-items: center!important;
    justify-content: center!important;
} 

/* Background menu mobile */
header .wp-block-navigation__responsive-container{ 
    background-color:  var(--wp--preset--color--custom-primary)!important;
} 

header .wp-block-navigation .wp-block-navigation-item { 
    justify-content: center; 

} 

header .wp-block-navigation ul li { 
    width: 100%; 
    margin-right: 100px!important;
} 

header .wp-block-navigation .wp-block-navigation__submenu-icon { 
    height: auto;
    width: auto; 
    position: absolute;
    right: 0px; 
    top: 0px; 
    padding: 3px;
} 

header .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .has-child .wp-block-navigation__submenu-container {
    display: none;
    width: 100%; 
    padding-top: 15px;
    text-align: center;
} 

header .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation__submenu-icon { 
    display: block; 
}

header .wp-block-navigation a, .wp-block-navigation__responsive-container-close, .wp-block-navigation-submenu__toggle {
    color:  var(--wp--preset--color--custom-secondary)!important; /* Text color */
    font-weight: 500;
}

header .wp-block-navigation a:hover {
    color:  var(--wp--preset--color--custom-secondary)!important; /* Text color hover*/
}


}

/* SubMenu */ 
@media only screen and (min-width: 1033px){

    .wp-block-navigation__submenu-container{
        background-color: var(--wp--preset--color--custom-submenu)!important;
        width: 567px!important; 
        position: absolute!important; 
        left: -70%!important;
        top: 150%!important; 
        display: grid!important;
        grid-template-columns: repeat(3, 1fr)!important; /* Define três colunas iguais */
        grid-column-gap: 16px!important;
        grid-row-gap: 16px!important; 
        list-style: none!important;
        padding: 20px!important; 
        border-radius: 16px;

        li{
        border-radius: 16px;
    
            a{
                color: var(--wp--preset--color--custom-secondary)!important;
                font-weight: 500!important;
            }
    
        }
    }
}


/* ============== Buttons ============== */


/*Buttons */
.header-wrapper .wp-block-button__link:hover {

}
.wp-block-button__link {
    transition: background-color 0.8s ease, color 0.3s ease, border-color 0.3s ease;
}
.btn-custom-primary:hover a{
    color: var(--wp--preset--color--custom-primary)!important;
    background-color: var(--wp--preset--color--custom-contrast)!important;

}
.btn-custom-secondary:hover a{
    color: var(--wp--preset--color--custom-contrast)!important;
    background-color: var(--wp--preset--color--custom-primary)!important;
}
.btn-custom-tertiary:hover a{
    color: var(--wp--preset--color--custom-secondary)!important;
    background-color: var(--wp--preset--color--custom-contrast)!important;
}

/* Slider BTN */
.btn-slider-primary a:hover{
    background-color: var(--wp--preset--color--custom-contrast)!important;
    border: 1px solid var(--wp--preset--color--custom-contrast)!important;

}
.btn-slider-secondary a:hover{
    color: var(--wp--preset--color--custom-contrast)!important;
    background-color: var(--wp--preset--color--custom-primary)!important;
    
}

/* Others BTNs Styles */ 
.btn-alternative a{
    width: 240px;
    text-align: left!important;
}
.btn-alternative a:hover{
    border: 1px solid var(--wp--preset--color--custom-contrast)!important;
    color: var(--wp--preset--color--custom-primary)!important;

}


/* ============== Main Style ============== */

@media only screen and (max-width: 1026px){
main{
}
}


/* ============== Front-Page Template ============== */

/* Form */
/* .custom-form {
    width: 90%;
    height: 500px;
    margin: 0 auto;
    padding: 20px;
    display: flex;
    align-items: left;
    flex-direction: column;
    justify-content: start;
}
.custom-form h4 {
    font-size: 18px;
    margin-bottom: 15px;
    color: var(--wp--preset--color--custom-contrast);
}
.custom-form form {
    display: flex;
    flex-direction: column;
}
.custom-form div {
    margin-bottom: 15px;
}
.custom-form label {
    display: block;
    margin-bottom: 5px;
    font-weight: bold;
    border-bottom: 1px solid var(--wp--preset--color--custom-text);
    color:  var(--wp--preset--color--custom-text);
}
.custom-form select {
    width: 100%;
    padding: 8px;
    border: none;
    border-radius: 4px;
}
.custom-form button {
    padding: 10px;
    border: none;
    background-color: rgba(0, 0, 0, 0);
    color: var(--wp--preset--color--custom-contrast);
    border: 1px solid var(--wp--preset--color--custom-contrast);
    border-radius: 99px;
    cursor: pointer;
    font-size: 16px;
}
.custom-form button:hover {
    background-color: var(--wp--preset--color--custom-contrast);
    color: #FFF;
    transition: 0.5s ease;
} */

.buy-form {
    background-color: var(--wp--preset--color--custom-primary);
    border-radius: 10px;
    width: 100%;
    display: flex;
    flex-direction: column;
}

.buy-form label {
    margin-top: 10px;
    color: var(--wp--preset--color--custom-secondary);
}

.buy-form select {
    border: none;
    border-bottom: 1px solid var(--wp--preset--color--custom-secondary);
    padding: 8px 0;
    margin-bottom: 10px;
    color: var(--wp--preset--color--custom-secondary);
    background-color: transparent;
    outline: none;
    width: 100%;
}

.buy-form select:focus {
    border-bottom: 1px solid var(--wp--preset--color--custom-contrast);
}

.buy-form button {
    background-color: transparent;
    color: var(--wp--preset--color--custom-contrast);
    border: 1px solid var(--wp--preset--color--custom-contrast);
    width: 100%;
    height: 52px;
    border-radius: 99px;
    margin-top: 20px;
    cursor: pointer;
    transition: background-color 0.3s, color 0.3s;
}

.buy-form button:hover {
    background-color: var(--wp--preset--color--custom-contrast);
    color: var(--wp--preset--color--custom-primary);
}

/* Hero Section*/
@media only screen and (max-width: 1032px){
.hero-section {
.hero-content{
}
}
}

/* New Listings Section*/
@media only screen and (max-width: 1032px){
.new-listings-section{
    padding: 0 20px!important;
    .new-listings-title{
    }
    .new-listings-content{
        h3{
        }
    }
}
}

/* About Us Section */
@media only screen and (max-width: 1032px){
.about-section{
    padding: 50px 20px!important;
    min-height: auto!important;

    .about-title{

    }
    .about-content{
        .wp-block-media-text{
            /* display: flex; */
        }
        img{
            /* width: 60px!important; */
        }

    }

}
}


/* Listings Section*/
.listings-row li{
    border-bottom: 1px solid var(--wp--preset--color--custom-text);
}
.listings-row li:last-child {
    border-bottom: none;
}

/* Agents Section*/
@media only screen and (max-width: 1032px){
    .agents-section{
        padding: 0!important;
        padding-top: 50px!important;
        display: flex!important;
        flex-direction: column;
      
    }
      .agents-content .wp-block-columns{
        display: flex!important;
        flex-direction: column;
       

        }
}

/* Testimonials Section*/
@media only screen and (max-width: 1032px){
    .testimonials-section{
        padding: 50px 20px!important;
        min-height: auto!important;

        .testimonials-title{

        }
        .testimonials-content{

        }
    }

}

/* Blog Section */
@media only screen and (max-width: 1026px){
    .blog-section{
        padding: 50px 20px!important;
        min-height: auto!important;
    
        .blog-title{
    
        }
        .blog-content{
    
        }
    }
}


/* Contact Section */
@media only screen and (max-width: 1032px){
    .contact-section{
        padding: 50px 20px!important;
        min-height: 35vh!important;
        .contact-content{
    
        }
    }
}

/* ============== About Template ============== */
@media only screen and (max-width: 1032px){
    .template-about--cover {
        padding-top: 50px!important;
    
    }
}



/* ============== About Template ============== */

.mission-section{
    position: relative;

    .mission-img{
        position: absolute;
        top: 80%;
        left: 50%;
        transform: translate(-50%, -50%);

        img{
            max-width: 1280px;
        }
        
    }

}

@media only screen and (max-width: 1032px){
     .template-about--cover{
        min-height: 25vh!important;
        }
    .template-about--cta{
        h1{
            text-align: left;
            font-size: 32px!important;
            padding: 20px 15px!important;
        }
    }
    .mission-section{
        padding: 50px 10px!important;
        min-height: 50vh!important;
    }

    .mission-img{
        position: absolute;
        top: 80%;
        left: 50%;
        transform: translate(-50%, -50%);

        img{
            max-width: 398px!important;
        }
        
    }
}


@media only screen and (max-width: 1032px){

.about-services{
    padding: 50px 0!important;
}
}

/* ============== Properties Template ============== */

@media only screen and (max-width: 1032px){
    .template-properties--cover{
       min-height: 25vh!important;
       }
    .propety-listing{
        padding: 50px 10px!important;
    }
}

.property-listing-form{

    select{
        border:none;
        background-color: transparent;
        font-size: 18px;
        font-family: var(--wp--preset--font-family--urbanist);
    }
}

/* ============== Blog Template ============== */

@media only screen and (max-width: 1032px){
    .template-blog--hero{
    min-height: 25vh!important;
    }
    .template-blog--content{
        padding: 50px 20px!important;
    }
    .template-blog--btns{
    }
    
}

/* ============== Career Details Template ============== */


/* Career Form */ 
.career-form {
    padding: 20px;
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 0;

    .form-group {
        margin-bottom: 20px;
    }
    
    .form-group label {
        display: block;
        margin-bottom: 5px;
        color: #0d0e13;
    }
    
    .form-group input {
        max-width: 100%;
        padding: 10px;
        border: none;
        border-bottom: 1px solid #0d0e13;
        color: #0d0e13;
        background: transparent;
        font-size: 16px;
        outline: none;
        transition: border-color 0.3s;
    }
    
    .form-group input:focus {
        border-bottom: 1px solid var(--wp--preset--color--custom-contrast);
    }
    
    button {
        max-width: 375px;
        height: 52px;
        background: transparent;
        color: var(--wp--preset--color--custom-contrast);
        border: 1px solid var(--wp--preset--color--custom-contrast);
        border-radius: 99px;
        font-size: 16px;
        cursor: pointer;
        transition: background 0.3s, color 0.3s;
    }
    
    button:hover {
        background: var(--wp--preset--color--custom-contrast);
        color: var(--wp--preset--color--custom-primary);
    }
}


/* ============== Contact Us Template ============== */

/* Contact Form */ 

.contact-form {
    padding: 20px;
    border-radius: 8px;

    .form-group {
        margin-bottom: 20px;
    }
    
    .form-group label {
        display: block;
        margin-bottom: 5px;
        color: #0d0e13;
    }
    
    .form-group input,
    .form-group textarea {
        width: 100%;
        padding: 10px;
        border: none;
        border-bottom: 1px solid #0d0e13;
        color: #0d0e13;
        background: transparent;
        font-size: 16px;
        outline: none;
        transition: border-color 0.3s;
    }
    
    
    .form-group input:focus,
    .form-group textarea:focus {
        border-bottom: 1px solid var(--wp--preset--color--custom-contrast);
    }
    
    button {
        width: 375px;
        height: 52px;
        background: transparent;
        color:var(--wp--preset--color--custom-contrast);
        border: 1px solid var(--wp--preset--color--custom-contrast);
        border-radius: 99px;
        font-size: 16px;
        cursor: pointer;
        transition: background 0.3s, color 0.3s;
    }
    
    
    button:hover {
        background: var(--wp--preset--color--custom-contrast);
        color: var(--wp--preset--color--custom-primary);
    }
}

@media only screen and (max-width: 1032px){
.contact-form {

    .form-group input,
    .form-group textarea {
        width: 80%!important;
    
    }
    button {
        width: 325px!important;

    }
}
}


/* ============== Properties Details Template ============== */


.timeline-container {
    position: relative;
    width: 100%;
    height: 20px; /* Altura ajustada para acomodar os pontos */
}

.timeline-line {
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: var(--wp--preset--color--custom-secondary);
    transform: translateY(-50%);
}

.timeline-point {
    position: absolute;
    top: 50%;
    width: 20px;
    height: 20px;
    background-color: var(--wp--preset--color--custom-contrast);
    border-radius: 50%;
    transform: translate(-50%, -50%);
}

.point-1 {
    left: calc(0% - 5px);
}

.point-2 {
    left: calc(35% - 5px);
}

.point-3 {
    left: calc(65% - 5px);
}

.point-4 {
    left: calc(95% - 5px);
}


.neighborhood-timeline{
    position: relative;
    .car-image {
        position: absolute;
        top: 80%;
        left: calc(0% - 5px);
        transform: translate(-50%, -50%);
        z-index: 99;
    }
}

@media only screen and (max-width: 1032px){
    .neighborhood-features{
        padding: 0!important;
        gap: 0!important;
    }
    .point-1 {
        left: calc(0% - 5px);
    }
    
    .point-2 {
        left: calc(35% - 5px);
    }
    
    .point-3 {
        left: calc(60% - 5px);
    }
    
    .point-4 {
        left: calc(95% - 5px);
    }
    .neighborhood-timeline{
        position: relative;
        .car-image {
            position: absolute;
            top: 80%;
            left: calc(0% - 5px);
            transform: translate(-50%, -50%);
            z-index: 99;
        }
    }
}

/* @media only screen and (max-width: 1032px) {
    .timeline-container {
        width: 50px;
        height: 100vh; 
    }

    .timeline-line {
    position: relative;

        top: 0;
        left: 50%;
        width: 1px;
        height: 100%;
        transform: translateX(-50%);
    }

    .timeline-point {
        top: calc(100% - 5px);
        left: 50%;
        transform: translate(-50%, 50%);
    }

    .point-1 {
        top: calc(75% - 5px);
        left: 50%;
    }

    .point-2 {
        top: calc(50% - 5px);
        left: 50%;
    }

    .point-3 {
        top: calc(25% - 5px);
        left: 50%;
    }

    .point-4 {
        top: calc(0% - 5px);
        left: 50%;
    }

    .car-image {
        position: absolute;
        top: 30px!important;
        left: 50%!important;
    }
} */

@media only screen and (max-width: 1032px){
    .template-404--cover {   
        background-repeat: no-repeat;
        background-size: cover;
        background-position: top;
        
    }
}



/* ============== Animations Effects ============== */


.fade-up-effect {
    opacity: 1;
}

.slide-up-effect {
    opacity: 1;
}