:root {
    -webkit-font-smoothing: antialiased; /* Mejora la nitidez */
    font-smooth: always;
    text-rendering: optimizeLegibility;
}


/* Configuración con fuentes TTF (versión temporal) */
@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/Montserrat-Regular.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/Montserrat-Light.ttf') format('truetype');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/Montserrat-Medium.ttf') format('truetype');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/Montserrat-Bold.ttf') format('truetype');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

/* Uso en el body */
body {
    font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    overflow-x: hidden;
    font-size: 13px;
    font-weight: 400; /* Peso regular por defecto */
}

/* General */
html {
    scroll-behavior: smooth;
}

a {
    transition: transform 0.3s ease-out; /* Más suave con ease-out */
    transform: scale(1); /* Estado inicial */
}

a:hover {
    transform: scale(1.03); /* Zoom mínimo del 5% */
}

button {
    transition: transform 0.3s ease-out; /* Más suave con ease-out */
    transform: scale(1); /* Estado inicial */
}

button:hover {
    transform: scale(1.03); /* Zoom mínimo del 5% */
}

h1, h2, h3, h4, h5, h6 {
    font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-weight: 600;
}

h5 {
    font-size: 16px !important;
    line-height: 20px !important;
}

#wrapper {
    background-color: #f7f7f7 !important;
    /* background-color: #ffffff !important; */
}
/* OCULTOS */
@media (max-width: 768px){
	.ocultarmobile {
		display:none !important;
	}
}
@media (min-width: 768px){
	.ocultardesk{
		display:none !important;
	}
}

.gotham-light{
    font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-weight: 400;
}
.gotham-black{
    font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-weight: 800;
}
.gotham-medium{
    font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-weight: 600;
}



/* Header */
#header{
    background-color: #fff;
    z-index: 500 !important;
}
#logo img { 
    max-height: 45px; 
}

.left-side {
	float: left;
	width: 20%;
	display: inline-block;

}

.right-side {
	float: right;
	width: 80%;
	display: inline-block;
}

#navigation {
    float: right;
}

#navigation.style-1 .current {
    border: none ;
}

#navigation.style-1 .current{
    color: #151515;
    font-weight: 800;
}
#navigation.style-1 ul li:hover {
    background-color: #ffffff;
    color: #151515 ;
}

#navigation.style-1 ul li:hover a {
    color: #151515;
}

@media only screen and (max-width: 1366px) and (min-width: 1240px) {
    
}
#header {
    padding: 0px;
}

#navigation ul li:hover ul a, #navigation ul ul a {
    line-height: 12px !important;
}
@media only screen and (max-width: 992px) {
    #header {
        padding-top: 20px;
        padding-bottom: 0px;
    }
}

#navigation.style-2.cloned, #header.cloned.sticky {
    padding-top: 0px;
    padding-bottom: 0px;
    z-index: 500 !important;
}

/* Banner */

.titulo-banner{
    font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: 30px !important;
}

.search-container {
    height: 90vh;
    padding: 236px 0 !important;
}
/* Ajustes para pantallas pequeñas */
@media (max-width: 768px) {
    .search-container {
        padding: 100px 0 !important;
    }
}

.search-container .main-search-input input {
    border-radius: 8px;
    font-size: 14px;
    height: 47px !important;
}

.search-container .chosen-container-single .chosen-single {
    border-radius: 8px;
    font-size: 13px;
    height: 44px;
    line-height: 44px;
}
.chosen-container-single .chosen-drop {
    margin-top: 1px;
    border-radius: 8px;
    padding-top: 8px;
}
.search-container .main-search-input button.button {
    height: 44px;
    border-radius: 8px;
}

.adv-search-btn a {
    padding: 5px 12px;
    font-size: 13px;
}


.slider-container {
    position: relative;
    width: 100%;
    height: 100vh;
    overflow: hidden;
}

.slider-container .slide {
    position: absolute;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    opacity: 0;
    transition: opacity 2s ease-in-out;
    animation: zoomEffect 10s infinite alternate;
}

.slider-container .slide.active {
    opacity: 1;
}

@keyframes zoomEffect {
    0% {
        transform: scale(1);
    }
    100% {
        transform: scale(1.2);
    }
}

/* Overlay */
.slider-container::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(54, 56, 62, 0.5); /* Color y opacidad */
    z-index: 1; /* Más bajo */
}

/* Contenido */
.search-container {
    position: relative;
    z-index: 2; /* Más alto que el overlay */
}
/* Estilo del contenedor */
.parallax {
    position: relative;
    width: 100%;
    /* height: 100vh; */
    overflow: hidden;
}

/* Fondo dinámico */
.slider-bg {
    position: absolute;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    opacity: 0;
    transition: opacity 2s ease-in-out;
    animation: zoomEffect 10s infinite alternate ease-in-out;
}

/* Animación de Zoom */
@keyframes zoomEffect {
    0% { transform: scale(1); }
    100% { transform: scale(1.2); }
}

/* Contenido dentro del slider */
.parallax .container {
    position: relative;
    z-index: 1000;
}


/* HOME */
.text-content h2 {
    font-size: 30px !important;
    line-height: 40px !important;
}




/* Styling for modal */
.modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.7);
    display: none;
    justify-content: center;
    align-items: center;
    z-index:  2500 !important;
}

.modaltop{
    z-index: 2500 !important;
}
.modal-content {
    background-color: #f7f7f7 !important;
    padding: 20px;
    border-radius: 5px;
    max-width: 1200px;  /* Ancho máximo */
    width: 90%;  /* Ancho relativo */
    max-height: 90%;
    overflow-y: auto;
    position: relative;
    margin-left: auto;
    margin-right: auto;
    margin-top: 50px;  /* Margen superior para separarlo del borde */
}

.close {
    position: fixed; /* Fija la posición */
    top: 15px;
    right: 15px;
    font-size: 25px;
    font-weight: bold;
    color: white;
    background: rgba(0, 0, 0, 0.7);
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 1500; /* Asegura que esté siempre sobre el modal */
    transition: background 0.3s;
}

.property-images img {
    max-width: 100%;
    margin-bottom: 10px;
}

.property-images {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.modal-content {
    overflow-y: auto; /* Activa el scroll vertical */
    scrollbar-width: thin; /* Hace la barra de desplazamiento más fina en Firefox */
    scrollbar-color: #888 #f0f0f0; /* Color de la barra y el fondo en Firefox */
}
.property-description h3.desc-headline {
    font-size: 19px;
}

h2.desc-headline {
    font-size: 23px;
}


/* Estilos para Chrome, Edge y Safari */
.modal-content::-webkit-scrollbar {
    width: 6px; /* Ancho de la barra de desplazamiento */
}

.modal-content::-webkit-scrollbar-track {
    background: #f0f0f0; /* Color de fondo */
    border-radius: 10px;
}

.modal-content::-webkit-scrollbar-thumb {
    background: #888; /* Color del scroll */
    border-radius: 10px;
}

.modal-content::-webkit-scrollbar-thumb:hover {
    background: #555; /* Color del scroll al pasar el mouse */
}



/* CARD PROPIEDADES */

.listing-item {
    border-radius: 8px;
    transform: scale(1); 
}
.listing-item:hover {
    transform: scale(1.02); /* Zoom mínimo del 5% */
    box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.4);
}
.listing-badges span {
    font-size: 10px;
    padding: 0px 8px;
    /* background-color: #222; */
    background-color: #151515;
    border-radius: 6px;
}
.owl-wrapper .listing-carousel {
    border-radius: 8px;
}
.owl-carousel .owl-wrapper-outer {
    border-radius: 8px;
}
.listing-carousel.owl-theme .owl-controls .owl-prev:before{
    background-color: transparent;
}
.listing-carousel.owl-theme .owl-controls .owl-next:after {
    background-color: transparent;
}
.listing-img-container:before {
    opacity: 0.6;
    background: linear-gradient(to bottom, transparent 65%, #151515);
    transition: opacity .3s;
}
.listing-img-container:after {
    opacity: 0.9;
    background: linear-gradient(to bottom, transparent 65%, #151515);
    transition: opacity .3s;
}
.list-layout .listing-img-container {
    max-width: 100px;
    height: 100px;
    border-radius: 8px 0px 0px 8px;
}

.listing-img-content .listing-price {
    font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-weight: 600;
    font-size: 18px !important;
    line-height: 15px;
}
.listing-img-content .listing-estado {
    font-size: 11px;
    padding: 6px 10px;
    background-color: #151515;
    border-radius: 6px;
    text-transform: uppercase;

}
.listing-img-content .listing-price i {
    font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-weight: 300;
    font-size: 12px !important;
}

.img-propiedad{
    min-height: 220px;
    width: 100%;
    background-size: cover;
    background-position: center;
    overflow: hidden;
    position: relative;
}


.listing-title h4 a {
    font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-weight: 600;
    font-size: 18px;
    line-height: 18px;
}
.listing-title p {
    font-size: 13px;
    margin-bottom: 0px;
    line-height: 14px;
}

.listing-features {
    padding: 0px 30px 16px 30px;
    border-radius: 0 0 8px 8px;
}


@media (max-width: 1239px) {
    .listing-features li {
        padding-top: 16px;
    }
}

.listing-features i{
    color: #222;
}


/* LISTADO DE PROPIEDADES */

.button{
    border-radius: 8px !important;
}
a.button{
    border-radius: 8px !important;
}



.listing-badges {
    z-index: 50 !important;
}
/* @media (max-width: 1100px) {
    .listing-content{
        margin-top: 250px;  
    }
} */

/* .boton-outline{
    background-color: #ffffff !important;
    color: #929291 !important;
    border: solid 1px #929291 !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    line-height: 40px !important;
    height: 40px !important;
    padding: 0px 15px;
} */



/* FLIP BANNER */
.flip-banner {
    height: 400px;
    z-index: 20 !important;
}
.flip-banner h2 {
    font-size: 28px  !important;
}

/* FOOTER */
#footer{
    font-size: 13px;
    line-height: 19px;
}
img.footer-logo {
    max-height: 50px;
}

#backtotop a {
    border-radius: 50px !important;
    color: #14D9A1 !important;
    background-color: #151515 !important;
}

.social-icons li a {
    border-radius: 40px;
}

/* BUSCADOR */
.more-search-options-trigger:before {
    content: "\f055";
}
.more-search-options-trigger.active:before {
    content: "\f056";
}
.more-search-options.relative .more-search-options-container {
    margin: 5px 0 5px 0  !important;
}
.checkboxes.in-row label {
    margin-top: 0px;
}
.checkboxes label {
    font-size: 12px;
}
section.search {
    padding: 20px 0;
}

section.search .active{
    background-color: transparent;
    color: #151515;
}

/* SEARCH CONTAINER */
section.search .chosen-container-single .chosen-default {
    font-size: 13px;
    line-height: 40px;
    height: 40px !important;
}
section.search .chosen-container-single .chosen-single {
    height: 40px;
    line-height: 40px;
    border-radius: 8px !important;
    font-size: 13px !important;
    margin-top: 5px  !important;
    
}
section.search .chosen-container-single .chosen-drop {
    font-size: 13px  !important;
}




.row.with-forms input, .row.with-forms input[type="text"], .row.with-forms input[type="password"], .row.with-forms input[type="email"], .row.with-forms input[type="number"], .row.with-forms textarea, .row.with-forms input, .row.with-forms select, .row.with-forms .chosen-container {
    margin-bottom: 0px;
    border-radius: 8px;
    
}
@media (max-width: 768px){
    .row.with-forms input, .row.with-forms input[type="text"], .row.with-forms input[type="password"], .row.with-forms input[type="email"], .row.with-forms input[type="number"], .row.with-forms textarea, .row.with-forms input, .row.with-forms select, .row.with-forms .chosen-container {
        margin-top: 3px;
        margin-bottom: 3px;
        height: 41px;
        line-height: 19px;
        padding: 10px;
    }
}

.chosen-container-single .chosen-default {
    border-radius: 8px;
    font-size: 13px;
    line-height: 40px;
    height: 40px !important;
}
.chosen-container-single .chosen-default, .row.with-forms input{
    border-radius: 8px;
    font-size: 13px;
    line-height: 40px;
    height: 40px !important;
}
button.button{
    color: #14D9A1;
}
.main-search-input button.button {
    border-radius: 8px;
    height: 40px;
    line-height: 22px;
    font-size: 14px;
    width: 100% !important;
    margin-left: 0px;
}

.select-orden{
    padding: 10px !important;;
    font-size: 12px !important;
    border-radius: 8px !important;
    margin-top:  0px !important;

    height: 35px;
    line-height: 19px;
}


/* DETALLE DE LA PROPIEDAD */

.sp-sidebar {
    position: sticky;
    top: 70px; /* Distancia desde la parte superior */
    height: fit-content; /* Ajusta la altura automáticamente */
}

#titlebar.property-titlebar {
    padding: 20px 0 !important;
    padding-bottom: 10px  !important;
    background: none;
    background-color: transparent;;
}
#titlebar.property-titlebar h1, #titlebar.property-titlebar h2 {
    font-size: 24px;
    line-height: 24px;
}
.property-price{
    font-size: 25px  !important;
}
.property-title {
    margin-right: 143px;
}

.titulo-detalle-propiedad{
    margin-bottom: 0px !important;
    margin-top: 5px !important;
}

.precio-propiedad{
    float: right;
    color: #fff;
    background-color: #151515;
    border-radius: 8px;
    font-size: 14px;
    line-height: 10px;
    
    padding: 13px 18px 13px 18px;
}
.back-to-listings{
    background-color: transparent;
    color: #66676b;
    border-right: solid 1px #66676b;
    border-radius: 0px;
}
.back-to-listings:hover{
    background-color: transparent;
    color: #151515;
    border-right: solid 1px #151515;
    border-radius: 0px;
}

.agent-widget {
    border-radius: 8px;
}

.font-12{
    font-size: 12px;
}

input[type="text"]{
    border-radius: 8px;
    font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: 13px;
    line-height: 40px;
    height: 40px !important;
}
input[type="email"]{
    border-radius: 8px;
    font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: 13px;
    line-height: 40px;
    height: 40px !important;
}
textarea{
    border-radius: 8px;
    font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: 13px;

}

button.button.fullwidth, a.button.fullwidth {
    border-radius: 8px;
    font-size: 13px;
    padding: 7px !important;
}

.property-features {
    columns: 1;
    -webkit-columns: 1;
    -moz-columns: 1;
}
.desc-headline{
    font-size: 19px;
}

.en-3-col {
    columns: 3;
    -webkit-columns: 3;
    -moz-columns: 3;
}

@media (max-width: 768px) {
    .en-3-col {
        columns: 1;
        -webkit-columns: 1;
        -moz-columns: 1;
    }
}

.show-more:after {
    /* background: linear-gradient(rgba(255, 255, 255, 0), #f7f7f7 88%); */
    /* background: rgba(255, 255, 255, 1); */
    background: linear-gradient(rgba(255, 255, 255, 0), #ffffff 100%);
}

.sidebar.right {
    padding-left: 0px;
}

.agent-title .agent-photo img {
    max-width: 55px;
}
.agent-details {
    margin-left: 68px;
}
.agent-details h5{
    font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: 15px !important;
    margin-top: 0px;
}

/* EMPRENDIMIENTOS */

.progress-container {
    display: flex;
    align-items: center;
    width: 100%; /* El contenedor se ajusta al 100% del ancho disponible */
    max-width: 800px; /* Opcional: para limitar el ancho máximo */
    margin: 0 auto; /* Centra el contenedor en la página */
    justify-content: space-between; /* Distribuye los elementos a lo largo del contenedor */
    padding-right: 10px;
    padding-bottom: 30px;
    padding-left: 3px;
}

.progress-point {
    position: relative;
    width: 25px;
    height: 25px;
    border-radius: 50%;
    background-color: rgb(233, 233, 233);;
    text-align: center;
    line-height: 20px;
    font-size: 14px;
    color: #999;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    z-index: 1; /* Asegura que los puntos estén por encima de las líneas */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* Sombra suave */
    border: 2px solid #ffffff;

}

.progress-line {
    flex-grow: 1; /* Permite que las líneas crezcan para llenar el espacio entre los puntos */
    height: 8px;
    background-color: rgb(233, 233, 233);
    margin: 0 -2px; /* Espacio entre el punto y la línea */
}

.active {
    background-color: #151515; /* Color del punto activo */
    color: white;
}

.active .progress-line {
    background-color: #151515; /* Color de la línea activa */
}

.progress-text {
    margin-top: 70px; /* Espacio entre el punto y el texto */
    font-size: 12px;
    color: #333;
}

.tabs-nav {
    list-style: none;
    display: flex;
    padding: 0;
    margin: 0;
    gap: 5px; /* Espaciado entre tabs */
    justify-content: flex-start; /* Alinea las pestañas a la izquierda */
    flex-wrap: wrap; /* Permite que se envuelvan si no caben */
}

.tabs-nav li a i {
    font-size: 14px;
}

.tabs-nav li {
    /* padding: 10px 15px; */
    background-color: transparent;
    /* border: 1px solid #e0e0e0; */
    color: #151515;
    cursor: pointer;
    transition: all 0.3s ease;
    height: 50px;
    width: 90px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 15px;
    box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.1);
    flex: 0 0 auto;
    white-space: nowrap;
}

.tabs-nav li a {
    text-decoration: none;
    color: inherit;
    font-size: 13px;
    line-height: 13px;
    padding: 0 5px; /* Espaciado interno para el texto */
}

.tabs-nav li.active {
    background-color: #14D9A1;
    color: #151515;
    box-shadow: 2px 2px 8px rgba(0, 0, 0, 0.2);
}

.tabs-nav li.active i {
    color: #151515;
}

.tabs-nav li.active a span {
    color: #151515 !important;
}

.tabs-nav li:hover {
    background-color: #ededed;
    color: #151515;
}

.tabs-nav li a:hover, 
.tabs-nav li.active a {
    border: none;
}

.style-1 .tabs-container .tab-content {
    border-top: none !important;
}


.tab-content {
    display: none;
}
.tab-content.active {
    display: block;
}

/* UNIDADES DISPONIBLES */
.tabla-unidades-disponibles {
    width: 100%;
    
}

.tabla-unidades-disponibles td{
    border-bottom: 1px solid #bbb;
    padding-bottom: 10px;
    padding-top: 10px;
}
.tabla-unidades-disponibles tr{
}
.tabla-unidades-disponibles tr:hover{
    background-color: #14D9A1;
    
}

.tabla-unidades-disponibles .titulo a{
    color: #151515;
    font-size: 12px !important;
}
.tabla-unidades-disponibles i{
    font-size: 12px;
}

.tabla-unidades-disponibles .imagen{
    margin-right: 20px ;
}
.precio-tabla {
    display: inline-block;
    background: #151515;
    color: #fff;
    border-radius: 8px;
    font-size: 13px;
    padding: 7px 0px;
    line-height: 17px;
    width: 100%;
}
.unidad-tabla {
    font-size: 14px !important;
    padding-left: 10px !important;
    margin-top: 0 !important;
}

.plano-tabla {
    border: 1px solid #151515;
    color: #151515;
    border-radius: 8px;
    font-size: 12px;
    padding: 6px 12px 7px 12px;
    text-align: center;
    font-weight: 500;
    cursor: pointer !important;
}
.plano-tabla:hover {
    background-color: #151515;
    border: 1px solid #151515;
    color: #14D9A1;
    
}
@media (max-width: 768px) {
    .precio-tabla {
        font-size: 12px !important;
    }
    .unidad-tabla {
        font-size: 12px !important;
    }
    .plano-tabla {
        font-size: 11px !important;
    }
}


/* EMPRESA */
.icon-box-1.alternative .icon-container {
    font-size: 40px;
    height: 90px;
    width: 90px;
    line-height: 90px;
}

.icon-box-1.alternative h3 {
    font-size: 18px;
    font-family: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

.icon-box-1.alternative p {
    font-size: 13px;
    line-height: 20px;
}
.text-content {
    z-index: 400 !important;
}

/* SERVICIOS */
.text-content p {
    font-size: 13px;
    line-height: 25px;
}
.icon-box-1.alternative {
    text-align: left;
}

/* CONTACTO */
#contact input {
    margin-bottom: 10px;
}
label {
    font-size: 12px;
    margin-bottom: 1px;
    margin-left: 5px;
}

/* MAP */
#map-container {
    z-index: 0 !important;
}


/* CAMBIOS PARA ULTIMA PRESENTACION */

/* Header Centrado - Versión mejorada */
@media (min-width: 992px) {
    #header .container {
        position: relative;
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 10px 15px 10px 15px;
    }
    
    
    #logo {
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
        z-index: 100;
    }
    
    .left-side {
        width: 50%;
        text-align: left;
        padding-right: 10%; /* Espacio para el logo */
    }
    
    .right-side {
        width: 50%;
        text-align: right;
        padding-left: 15%; /* Espacio para el logo */
    }
    
    #navigation ul {
        display: flex;
        margin: 0;
        padding: 0;
        list-style: none;
    }
    
    .left-side #navigation ul {
        justify-content: flex-start;
    }
    
    .right-side #navigation ul {
        justify-content: flex-end;
    }
    
    #navigation ul li {
        margin: 0 10px;
    }
    
    /* Primer item izquierdo pegado al borde */
    .left-side #navigation ul li:first-child {
        margin-left: -15px; /* Compensa el padding del container */
    }
    
    /* Último item derecho pegado al borde */
    .right-side #navigation ul li:last-child {
        margin-right: -15px; /* Compensa el padding del container */
    }
}

/* Header Mobile */
.mobile-navigation {
    display: none; /* Oculto por defecto */
}

@media (max-width: 991px) {
    /* Ocultar navegación desktop en mobile */
    .left-side, 
    .right-side {
        display: none;
    }
    
    /* Mostrar navegación mobile */
    #header .container {
        display: flex;
        justify-content: space-between;
        align-items: center;
        /* padding: 12px 15px; Añadimos padding lateral */
        flex-wrap: nowrap; /* Añade esto para evitar saltos de línea */
    }
    
    #logo {
        margin-bottom: 0;
        text-align: left;
        flex: 0 0 auto; /* Elimina flex:1 para que no ocupe todo el espacio */
        width: auto; /* Ancho automático */
        order: 1; /* Logo primero */
        padding-left: 10px;
    }
    
    .mobile-navigation {
        display: flex;
        align-items: center;
        order: 3; /* Navegación móvil al final */
    }
    
    .mmenu-trigger {
        margin-left: 15px; /* Espacio entre logo y botón */
        order: 2; /* Botón hamburguesa después del logo */
        margin-top: 10px;
        margin-bottom: 10px;
    }
    
    /* Elimina cualquier margen o padding que pueda estar centrando los elementos */
    #header {
        padding: 0 !important;
    }
    
    /* Asegúrate que el contenedor no tenga texto centrado */
    .container {
        text-align: left !important;
    }
    
    /* Estilos específicos para el botón hamburguesa */
    .hamburger-box {
        width: 36px;
        height: 36px;
    }
    
    .hamburger-inner, 
    .hamburger-inner::before, 
    .hamburger-inner::after {
        width: 36px;
    }
    
    .mmenu-trigger {
        position: static;
        margin-left: auto;
    }
    
    #mobile-menu {
        display: none;
        width: 100%;
        position: absolute;
        top: 100%;
        left: 0;
        background: #fff;
        z-index: 1000;
        padding: 15px;
        box-shadow: 0 5px 10px rgba(0,0,0,0.1);
    }
    
    #mobile-menu.active {
        display: block;
    }
    
    #mobile-menu ul {
        list-style: none;
        padding: 0;
        margin: 0;
    }
    
    #mobile-menu ul li {
        margin: 10px 0;
    }
    
    #mobile-menu ul li a {
        display: block;
        padding: 8px 0;
        color: #333;
    }
    
    #mobile-menu ul li a.current {
        font-weight: 800;
        color: #151515;
    }
}

#top-bar, #top-bar .container {
    padding: 5px; 
}
@media (max-width: 991px) {
    #top-bar, #top-bar .container {
        width: 100%;
        padding: 0px 0px 0px 0px;
        padding-right: 8px;
        display: flex;
        justify-content: space-between;
        align-items: center;
        flex-wrap: nowrap;
    }
}

/* Desktop styles */
@media (min-width: 992px) {
    .mobile-navigation {
        display: none !important; /* Asegura que no se muestre en desktop */
    }
    
    .left-side,
    .right-side {
        display: block !important; /* Asegura que se muestre en desktop */
    }
}


/* MENU DESPLEGABLE CORRECTO */
#navigation.style-1 ul ul {
    position: absolute;
    top: 100%;
    left: 15px;
    width: 200px;
    background: #fff;
    box-shadow: 0 3px 10px rgba(0,0,0,0.1);
    border-radius: 4px;
    z-index: 100;
    display: none;
    margin-top: 5px;
}

#navigation.style-1 ul li:hover > ul {
    display: block;
}

#navigation.style-1 ul ul li {
    float: none;
    position: relative;
    margin: 0;
    padding: 0;
    border-bottom: 1px solid #f0f0f0;
}

#navigation.style-1 ul ul li:last-child {
    border-bottom: none;
}

#navigation.style-1 ul ul a {
    padding: 10px 15px !important;
    color: #555 !important;
    white-space: nowrap;
    display: block;
}

#navigation.style-1 ul ul a:hover {
    /* background-color: #f9f9f9; */
    color: #151515 !important;
}

#navigation.style-1 ul ul ul {
    left: 100%;
    top: 0;
    margin-top: 0;
}


/* MENÚ PRINCIPAL - AJUSTES FINOS */
#navigation.style-1 ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

#navigation.style-1 > ul > li {
    position: relative;
    display: inline-block;
    margin: 0 2px; /* Espacio entre ítems principales */
}

/* ITEMS PRINCIPALES */
#navigation.style-1 > ul > li > a {
    padding: 8px 20px !important;
    display: block;
    text-decoration: none;
    transition: all 0.3s;
    font-size: 14px !important;
}



/* SUBMENÚS - NIVEL 1 */
#navigation.style-1 ul ul {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 220px;
    background: #fff;
    box-shadow: 0 5px 15px rgba(0,0,0,0.1);
    border-radius: 8px;
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: all 0.3s ease;
    margin-top: 5px; /* Espacio entre item y submenú */
    padding: 8px 0 !important; /* Padding interno del submenú */
}

#navigation.style-1 ul li:hover > ul {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* ITEMS DE SUBMENÚ */
#navigation.style-1 ul ul li {
    display: block;
    margin: 0 !important;
    padding: 0 !important;
    border-bottom: 1px solid #f5f5f5;
}

#navigation.style-1 ul ul li:last-child {
    border-bottom: none;
}

#navigation.style-1 ul ul a {
    padding: 10px 20px !important;
    color: #555 !important;
    white-space: nowrap;
    text-align: left;
    font-size: 14px !important;
    transition: all 0.2s;
}

/* SUBMENÚS - NIVEL 2+ (DESPLEGABLE LATERAL) */
#navigation.style-1 ul ul ul {
    left: 100%;
    top: -8px; /* Alineación vertical */
    margin-left: 0;
}

/* FLECHA INDICADORA */
#navigation.style-1 > ul > li > a:after {
    content: '\f107';
    font-family: 'FontAwesome';
    margin-left: 8px;
    font-size: 12px;
}

#navigation.style-1 ul ul > li > a:after {
    content: '\f105';
    float: right;
}

/* ESTADO ACTIVO/HOVER */
#navigation.style-1 ul ul a:hover,
#navigation.style-1 ul ul li:hover > a {
    /* background: #f9f9f9; */
    color: #151515 !important;
    padding-left: 22px !important;
}

/* MOBILE - AJUSTES */
@media (max-width: 992px) {
    #navigation.style-1 ul ul {
        position: static;
        box-shadow: none;
        opacity: 1;
        visibility: visible;
        display: none;
        transform: none;
        padding-left: 15px !important;
    }
    
    #navigation.style-1 ul li:hover > ul {
        display: block;
    }
    
    #navigation.style-1 ul ul ul {
        left: 0;
    }
}

/* SOLUCIÓN PARA FLECHAS SOLO EN ITEMS CON SUBMENÚ */
#navigation.style-1 > ul > li:not(:has(ul)) > a:after,
#navigation.style-1 ul ul > li:not(:has(ul)) > a:after {
    content: none !important; /* Oculta flecha si no hay submenú */
}

#navigation.style-1 > ul > li:has(ul) > a:after {
    content: '\f107'; /* Flecha hacia abajo solo para items con submenú */
    font-family: 'FontAwesome';
    margin-left: 8px;
    font-size: 12px;
    display: none !important;
}

#navigation.style-1 ul ul > li:has(ul) > a:after {
    content: '\f105'; /* Flecha hacia derecha solo para subitems con submenú */
    float: right;
}



/* CAMBIOS FINALES */
.mfp-gallery .mfp-content .mfp-close {
    display: block;
}

.og-close:before, .mfp-close:before {
    transform: translate(-50%, -12.2%);
}


/* Asegura que el botón de cerrar esté visible */
.mfp-close {
    top: 20px !important;
    right: 20px !important;
    color: #FFF !important;
    font-size: 40px !important;
    opacity: 1 !important;
}

/* Ajusta el contenedor de la imagen */
.mfp-image-holder .mfp-content {
    max-width: 90% !important;
    max-height: 90vh !important;
}

/* Fondo oscuro */
.mfp-bg {
    opacity: 0.8 !important;
}

/* Mueve la "X" fuera de la imagen, a la esquina de la pantalla */
.mfp-close {
    position: fixed !important;  /* Fija la posición respecto al viewport */
    top: 10px !important;
    right: 55px !important;
    color: #FFF !important;
    font-size: 50px !important;
    opacity: 1 !important;
    z-index: 9999 !important;  /* Asegura que esté por encima de todo */
    background: transparent;
    width: 40px !important;
    height: 40px !important;
    line-height: 40px !important;
    text-align: center !important;
    border-radius: 50% !important;
}

/* Ajusta el contenedor de la imagen para que no se solape */
.mfp-image-holder .mfp-content {
    max-width: 90% !important;
    max-height: 90vh !important;
    margin-top: 40px !important;  /* Evita que la imagen tape la "X" */
}

/* Fondo oscuro del popup */
.mfp-bg {
    opacity: 0.8 !important;
}



/* PARA EL DETALLE DE LA PROPIEDAD DE HOVER GALERIA Y ESAS COSAS */
.property-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px;
}

.property-header {
    position: relative;
    margin-bottom: 30px;
}

.property-cover {
    width: 100%;
    height: 500px;
    object-fit: cover;
    cursor: pointer;
    border-radius: 8px;
}

.media-buttons {
    position: absolute;
    bottom: -20px;
    left: 50%; /* Cambiamos de left: 20px a 50% */
    transform: translateX(-50%); /* Esto compensa el 50% para centrar exactamente */
    display: flex;
    gap: 10px;
    
}

.media-button {
    border-radius: 8px;
    height: 40px;
    line-height: 22px;
    font-size: 13px;
    border: none;
    cursor: pointer;
    transition: background-color 0.3s;
    color: #151515;
    background-color: #fff;
    padding: 10px 20px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
}
@media (min-width: 767px) {
    .media-button {
        width: 100px;
    }
}

.media-button:hover {
    background-color: #151515;
    color: #14D9A1;
}

@media (min-width: 767px) {
    .salto::after {
        content: "";
        display: block;
    }
}


.titulos-servicios{
    font-size: 19px !important;
    font-family: 'Montserrat', sans-serif !important;
}

.texto-servicios{
    font-size: 15px !important;
    line-height: 25px !important;
}

.style-2 .ui-accordion .ui-accordion-header, .style-2 .trigger a {
    font-size: 16px !important;
}


.whatsapp-btn {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    width: 60px;
    height: 60px;
    background-color: #14D9A1;
    border-radius: 50px;
    color: white;
    text-decoration: none;
    font-family: Arial, sans-serif;
    font-weight: bold;
    overflow: hidden;
    transition: all 0.3s ease;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
}

.whatsapp-btn:hover {
    width: 200px;
    color: #ffffff;
}

.whatsapp-icon {
    font-size: 30px;
    margin: 0 15px;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 30px;
    z-index: 2;
}

.whatsapp-text {
    white-space: nowrap;
    opacity: 0;
    transition: opacity 0.2s ease;
    transition-delay: 0.1s;
    position: absolute;
    left: 20px;
    font-size: 15px;
}

.whatsapp-btn:hover .whatsapp-text {
    opacity: 1;
}

.espaciado-peque{
    padding: 0 3px !important;
}

.chosen-container-single .chosen-single span {
    color: #333;
}

.footer-links li a:hover{
    color: #14D9A1 !important;
}

.boton-verde-negro{
    background-color: #14D9A1 !important;
    color: #333 !important;
}
.boton-verde-negro:hover{
    background-color: #333 !important;
    color: #14D9A1 !important;
}
.estamos-con-vos{
    font-size: 17px;
    text-align: center;
    margin-bottom: 10px;
    color: #333;
}



/* PRELOADER */
/* Estilos para el preloader */
#preloader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #151515;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999;
    transition: transform 1s ease-out;
}

.logo-container {
    position: relative;
    width: 250px;
    height: auto;
}
@media only screen and (max-width: 992px) {
    .logo-container {
        width: 200px;
    }
}

#logo1 {
    width: 100%;
    height: auto;
    
}

#logo2 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: auto;
    
}



/* Clase para la animación de salida */
.preloader-out {
    transform: translateY(-100%);
}

/* Ocultar scroll durante el preloader */
body.preloader-active {
    overflow: hidden;
}

/* Estilos para el contenedor del mensaje */
.message-container {
    position: absolute;
    width: 100%;
    text-align: center;
    color: #14D9A1;
    font-size: 35px;
    opacity: 0;
    transition: opacity 0.5s ease;
    line-height: 40px;
}

.message-container p {
    margin: 0;
    padding: 0;
}

/* Mantener los estilos existentes y agregar: */
#preloader {
    /* tus estilos existentes */
    flex-direction: column;
}

.logo-container {
    /* tus estilos existentes */
    display: none; /* Inicialmente oculto */
    opacity: 1;
}
/* PRELOADER END */

.fuente-14{
    font-size: 14px !important;
}

.underline{
    text-decoration: underline;
    text-decoration-color: #14D9A1; /* Cambia solo el color de la línea */
    text-decoration-thickness: 2px; /* o el grosor que prefieras */
    text-underline-offset: 3px;     /* separación del subrayado */
}

.icono-empresa{
    text-align: right;
}

@media only screen and (max-width: 992px) {
    .icono-empresa{
        text-align: center;
    }
}


.boton-home-busqueda:hover{
    background-color: #151515 !important;
    color: #14D9A1 !important;
}


/* PARA LA NAVEGACION DE LA GALERIA */
portada-container {
    position: relative;
    display: inline-block;
    width: 100%;
}

.nav-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    background-color: rgba(255, 255, 255, 0.7);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 10;
    font-size: 20px;
    color: #333;
}

.nav-arrow:hover {
    background-color: rgba(255, 255, 255, 0.9);
}

.arrow-prev {
    left: 15px;
}

.arrow-next {
    right: 15px;
}


@media (max-width: 768px){
	.owl-theme .owl-controls .owl-buttons {
        margin-top: 30px !important;
    }
}